登录
加入联盟
找回密码
航空人生
新一代连飞客户端下载
空管人生
中国航空运动协会推荐
WEFLY
模拟飞行玩家聊天工具
门户
文章
商城
二手市场
外包服务
模飞软件
硬件设备
飞行体验
学院
云课堂
问答
资料下载
论坛
模拟飞行
低空飞行
太空探索
航圈
资源
素材
下载
企业
无人机论坛
»
论坛
›
无人机DIY专区
›
图像视觉
›
openlayers6「七」地图控件controls详解
返回列表
发新帖
查看:
572
|
回复:
0
openlayers6「七」地图控件controls详解
[复制链接]
trilobite
trilobite
当前离线
积分
977
窥视卡
雷达卡
312
主题
352
帖子
977
积分
高级飞友
高级飞友, 积分 977, 距离下一级还需 23 积分
高级飞友, 积分 977, 距离下一级还需 23 积分
积分
977
飞币
623
注册时间
2017-7-26
发消息
发表于 2022-10-23 04:25:14
|
显示全部楼层
|
阅读模式
文章目录
1. controls 简述
2. 常见的 controls 控件
3. 控件的使用
3.1 fullscreen 全屏控件
3.2 mouseposition 鼠标位置控件
3.3 overviewmap 地图全局视图(鹰眼图)控件
3.4 scaleline 比例尺控件
3.5 zoom 缩放控件
3.6 zoomslider 缩放滑块刻度控件
4. 总结
1. controls 简述
上篇文章我们将了在地图上的交互(interaction),那些都是一些隐性的需要去使用才能知道存在有这样一个东西,就像彩蛋一样。这篇我们主要讲地图上的控件(controls),这些可以说都是显性的东西,如果设置了,打开地图页面就能够看到的东西。场景
跟 interaction交互一样,可以看到官网的描述:最初添加到地图的控件。如果未指定, module:ol/control~defaults则使用。也就是说这个属性 不是必须存在 的,默认使用的是control~defaults 内容,并且是已 Array数组形式存在,也就是说可以像图层和交互一样,可以多个控件功能承载在地图上。
2. 常见的 controls 控件
controldefaults,地图默认包含的控件,包含缩放控件和旋转控件;
fullscreen,全屏控件,用于全屏幕查看地图;
mouseposition,鼠标位置控件,显示鼠标所在地图位置的坐标,可以自定义投影;
overviewmap,地图全局视图控件(鹰眼图);
scaleline,比例尺控件;
zoom,缩放控件;
zoomslider,缩放滑块刻度控件;
3. 控件的使用
3.1 fullscreen 全屏控件
import { defaults as defaultControls, FullScreen } from "ol/control";
this.map.addControl(new FullScreen());
1
2
3.2 mouseposition 鼠标位置控件
import MousePosition from "ol/control/MousePosition";
// 向地图添加 MousePosition
var mousePositionControl = new MousePosition({
//坐标格式
coordinateFormat: createStringXY(5),
//地图投影坐标系(若未设置则输出为默认投影坐标系下的坐标)
projection: "EPSG:4326",
//坐标信息显示样式类名,默认是'ol-mouse-position'
className: "custom-mouse-position",
//显示鼠标位置信息的目标容器
target: document.getElementById("mouse-position"),
//未定义坐标的标记
undefinedHTML: " "
});
this.map.addControl(mousePositionControl);
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
3.3 overviewmap 地图全局视图(鹰眼图)控件
参数:以下参数都为可选,添加如下代码:
collapsed,收缩选项,默认为true,收缩;
collapseLabel,收缩后的图标按钮;
collapsible,是否可以收缩为图标按钮,默认为 true;
label,当 overviewmapcontrol 收缩为图标按钮时,显示在图标按钮上的文字或者符号,默认为 »;
layers,overviewmapcontrol针对的图层,默认情况下为所有图层,一般这里设置的图层和map图层数据一致;
render,当 overviewmapcontrol 重新绘制时,调用的函数;
target,放置的 HTML 元素;
tipLabel,鼠标放置在图标按钮上的提示文字。
var overviewMapControl = new OverviewMap({
layers: [
new TileLayer({
source: new XYZ({
url:
"http://map.geoq.cn/ArcGIS/rest/services/ChinaOnlineStreetPurplishBlue/MapServer/tile/{z}/{y}/{x}"
})
})
]
});
this.map = new Map({
target: target,
layers: tileLayer,
view: view,
// 添加鹰眼图的控件
controls: defaultControls({ zoom: true }).extend([
overviewMapControl
])
});
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
3.4 scaleline 比例尺控件
import { defaults as defaultControls,ScaleLine} from "ol/control";
this.map.addControl(new ScaleLine());
1
2
3.5 zoom 缩放控件
controls: defaultControls({ zoom: true }).extend([])
1
3.6 zoomslider 缩放滑块刻度控件
import { defaults as defaultControls, ZoomSlider } from "ol/control";
this.map.addControl(new ZoomSlider());
1
2
4. 总结
这里只是简单介绍了几个常用的控件全屏,鼠标位置,鹰眼图,比例尺,缩放,缩放滑块等,更多的控件可以去官网查看。
controls
,
比例尺
,
地图控
,
解文章
,
滑块
回复
使用道具
举报
提升卡
置顶卡
沉默卡
喧嚣卡
变色卡
千斤顶
照妖镜
返回列表
发新帖
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
|
加入联盟
本版积分规则
发表回复
回帖后跳转到最后一页
快速回复
返回顶部
返回列表