Leaflet:LatLng、LatLngBounds、Point、Bounds、Icon
LatLng
代表一个有着确定经纬度坐标的地理点。
1、用例
var latlng = L.latlng(50.5,30.5);
所有Leaflet的方法中接收的LatLng参数均可以用数组[ ]或者一个表示经纬度的Key/Value表示:
map.panTo( [50,30] );
map.panTo( {lon : 30 , lat : 50});
map.panTo( {lat : 50 , lon : 30});
map.panTo( L.latLng( 50 ,30 ));
2、初始化
L.latLng( lat , lon , <Number>altitude?)//在(lat lon)处创建一个地理点,第三个参数表示高度
L.latLng( [ lat , lon , alt?] )
L.latLng( { latitude : lat , longitude : lon , alt : n?})
注意第一个字母小写,第二个L才大写
3、方法
equals( <LatLng>otherlatlng , <Number>maxMargin?)//第二个参数表示误差值,如果给定点与原坐标之间的经纬度差值在误差值内,就返回true
toString() //返回LatLng的String写法,类似LatLng(lat,lng)这样
distanceTo(<LatLng>otherLatLng)//计算两点间的距离(单位m)
wrap() //返回新的LatLng对象,它的经度longitude与原点经度刚好相反(区间是-180~180)
toBounds(<Number>sizeInMeters)//返回LatLngBounds,边长单位m,长度是LatLon点坐标值的一半
LatLngBounds
代表地图上的一个矩形地理区域
1、用例
var corner1=L.latLng(41.712,-74.227),
corner2=L.latLng(40.774-74.125),
bounds=L.latLngBounds(corner1,corner2);
所有接受LatLngBounds作为参数的方法,均可以用一个包含两个LatLng的Array[ ]作为代替,比如:
map.fitBounds(bounds) //等同于 map.fitBounds([corner1 , corner2]) //等同于 map.fitBounds([ [40.712, -74.227] , [40.774, -74.125] ]);
2、初始化
L.latLngBounds( <LatLng>corner1 , <LatLng>corner2 )
L.latLngBounds( <LatLng[]> latlngs )
第二种方法在用于map.fitBounds()作为参数时会很有用。
3、方法
extend(<LatLng> latlng) //延伸该Bounds到可以包含给定点
extend( <LatLngBounds> otherBounds) //延伸到包含给定Bounds
pad( <Number> bufferRation ) //根据参数值决定延伸还是收缩该Bounds。0.5表示各个方向上延伸50%,负数表示收缩
getCenter() //返回LatLng;返回中心点
getSouthWest()
getNorthEast()
getNorthWest()
getSouthEast()
getWest() //返回最西边的经度值
getSouth()
getEast()
getWest()
contains(<LatLngBounds>otherBounds) //是否包含给定的Bounds区域
contains(<LatLng> latlng) //是否包含给定点
intersects(<LatLngBounds> otherBounds) //是否与给定区域相交
overlaps(<LatLngBounds> otherBounds) //是否与给定区域部分重叠(区别于相交是,相交可以是点,而重叠的部分一定是一个Bounds)
toBBoxString() //返回构成该Bounds的右下和左上角点的坐标的String形式
equals(<LatLngBounds>otherBounds,<Number>maxMargin?)//是否在经纬度误差为maxMargin的前提下,两块Bounds的范围相同?
Point
代表一个点(x,y),区别于LatLng是Point的坐标是以像素为单位,而LatLng的单位是°;或者说,Point是绝对于Web的,不管你Map怎么变,该Point都始终在Web页面的那个位置处;而LatLng则是绝对于Map的,它在地图上的坐标就是LatLng。
常用于地图平移的参数。
1、用例
var point = L.point(200 , 300);
所有Leaflet的方法中接收Point类型作为参数的,均可以接收一个[ x , y ]作为替代。
2、初始化
L.point( x , y , <Boolean> round? ) //round表示是否进行四舍五入
L.point([ x , y ])
L.point( { x:Number , y:Number } )
3、方法
clone() //返回当前点的副本
add(<Point> otherPoint) //返回两个点坐标的加和
subtract(otherPoint) //返回两个点的差
divideBy(n) //返回除以n后的坐标
multiplyBy(n) //返回乘n后的坐标
scaleBy( <Point>scale ) //两个点的对应坐标相乘得到新点
unscaleBy( scale ) //原点两坐标除以scale的坐标得到新点
round() //返回一个四舍五入后的点坐标的副本
floor() //向下取整
ceil() //向上取整
trunc() //向0取整
distanceTo(otherPoint) //返回两点间的笛卡尔距离
equals(otherPoint) //如果两点坐标相同,返回true
contains(otherPoint) //如果otherPoint的每个坐标绝对值都小于原点,则返回true
toString()
Bounds
一个矩形区域,长度单位是像素。与Point的关系就像是LatLngBounds与LatLng的关系。
1、用例
var p1=L.point(10,10),
p2=L.point(40,60),
bounds=L.bounds( p1 , p2 )
所有Leaflet方法中接收Bounds作为参数的,都可以将参数替换为Array [ point1 , point2 ]的形式。
2、初始化
L.bounds(<Point>corner1 , <Point>corner2)
L.bounds( [ corner1 , corner2 ])
3、方法
其实方法与LatLngBounds的方法类似,但是由于名字不太一样,所以这里还是写出来:
extend(<Point> point) //延伸该bounds到可以包含给定点
getCenter(<Boolean> round?)//取中心点,round表示是否四舍五入
getBottomLeft() //返回左下角的Point
getTopRight()
getTopLeft()
getBottomRight()
getSize() //返回一个Point,表示该Bounds的长和宽
contains(<Bounds>otherBounds) //如果包含给定Bounds就返回true
contains(<Point> point) //如果包含给定point就返回true
intersects(<Bounds>otherBounds) //如果两个Bounds相交,就返回true
overlaps(<Bounds>otherBounds) //如果两个Bounds有重叠区域,就返回true
4、属性,Properties
min //类型Point,左上角的点
max //右下角的点
Icon
Icon就是Marker的图标
1、用例
var myIcon=L.icon({
iconUrl:'my-icon.png',
iconSize:[38,95],
iconAnchor:[22,94],
popupAnchor:[-3,-76],
shadowUrl:'my-icon-shadow.png',
shadowSize:[68,95],
shadowAnchor:[22,94]
}); L.marker( [50.505 , 30.57],{icon: myIcon}).addTo(map);
默认的Icon是一个蓝色的Icon(就是我们默认设置Marker的样式)。
2、初始化
L.icon(<Icon options>options)
3、参数
iconUrl //Icon图的URL,绝对地址或者相对于根目录的地址
iconRetinaUrl //手机屏中的icon的URL
iconSize //类型Point,表示icon的尺寸(单位Pixel)
iconAnchor //类型Point,Icon图标左上角的坐标(以实际点的坐标为(0,0),相对于实际点的pixel坐标)
popupAnchor //Popup的坐标
shadowUrl //Icon 阴影的URL
shadowSize
shadowAnchor
className //给Icon和shadow图的类命名
5、Icon.Default
如果想自制默认icon,就修改L.Marker.prototype.options
Leaflet:LatLng、LatLngBounds、Point、Bounds、Icon的更多相关文章
- Leaflet:Path、Polyline、Polygon、Rectangle、Circle、CircleMarker
下边介绍Vector Layer Path(Layer) Path是其他Vector Layer的父类,比如Polyline.Polygon.Rectangle.Circle.CircleMarker ...
- Leaflet:Marker、Popup类
Marker.Popup.Tooltip类都是继承自Layer类:Event与Layer Marker 1.用例 L.marker([41,123]).addTo(map); 2.实例化 L.mark ...
- Leaflet:LayerGroup、FeatureGroup
LayerGroup(Layer) Layer 用法:把一些Layer集中到一个组Group中,以便作为一个整体进行操作.如果把该Group加入到了Map中,任何从这个Group增加或者移除Layer ...
- C#、JAVA操作Hadoop(HDFS、Map/Reduce)真实过程概述。组件、源码下载。无法解决:Response status code does not indicate success: 500。
一.Hadoop环境配置概述 三台虚拟机,操作系统为:Ubuntu 16.04. Hadoop版本:2.7.2 NameNode:192.168.72.132 DataNode:192.168.72. ...
- 教你一招:解决win10/win8.1系统在安装、卸载软件时出现2502、2503错误代码的问题
经常遇到win10/win8.1系统在安装.卸载软件时出现2502.2503错误代码的问题. 解决办法: 1.打开任务管理器后,切换到“详细信息”选项卡,找到explore.exe这个进程,然后结束进 ...
- TFS API:三、TFS WorkItem添加和修改、保存
TFS API:三.TFS WorkItem添加和修改.保存 WorkItemStore:表示跟踪与运行 Team Foundation Server的服务器的工作项客户端连接. A.添加工作项 1 ...
- C#与Java对比学习:类型判断、类与接口继承、代码规范与编码习惯、常量定义
类型判断符号: C#:object a; if(a is int) { } 用 is 符号判断 Java:object a; if(a instanceof Integer) { } 用 inst ...
- 转载:谈谈Unicode编码,简要解释UCS、UTF、BMP、BOM等名词
转载: 谈谈Unicode编码,简要解释UCS.UTF.BMP.BOM等名词 这是一篇程序员写给程序员的趣味读物.所谓趣味是指可以比较轻松地了解一些原来不清楚的概念,增进知识,类似于打RPG游戏的升级 ...
- Java多线程21:多线程下的其他组件之CyclicBarrier、Callable、Future和FutureTask
CyclicBarrier 接着讲多线程下的其他组件,第一个要讲的就是CyclicBarrier.CyclicBarrier从字面理解是指循环屏障,它可以协同多个线程,让多个线程在这个屏障前等待,直到 ...
随机推荐
- Java应用程序OOM分析
内存泄露:申请使用完的内存没有释放,导致虚拟机不能再次使用该内存,此时这段内存就泄露了,因为申请者不用了,而又不能被虚拟机分配给别人用. 内存溢出:申请的内存超出了JVM能提供的内存大小,此时称之为溢 ...
- Python:使用pyinstaller打包含有gettext locales语言环境的项目
问题 如何使用 pyinstaller 打包使用了 gettext 本地化的项目,最终只生成一个 exe 文件 起因 最近在用 pyhton 做一个图片处理的小工具,顺便接触了一下 gettext,用 ...
- SQL语句 order by 升序和 降序查询
原文 https://blog.csdn.net/u010649766/article/details/76180523?utm_medium=distribute.pc_relevant_t0.no ...
- ApacheCN C/C++ 译文集(二) 20211204 更新
编写高效程序的艺术 零.序言 第一部分:性能基础 一.性能和并发性介绍 二.性能测量 三.CPU 架构.资源和性能 四.内存架构和性能 五.线程.内存和并发 第二部分:高级并发 六.并发和性能 七.并 ...
- Nacos极简教程
简介 Nacos是服务发现与注册,服务配置中心. Nacos 具有如下特性: 服务发现和服务健康监测:支持基于DNS和基于RPC的服务发现,支持对服务的实时的健康检查,阻止向不健康的主机或服务实例发送 ...
- 关于unix下cp命令复制权限不够的问题
例如要将mysql-5.7.17-macos10.12-x86_64.tar.gz 拷贝到/usr/local目录下时,执行cp mysql-5.7.17-macos10.12-x86_64.tar. ...
- Zookeeper、Kafka集群与Filebeat+Kafka+ELK架构
Zookeeper.Kafka集群与Filebeat+Kafka+ELK架构 目录 Zookeeper.Kafka集群与Filebeat+Kafka+ELK架构 一.Zookeeper 1. Zook ...
- 这个Dubbo注册中心扩展,有点意思!
今天想和大家聊聊Dubbo源码中实现的一个注册中心扩展.它很特殊,也帮我解决了一个困扰已久的问题,刚刚在生产中用了,效果很好,迫不及待想分享给大家. Dubbo的扩展性非常灵活,可以无侵入源码加载自定 ...
- LinkedHashSet、Map、Map接口HashMap、Hashtable,TreeSet、TreeMap、如何选择使用集合实现类,Collections工具类
一.Set接口实现类LinkedHashSet 实现继承图: 1.LinkedHashSet的全面说明 1) LinkedHashSet是 HashSet的子类 2) LinkedHashSet底层是 ...
- linxu 查看运行日志
journalctl - 检索 systemd 日志 journalctl 可用于检索 systemd(1) 日志(由 systemd-journald.service(8) 记录). 如果不带任何参 ...