MapBox离线地图+python获取瓦片数据

工作中需要使用离线地图。

使用工具:MapBox离线地图+python获取瓦片数据

前端页面:

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title>Display a map on a webpage</title>
    <meta name="viewport" content="initial-scale=1,maximum-scale=1,user-scalable=no">
    <link href="https://api.mapbox.com/mapbox-gl-js/v2.8.2/mapbox-gl.css" rel="stylesheet">
    <script src="https://api.mapbox.com/mapbox-gl-js/v2.8.2/mapbox-gl.js"></script>
    <style>
        body {
            margin: 0;
            padding: 0;
        }

        #map {
            position: absolute;
            top: 0;
            bottom: 0;
            width: 100%;
        }
    </style>
</head>
<body>
    <div id="map"></div>
    <script>
        
        var vectorTileBackgroundLayer = {
            "version": 8,
            "sources": {
                "raster-tile": {
                    "type": "raster",
                    "tiles": ["http://10.1.10.109/tiandituImgLabel/{z}/{x}/{y}.png"],
                    "tileSize": 256
                }
            },
            "layers": [
                {
                    "id": "simple-tiles",
                    "type": "raster",
                    "source": "raster-tile",
                    "minzoom": 6,
                    "maxzoom": 22
                }
            ]
        };

        mapboxgl.accessToken = '您的钥匙';
        const map = new mapboxgl.Map({
            container: 'map', // container ID
            style: vectorTileBackgroundLayer,
            center: [118.1517713497023, 39.63166152545793], // 初始坐标系
            zoom: 11,     // starting zoom 地图初始的拉伸比例
            pitch: 0,  //地图的角度,不写默认是0,取值是0-60度,一般在3D中使用
            bearing: 0, //地图的初始方向,值是北的逆时针度数,默认是0,即是正北
            antialias: true, //抗锯齿,通过false关闭提升性能
            minZoom: 11,
            maxZoom: 18,
        });
    </script>

</body>
</html>

其中  tiles 的网络指向就是下载的地图瓦片图片数据网站:必须是网站要不就没有办法访问图片。

网站样子如下:

 下地图瓦片图片的工具用的python代码如下:


from urllib import request
import re
import urllib.request
import os
import random
import math
 
agents = [
    'Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/60.0.3112.101 Safari/537.36',
    'Mozilla/5.0 (Windows; U; Windows NT 6.1; en-US) AppleWebKit/532.5 (KHTML, like Gecko) Chrome/4.0.249.0 Safari/532.5',
    'Mozilla/5.0 (Windows; U; Windows NT 5.2; en-US) AppleWebKit/532.9 (KHTML, like Gecko) Chrome/5.0.310.0 Safari/532.9',
    'Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US) AppleWebKit/534.7 (KHTML, like Gecko) Chrome/7.0.514.0 Safari/534.7',
    'Mozilla/5.0 (Windows; U; Windows NT 6.0; en-US) AppleWebKit/534.14 (KHTML, like Gecko) Chrome/9.0.601.0 Safari/534.14',
    'Mozilla/5.0 (Windows; U; Windows NT 6.1; en-US) AppleWebKit/534.14 (KHTML, like Gecko) Chrome/10.0.601.0 Safari/534.14',
    'Mozilla/5.0 (Windows; U; Windows NT 6.1; en-US) AppleWebKit/534.20 (KHTML, like Gecko) Chrome/11.0.672.2 Safari/534.20', 
    'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/534.27 (KHTML, like Gecko) Chrome/12.0.712.0 Safari/534.27',
    'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/535.1 (KHTML, like Gecko) Chrome/13.0.782.24 Safari/535.1']
def deg2num(lat_deg, lon_deg, zoom):
    lat_rad = math.radians(lat_deg)
    n = 2.0 ** zoom
    xtile = int((lon_deg + 180.0) / 360.0 * n)
    ytile = int((1.0 - math.log(math.tan(lat_rad) + (1 / math.cos(lat_rad))) / math.pi) / 2.0 * n)
    return (xtile, ytile)

def getimg(Tpath, Spath, x, y):
    try:
        f = open(Spath, 'wb')
        req = urllib.request.Request(Tpath)
        req.add_header('User-Agent', random.choice(agents))  # �������������ͷ
        pic = urllib.request.urlopen(req, timeout=60)
 
        f.write(pic.read())
        f.close()
        print(str(x) + '_' + str(y) + 'ok')
    except Exception:
        print(str(x) + '_' + str(y) + 'error')
        #getimg(Tpath, Spath, x, y)

zoom = 16
lefttop = deg2num(39.7486, 118.0085, zoom) 
rightbottom = deg2num(39.4910, 118.3808, zoom)
print(rightbottom)
print(lefttop)
print(str(lefttop[0]))
print(str(rightbottom[0]))
print(str(lefttop[1]))
print(str(rightbottom[1]))
print("all" + str(lefttop[0] - rightbottom[0]))
print("all" + str(lefttop[1] - rightbottom[1]))

