- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我使用下面的示例代码来展示 Google 地方信息的自动完成搜索。目前它默认当前位置为澳大利亚悉尼。
https://developers.google.com/maps/documentation/javascript/examples/places-searchbox
我目前正在收集用户位置的纬度和经度:
架构.rb
create_table "users", force: :cascade do |t|
t.datetime "created_at", null: false
t.datetime "updated_at", null: false
t.float "latitude"
t.float "longitude"
end
如何修改我假设的这部分(不确定为什么那里有两组坐标)
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);
默认为我用户的当前位置?
最佳答案
我在 Rails 中构建了一个类似的解决方案。基本上,我向 Rails Controller 中的方法发出 ajax 请求,并将用户记录作为 JSON 返回,该记录可用于设置我们的 map 。我已经调整了代码以满足您的具体需求。
我们首先在 asset pipeline 下设置一个单独的 js 文件:
将以下内容放在/app/assets/javascripts/gmap.js 下
var worldMap = {
init: function(){
// fetch our user record for lat/long
$.ajax({
url: '/user/location',
dataType: 'json',
success: function( data ){
worldMap.lat = data.latitude;
worldMap.lng = data.longitude;
worldMap.setupMap();
}
});
},
setupMap: function(){
// we now have user location loaded so build map
worldMap.map = new google.maps.Map( document.getElementById( "map" ), {
zoom: 3,
center: {
lat: worldMap.lat,
lng: worldMap.lng
}
});
// now lets add autocomplete search
var searchbox = (document.getElementById('search-controls'));
var input = document.getElementById('pac-input');
worldMap.map.controls[ google.maps.ControlPosition.LEFT_TOP ].push( searchbox );
var autocomplete = new google.maps.places.Autocomplete(input);
autocomplete.bindTo('bounds', worldMap.map);
google.maps.event.addListener(autocomplete, 'place_changed', function() {
var place = autocomplete.getPlace();
if (!place.geometry) { return; }
// center map on chosen location
if (place.geometry.viewport) {
worldMap.map.fitBounds(place.geometry.viewport);
} else {
worldMap.map.setCenter(place.geometry.location);
worldMap.map.setZoom(17);
}
});
}
}
然后,一旦 DOM 加载,我们就可以调用新的 map 设置代码,并将其添加到/app/assets/javascripts/application.js 中:
window.onload = function(){
worldMap.init();
}
现在我们可以设置路由,将此行添加到/config/routes.rb:
get 'user/location', :controller => 'users', :action => 'user_location', :as => 'user_latlng'
然后最后将该方法添加到我们的用户 Controller /app/controllers/users_controller.rb:
def user_location
@user = User.select(:latitude, :longitude).where(id: current_user.id).limit(1)
render json: @user.first
end
在您看来,您将需要我们的 JS 正在寻找的搜索框和 map div:
<div id="search-controls" class="controls">
<input type="text" id="pac-input" placeholder="Search" />
</div>
<div id="map"></div>
关于javascript - 通过 Google 地方信息显示当前位置,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31412357/
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
操作无法完成。 Places API 库中发生内部错误。如果您认为此错误代表错误,请使用我们社区和支持页面 (https://developers.google.com/places/support)
我正在尝试在我的项目中使用 google places,我将其设置在 fragment 中而不是 Activity 中,我的自动完成 fragment 在 fragment 中。但是,当我尝试搜索它时
我的目的是使用R来查询google api。 我有一个地址和名称列表(属于商店、餐馆等),我需要为每个地址和名称存储: “纬度”、“经度”、“业务类型” 我的想法是使用 google place ap
我正在寻找设置一个自动完成的谷歌地方小部件。 我有一个带有“searchFieldText”id 的输入类型文本。 这是我的 JS 代码: var inputsec = document.getEle
是否可以使用图形 API(或地址/ zip )按纬度/经度和半径获取地点?我在文档中的任何地方都看不到它 最佳答案 搜索 URL 的以下格式将返回某个位置附近的地点列表: https://graph.
我正在探索 Google API,主要是 Places API。由于对 Google Places API 的请求数限制为 100,000,因此我正在寻找方法来最大限度地减少发送到 API 的请求数。
伙计们,我在我的应用程序中有一个功能,可以使用 GetFiles 在特定目录中搜索特定文件。方法 System.IO.Directory.GetFiles(string path, string
我已经在 Laravel 5.3 上使用 where 查询成功创建了许多函数,但是这次发生了一些奇怪的事情。 public function show($id){ $artikel = Art
我正在为我的 iPhone 应用程序使用 Facebook 图形 API 来获取附近地点的列表,我使用带有一些参数的“搜索”请求。我得到的响应是一个包含以下信息的地点列表:“纬度”、“经度”、“名称”
我有一个 Android 应用程序,我在其中使用 Google map 显示附近的地方,如加油站、药店等。我正在使用 map 和地点 API。 https://maps.googleapis.com/
我是一名优秀的程序员,十分优秀!