zoukankan      html  css  js  c++  java
  • 百度地图 使用两条平行线表示路线

    根据他人的程序修改的,原文是如何利用百度地图JSAPI画带箭头的线?

    在此,使用两条平行线表示路线。


    1.坐标计算:


    2.代码如下:

    <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
    <%
    	String path = request.getContextPath();
    	String basePath = request.getScheme() + "://"
    			+ request.getServerName() + ":" + request.getServerPort()
    			+ path + "/";
    %>
    
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
    <html>
    <head>
    <base href="<%=basePath%>">
    
    <title>值班员主界面</title>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <meta name="viewport" content="initial-scale=1.0, user-scalable=no" />
    <style type="text/css">
    body,html {
    	 100%;
    	height: 100%;
    	margin: 0;
    	font-family: "微软雅黑";
    }
    
    #allmap {
    	height: 100%;
    	 100%;
    }
    </style>
    <script type="text/javascript"
    	src="http://api.map.baidu.com/api?v=2.0&ak=Tv58ayKXGwWUzEcg2WoBw1qQrIkVww9B"></script>
    <!-- ak表示的是百度地图的key值	-->
    </head>
    
    <body>
    	<div id="allmap"></div>
    </body>
    </html>
    
    
    <script type="text/javascript">
    	var routeLine = [ 
    		"114.402781,30.498467", "114.402759,30.498304",
    		"114.402723,30.498086", "114.402683,30.497872",
    		"114.402647,30.497627", "114.402543,30.49751",
    		"114.402341,30.497569", "114.402265,30.497592",
    		"114.401367,30.497751", "114.400917,30.497806",
    		"114.400792,30.497829", "114.400644,30.497849",
    		"114.400446,30.497872", "114.400194,30.497915",
    		"114.400096,30.497934", "114.400028,30.497771",
    		"114.40001,30.497569", "114.400001,30.497456",
    		"114.400006,30.49725", "114.399988,30.497106",
    		"114.399925,30.496946", "114.399898,30.49688",
    		"114.399884,30.496849", "114.399875,30.496818", ];
    		
    	var point_local = new BMap.Point(114.399916, 30.493214); //屏幕中心点坐标
    
    	// 初始化百度地图API功能
    	// 创建Map实例,并设置地图允许的最小/大级别(可选)
    	var map = new BMap.Map("allmap");
    	var localhost_Icon = new BMap.Icon("images/Point_local.png", 
    		new BMap.Size(32, 49), {anchor: new BMap.Size(16, 48)
    	});
    	//设置引用图标的名字以及大小,并设置图片相对于所加的点的位置
    	map.centerAndZoom(point_local, 16); // 初始化地图,设置中心点坐标(经度,纬度)和地图缩放级别
    	map.enableScrollWheelZoom(true); // 开启鼠标滚轮缩放
    	map.addOverlay(new BMap.Marker(point_local, {icon: localhost_Icon}));
    
    
    	drawRouteLine(routeLine); // 描绘轨迹线路
    
    	
    ////////////////////////////////////////////////////	
    	
    	// 描绘轨迹线路
    	function drawRouteLine(routeLine) {
    		if(routeLine.length<2)	return;
    		var routeLineArray = [];
    		for ( var i = 0; i < routeLine.length; i++) {
    			var x = routeLine[i].split(",")[0];
    			var y = routeLine[i].split(",")[1];
    			routeLineArray[i] = new BMap.Point(x, y);
    		}
    		var polyline = new BMap.Polyline(routeLineArray, {strokeColor:"red", strokeWeight:2, strokeOpacity:0.5}); //创建折线
    //		map.addOverlay(polyline); 
    		
    		var linePoint = polyline.getPath(); //线的坐标串  
    		
    		var length = 1;		//管子半径
    		var LinePointUp=new Array(), LinePointDown=new Array();
    		for (var i=0; i<linePoint.length; i++) {
    			var pixelStart;
    			var pixelEnd;
    			var PixelArr;
    				
    			if(i==0){
    				pixelStart = map.pointToPixel(linePoint[i+1]); //坐标转换为可视区域坐标
    				pixelEnd = map.pointToPixel(linePoint[i]);
    			}else {
    				pixelStart = map.pointToPixel(linePoint[i-1]);
    				pixelEnd = map.pointToPixel(linePoint[i]);
    			}
    			//计算偏差点坐标
    			PixelArr = getPixel(pixelStart, pixelEnd, length);
    			var pixelPointa = map.pixelToPoint(new BMap.Pixel(PixelArr[0],PixelArr[1]));
    			var pixelPointb = map.pixelToPoint(new BMap.Pixel(PixelArr[2],PixelArr[3]));
    			if(i==0){		//第一个点需要交换处理
    				var pixelPointTem = pixelPointa;
    				pixelPointa=pixelPointb;
    				pixelPointb=pixelPointTem;
    			}
    			LinePointUp[i] = pixelPointa;
    			LinePointDown[i] = pixelPointb;
    		}
    		var PixelLine1a = new BMap.Polyline(
    		    LinePointUp, {strokeColor:"green", strokeWeight:2, strokeOpacity:0.5});  
    		map.addOverlay(PixelLine1a); 
    		
    		var PixelLine2b = new BMap.Polyline(
    		    LinePointDown, {strokeColor:"green", strokeWeight:2, strokeOpacity:0.5});  
    		map.addOverlay(PixelLine2b); 
    	}
    	
    
    	
    	function getPixel(pixelStart, pixelEnd, length){
    		var r = length; 	//管子半径
    		var delta = 0; 		//主线斜率,垂直时无斜率  
    		var param = 0; 		//代码简洁考虑  
    		var pixelXa, pixelYa, pixelXb, pixelYb;
    		//计算偏差点坐标
    		if (pixelEnd.x - pixelStart.x == 0) { //斜率不存在是时  
    			if (pixelEnd.y > pixelStart.y) {
    				pixelXa = pixelEnd.x-r;
    				pixelXb = pixelEnd.x+r;
    			}else{
    				pixelXa = pixelEnd.x+r;
    				pixelXb = pixelEnd.x-r;
    			}
    			pixelYa = pixelEnd.y;	pixelYb = pixelEnd.y;
    		} else { //斜率存在时  
    			delta = (pixelEnd.y - pixelStart.y)/(pixelEnd.x-pixelStart.x);	//斜率
    			param = Math.sqrt(delta * delta + 1);
    			//已知直角三角形两个点坐标及其中一个角,求另外一个点坐标算法 
    			if (pixelEnd.x > pixelStart.x) {	//第一、四象限  
    				pixelXa = pixelEnd.x-r*delta/param;		pixelYa = pixelEnd.y+r/param; 
    				pixelXb = pixelEnd.x+r*delta/param;		pixelYb = pixelEnd.y-r/param;
    			}else{		//第二、三象限  
    				pixelXa = pixelEnd.x+r*delta/param;		pixelYa = pixelEnd.y-r/param;
    				pixelXb = pixelEnd.x-r*delta/param;		pixelYb = pixelEnd.y+r/param; 
    			}
    		}
    		return [pixelXa,pixelYa, pixelXb, pixelYb];
    	}
    ////////////////////////////////////////////////////////
    </script>


    现在的问题:在拐角的转折做的不好,特别是在外角部分。


  • 相关阅读:
    类的组合
    类的继承和派生
    面向对象编程
    正则表达式
    sys模块 logging模块 序列化模块
    time 模块,random模块,os模块
    递归函数
    interface有没有继承Object
    UTF-8和GBK的区别
    九皇后
  • 原文地址:https://www.cnblogs.com/anyuan9/p/6171525.html
Copyright © 2011-2022 走看看