百度地图瓦片 android,百度地图自定义瓦片图获取

nodejs代码

const request = require('request');

const fs = require('fs');

const bagpipe = require('bagpipe');

const TileLnglatTransform = require('tile-lnglat-transform');

let [x1, y1] = [72.26, 54.57]; // 起始点坐标(左上角)

let [x2, y2] = [137.31, 17.8]; // 终点坐标(右下角)

let TileLnglatTransformBaidu = TileLnglatTransform.TileLnglatTransformBaidu; // 根据地图平台使用转换类 这里是用百度的

let tileArr = [];

let [minZoom, maxZoom] = [5, 9]; // 最大最小缩放等级

/* 循环产生瓦片图目录结构 */

for (let i = minZoom; i <= maxZoom; i++) {

tileArr[i] = {};

p1 = TileLnglatTransformBaidu.lnglatToTile(x1, y1, i);

p2 = TileLnglatTransformBaidu.lnglatToTile(x2, y2, i);

tileArr[i].t = i; // 层级

tileArr[i].x = [p1.tileX, p2.tileX]; // 横坐标范围

tileArr[i].y = [p2.tileY, p1.tileY]; // 纵坐标范围

}

let bagGrep = new bagpipe(20, { timeout: 1000 });

let path = './default'; // 这个是你图片要存放的位置

fs.access(path, fs.constants.F_OK, err => {

if (err) fs.mkdir(path, err => {});

for (let z = minZoom; z <= tileArr.length - 1; z++) {

fs.access(`${path}/${z}`, fs.constants.F_OK, err => {

if (err) fs.mkdir(`${path}/${z}`, err => {});

for (let x = tileArr[z].x[0]; x <= tileArr[z].x[1]; x++) {

fs.access(`${path}/${z}/${x}`, fs.constants.F_OK, err => {

if (err) fs.mkdir(`${path}/${z}/${x}`, err => {});

});

}

});

}

setTimeout(() => {

requestPush(); // 先要产生xyz.js 操作完createLevelArr的流程后再执行这个

// createLevelArr(); // 后面有说这个的用处

}, 1000);

});

const writeFile = data => {

fs.writeFile('./xyz.js', data, function(err) {

if (err) {

throw err;

}

});

};

/*

* 这个函数是获取一个{x,y,z}的对象数组 并且写入本地的xyz.js

* 然后你自己需要在前端搭建一个百度地图2.0版本的demo https://www.echartsjs.com/examples/editor.html?c=map-polygon 按他这个来 但是样式你改成你需要的

* 重要的事情说三遍! 2.0版本 2.0版本 2.0版本

* 以上准备做完后 F12找到一个瓦片图的加载地址复制下来 接下来你需要去缓存所有的百度地图自定义瓦片图片 做法如下:

* 在前端demo中引入xyz.js 遍历这个数组 用img标签加载 设置src(路径看download方法中的 产生图片URL 开始 -> 产生图片URL 结束)

* 确保图片都加载了一遍 做完这些你就可以注释上面的createLevelArr调用 打开requestPush调用 然后就能拿到你所有需要的自定义瓦片图了

*/

const createLevelArr = () => {

let allXYZ = [];

for (let z = minZoom; z <= tileArr.length - 1; z++) {

for (let x = tileArr[z].x[0]; x <= tileArr[z].x[1]; x++) {

for (let y = tileArr[z].y[0]; y <= tileArr[z].y[1]; y++) {

allXYZ.push({

x,

y,

z

});

}

}

}

writeFile(JSON.stringify(allXYZ));

};

const requestPush = () => {

for (let z = minZoom; z <= tileArr.length - 1; z++) {

for (let x = tileArr[z].x[0]; x <= tileArr[z].x[1]; x++) {

for (let y = tileArr[z].y[0]; y <= tileArr[z].y[1]; y++) {

bagGrep.push(download, x, y, z);

}

}

}

};

