【07】openlayers 矢量图层

创建地图:

//创建地图
var map = new ol.Map({
    //设置显示地图的视图
    view: new ol.View({
        center: [0, 0],//义地图显示中心于经度0度,纬度0度处
        zoom: 1 //定义地图显示层级为1
    }),
    //创建地图图层
    layers: [
        //创建一个使用Open Street Map地图源的瓦片图层
        new ol.layer.Tile({
            source: new ol.source.OSM()
        })
    ],
    //让id为map的div作为地图的容器
    target: 'map'
});

创建矢量图层:

//矢量图层vectorlayer
let vectorlayer = new ol.layer.Vector({
    source:source,//矢量图层源
    style:style,//矢量图层样式
    opacity:1,//透明度,默认为1
    visible:true,//是不显示,默认true
    extent:[100,34,103,36],//可选参数,图层渲染范围,[minLon,minLat,maxLon,maxLat]
    zIndex:1,//图层渲染索引,默认是按加载顺序叠加
})
map.addLayer(vectorlayer)

矢量图层关于map的方法:

//添加矢量图层
map.addLayer(vectorlayer)
//删除切片图层
map.removeLayer(vectorlayer)

矢量图层自身方法:

//矢量图层的常用方法
//获取-设置,图层的可见范围
vectorlayer.getExtent();
vectorlayer.setExtent([100,34,103,36]);
//获取-设置,图层最大缩放级别
vectorlayer.getMaxZoom()
vectorlayer.setMaxZoom(18)
//获取-设置,图层最小缩放级别
vectorlayer.getMinZoom()
vectorlayer.setMinZoom(2)
//获取-设置,图层的不透明度
vectorlayer.getOpacity()
vectorlayer.setOpacity(1)
//获取-设置,图层源
vectorlayer.getSource()
vectorlayer.setSource(new ol.source.OSM())
//获取-设置,图层的可见性
vectorlayer.getVisible()
vectorlayer.setVisible(true)
//获取-设置,图层的Z索引
vectorlayer.getZIndex()
vectorlayer.setZIndex(2)
//绑定事件-取消事件 type事件类型,listener函数体
vectorlayer.on(type,listener)
vectorlayer.un(type,listener)

//获取与视口上给定像素相交的最高要素
vectorlayer.getFeatures([200,600])
//获取-设置,图层样式
vectorlayer.getStyle()
vectorlayer.setStyle(style)

 

下面重点介绍:矢量图层样式(style) 和 矢量图层源(source)

矢量样式:style

let style = new ol.style.Style({
    //填充样式(面)
    fill: new ol.style.Fill({
        color: 'rgba(255, 255, 255, 0.2)'
    }),
    //描边样式(线)
    stroke: new ol.style.Stroke({
        color: '#ffcc33',
        width: 2
    }),
    //图像样式
    image:image,
    //文字样式
    text:new ol.style.Text({
        font:'20px sans-serif',//字体大小,样式
        offsetX:0,//水平文本偏移量(以像素为单位)
        offsetY:0,//垂直文本偏移量(以像素为单位)
        scale:1,//字体放大倍数
        rotation:(Math.PI/180)*30,//旋转角度(顺时针旋转)
        text:'哇哈哈',//文字内容
        textAlign:'center',// 文字对齐方式 'left','right','center'
        fill:new ol.style.Fill({//文字填充颜色
            color: 'green'
        }),
        stroke: new ol.style.Stroke({//描边样式
            color: '#fff',
            width: 2
        }),
        padding:[0,0,0,0],//在文本周围填充像素
    })
})

矢量样式里的图像样式:image

