Google Maps Javascript API V3中的旋转标记
我没有做太多的编码,但我试着写一些我认为会通过phonegap/cordova运行的简单代码。现在我想让它做的就是找到我,在我移动/行走/驾驶和旋转的过程中,用标准的三角形标记在我的位置上 我真的很难计算出旋转/方位/航向,因为我没有终点线或多边形线可以跟随。现在我有它定位好,把标记放在地图上,更新好,保持标记在中间。当然,我会增加很多,但这是我有麻烦的部分。我在旋转部分的代码中加入了一个***//我想用我认为可能有效的代码来修复它。我可能会将其转换为一个名为heading的变量,但它显示了这个概念 我的问题是我不知道如何往返拉丁。我正在使用navigator.geolocation.watchPosition跟踪位置更改,因此我不知道如何获取上一个latlng。另外,如果有一种更简单的方法来做我想做的事情,我会洗耳恭听。我觉得我想得太多了,但也许真的需要这么多 我删除了我的api代码,但除此之外,所有这些都可以按原样工作Google Maps Javascript API V3中的旋转标记,javascript,google-maps-api-3,Javascript,Google Maps Api 3,我没有做太多的编码,但我试着写一些我认为会通过phonegap/cordova运行的简单代码。现在我想让它做的就是找到我,在我移动/行走/驾驶和旋转的过程中,用标准的三角形标记在我的位置上 我真的很难计算出旋转/方位/航向,因为我没有终点线或多边形线可以跟随。现在我有它定位好,把标记放在地图上,更新好,保持标记在中间。当然,我会增加很多,但这是我有麻烦的部分。我在旋转部分的代码中加入了一个***//我想用我认为可能有效的代码来修复它。我可能会将其转换为一个名为heading的变量,但它显示了这个
<!DOCTYPE html>
<html>
<head>
<title>GEOCODING TEST</title>
<style type="text/css">
html,
body {
height: 100% ;
margin: 0px 0px 0px 0px ;
overflow: hidden ;
padding: 0px 0px 0px 0px ;
width: 100% ;
}
#mapContainer {
height: 100% ;
width: 100% ;
}
</style>
<script src="https://maps.googleapis.com/maps/api/js?key={MYAPIKEY}" type=
"text/javascript">
</script>
<script src=
"http://ajax.googleapis.com/ajax/libs/jquery/1.4.2/jquery.min.js" type=
"text/javascript">
</script>
</head>
<body>
<div id="mapContainer">
</div>
<script type="text/javascript">
var mapContainer = $( "#mapContainer" );
map = new google.maps.Map(
mapContainer[ 0 ],
{
zoom: 15,
center: new google.maps.LatLng(
40.700683,
-73.925972
),
mapTypeId: google.maps.MapTypeId.TERRAIN
}
);
function addMarker (latitude, longitude){
var marker = new google.maps.Marker({
map: map,
position: new google.maps.LatLng(
latitude,
longitude
),
flat: true,
icon: {
path: google.maps.SymbolPath.FORWARD_CLOSED_ARROW,
strokeColor : 'red',
strokeWeight : 3,
scale: 6,
***//rotation: google.maps.geometry.spherical.computeHeading(from:LatLng, to:LatLng)
},
});
return( marker );
}
function updateMarker( marker, latitude, longitude, label ){
marker.setPosition(
new google.maps.LatLng(
latitude,
longitude
)
);
if (label){
marker.setTitle( label );
}
}
if (navigator.geolocation) {
var locationMarker = null;
navigator.geolocation.getCurrentPosition(
function( position ){
if (locationMarker){
return;
}
console.log( "Initial Position Found" );
locationMarker = addMarker(
position.coords.latitude,
position.coords.longitude,
"Initial Position"
);
},
function( error ){
console.log( "Something went wrong: ", error );
},
{
timeout: (5 * 1000),
maximumAge: (1000 * 60 * 15),
enableHighAccuracy: true
}
);
var positionTimer = navigator.geolocation.watchPosition(
function( position ){
console.log( "Newer Position Found" );
console.log (position);
updateMarker(
locationMarker,
position.coords.latitude,
position.coords.longitude,
"Updated / Accurate Position"
);
var pos = new google.maps.LatLng(
position.coords.latitude,
position.coords.longitude);
map.setCenter(pos);
}
);
setTimeout(
function(){
// Clear the position watcher.
navigator.geolocation.clearWatch( positionTimer );
},
(1000 * 60 * 5)
);
}
</script>
<div id="map-canvas" style="width: 100%; height: 100%">
</div>
</body>
</html>
有一个为此目的而创建的google库,名为 此库中包含一组导航功能,可帮助您计算距离、航向等 你可以找到一个明确的例子:
该多段线是一条连接出发点和目的点的虚拟线。为此创建了一个google库,名为 此库中包含一组导航功能,可帮助您计算距离、航向等 你可以找到一个明确的例子:
该多段线是连接出发点和目的点的虚拟线。由于很难预测未来,如果GPS设备没有实时航向,请使用上一个点和更新的点。如果它没有移动或移动速度不够快,这将不会特别准确
function updateMarker(marker, latitude, longitude, label) {
var prevPosn = marker.getPosition();
marker.setPosition(
new google.maps.LatLng(
latitude,
longitude
)
);
marker.setIcon({
path: google.maps.SymbolPath.FORWARD_CLOSED_ARROW,
strokeColor: 'red',
strokeWeight: 3,
scale: 6,
rotation: google.maps.geometry.spherical.computeHeading(prevPosn, marker.getPosition())
})
if (label) {
marker.setTitle(label);
}
}
由于很难预测未来,如果您没有GPS设备的实时航向,请使用之前的点和更新的点。如果它没有移动或移动速度不够快,这将不会特别准确
function updateMarker(marker, latitude, longitude, label) {
var prevPosn = marker.getPosition();
marker.setPosition(
new google.maps.LatLng(
latitude,
longitude
)
);
marker.setIcon({
path: google.maps.SymbolPath.FORWARD_CLOSED_ARROW,
strokeColor: 'red',
strokeWeight: 3,
scale: 6,
rotation: google.maps.geometry.spherical.computeHeading(prevPosn, marker.getPosition())
})
if (label) {
marker.setTitle(label);
}
}