Openlayers2中聚类的动态实现

概述:

前面的文章中,讲述了Arcgis for js中聚类分析与展示,在本文,讲述如何在Openlayers2中聚类分析的实现。


实现效果:

Openlayers2中聚类的动态实现_第1张图片

Openlayers2中聚类的动态实现_第2张图片

Openlayers2中聚类的动态实现_第3张图片


实现:

主要分为:1、点的聚类;2、聚类点随着地图缩放的更新;3、聚类点的详细。

1、点的聚类与更新

            var style = new OpenLayers.Style({
                pointRadius: "${radius}",
                fillColor: "#ff0000",
                label: "${name}",
                fontSize: "8px",
                cursor : "pointer",
                fontWeight:"bold",
                fontColor: "#ffffff",
                fontFamily:"sans-serif",
                fillOpacity: 0.8,
                strokeColor: "#ff0000",
                strokeWidth: "3",
                strokeOpacity: 1
            }, {
                context: {
                    width: function ( feature ) {
                        return ( feature.cluster ) ? 2 : 1;
                    },
                    radius: function ( feature ) {
                        var pix = 2;
                        if ( feature.cluster ) {
                            pix = Math.min( feature.attributes.count, 7 ) + 5;
                        }
                        return pix;
                    },
                    name: function ( feature ) {
                        var name;
                        if ( feature.attributes.count > 1 ) {
                            name = feature.attributes.count;
                        } else {
                            name = feature.cluster[0].attributes.name;
                        }
                        return name;
                    }
                }
            });
            strategy = new OpenLayers.Strategy.Cluster();
            clusters = new OpenLayers.Layer.Vector( "Clusters", {
                strategies: [strategy],
                styleMap: new OpenLayers.StyleMap( {
                    "default": style,
                    "select": {
                        fillColor: "#0000ff",
                        strokeColor: "#0000ff"
                    }
                } )
            });
            map.addLayer(clusters);
            var distance = 150;
            var threshold = 1;
            strategy.distance = distance || strategy.distance;
            strategy.threshold = threshold || strategy.threshold;
            clusters.addFeatures(features2);

2、点的详细

            var vectors = new OpenLayers.Layer.Vector("select",{
                styleMap: new OpenLayers.StyleMap({
                    "default": {
                        fillColor: "#00ffff",
                        strokeColor: "#00ffff",
                        pointRadius: "2"
                    }
                })
            });
            map.addLayer(vectors);
            var select =  new OpenLayers.Control.SelectFeature(
                    clusters,
                    {
                        clickout: true,
                        toggle: false,
                        multiple: false,
                        hover: false,
                        toggleKey: "ctrlKey", // ctrl key removes from selection
                        multipleKey: "shiftKey", // shift key adds to selection
                        box: false
                    }
            );
            map.addControl(select);
            select.activate();
            clusters.events.on({
                'featureselected': function(feature) {
                    vectors.removeAllFeatures();
                    var cluster = feature.feature.cluster;
                    vectors.addFeatures(cluster);
                },
                'featureunselected': function(feature) {
                    vectors.removeAllFeatures();
                }
            });
            map.events.register("zoomend",map,function(){
                vectors.removeAllFeatures();
            });