//图像样式(点)
let image = new ol.style.Circle({
    radius: 10, 
    fill: new ol.style.Fill({
        color: 'red'
    }),
    stroke: new ol.style.Stroke({
        color: '#ffcc33',
        width: 2
    })
})
//如果是图标
let image = new ol.style.Icon({
    src:'',//图片来源
    color:'',//图标颜色,
    opacity:1,//透明度
    scale:1,//放大缩小倍数
    rotation:(Math.PI/180)*deg,//旋转角度,顺时针旋转
})
//如果是正方形
let image = new ol.style.RegularShape({
    fill: new ol.style.Fill({
        color: 'red'
    }),//填充色
    stroke: new ol.style.Stroke({
        color: '#ffcc33',
        width: 2
    }),//边线样式
    points: 4,//边数
    radius: 10,//半径
    angle: (Math.PI/4),//形状的角度(弧度单位)
    rotation:(Math.PI/180)*deg,//旋转角度
    rotateWithView:false,//是否跟随视图旋转形状
})
//如果是五角星
let image = new ol.style.RegularShape({
    fill: new ol.style.Fill({
        color: 'red'
    }),//填充色
    stroke: new ol.style.Stroke({
        color: '#ffcc33',
        width: 2
    }),//边线样式
    points: 5,//边数
    radius: 10,//半径
    radius2: 4,//内半径
    angle: 0//形状的角度(弧度单位)
})
//如果是三角形
let image = new ol.style.RegularShape({
    fill: new ol.style.Fill({
        color: 'red'
    }),//填充色
    stroke: new ol.style.Stroke({
        color: '#ffcc33',
        width: 2
    }),//边线样式
    points: 3,//边数
    radius: 10,//半径
    rotation: (Math.PI/180)*deg,//旋转角度
    angle: 0//形状的角度(弧度单位)
})
//如果是十字
let image = new ol.style.RegularShape({
    fill: new ol.style.Fill({
        color: 'red'
    }),//填充色
    stroke: new ol.style.Stroke({
        color: '#ffcc33',
        width: 2
    }),//边线样式
    points: 4,//边数
    radius: 10,//半径
    radius2: 0,//内半径
    angle: 0//形状的角度(弧度单位)
})
//如果是X型
let image = new ol.style.RegularShape({
    fill: new ol.style.Fill({
        color: 'red'
    }),//填充色
    stroke: new ol.style.Stroke({
        color: '#ffcc33',
        width: 2
    }),//边线样式
    points: 4,//边数
    radius: 10,//半径
    radius2: 0,//内半径
    angle: (Math.PI/4)//形状的角度(弧度单位)
})

矢量样式style的方法:

//克隆
style.clone()
//获取
style.getFill()
style.getStroke();
style.getImage();
style.getText();
//设置
style.setFill(fill)
style.setImage(image)
style.setStroke(stroke)
style.setText(text)    

矢量图层源:point,line,polygon,wkt

//矢量图层源 :point,line,polygon,wkt
let source = new ol.source.Vector({
    features:[point,line,polygon,wkt]//矢量
})
//矢量点 - 图标
let point = new ol.Feature(
        new ol.geom.Point([108,34])
    )
//矢量 线
let line = new ol.Feature(
        new ol.geom.LineString([[108,34],[100,34],[100,40]])
    )
//矢量面
let polygon = new ol.Feature(
        new ol.geom.Polygon([[[90,34],[108,34],[90,40]]])
    )
//wkt
let wktData = 'POLYGON((10.689 -25.092, 34.595 ' +
      '-20.170, 38.814 -35.639, 13.502 ' +
      '-39.155, 10.689 -25.092))';
let wkt = (new ol.format.WKT()).readFeature(wktData, {
    dataProjection: 'EPSG:4326',//数据的投影
    featureProjection: 'EPSG:3857'//创建的要素几何的投影
})

矢量图层源:geojson

//矢量图层源:geojson
//加载方法一
let source = new ol.source.Vector({
    url:'data.geojson',//geojson 路径
    format: new ol.format.GeoJSON({
        dataProjection:'EPSG:4326',//默认数据投影'EPSG:4326'
    })
})
//加载方法二
let source = new ol.source.Vector({
    features: (new ol.format.GeoJSON()).readFeatures(geojsonData)
})

矢量图层源:topjson

//矢量图层源:topjson
let source = new ol.source.Vector({
    url: 'topjson.json',//路径
    format: new ol.format.TopoJSON({
        layers: ['countries'] //子级名称
    }),
    overlaps: false,//该源可能具有重叠的几何形状,是否重叠
})

矢量图层源:kml

//矢量图层源:kml
let source = new ol.source.Vector({
    url: "data.kml",
    format: new ol.format.KML({
        extractStyles:true,//从KML中提取样式
        showPointNames:true,//将名称显示为包含点的地标的标签
        writeStyles:true,//将样式写入KML
    })
})

矢量图层源:gpx

let source = new ol.source.Vector({
    // GPX数据路径
    url: 'data.gpx',
    // 指定数据格式为GPX
    format: new ol.format.GPX()
})

矢量图层源:mvt

let source = new ol.source.VectorTile({
    format: new ol.format.MVT(),
    url: '',//数据路径
})

矢量图层源 source 的自身方法:

//source 方法
//添加-删除feature
source.addFeature(feature)
source.removeFeature(feature)
source.addFeatures(features)
//遍历feature
source.forEachFeature(callback)
//获取
source.getFeatureById(id)
source.getFeatures()
//绑定事件-取消事件 type事件类型,listener函数体
source.on(type,listener)
source.un(type,listener)

矢量点聚合Cluster

//点聚合Cluster
let clusterSource = new ol.source.Cluster({
  distance:20,//间隔最小距离,默认20像素
  source: source,//资源,点
});
//设置距离
clusterSource.setDistance(10)

 

你可能感兴趣的:(【07】openlayers 矢量图层)