rootDir = "D:\\GetMapTile\\tiandituImgLabel\\"

for x in range(lefttop[0], rightbottom[0]):
    for y in range(lefttop[1], rightbottom[1]):
        tilepath = 'https://a.tile.openstreetmap.org/'+str(zoom)+'/'+str(x)+'/'+str(y)+'.png';
        print(tilepath)
        path = rootDir + str(zoom) + "\\" + str(x)
        if not os.path.exists(path):
            os.makedirs(path)
        getimg(tilepath, os.path.join(path, str(y) + ".png"), x, y)
print('all ok')

总结:前端用的MapboxGL加载地图瓦片,需要使用钥匙,这里不使用钥匙会有各种的问题,建议还是使用钥匙。数据使用python抓取openstreetmap中的地图瓦片。

  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Mapbox离线地图可以通过将地图数据下载到本地设备上来实现。一般来说,使用Mapbox离线地图需要以下步骤: 1. 获取地图数据:使用Mapbox Studio或Mapbox GL JS下载地图数据地图数据可以是矢量数据或栅格数据。 2. 导出地图数据:将下载的地图数据导出为MBTiles格式的瓦片集。MBTiles格式是一种SQLite数据库格式,可以将多个瓦片集存储在一个文件中。 3. 在应用程序中加载地图:使用Mapbox SDK加载离线地图。此外,需要设置地图样式和图层属性。 下面是一个使用Mapbox SDK加载离线地图的示例代码: ```java // 设置离线地图路径 String offlineMapPath = "/path/to/offline/map"; FileSource fileSource = new FileSource("offline-map", new TileSet("tileset", offlineMapPath)); // 设置地图样式 Style.Builder styleBuilder = new Style.Builder().fromUri("mapbox://styles/mapbox/streets-v11"); // 添加离线瓦片集 styleBuilder.withSource(new VectorSource("offline-tiles", fileSource).withMaxZoom(16)); // 创建地图对象 MapView mapView = new MapView(context, new MapboxMapOptions().style(styleBuilder.build())); // 在地图上添加图层 MapboxMap mapboxMap = mapView.getMapboxMap(); mapboxMap.setStyle(styleBuilder.build(), new Style.OnStyleLoaded() { @Override public void onStyleLoaded(@NonNull Style style) { // 添加图层 style.addLayer(new SymbolLayer("layer-id", "offline-tiles")); } }); ``` 在线地图离线地图可以通过判断网络状态来动态加载。当应用程序处于离线状态时,可以自动切换到离线地图。当应用程序处于在线状态时,可以自动切换到在线地图。下面是一个使用Mapbox SDK动态加载在线和离线地图的示例代码: ```java // 判断网络状态 boolean isOnline = isNetworkAvailable(context); // 设置地图样式 Style.Builder styleBuilder = new Style.Builder(); if (isOnline) { styleBuilder.fromUri("mapbox://styles/mapbox/streets-v11"); } else { // 设置离线地图路径 String offlineMapPath = "/path/to/offline/map"; FileSource fileSource = new FileSource("offline-map", new TileSet("tileset", offlineMapPath)); styleBuilder.withSource(new VectorSource("offline-tiles", fileSource).withMaxZoom(16)); } // 创建地图对象 MapView mapView = new MapView(context, new MapboxMapOptions().style(styleBuilder.build())); // 在地图上添加图层 MapboxMap mapboxMap = mapView.getMapboxMap(); mapboxMap.setStyle(styleBuilder.build(), new Style.OnStyleLoaded() { @Override public void onStyleLoaded(@NonNull Style style) { if (isOnline) { // 添加在线图层 style.addLayer(new SymbolLayer("layer-id", "source-id")); } else { // 添加离线图层 style.addLayer(new SymbolLayer("layer-id", "offline-tiles")); } } }); // 监听网络状态变化 ConnectivityManager connectivityManager = (ConnectivityManager) context.getSystemService(Context.CONNECTIVITY_SERVICE); connectivityManager.registerDefaultNetworkCallback(new ConnectivityManager.NetworkCallback() { @Override public void onAvailable(@NonNull Network network) { super.onAvailable(network); // 切换到在线地图 mapboxMap.getStyle(new Style.OnStyleLoaded() { @Override public void onStyleLoaded(@NonNull Style style) { style.removeLayer("layer-id"); style.removeSource("offline-tiles"); style.addLayer(new SymbolLayer("layer-id", "source-id")); } }); } @Override public void onLost(@NonNull Network network) { super.onLost(network); // 切换到离线地图 mapboxMap.getStyle(new Style.OnStyleLoaded() { @Override public void onStyleLoaded(@NonNull Style style) { style.removeLayer("layer-id"); style.removeSource("source-id"); style.addLayer(new SymbolLayer("layer-id", "offline-tiles")); } }); } }); ``` 这是一个示例代码,具体实现需要根据实际情况进行调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值