谷歌地图API v3搜索框,带有可拖动的标记和输入框
google map api v3 search box with dragable marker and input box
我正在使用谷歌地图 api v3。我想实现像这个一 https://developers.google.com/maps/documentation/javascript/examples/places 搜索框这样的谷歌地图,但带有可拖动的标记,可将当前的纬度,LNG分别放入两个不同的输入框中。
任何帮助表示赞赏,谢谢。
与您
提供的链接相同的 HTML。
我刚刚添加了
<input id="lat">
<input id="lng">
在标记中的某个地方。
function initialize() {
var markers = [];
var map = new google.maps.Map(document.getElementById('map-canvas'), {
mapTypeId: google.maps.MapTypeId.ROADMAP
});
var defaultBounds = new google.maps.LatLngBounds(
new google.maps.LatLng(-33.8902, 151.1759),
new google.maps.LatLng(-33.8474, 151.2631));
map.fitBounds(defaultBounds);
var input = /** @type {HTMLInputElement} */(
document.getElementById('pac-input')
);
map.controls[google.maps.ControlPosition.TOP_LEFT].push(input);
var searchBox = new google.maps.places.SearchBox(
/** @type {HTMLInputElement} */(input));
google.maps.event.addListener(searchBox, 'places_changed', function() {
var places = searchBox.getPlaces();
if (places.length == 0) {
return;
}
for (var i = 0, marker; marker = markers[i]; i++) {
marker.setMap(null);
}
markers = [];
var bounds = new google.maps.LatLngBounds();
for (var i = 0, place; place = places[i]; i++) {
var image = {
url: place.icon,
size: new google.maps.Size(71, 71),
origin: new google.maps.Point(0, 0),
anchor: new google.maps.Point(17, 34),
scaledSize: new google.maps.Size(25, 25)
};
var marker = new google.maps.Marker({
draggable: true,
map: map,
icon: image,
title: place.name,
position: place.geometry.location
});
// drag response
google.maps.event.addListener(marker, 'dragend', function(e) {
displayPosition(this.getPosition());
});
// click response
google.maps.event.addListener(marker, 'click', function(e) {
displayPosition(this.getPosition());
});
markers.push(marker);
bounds.extend(place.geometry.location);
}
map.fitBounds(bounds);
});
google.maps.event.addListener(map, 'bounds_changed', function() {
var bounds = map.getBounds();
searchBox.setBounds(bounds);
});
// displays a position on two <input> elements
function displayPosition(pos) {
document.getElementById('lat').value = pos.lat();
document.getElementById('lng').value = pos.lng();
}
}
google.maps.event.addDomListener(window, 'load', initialize);
相关文章:
- 如何将可拖动的谷歌地图标记的地址传递到输入字段中
- 如何在拖动行时更新输入值
- 检测用户拖动范围类型输入
- 当输入[范围]值更改/拇指拖动时触发功能
- 通过可拖动的 SVG 形状设置 HTML 输入值 ?(或画布)
- 流星“变化”值在释放鼠标时出现,而不是在拖动输入滑块时出现
- 谷歌地图API v3搜索框,带有可拖动的标记和输入框
- 通过单击并拖动来更新 HTML 输入字段的值(类似于 unity3d 界面)
- 在传单地图上设置并拖动标记可更新表单输入字段,而无需发送
- 传单地理编码和可拖动标记在输入字段中显示结果
- 拖动到输入的链接并将其文本附加到其中
- 如何使文本输入框可调整大小(如textarea)通过拖动其右下角使用jQuery
- 使用Jquery可拖动和可调整大小的文本区域-不能使用左键输入文本
- 如何访问拖动的文本(或:如何将文本拖动到输入“工作”中?)
- 图像作为可拖动的输入元素
- 带有可拖动标记和输入框的谷歌地图搜索框
- 当拖动结束时,HTML输入元素范围检测
- jQuery滑块,在刷新后拖动输入值
- html5 -可拖动输入元素
- 如何使用jquery在拖动输入时创建多个放置区域