详细代码如下:

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title>openlayers map</title>
    <link rel="stylesheet" href="../../../plugin/OpenLayers-2.13.1/theme/default/style.css" type="text/css">
    <style>
        html, body,#map{
            padding:0;
            margin:0;
            height:100%;
            overflow: hidden;
        }
    </style>
    <script src="../../../plugin/OpenLayers-2.13.1/OpenLayers.js"></script>
    <script src="../../../plugin/jquery/jquery-1.8.3.js"></script>
    <script src="data/county.js"></script>
    <script>
        var map, strategy, clusters;
        var features2 = [];
        $(function(){
            var bounds = new OpenLayers.Bounds(
                    73.45100463562233, 18.16324718764174,
                    134.97679764650596, 53.531943152223576
            );
            var mapOptions = {
                resolutions: [0.703125, 0.3515625, 0.17578125, 0.087890625, 0.0439453125, 0.02197265625, 0.010986328125, 0.0054931640625, 0.00274658203125, 0.001373291015625, 6.866455078125E-4, 3.4332275390625E-4, 1.71661376953125E-4, 8.58306884765625E-5, 4.291534423828125E-5, 2.1457672119140625E-5, 1.0728836059570312E-5, 5.364418029785156E-6, 2.682209014892578E-6, 1.341104507446289E-6, 6.705522537231445E-7, 3.3527612686157227E-7],
                projection: new OpenLayers.Projection('EPSG:4326'),
                maxExtent: new OpenLayers.Bounds(-180.0,-90.0,180.0,90.0),
                units: "degrees",
                controls: []
            };
            map = new OpenLayers.Map('map', mapOptions );
            map.addLayer(getWms("province"));
            map.addControl(new OpenLayers.Control.Zoom());
            map.addControl(new OpenLayers.Control.Navigation());
            map.zoomToExtent(bounds);
            addCluster();
        });
        function getWms(layer){
            return new OpenLayers.Layer.WMS(
                    "Geoserver layers - Tiled",
                    "http://localhost:8088/geoserver/lzugis/wms",
                    {
                        "LAYERS": layer,
                        "STYLES": '',
                        format: 'image/png'
                    },
                    {
                        buffer: 0,
                        displayOutsideMaxExtent: true,
                        isBaseLayer: true,
                        yx : {'EPSG:4326' : true}
                    }
            );
        }
        function addCluster(){
            if ( countydata != null ) {
                for (var i = 0; i < countydata.length; i++) {
                    var county = countydata[i];
                    var point3 = new OpenLayers.Geometry.Point(county.x, county.y );
                    var geometry = point3.clone();
                    var pointFeature3 = new OpenLayers.Feature.Vector(geometry);
                    pointFeature3.attributes = {
                        name: county.name
                    };
                    features2.push(pointFeature3);
                }
            }
            var style = new OpenLayers.Style({
                pointRadius: "${radius}",
                fillColor: "#ff0000",
                label: "${name}",
                fontSize: "8px",
                cursor : "pointer",
                fontWeight:"bold",
                fontColor: "#ffffff",
                fontFamily:"sans-serif",
                fillOpacity: 0.8,
                strokeColor: "#ff0000",
                strokeWidth: "3",
                strokeOpacity: 1
            }, {
                context: {
                    width: function ( feature ) {
                        return ( feature.cluster ) ? 2 : 1;
                    },
                    radius: function ( feature ) {
                        var pix = 2;
                        if ( feature.cluster ) {
                            pix = Math.min( feature.attributes.count, 7 ) + 5;
                        }
                        return pix;
                    },
                    name: function ( feature ) {
                        var name;
                        if ( feature.attributes.count > 1 ) {
                            name = feature.attributes.count;
                        } else {
                            name = feature.cluster[0].attributes.name;
                        }
                        return name;
                    }
                }
            });
            strategy = new OpenLayers.Strategy.Cluster();
            clusters = new OpenLayers.Layer.Vector( "Clusters", {
                strategies: [strategy],
                styleMap: new OpenLayers.StyleMap( {
                    "default": style,
                    "select": {
                        fillColor: "#0000ff",
                        strokeColor: "#0000ff"
                    }
                } )
            });
            map.addLayer(clusters);
            var distance = 150;
            var threshold = 1;
            strategy.distance = distance || strategy.distance;
            strategy.threshold = threshold || strategy.threshold;
            clusters.addFeatures(features2);

            var vectors = new OpenLayers.Layer.Vector("select",{
                styleMap: new OpenLayers.StyleMap({
                    "default": {
                        fillColor: "#00ffff",
                        strokeColor: "#00ffff",
                        pointRadius: "2"
                    }
                })
            });
            map.addLayer(vectors);
            var select =  new OpenLayers.Control.SelectFeature(
                    clusters,
                    {
                        clickout: true,
                        toggle: false,
                        multiple: false,
                        hover: false,
                        toggleKey: "ctrlKey", // ctrl key removes from selection
                        multipleKey: "shiftKey", // shift key adds to selection
                        box: false
                    }
            );
            map.addControl(select);
            select.activate();
            clusters.events.on({
                'featureselected': function(feature) {
                    vectors.removeAllFeatures();
                    var cluster = feature.feature.cluster;
                    vectors.addFeatures(cluster);
                },
                'featureunselected': function(feature) {
                    vectors.removeAllFeatures();
                }
            });
            map.events.register("zoomend",map,function(){
                vectors.removeAllFeatures();
            });
        };
    </script>
</head>
<body>
    <div id="map"></div>
</body>
</html>



你可能感兴趣的:(cluster,统计图,OpenLayers)