在高德地图上用svg.js绘制简单图形
这段时间做的一个项目,需要在地图上绘制简单的图形。在学习高德地图
JS API的过程中,发现高德地图提供的点、线等API并不能满足我的需求,还好它开放了自定义图层CustomLayer,官方说自定义图层支持canvas、svg、甚至dom,这里我用的是svg,多说无益,上代码。
一、高德地图
以下的步骤在官方文档中都有,而且官方文档比较齐全。
- 首先需要去高德API官网申请自己的key,此步略过。
- 拿到key后在页面中引入地图所用的js
js <script type="text/javascript" src="https://webapi.amap.com/maps?v=1.4.15&key=申请的key"></script> - 准备一个放置地图的容器,指定特定的高度,宽度。我是将容器高度宽度全部设置为100%。
html <div id="container"></div>
css html, body, #container { margin: 0; padding: 0; width: 100%; height: 100%; } 最后一步,在js中指定容器,加载地图,然后就可以在页面中看到你的地图了。
js // 第一个参数是容器名称,第二个参数可以按自己需求随意配置。 var map = new AMap.Map('container', { zoom: 15, // 缩放等级 center: [115.49481017, 38.88656455], // 中心点 features: ['bg', 'road', 'building'] // 设置地图中显示的元素, 'bg'(地图背景)、'point'(POI点)、'road'(道路)、'building'(建筑物) });二、自定义图层
下面开始编写自定义图层,除过地图所用的js文件,我还用到了
jquery。- 首先地图有一部分是异步加载的,所以需要在地图加载完成后,再去编写自定义图层,否则容易报错,而地图也给我们提供了
complete事件。
js map.on('complete', function(){ // TODO 编写自定义图层 }) - 声明
svg,创建图层svg和地图类似,也需要先声明一个容器,此容器和地图等宽等高
js var svg = $('<svg id="drawing" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1" ></svg>')[0];
css #drawing { margin: 0; padding: 0; width: 100%; height: 100%; }- 创建图层
js // 第一个参数传入我们创建的svg对象,第二个参数为图层配置,可以根据自己需求进行配置 var customLayer = new AMap.CustomLayer(svg, { zIndex: 100, zooms: [3, 18], alwaysRender: true }); map.add(customLayer); // 要把图层添加到地图中
二、在图层中画自己喜欢的图形。
- 为了简化代码,项目中采用了svg.js
js // 调用svg.js提供的SVG函数,传入我们创建的svg对象,创建所需要的draw对象。 var draw = SVG(svg); 现在我们开始在地图上画线。
我们规定在地图上单击即为线的起点,再进行单击即为线的终点。
- 为地图注册单机事件
js var isDraw = false; // 用来判断是开始画线还是结束画线。 var startPix; // 用来存储起点 map.on('click', function(ev){ isDraw = !isDraw; if(isDraw) { // isDraw为true就标明起点 startPos = ev.pixel; }else{ // isDraw为false就画线。 } }) - 编写画线函数
js function drawLine(start, end) { var lineWth = 3; var lineColor = 'blue'; var x = start.x; var y = start.y; var x1 = end.x; var y1 = end.y; line = draw.line(x, y, x1, y1).stroke({ color: lineColor, width: lineWth }); return line; } 完善地图单击事件
js map.on('click', function(ev){ isDraw = !isDraw; if(isDraw){ // isDraw为true就标明起点 startPix = ev.pixel; }else{ // isDraw为false就画线。 var endPix = ev.pixel; drawLine(startPix, endPix); } })至此就可以在地图上简单的画直线了。
- 为地图注册单机事件
让线跟随鼠标移动
当我们单击地图开始画线时,此时地图上没有任何东西,再点击地图时,线突然的出现,这样显得比较突兀。现在我们需要修改成,当开始画线时,线跟随鼠标移动而移动,再点击地图时,结束画线。
我们需要先注册地图
mousemove事件
js map.on('mousemove', function (ev) { if(isDraw) { drawLine(startPix, ev.pixel) } });我们以为已经完成了,但是现在出现了一个小问题:

所有画的线都留下了来了,这时我们需要将多余的线去掉。
在鼠标移动时 去掉多余的线,这里需要用到
draw对象的group功能。
js var lineGroup; // 声明一个对象 存储line。 map.on('click', function(ev){ isDraw = !isDraw; if(isDraw){ // isDraw为true就标明起点 startPix = ev.pixel; lineGroup = draw.group(); // 开始画线时创建一个group。 }else{ // isDraw为false就画线。 var endPix = ev.pixel; drawLine(startPix, endPix); } }); map.on('mousemove', function(ev){ if(isDraw) { lineGroup.clear(); // 在鼠标移动时先将group清空。 var line = drawLine(startPix, ev.pixel); lineGroup.add(line);// 将新线添加到group中。 } })至此,我们完成了让线跟随鼠标移动。
三、地图重绘时,让画的线随实际经纬度坐标重绘。
我们现在所画的线,在拖动、放大、缩小地图时,是不会跟随地图变化而变化的。
- 需要创建一个数组用来存储坐标点,一个对象用来存储起点坐标。
js var positions = []; var startPos; - 开始画线记录起始点经纬度坐标,结束画线时将两点坐标存入数组。
js map.on('click', function(ev){ isDraw = !isDraw; if(isDraw){ // isDraw为true就标明起点 startPos = ev.lnglat; /*手动高亮*/ startPix = ev.pixel; lineGroup = draw.group(); }else{ // isDraw为false就画线。 var endPix = ev.pixel; drawLine(startPix, endPix); positions.push({ /*手动高亮*/ start: startPos, end: ev.lnglat }) } }); 注册重绘事件
我们要注册的是自定义层的重绘事件。
js customLayer.render = onRender; function onRender() { draw.clear(); // 先将画板清空 for(var i = 0;i < positions.length;i++){ // 需要将经纬度坐标转换为容器内坐标,lngLatToContainer是高德提供的转换方法 var startPixCon = map.lngLatToContainer(positions[i].start); var endPixCon = map.lngLatToContainer(positions[i].end); drawLine(startPixCon, endPixCon); } }
现在我们画的线就可以随地图变化而变化了。
在高德地图上用svg.js绘制简单图形的更多相关文章
- 使用Excel VBA编程将网点的百度坐标转换后标注到高德地图上
公司网点表存储的坐标是百度坐标,现需要将网点位置标注到高德地图上,研究了一下高德地图的云图数据模版 http://lbs.amap.com/yuntu/reference/cloudstorage和坐 ...
- 基于svg.js实现对图形的拖拽、选择和编辑操作
本文主要记录如何使用 svg.js 实现对图形的拖拽,选择,图像渲染及各类形状的绘制操作. 1.关于SVG SVG 是可缩放的矢量图形,使用XML格式定义图像,可以生成对应的DOM节点,便于对单个图形 ...
- 学习笔记:HTML5 Canvas绘制简单图形
HTML5 Canvas绘制简单图形 1.添加Canvas标签,添加id供js操作. <canvas id="mycanvas" height="700" ...
- Java入门:绘制简单图形
在上一节,我们学习了如何使用swing和awt工具创建一个空的窗口,本节学习如何绘制简单图形. 基本绘图介绍 Java中绘制基本图形,可以使用Java类库中的Graphics类,此类位于java.aw ...
- CSS绘制简单图形
究竟该用字体图标.图片图标.还是CSS画一个图标?我也不知道.各有千秋吧.本文将介绍如何用css绘制简单的图形,所有测试在chrome58.0完成,如果你不能得到正确结果请到caniuse查一查看看是 ...
- shape-自绘制简单图形
shape 可以绘制简单的图形,颜色等.它主要就是应用于selector 的一些状态. 本文内容参考自http://www.cnblogs.com/cyanfei/archive/2012/07/27 ...
- 利用 turtle库绘制简单图形
turtle库是python的基础绘图库,这个库被介绍为一个最常用的用来介绍编程知识的方法库,其主要是用于程序设计入门,是标准库之一,利用turtle可以制作很多复杂的绘图. turtle名称含义为“ ...
- Windows控制台下绘制简单图形
最近接触到一个很有意思的问题,如何在Windows控制台下画图,翻遍了C的头文件也没找到画图的函数,好吧,那就用Windows提供的API函数吧,看来想移植是没戏了.先画一个简单的图,类似心电图那种吧 ...
- ubuntu 上安装node.js 的简单方法
一.安装 1.$ sudo apt-get install nodejs 2.$ sudo apt-get install npm 二.升级 1.升级npm命令如下: $ sudo npm i ...
随机推荐
- Matlab高级教程_第二篇:一个简单的混编例子
1. 常用的混编是MATLAB和VS两个编辑器之间的混编方式. 2. 因为MATLAB的核是C型语言,因此常见的混编方式是MATLAB和C型语言的混编. 3. 这里介绍一个简单的MATLAB语言混编成 ...
- 九、linux-msyql下的mysql主从复制深度实战
1.上节基本诉说了mysql主从同步,这里想说明的是,其一从库在请求主库进行同步的时候,是主库的主线程进行用户名.密码的验证,在验证通过后,将请求转交给I/O线程负责同步:其二从库sql线程在读取中继 ...
- 三十六、www服务nginx介绍
一.Nginx介绍 ,相对于LAMP经典组合而言,LNMP是近几年来流行的组合.(linux+nginx+mysql+php) Nginx是一个开源www服务软件,是俄罗斯人开发的,本身是一款静态ww ...
- 基础篇七:默认配置语法(/etc/nginx/nginx.conf)
首选我们 vim nginx.conf 参照上图,我们看看nginx.conf 的个参数含义 我们再看看 /etc/nginx/conf.d/default.conf
- Estimating Gene Frequencies| method of maximum likelihood|point estimate
I.11 Estimating Gene Frequencies 在小样本上计算基因A的概率PA,举例如下: 通过加大样本会将通过观察值得到的数趋近于真实数据,所以该问题转化为了统计学上利用大量观察值 ...
- 吴裕雄--天生自然python学习笔记:爬取我国 1990 年到 2017年 GDP 数据并绘图显示
绘制图形所需的数据源通常是不固定的,比如,有时我们会需要从网页抓取, 也可能需从文件或数据库中获取. 利用抓取网页数据技术,把我国 1990 年到 2016 年的 GDP 数据抓取出来 ,再利用 Ma ...
- HTML常用数据类型
.数学函数: Math.ceil():天花板数 //大于当前小数的最小整数 Math.floor():地板数 //小于当前小数的最大整数 Math.round():四舍五入取整数 Math.rando ...
- mysql 优化2 慢查询
默认情况下mysql不记录慢查询日志,需要在启动的时候指定 bin\mysqld.exe - -slow-query-log 通过慢查询日志定位执行效率较低的SQL语句.慢查询日志记录了所有执行时间超 ...
- 17)将index.php中的代码放到Framework中封装起来
目录结构: 发生改动的类代码: 新增类:Framework.class.php <?php /** * Created by PhpStorm. * User: Interact * Date: ...
- JavaScript设计模式一:工厂模式和构造器模式
转自:http://segmentfault.com/a/1190000002525792 什么是模式 前阵子准备期末考试,挺累也挺忙的,实在闲不得空来更新文章,今天和大家说说javascript中的 ...