const download = (x, y, z) => {

// 产生图片URL 开始

let baiduApiArr = [

'http://api0.map.bdimg.com/',

'http://api1.map.bdimg.com/',

'http://api2.map.bdimg.com/'

];

let main = baiduApiArr[Math.abs(x + y) % baiduApiArr.length]; // 百度地址切换的规则 百度地图源码中有

// 下面这个url是获取自定义瓦片图的地址 (这个url的获取就是你用百度地图2.0版本的库搭建一个本地的demo 把地图跑出来 然后你去看它的图片请求 复制一条过来就好了)

//let url =

// 'http://api0.map.bdimg.com/customimage/tile?&x=7&y=2&z=5&udt=20190718&scale=1&ak=填你自己的ak&styles=t%3Awater%7Ce%3Aall%7Cc%3A%233990e9%2Ct%3Aland%7Ce%3Aall%7Cc%3A%23004981%2Ct%3Aboundary%7Ce%3Ag%7Cc%3A%23064f85%2Ct%3Arailway%7Ce%3Aall%7Cv%3Aoff%2Ct%3Ahighway%7Ce%3Ag%7Cc%3A%23004981%2Ct%3Ahighway%7Ce%3Ag.f%7Cc%3A%23005b96%7Cl%3A1%2Ct%3Ahighway%7Ce%3Al%7Cv%3Aoff%2Ct%3Aarterial%7Ce%3Ag%7Cc%3A%23004981%2Ct%3Aarterial%7Ce%3Ag.f%7Cc%3A%2300508b%2Ct%3Apoi%7Ce%3Aall%7Cv%3Aoff%2Ct%3Agreen%7Ce%3Aall%7Cv%3Aoff%7Cc%3A%23056197%2Ct%3Asubway%7Ce%3Aall%7Cv%3Aoff%2Ct%3Amanmade%7Ce%3Aall%7Cv%3Aoff%2Ct%3Alocal%7Ce%3Aall%7Cv%3Aoff%2Ct%3Aarterial%7Ce%3Al%7Cv%3Aoff%2Ct%3Aboundary%7Ce%3Ag.f%7Cc%3A%23029fd4%2Ct%3Abuilding%7Ce%3Aall%7Cc%3A%231a5787%2Ct%3Alabel%7Ce%3Aall%7Cv%3Aoff';

let url = `${main}customimage/tile?&x=${x}&y=${x}&z=${z}&customid=undefined`; // 这个是默认样式的瓦片图

// 产生图片URL 结束

request(

{

url,

timeout: 180000 // 响应时间可以设高点

},

(err, res, body) => {

if (err) {

console.log(err + '&' + x + '&' + y + '&' + z);

}

}

).pipe(fs.createWriteStream(`${path}/${z}/${x}/${y}.png`));

};

前端代码就不上了

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/333366.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

IntelliJ IDEA for Mac 如何自定义快捷键_设置快捷键

文章目录设置代码补全快捷键设置展开全部的快捷键折叠全部快捷键设置代码补全快捷键 代码自动补全&#xff0c;即智能提示。 打开【系统偏好设置】如下图所示&#xff1a; 在左侧的菜单栏中找到 Keymap → Main Menu → Code → Code Completion → Basic&#xff1a; 设…

android8 老手机,华为多款老旧手机获升安卓8.0,流畅度飙升!

原标题&#xff1a;华为多款老旧手机获升安卓8.0&#xff0c;流畅度飙升&#xff01;一直以来&#xff0c;在手机用户圈都有这么一个共识&#xff0c;那就是安卓手机不如iPhone流畅&#xff0c;之前安卓手机给人的印象就是容易卡顿&#xff0c;而谷歌则一直在为此事苦恼&#x…

java12关键字var_Java 10:“ var”关键字

java12关键字varJava 10使用关键字var引入了局部变量类型推断 。 这意味着无需编写&#xff1a; Map<Department, List<Employee>> map new HashMap<>(); // ... for (Entry<Department, List<Employee>> dept : map.entrySet()) {List<Emp…

IntelliJ IDEA for Mac自定义动态代码模板快捷键(Live Templates Shortcut)

文章目录查看更多的快捷键常用的代码模板自定义代码模板快捷键格式化等号文档注释代码模板快捷键应用示例声明定义引用类型变量数组的 for 循环指定循环次数的 for 循环增强 for 循环倒序 for 循环自动生成普通 for 循环语句自动生成main 方法自动生成输出语句自动生成增强for循…

android udp 设备发现,两台Android设备之间进行UDP连接(使用多播地址)~~求大神指点...

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼首先 发送端&#xff1a;package com.example.multicastclient;import android.support.v7.app.ActionBarActivity;import java.io.IOException;import java.net.DatagramPacket;import java.net.InetAddress;import java.net.Mult…

java serial_Java的@Serial批注

java serialJDK可能正在使用JDK 11 &#xff1a; Serial获得另一个标准&#xff08;预定义&#xff09;注释 。 JDK-8202385 [“标记与序列相关的字段和方法的注释”]的目的是添加“某种“ SerialRelated”注释&#xff0c;以促进对序列字段和方法的声明的自动检查。” 这种想法…

IntelliJ IDEA 选中变量名,高亮显示其它地方的这个变量名,高亮颜色如何设置呢?

选中了一个变量名&#xff0c;会高亮显示位于别的地方的这个变量名&#xff0c;那么怎么修改其他地方的高亮颜色&#xff1f; 按下 Command , 打开偏好设置窗口&#xff0c;接着看下图&#xff1a;

rest和rest ful_还有更多REST技巧

rest和rest ful在以前的博客文章中&#xff0c;我介绍了一些实现REST体系结构的想法和技巧。 在这篇文章中&#xff0c;我将介绍更多的想法和技巧。 快取 缓存是原始论文的很大一部分。 见5.1.4节 策略包括验证&#xff08; 客户端检查它是否具有最新版本 &#xff09;和过期…

