`
jjxliu306
  • 浏览: 157930 次
  • 性别: Icon_minigender_1
  • 来自: 西安
社区版块
存档分类
最新评论

Openlayers2扩展markers图层

    博客分类:
  • GIS
阅读更多

使用ol2中经常会碰到添加marker数据,并在数据之上提供marker的鼠标点击事件,弹出popup详细信息,对此进行了简单封装,详见:

 

1、marker的数据元素

 

 /**
 * Class: MarkersLayer.Source
 */
MarkersLayer.Source = OpenLayers.Class({
 
  lonlat:null , //坐标 
  icon:null, //marker的icon地址
  title:null, //marker的title 不为空时存在marker点击事件,弹出的popup的title
  description:null, //title不为空时点击出现的popup中的描述信息
  
  initialize: function(lonlat ,icon,title, description) {
    this.lonlat = lonlat;
    this.icon = icon ;
    this.title = title;
    this.description = description ;
  },
 
  CLASS_NAME: 'MarkersLayer.Source'
});

 

 

 

2、markers的marker集合图层,继承自OpenLayers.Layer.Markers,只是做了简单封装

 

/**
* Marker集合图层,从layer中继承
*/
OpenLayers.Layer.MarkersLayer = OpenLayers.Class(OpenLayers.Layer.Markers, {
 
  /**
    * 所有的maker集合
    */
    ms :null ,
	//是否加载
    loaded:false,
    
    putMarkers:function(_markers) {
    	this.ms = _markers ;
		if(this.loaded)
		for(var i in  _markers) { 
    			//创建marker 
    			var marker = this.createMarker(_markers[i]);
    	 
    			this.addMarker(marker); 
    		 
    	}
    },
     
   
   	
   
    moveTo : function(bounds, zoomChanged, minor) {
      	OpenLayers.Layer.Markers.prototype.moveTo.apply(this, arguments);
     	//判断是否要加载markers
        if(this.visibility && !this.loaded && this.ms && this.ms.length > 0){
        	this.loaded = true;
            for(var i in  this.ms) { 
    			//创建marker 
    			var marker = this.createMarker(this.ms[i]);
    	 
    			this.addMarker(marker); 
    		 
    	 	}
        }
     
        
    },
    
     
     
 /**
 *当前显示的popup buffer
 */
   show_pp : null ,
 
     createMarker:function(m) {

	   var _map = this.map;

	   var lonlat = m.lonlat;
	   var icon_url = m.icon ;
	   var desc = m.description;
	   var title = m.title ;


	   var size = new OpenLayers.Size(18, 32);
	   var offset = new OpenLayers.Pixel(-(size.w / 2), -size.h);

	   //var mark_url = '../resource/js/ol/img/' + icon_url;
	   var mark_url =  icon_url;
	   var icon = new OpenLayers.Icon(mark_url, size, offset);


	   var marker = new OpenLayers.Marker(lonlat, icon);


	   //拼接提示信息
	   if(title ) {
                //此处优化为点击后在去创建popup 而不是提前都创建好,优化加载速度
		marker.title = title;
		marker.desc = desc;
			 
		marker.layer = this ;

		 marker.events.register("click", marker, this.clickEvent);

	   } 

	   return marker ;

   }  ,

    
     /**
    * marker 点击事件
    */
   clickEvent:function(evt){

	  var sp = this.layer.show_pp;
	   var m_popup = this.popup ;
	   
	   //如果当前已经弹出和待弹出的不是一个 则隐藏已经弹出的
	   if (sp && sp != m_popup) {
		   sp.hide(); 
	   }  
	   
	   //判断marker是否包含popup
		
		if(!m_popup) {
			//创建popup
			var innerhtml =  "<table class='poptable'>";

		    innerhtml += "<tr><td style='text-align:left'> " + this.title + "</td> </tr>";
		    innerhtml += "<tr><td style='text-align:left'> " + this.desc +  " </td></tr>";
		    innerhtml += "</td></tr></table>";
			m_popup = new OpenLayers.Popup("click",
				   this.lonlat,
				   null,
				   innerhtml,
				   true);
		   
		   m_popup.panMapIfOutOfView = true;
		   m_popup.autoSize = true;
		   m_popup.hide();
 		    
		   this.map.addPopup(m_popup);
		   this.popup = m_popup ;
			
		}
		
		m_popup.toggle(); 
	   this.layer.show_pp  = m_popup;
	   OpenLayers.Event.stop(evt);

   }, 
    
    
    getDataExtent: function () {
        var maxExtent = null;
         
        var _map = this.map ;
         
        if (_map && this.ms && (this.ms.length > 0)) {
              var maxExtent = new OpenLayers.Bounds();
            for(var i=0, len=this.ms.length; i<len; i++) {
                var m = this.ms[i];
                maxExtent.extend(m.lonlat);
            }
        }
 
 
        return maxExtent;
    },
    CLASS_NAME: "OpenLayers.Layer.MarkersLayer"
});
 

 

 

3、调用:

var ms = new Array(); //marker.souces
 
for(var i = 0 ; i < 100 ; i++) {
 
var lon = 120 + Math.random() * 0.5 ; //经纬随机
var lat = 30 + Math.random() * 0.5;//纬度随机
 
var icon = Math.random() > 0.5 ? 'img/marker-blue.png' : 'img/marker-green.png' ;
 
var lonlat = new OpenLayers.LonLat(lon, lat).transform(_displayProjection, _projection);
 
var marker = new MarkersLayer.Source(lonlat , icon , 'test title ' + i , 'test descrition ' + lon + "," +lat);
 
ms.push(marker);
 
}
 
var ml = new OpenLayers.Layer.MarkersLayer('test markerlayer');
ml.putMarkers(ms); //压入数据
 

 

 

 

附件里有demo可以直接查看

 

0
0
分享到:
评论

相关推荐

    openlayers 添加标注 markers

    openlayers 添加标注 markers 怎么给Google地图添加标注

    openlayers 编辑geoserver图层

    2. **编辑**:当用户选择地图上的某个要素时,OpenLayers可以打开一个编辑窗口,允许用户修改属性值。编辑完成后,通过WFS-T(Transaction)提交更改到GeoServer,更新后台数据。 3. **新增**:用户可以在地图上...

    openlayers 矢量图层注记

    openlayers 中利用矢量图层添加注记的示例。

    OpenLayers图层组控制

    iClient for OpenLayers控制图层组显隐方式的实现步骤。 下载后直接运行目录下:example\示例\图层组控制.html(需要修改里面的服务地址url为自己发布的服务信息)

    Openlayers通过元素获取图层,通过点元素获取线元素

    Openlayers虽然提供了很多方法, 一般是从图层(Layer)获取获取元素(feature),或者从元素(Feature)获取坐标(Coordinate)。获取到的一般都是集合。但是想要反着通过元素(feature)获取图层(Layer).OL选择...

    openlayers3 获取点图层数据并添加标注和展示标注信息实例

    openlayers3 显示静态地图,从后台查询点数据(后台java代码没有提交,太简单了。。。)展示到地图并添加标注,给标注添加点击事件并展示标注信息,初次接触开源GIS,代码中有错误还请各位看官指正,感谢!

    OpenLayers地图加入google图层

    OpenLayers地图加入google图层 OpenLayers google layer 自己可以用google账号登录申请特定域名的地图key.

    openlayers图层开关控件

    2. **添加图层到地图**:将创建的图层添加到OpenLayers地图实例中。每个图层都有一个唯一的标识符,便于管理和操作。 3. **创建图层开关控件**:通过`new ol.control.Layers()`来创建图层开关控件实例。 4. **添加...

    openlayers编辑地图图层并保存到geoserver

    这个程序示例展示了如何结合OpenLayers和GeoServer实现地图图层的编辑功能,这在GIS(地理信息系统)开发中是非常常见的需求。GeoServer是一个开源的GIS服务器,能够发布地图数据并提供WFS(Web Feature Service)等...

    openlayers的WebGLPointsLayer图层,textureCoord纹理坐标的match匹配表达式文件

    openlayers的WebGLPointsLayer图层,textureCoord纹理坐标的match匹配表达式文件,注释掉了大部分编码和坐标,使用时打开注释。

    openlayers图层控制加入group layer功能

    开发时,有时候图层很多,需要有同时打开关闭多个图层的功能,但是正式版的layerSwitcher不支持group layer功能. 从网上搜到layerSwitcher的扩展,是在源代码里添加对grouplayer的操作和事件支持. 对layerSwitcher....

    openlayers 中自定义扩展简单引用

    对于图层扩展,你可以在地图的`layers`数组中添加;对于交互扩展,可以添加到地图的`interactions`集合中。 4. **引用扩展**:在其他代码中,你可以通过类名来引用你的自定义扩展,以便在需要的地方使用它。这通常...

    OpenLayers实现图层切换控件

    在OpenLayers中,图层切换控件是用于让用户在多个图层之间自由切换的重要功能。由于OpenLayers库本身并未直接提供这样的...在实际项目中,可以根据需求进行扩展,例如添加更多图层、优化UI设计或者添加图层分组功能等。

    ol-ext插件,具体实现过程见使用openlayers的扩展插件实现矢量图层的3D渲染

    2. **创建3D图层**:在OpenLayers中,你需要创建一个特殊的图层类型,如`ol.layer.Vector3D`,这将用于3D渲染矢量数据。 3. **数据准备**:为了在3D中显示,矢量数据需要转换为包含高度信息的格式。这可能涉及到...

    Openlayers扩展插件ol-ext ,2022年4月版本v3.2.23

    而ol-ext是针对OpenLayers的一个扩展插件,它增加了许多额外的功能和视觉效果,使得地图开发更为便捷和美观。 在2022年4月发布的ol-ext版本v3.2.23中,我们关注以下几个关键知识点: 1. **图形和符号**:ol-ext...

    openlayers扩展

    在实际应用中,除了上述扩展,OpenLayers还支持其他许多高级功能的扩展,如图层管理、标记、测量、地理编码等。开发者可以根据需求,利用OpenLayers的模块化设计,灵活地扩展和定制地图应用。 至于“电子地图测试”...

    openlayers中文文档2

    OpenLayers 支持各种类型的图层,如TileLayer(瓦片图层)、VectorLayer(矢量图层)和ImageLayer(图像图层)。每个图层都有自己的属性和方法,如透明度设置、可见性控制等。 **2. Map(地图)** `map.html` 关注...

    openlayers扩展:风场可视化(wind-layer)

    它结合了OpenLayers的核心库、风场图层扩展、数据文件、用户交互界面和高效的Web服务器部署策略,为用户呈现了一个动态、可交互的风场地图应用。开发者可以借此学习如何在OpenLayers中创建自定义图层,以及如何利用...

    Openlayers扩展右键菜单

    "OpenLayers扩展右键菜单"是一个项目,旨在帮助开发者为他们的OpenLayers地图应用添加自定义的右键上下文菜单。这个扩展允许用户在地图上点击右键时触发特定的操作,例如测量距离、添加图层、获取地图坐标等。 开发...

Global site tag (gtag.js) - Google Analytics