真的能提供一些帮助,当用户接近某个特定的设定点时,我试图在sencha的帮助下在Android手机上发出警报。
在我看来,我有一张地图
{
xtype: 'map',
id: 'mapOne',
cls: 'center',
flex: 1,
width: '100%',
mapOptions : {
mapTypeControl : false,
navigationControl : true,
streetViewControl : false,
backgroundColor: 'transparent',
disableDoubleClickZoom: true,
zoom: 10,
draggable: true,
keyboardShortcuts: true,
scrollwheel: false,
enableHighAccuracy: true
},
listeners : {
maprender : function(comp, map){
var currentMarker = new google.maps.Marker({
position: new google.maps.LatLng(setlat,setlon),
//title : 'Sencha HQ',
map: map,
icon: image
});
setTimeout( function(){map.panTo (new google.maps.LatLng(markerlat, markerlong));} , 1);
}
}
在我的控制器中,我在渲染地图之前设置了以下内容
var poi = new google.maps.LatLng(markerlat, markerlong);
然后在我的控制器中按照以下方式初始化地理定位对象
var geo = Ext.create('Ext.util.Geolocation', {
autoUpdate: true,
frequency :3000,//every 3 seconds
listeners: {
locationupdate: function(geo) {
var curlat = geo.position.coords.latitude;
var curlong = geo.position.coords.longitude;
console.log('New GEO CURRENT: ' + curlat + ' ' + curlong);
var me = new google.maps.LatLng(curlat, curlong);
if (me == poi){
alert("poi found");
}
},
locationerror: function(geo, bTimeout, bPermissionDenied, bLocationUnavailable, message) {
if(bTimeout){
alert('Timeout occurred.');
} else {
alert('Error occurred.');
}
}
}
});
我还设置了一个地理标记,以确定我是否在poi附近被检测到。
GeoMarker = new GeolocationMarker(mapOne);
它直接在标记顶部显示我的GeoMarker,没有警报。我尝试了几个不同的类似的东西,没有像下面那样成功....
if (GeoMarker == poi){
alert("poi found");
}
我知道我的过程在这两种情况下都是错误的,因为我的位置与poi不完全相同,但我无法弄清楚如何设置当前位置的正确接近度以提醒。我发现很难找到任何文档来展示如何成功地实现类似于poi警报的东西。任何可能有用的文档的帮助或链接将不胜感激。
提前致谢
答案 0 :(得分:0)
我首先通过使用'if'语句来检查两个点的纬度和经度值之间的差异是否小于设定变量,从而获得了成功的结果。但我认为必须有一种更有效的方法,通过当前位置周围的某种形式的半径来实现这一点。
最后遇到了这个帖子.... Calculate distance between two points in google maps V3正如它在其中一个答案中建议的那样,我成功地使用了以下内容......
google.maps.geometry.spherical.computeDistanceBetween (latLngA, latLngB);
检查两点之间的距离是否小于我想要的距离。希望这可以帮助将来的某个人。
尽管如此,欢迎来自任何人的任何信息以实现相同的替代方法。