html实心圆点特殊符号,和平精英名称添加圆点符号的方法 和平精英圆点符号代码分享...

和平精英怎么在名字中添加圆点符号呢&#xff1f;昵称中是可以加入圆点符号的&#xff0c;很多小伙伴们都想要一个性一点的名字&#xff0c;那么就可以用到各种各样的特殊符号&#xff0c;圆点符号复制的代码小编已经分享到下面了&#xff0c;有需要这个圆点符号的玩家快带走吧…

Java包装类和基本数据类型的对照

int --> Integer byte --> Byte short --> Short long --> Long boolean --> Boolean char --> Character double --> Double float --> Float 注&#xff1a;基本类型自动转换成对应的包装类型&#xff0c;叫自动装箱&#xff1b;包装类型转换成对应…

java 8 stream_Java 8 Stream示例

java 8 stream这篇文章将帮助您了解Java 8中一些重要且经常使用的Stream操作&#xff0c;这使您使用Java编程变得容易。 让我们以传统示例为例&#xff0c;“员工和部门”。 public class Employee {private String name;private Integer age;private String city;private De…

html怎么设置图片隐藏,css3如何隐藏图片?

css3隐藏图片的方法&#xff1a;1、为图片元素设置display:none;样式来隐藏。2、使用visibility:hidden;样式隐藏图片。3、使用opacity:0;样式通过设置图片完全透明来设置图片不可见。css中可以使用下面几种样式隐藏图片&#xff1a;display:none;visibility:hidden;opacity:0;…

IntelliJ IDEA修改项目的根目录名称_修改包目录的名称_修改模块名称_修改项目名称

文章目录修改项目根目录的名称修改包目录的名称模块重命名修改了项目根目录后&#xff0c;必须删除项目和 .idea 文件&#xff0c;重新导入&#xff08;重点&#xff09;新版本的 IDEA 取消了 Import Project 入口修改项目根目录的名称 如果仅仅修改项目的名称&#xff0c;而不…

容器rocker_用Rocker制作模板

容器rocker在本文中&#xff0c;我们将快速介绍Rocker &#xff0c;这是一个静态类型化的快速Java 8模板引擎。 必需的依赖项 要开始使用Rocker&#xff0c;我们需要在项目中添加以下依赖项&#xff1a; <dependency><groupId>com.fizzed</groupId><art…

android 开源 示波器,上个老外的开源虚拟示波器

这个老贵~&#xff01;Price USD (US Dollar) $ 1595.00Network BitScope 442 ( BS442N )(原文件名:bs445n.png)(原文件名:bs440e.jpg)BS442NBS325NBS325UBS100UBS50UThe correct appearance of this website is only visible in graphical browsers that support web standard…

Java子类的成员方法可以直接调用父类的成员方法和成员变量

public class Teacher extends Employee {public static void main(String[] args) {}public void method() {super.method(); // 可以直接调父类的成员方法super.name; // 访问父类的成员变量System.out.println("子类方法执行&#xff01;");} }我的理解&#xff1…

java类似sizeof_如何用Java编写类似C的Sizeof函数

java类似sizeof如果您刚开始学习Java并且是C语言背景&#xff0c;那么您可能已经注意到Java和C编程语言之间存在一些差异&#xff0c;例如String是Java中的对象&#xff0c;而不是NULL终止的字符数组。 同样&#xff0c;Java中没有sizeof&#xff08;&#xff09;运算符。 所有…

html文件压缩成gzip,前端性能优化成神之路-HTTP压缩开启gzip

什么是HTTP压缩cssHTTP压缩是指: Web服务器和浏览器之间压缩传输的”文本内容“的方法。 HTTP采用通用的压缩算法&#xff0c;好比gzip来压缩HTML,Javascript, CSS文件。 能大大减小网络传输的数据量&#xff0c;提升了用户显示网页的速度。固然&#xff0c;同时会增长一点点服…

Java中父类的静态变量和静态方法的继承问题

1.普通父类的静态变量和方法&#xff0c;可以通过子类的名称访问和调用 2.普通父类的静态变量和方法&#xff0c;可以通过子类的实例对象访问和调用 3.抽象父类的静态变量和方法&#xff0c;可以通过具体子类的名称访问和调用 4.抽象父类的静态变量和方法&#xff0c;可以通过具…

jdk10与jdk9的区别_JDK 8与JDK 10:三元/拆箱的区别

jdk10与jdk9的区别最近的Nicolai Parlog &#xff08; nipafx &#xff09; 鸣叫引起了我的注意&#xff0c;因为它引用了一个有趣的StackOverflow讨论 &#xff0c;该讨论涉及JDK 8和JDK 10之间的行为更改&#xff0c;并询问“为什么&#xff1f;” SerCe 在StackOverflow线程…