Openlayers2图层加载(二)加载矢量图层

本文介绍如何使用OpenLayers加载GeoJSON矢量图层,包括设置数据源、定义图层投影、制定策略及协议,并展示了一个加载河流矢量数据的具体示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

加载矢量图层文件

通过WMS请求获取到图层,其实是一张张图片拼在一起的。而矢量图层,是由矢量数据来构造的。OpenLayer是中支持的矢量数据文件格式较多,如GeoJSON、KML、XML等。
以加载GeoJson为例,如下

数据源:GeoJSON文件

示例数据一级河流,命名为river.geosion。

function initMap(){
	var map,baseLayer	
	map = new OpenLayers.Map("map");

	baseLayer = new OpenLayers.Layer.WMS(
			"basic",
			"http://localhost:8080/geoserver/chinaNS/wms",
			{
                    layers: "chinaNS:shengjie"
			},
			{isBaseLayer:true}
    );

    var vectorLayer = new OpenLayers.Layer.Vector(
        'vector',
        {
            projection:"EPSG:4326",
            strategies: [new OpenLayers.Strategy.Fixed()],
            protocol: new OpenLayers.Protocol.HTTP({
                url: "../data/river.geojson",
                format: new OpenLayers.Format.GeoJSON()
            })
        }
    );

	map.addLayers([baseLayer,vectorLayer]);
	map.setCenter(new OpenLayers.LonLat(108, 34), 4);
}



html代码

<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<meta name="viewport" content="width=device-width, initial-scale=1.0">
	<meta http-equiv="X-UA-Compatible" content="ie=edge">
	<title>Document</title>
	<link href="/css/map.css" rel="stylesheet">
	<script src="/jquery-2.0.0/jquery.min.js"></script>
	<style>
		#map{
			width: 100%;
			height: 768px;
		}
	</style>
</head>
<body>
	<div id="map"></div>
    <script src="../openlayers2/lib/OpenLayers.js"></script>
    <script src="../js/ol2/eg/loadVector.js"></script>
    <script>
        $(document).ready(function(){
            initMap();
        })
    </script>
</body>
</html>

结果
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值