OL3矢量图层样式自定义

概述:

本文讲述如何在OL3中加载Geojson并动态修改图层样式。


效果:


地图展示


样式修改面板


实现代码:

<html xmlns="http://www.w3.org/1999/xhtml">
<head>
	<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
	<title>Ol3 wms</title>
	<link rel="stylesheet" type="text/css" href="../../../plugin/ol3/css/ol.css"/>
	<style type="text/css">
		body, #map {
			border: 0px;
			margin: 0px;
			padding: 0px;
			 100%;
			height: 100%;
			font-size: 13px;
		}
		.style-box{
			position: absolute;
			top: 10px;
			right: 10px;
			z-index: 999;
			background: #ffffff;
			border: 1px solid #cccccc;
			box-shadow: 2px 2px 3px #C0C0C0;
			padding: 10px;
			border-radius: 4px;
		}
		.style-box ul{
			margin: 0px;
		}
		.style-box ul li{
			list-style: none;
			margin: 0px;
			margin-left: -40px;
		}
		.style-box ul li h5{
			margin: 6px 0px;
		}
	</style>
	<script type="text/javascript" src="../../../plugin/ol3/build/ol-debug.js"></script>
	<script type="text/javascript" src="../../../plugin/jquery/jquery-1.8.3.js"></script>
	<script type="text/javascript" src="extends/color_exchange.js"></script>
	<script type="text/javascript">
		function init(){
			var bounds = [73.4510046356223, 18.1632471876417,
				134.976797646506, 53.5319431522236];
			var projection = new ol.proj.Projection({
				code: 'EPSG:4326',
				units: 'degrees'
			});
			$.get("data/province.geojson",null,function(result){
				var features = (new ol.format.GeoJSON()).readFeatures(result);
				var vectorSource = new ol.source.Vector();
				vectorSource.addFeatures(features);
				var vector = new ol.layer.Vector({
					source: vectorSource,
					style:getStyle("blue", "true", 2)
				});
				var map = new ol.Map({
					controls: ol.control.defaults({
						attribution: false
					}),
					target: 'map',
					layers: [vector],
					view: new ol.View({
						projection: projection
					})
				});
				map.getView().fit(bounds, map.getSize());
				//线的颜色
				$("input[name='linecolor']").on("change",function(){
                    var _color = $(this).val();
				    if(_color===""){
                        $("#linecolor").show();
					}
					else{
                        $("#linecolor").attr("value", _color).hide();
					}
                    vector.setStyle(getStyle());
				});
                //填充颜色
                $("input[name='fillcolor']").on("change",function(){
                    var _color = $(this).val();
                    if(_color===""){
                        $("#fillcolor").show();
                    }
                    else{
                        $("#fillcolor").attr("value", _color).hide();
                    }
                    vector.setStyle(getStyle());
                });
				//透明度,线的颜色,填充颜色,线条类型,线条宽度
                $("input[name='linetype'], input[name='linewidth'], #islabel").on("change",function(){
                    vector.setStyle(getStyle());
                });
                $("#opacity, #linecolor, #fillcolor").on("input propertychange",function(){
                    vector.setStyle(getStyle());
                });
			});
		}

		function getStyle() {
            var color = $("input[name='linecolor']:checked").val();
            var fillColor = $("#fillcolor").val();
            var opacity = $("#opacity").val();
            if(color===""){
                color = $("#linecolor").val();
            }
            fillColor = fillColor.colorRgb();
            var _fillColor = "RGBA("+fillColor[0]+","+fillColor[1]+","+fillColor[2]+","+opacity+")";
            var dash = $("input[name='linetype']:checked").val();
            var width = parseInt($("input[name='linewidth']").val());
		    var _dash = dash==="true"?3*0;
		    var islabel = $("#islabel")[0].checked;
            return function(feature, resolution){
                var name = feature.get("name");
                var lblcolor = '#000000';
                if(!islabel)lblcolor = 'rgba(0,0,0,0)';
                return new ol.style.Style({
                    stroke: new ol.style.Stroke({
                        color: color,
                        lineDash: [_dash, _dash],
                         width
                    }),
                    fill: new ol.style.Fill({
                        color: _fillColor,
                        opacity:opacity
                    }),
                    text: new ol.style.Text({
                        text: name,
                        fill: new ol.style.Fill({
                            color:lblcolor
                        })
                    })
                });
			}
        }
	</script>
</head>
<body onLoad="init()">
<div id="map">
	<div class="style-box">
		<ul>
			<li>
				<h5>
					<input type="checkbox" name="islabel" id="islabel">显示标注
				</h5>
			</li>
			<li>
				<h5>填充颜色:</h5>
				<input type="radio" name="fillcolor" value="#000000">黑色
				<input type="radio" name="fillcolor" value="#0000ff" checked="checked">蓝色
				<input type="radio" name="fillcolor" value="#ff0000">红色
				<input type="radio" name="fillcolor" value="">自定义
				<input type="color" id="fillcolor" value="#0000ff" style="display: none;"/>
			</li>
			<li>
				<h5>填充透明度:</h5>
				<input type="number" id="opacity" value="0.3" min="0" max="1" step="0.1" style=" 100%;">
			</li>
			<li>
				<h5>线条颜色:</h5>
				<input type="radio" name="linecolor" value="#000000">黑色
				<input type="radio" name="linecolor" value="#0000ff" checked="checked">蓝色
				<input type="radio" name="linecolor" value="#ff0000">红色
				<input type="radio" name="linecolor" value="">自定义
				<input type="color" id="linecolor" value="#0000ff" style="display: none;"/>
			</li>
			<li>
				<h5>线条类型:</h5>
				<input type="radio" name="linetype" value="false">实线
				<input type="radio" name="linetype" value="true" checked="checked">虚线
			</li>
			<li>
				<h5>线条宽度:</h5>
				<input type="number" name="linewidth" value="2" min="1" max="5" style=" 100%;">
			</li>
		</ul>
	</div>
</div>
</body>
</html>

---------------------------------------------------------------------------------------------------------------

技术博客

CSDN:http://blog.csdn.NET/gisshixisheng

博客园:http://www.cnblogs.com/lzugis/

在线教程

http://edu.csdn.Net/course/detail/799

Github

https://github.com/lzugis/

联系方式

q       q:1004740957

e-mail:niujp08@qq.com

公众号:lzugis15

Q Q 群:452117357(webgis)

             337469080(Android)



原文地址:https://www.cnblogs.com/lzugis/p/7224351.html