`
jjxliu306
  • 浏览: 159258 次
  • 性别: 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-2.13

    2. **图层处理**:用户可以添加多个图层到地图上,每个图层可以有不同的数据源和样式。例如,你可以添加卫星图像图层、地形图层或者自定义的数据图层。 3. **地理坐标系统和投影**:OpenLayers 支持多种地理坐标...

    geomap

    7. **插件(Plugins)**:geomap可能有丰富的插件库,扩展了地图的功能,如标记(Markers)、热力图(Heatmaps)、图例生成器等。 **应用场景:** - **位置服务**:在网页上展示用户的位置,或者提供基于位置的...

    计算机发展与计算机应用概述.pdf

    计算机发展与计算机应用概述.pdf

    计算机二级公共基础知识全集合.pdf

    计算机二级公共基础知识全集合.pdf

    计算机机试答案.pdf

    计算机机试答案.pdf

    基于STM32F103的750W全桥逆变器并离网设计方案及其实现

    内容概要:本文详细介绍了基于STM32F103RCT6的750W全桥逆变器设计方案,涵盖硬件电路设计、软件编程以及保护机制等方面。硬件部分包括主控芯片的选择、PWM配置、Boost升压电路、PCB布局优化等;软件部分涉及并离网切换的状态机设计、过流保护、风扇控制算法、并机功能实现等。文中还分享了许多实战经验和调试技巧,如死区时间配置、电流采样方法、并网同步算法等。 适合人群:具有一定电子电路和嵌入式开发基础的技术人员,尤其是从事逆变器及相关电力电子产品开发的工程师。 使用场景及目标:适用于希望深入了解逆变器工作原理和技术实现的开发者,特别是那些需要掌握并离网切换、高效电源管理及可靠保护机制的人群。目标是帮助读者构建一个稳定可靠的逆变器系统,能够应对各种复杂的工作环境。 其他说明:本文不仅提供了详细的理论讲解,还有丰富的代码片段和实践经验分享,有助于读者更好地理解和应用相关技术。

    基于Simulink的单相全桥逆变器仿真与优化:MATLAB环境下的详细实现

    内容概要:本文详细介绍了如何利用Simulink在MATLAB环境中搭建单相全桥逆变器的仿真模型。首先,通过构建H桥结构,连接直流电源和RL负载,并引入PWM控制器进行开关管的控制。接着,针对仿真过程中遇到的各种问题,如谐波失真、开关管直通等问题,提出了具体的解决方案,包括加入LC滤波器、设置死区时间和优化PWM参数等。此外,还探讨了通过MATLAB脚本自动化测试不同参数组合的方法,以及如何提高电压利用率和降低谐波失真。最终,通过对仿真结果的分析,验证了所提方法的有效性和优越性。 适合人群:电力电子工程师、科研人员、高校学生等对逆变器仿真感兴趣的群体。 使用场景及目标:适用于研究和开发高效、稳定的逆变器系统,旨在通过仿真手段减少实验成本,优化设计方案,提高系统的性能指标。 其他说明:文中提供了详细的建模步骤和技术细节,帮助读者更好地理解和掌握相关技术和方法。同时,强调了仿真参数的选择和优化对于获得理想仿真结果的重要性。

    计算机红外通信.pdf

    计算机红外通信.pdf

    软考考试学习必备资料.md

    软考考试学习必备资料.md

    基于cornerstonejs开发移动端

    基于cornerstonejs开发移动端

    JavaScript网页设计高级案例:构建交互式图片画廊#JavaScript

    构建交互式图片画廊

    在学习Wpf的过程中,手搓了一个2048

    源码

    Bosch Rexroth IndraWorks Ds IndraWorks Ds 14V16.310.0

    Bosch Rexroth IndraWorks Ds IndraWorks Ds 14V16.310.0

    java面向对象 - 类与对象

    java面向对象 - 类与对象

    电机控制领域无感FOC算法的AT32平台实现及其鲁棒性优化

    内容概要:本文详细介绍了基于AT32平台的无感FOC(Field-Oriented Control)控制算法,特别是针对永磁同步电机(PMSM)和无刷直流电机(BLDC)的位置速度观测器实现。文章首先展示了启动策略的独特之处,即跳过传统前馈强拖阶段,直接利用矢量控制环和观测器协同启动。接着深入探讨了磁链观测器的核心算法,包括磁链积分、反正切求角度以及速度估算部分使用的改良版PLL。此外,文中还提到了容差配置模块,用于提高系统的鲁棒性和稳定性。最后,强调了模块间良好的解耦设计,使得各功能模块拥有明确的输入输出接口,增强了代码的可维护性和移植性。 适合人群:从事电机控制系统开发的技术人员,尤其是对无感FOC算法感兴趣的工程师。 使用场景及目标:适用于需要高精度、快速响应的电机控制系统开发项目,旨在提升系统的鲁棒性和稳定性,特别是在电机参数存在偏差的情况下依然能够保持良好性能。 其他说明:文章不仅提供了详细的代码实现,还分享了许多实用的经验和技术细节,如启动策略、磁链观测器的物理本质、速度估算方法等,有助于读者更好地理解和应用无感FOC算法。

    计算机机房de设置与维护.pdf

    计算机机房de设置与维护.pdf

    《Java 面试进阶指北 》 质量很高,专为面试打造

    《Java 面试进阶指北 》 质量很高,专为面试打造

    外转子开关磁阻电机多目标优化的NSGA-II算法实现与Matlab代码解析

    内容概要:本文详细介绍了外转子开关磁阻电机(ER-SRM)的多目标优化方法,主要采用NSGA-II算法进行优化。文章首先解释了为什么ER-SRM比传统内转子电机更难以优化,接着展示了如何利用NSGA-II算法解决这一难题。文中提供了详细的Matlab代码,包括种群初始化、交叉变异操作、非支配排序以及目标函数的定义。此外,还讨论了优化过程中的一些注意事项,如初始种群多样性的保持、交叉变异参数的选择、目标函数的设计等。最后,通过具体的案例和图表展示了优化结果及其应用价值。 适合人群:从事电机设计与优化的研究人员和技术人员,尤其是对外转子开关磁阻电机感兴趣的读者。 使用场景及目标:适用于需要同时优化电机效率、转矩波动和制造成本等多种目标的情况。通过NSGA-II算法,可以在多个相互冲突的目标间找到最佳平衡点,从而提高电机的整体性能。 其他说明:文章不仅提供了完整的Matlab代码实现,还分享了许多实践经验,如参数设置的经验公式、常见错误及解决方案等。这对于理解和掌握NSGA-II算法的实际应用非常有帮助。

    "慢行智远"是一款专业的串口数据采集与波形分析软件 软件支持多通道波形显示、数据记录、协议解析等功能,界面友好,操作简便,是您进行串口通信与数据分析的得力助手

    慢行智远V2.0"是一款专业的串口数据采集与信号分析软件,集成了多通道数据采集、实时波形显示、FFT频谱分析、FIR滤波处理等高级功能。软件提供直观的用户界面,支持亮色/暗色两种主题,具备强大的数据处理与可视化能力。核心功能包括: 全面的串口通信支持(多种波特率、数据位、停止位、校验位配置) 多通道(最多4通道)波形实时显示与分析 高级信号处理(FFT频谱分析、FIR滤波、信号平滑等) 智能数据管理(断行数据处理、大数据量优化) 数据记录与导出(文本、CSV、图像多种格式) 自适应界面设计(支持高DPI显示、暗色主题) 适用人群 嵌入式开发工程师:需要通过串口调试单片机、开发板等嵌入式设备 电子工程师:进行电路测试、信号采集与分析的专业人员 工业自动化技术人员:监测工业设备数据、进行状态分析 科研教育工作者:用于实验数据采集、科学研究与教学演示 医疗设备开发人员:分析生物电信号、开发医疗监测设备 物联网开发者:调试传感器网络、分析传感器数据 硬件测试工程师:进行产品质量检测、性能评估 使用场景及目标 研发调试场景 单片机开发:实时监控传感器数据、调试通信协议、观察系统运行状态等等

Global site tag (gtag.js) - Google Analytics