`
Tank03
  • 浏览: 81934 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

Mapabc地图----生成路线

阅读更多

//下面这一段代码是一定要定义的  
//<---------------------------------开始---------------------------------------->
	/*
	 * 下面是生成线路的几个函数(请勿修改)<~----------------------------------------------------------------------------------->
	 * */
	var areaId;
	var resultStr="";
	var totalcount=0;//当前线路中一共选择的记录数
	var currentLineEqui = new Array(); //当前线路设备
	/***/
	function RouteSearch(){
		this.routeSType="rs";
		this.start_x = "";this.start_y = "";this.start_name = "";this.start_address = "";this.start_tel = "";this.start_pid = "";this.start_citycode = "";this.start_cityname = "";this.start_detailLink="";this.start_type="";
		this.end_x = "";this.end_y = "";this.end_name = "";this.end_address = "";this.end_tel = "";this.end_pid = "";this.end_citycode = "";	this.end_cityname = "";this.end_detailLink="";this.end_type="";
		this.route_segment;
	}
	var routeS = new RouteSearch();
	function createNewCashLine(){
		resultStr="";
		totalcount = 0;
		currentLineEqui = [];
		mapObj.removeOverlayById(areaId);
		document.getElementById("result").innerHTML="";
	}

	function routeSearch_CallBack(data){
		var resultStr="";
		if(data.error_message != null){
			resultStr="查询异常!"+data.error_message;
		}else{
		switch(data.message){
		case 'ok':
			var route_count = data.count;
			if(route_count==0){
				resultStr="<div>&nbsp;&nbsp;&nbsp;&nbsp;未查找到任何结果!</div>";
			}else{
				var route_text = "";var road_length = 0;
				var route_content = new Array();
				routeS.route_segment = new Array();
				for(var i=0;i<route_count;i++){
					routeS.route_segment[i] = data.segmengList[i].coor;//每一条路线的XY
				}
				var allover = new Array();
				var arr = new Array();
				var poi_xy_r = data.coors.split(",");
				var poi_xy_rl = poi_xy_r.length-2
				for(var j=0;j<poi_xy_rl;j=j+2){
					arr.push(new MLngLat(poi_xy_r[j],poi_xy_r[j+1]));
				}
				var lineopt = new MLineOptions();
				lineopt.lineStyle.thickness=6;
				lineopt.lineStyle.color=0x005cb5;
				lineopt.lineStyle.alpha=0.8;
				var line = new MPolyline(arr,lineopt);
				lineopt.canShowTip=false;
				allover.push(line);
				/*起点终点*/
				var lineStyle=new MLineStyle();
				lineStyle.thickness=2;
				lineStyle.alpha=1;
				lineStyle.lineType= LINE_DASHED;
				var fontStyle=new MFontStyle();
				fontStyle.name="Arial";
				fontStyle.size=12;
				fontStyle.color= 0xffffff;
				fontStyle.bold=true;
				var fontStyle1=new MFontStyle();
				fontStyle1.name="Arial";
				fontStyle1.size=13;
				fontStyle1.color= 0x000000;
				fontStyle1.bold=false;
				var fillStyle=new MFillStyle();
				fillStyle.color= 0xFFFFFF; //填充色
				fillStyle.alpha=1;
				var fillStyle1=new MFillStyle();
				fillStyle1.color= 0x005cb5; //填充色
				fillStyle1.alpha=1;
				
				mapObj.addOverlays(allover,true);
			}
		break;
		case 'error':
				resultStr= "<div class=\"default\"><div class=\"default_title\">对不起!网络繁忙!请稍后重新尝试!</div><div class=\"d_link\"><div class=\"d_right\"></div><div class=\"suggest\"><strong>建议:</strong><br />如果您刷新页后仍无法显示结果,请过几分钟后再次尝试或者与信息化小组联系。<br /></div></div></span>错误信息:"+data.message+"</div>";
			break;
			default:
				resultStr= "<div class=\"default\"><div class=\"default_title\">对不起!网络繁忙!请稍后重新尝试!</div><div class=\"d_link\"><div class=\"d_right\"></div><div class=\"suggest\"><strong>建议:</strong><br />如果您刷新页后仍无法显示结果,请过几分钟后再次尝试或者与信息化小组联系。<br /></div></div></span>错误信息:"+data.message+"</div>";
			}
		}
	}

//<---------------------------------结束---------------------------------------->
 //上面是基本线路生成的定义,下面是具体路线生成
//<----------------------------------------开始---------------------------------------->

	function generateLine(){//生成路线
		if(linetemp!=null ){
                //linetemp--->是一个数组
                /***
                  var equipmentArr = [];
                  var equipment1 = {
	                               'id':'01',
	                               'name':'01',
	                               'lon':'113.33034682099', //经度
	                               'lat':'23.136111090227', //纬度
	                               'address':'广州市天河区华康小学',
	                               'status':'0'
                    };
                   var equipment2 = {
	                              'id':'02',
	                              'name':'02',
	                              'lon':'113.33669829193', //经度
                            	      'lat':'23.131138554636', //纬度
	                              'address':'广州市天河区石牌西路东园小区',
	                              'status':'0'
                   };
                  var equipment3 = {
	                              'id':'03',
	                              'name':'03',
	                              'lon':'113.33738493744', //经度
	                              'lat':'23.125060760778', //纬度
	                              'address':'广州市天河区海乐路',
	                              'status':'1'
                   };
                   linetemp.push(equipment1);
                   linetemp.push(equipment2);
                   linetemp.push(equipment3);

               **/
		for(var i=0;i<linetemp.length;i++){
				var linest = new MLineStyle();
				  linest.alpha = 1;
				  linest.color = 0xFF3300 ;
				  linest.thickness = 3;
				  linest.lineType= LINE_DASHED;
				if(i==linetemp.length-1)return;
				mapObj.panTo(new MLngLat(linetemp[i+1].lon,linetemp[i+1].lat));
				var startXY= new MLngLat(linetemp[i].lon,linetemp[i].lat);
				var endXY = new MLngLat(linetemp[i+1].lon,linetemp[i+1].lat);
				var mls = new MRouteSearch();
				var opt =new MRouteSearchOptions();
				opt.per=90;//抽吸函数,表示在地图上画导航路径的关键点的个数。默认为150
				opt.routeType=0;//路径计算规则,0表示速度优先(默认)
				opt.name="";//避让区域名称
				var regionL="";//避让区域坐标
				routeS.start_x=linetemp[i].lon;
				routeS.start_y=linetemp[i].lat;
				routeS.end_x=linetemp[i+1].lon;
				routeS.end_y=linetemp[i+1].lat;
				mls.setCallbackFunction(routeSearch_CallBack);
				mls.routeSearchByTwoPoi(startXY,endXY,opt,linest);	
			}
		}
		
	}


//<----------------------------------------结束---------------------------------------->
 
分享到:
评论

相关推荐

    地图方面的,定位功能,用的是mapabc

    "地图方面的,定位功能,用的是mapabc" 这个标题和描述暗示了我们正在讨论一个使用MapABC地图服务来实现定位功能的系统或应用。MapABC是中国国内提供地图API和位置服务的公司,它为开发者提供了丰富的地图数据和强大...

    mapabc文档

    `RouteSearch`类提供了计算路线、绘制路径的功能,通过设置起始点、终点和途经点,结合不同的策略(如最短时间、最短距离等),可以生成相应的导航路线。 六、事件监听 MapABC API提供了丰富的事件监听机制,如...

    加载不同地图

    可以使用地图瓦片生成工具(如MapTiler或GDAL)将GIS数据转换为Web可用的瓦片格式,然后在Web应用中通过设置自定义图层来加载这些瓦片。例如,使用Leaflet可以轻松添加自定义图层,并设定瓦片URL模板。 总的来说,...

    地图API&SDK市场分析报告

    2. **国内竞争者**:国内有高德、Mapabc、Mapbar、51地图、百度地图、搜狗地图、阿里地图等,竞争激烈。 ### 七、客户分析 1. **地图API的客户分析**:关注电子地图数据源提供商、综合门户和专业解决方案服务商等,...

    车辆管理系统功能介绍.doc

    4. **电子地图**:系统采用MapABC的最新、正版、不断更新的地图,显示车辆位置和轨迹,同时标注周边设施如停车场、加油站等。 5. **行车轨迹查询**:用户可查询任意时间段内的车辆行驶轨迹,系统动态回放运行情况,...

Global site tag (gtag.js) - Google Analytics