默认添加的交互功能,规定了默认包含在地图中的功能,主要是最为常用的功能,如缩放、平移和旋转地图等,具体功能有如下这些:
很多事件都兼容移动设备的触摸屏,键盘,鼠标事件,如果要更改默认的选项,需要在相应的选项设置为 false。如果想去掉默认的 DoubleClickZoom 功能,配置如下:
interactions: interaction.defaults({
doubleClickZoom: false, // 关闭双击缩放
mouseWheelZoom: false // 关闭滚轮缩放
})
这样就去除了缩放功能,去除其他的默认功能,是一样的。
绘图交互允许绘制几何地理要素
给地图添加该交互功能,首先需要实例化一个ol.interaction.Draw,必须指定 source和type属性:
const draw = new interaction.Draw({
source, // 绘制图形的图层源 没有时可设置为layers下的new TileLayer配置项的source
type: "Polygon" // 添加的绘图类型
});
map.addInteraction(draw) // 添加绘制功能到图层
// map.removeInteraction(draw) // 从图层移除绘制功能
interactions:interaction.defaults().extend([
new interaction.DragRotateAndZoom()
])
设置配置项的interactions
为interaction.DragRotateAndZoom()
可以通过拖拽实现旋转和缩放地图的功能
这个功能的使用方法是首先按住键盘的 shift 按钮,然后使用鼠标点住地图一点,然后拖拽鼠标围绕地图中心旋转,地图就会旋转相应的角度;如果拖拽鼠标远离地图中心,就会实现地图的放大,靠近地图中心,地图就会缩小。
该功能是两个单独功能的合体: dragzoom
和 dragrotate
,一个负责拖拽缩放,一个负责拖拽旋转
在地图上拉出一个矩形框,一般配合使用一个辅助按键,如Shift,常用于放大功能,该功能是默认添加在地图中的。
没有其他功能冲突的默认情况下(如上面dragrotateandzoom interaction
拖拽缩放),按下Shift,然后拖动鼠标拉框,然后地图就会将框内内容放大。
将空间数据使用鼠标或者手指拖拽到地图中,解析成一个图层添加到地图中。
目前只支持矢量数据,未来可能支持更多的空间数据格式。
支持的格式包括 GeoJSON、GML、 KML、 GPX、 OSMXML、 TopoJSON、 IGC
。
首先实例化一个 draganddropinteraction
:
var dragAndDropInteraction = new ol.interaction.DragAndDrop({
formatConstructors: [
ol.format.GeoJSON,
ol.format
]
})
formatConstructors 表示想要支持的格式,这里我选择了支持两种常见的格式:GeoJSON
和 KML
,然后将该交互添加到地图中:
var interactions = ol.interaction.defaults().extend([
new ol.interaction.DragRotateAndZoom(),
dragAndDropInteraction
])
如果想在添加数据的时候定义一些额外行为,比如缩放到添加到数据的范围,需要注册 interaction
的事件dragAndDropInteraction.on('addfeatures', function(event) {})
包含 ol.interaction.KeyboardZoom
和 ol.interaction.KeyboardPan
,分别是键盘缩放和键盘平移。
默认添加到地图中,但是只有当焦点在包含地图的 HTML 元素上,才可用。
可以通过修改 ol.Map
的 keyboardEventTarget
属性,修改键盘事件的关联 HTML 元素。
ol.interaction.KeyboardZoom
,使用键盘+ 和 - 进行地图缩放
ol.interaction.KeyboardPan
,使用方向键平移地图
select是用来选中要素的,而 modify 是修改要素的,主要是通过拖拽方式修改点的坐标
模拟选中并修改要素的交互功能需要添加如下代码:
/*select*/ ol.interaction.Select();
/*moddify*/ ol.interaction.Modify({
features:select.getFeatures()
});
features:select.getFeatures()
目的为修改选中的要素。
然后将两个交互功能添加到 map 中就可以使用其功能了
这两个功能针对触摸屏,两个手指按住地图,增减距离来实现缩放,旋转手指,地图跟着旋转。默认添加到地图中。
针对鼠标的行为按下Down
、移动Move
和抬起Up
,自定义事件。
这三个事件发生有先后顺序,首先是触发按下,之后是移动事件,最后是抬起事件。
只要配置相关的属性,包含handleDownEvent
,handleDragEvent
,handleMoveEvent
handleUpEvent
分别对应鼠标的 down
、drag
、move
和up
四种事件。
例如配置鼠标的按下左键事件,当按下鼠标左键时候,就会触发 fun函数 :
.interaction.Pointer({
handleDownEvent: fun
})
当修改和绘制矢量要素时,鼠标距离某个要素一定距离之内,自动吸附到要素。
可以配置的选项有 具有捕捉吸附功能的要素集 或者 矢量图层,发生捕捉的最大距离(像素为单位),使用方法如下:
new ol.interaction.Snap({
features: 要素集(ol.Collection),
pixelTolerance: 捕捉发生的距离,像素数,
source: 具有捕捉功能的图层(ol.source.Vector)
})