9

我正在使用 Google Street View Image API 来显示地址的图像。尽管大多数图像都非常准确,但我注意到有一些是从错误的角度拍摄的,比如拐角处的房子,图像来自小街,而不是前街。当我检查谷歌地图时,左侧面板顶部显示的图像是正确的。

例子; 下面是使用API 说明中的 URL 参数的图像; http://maps.googleapis.com/maps/api/streetview?size=300x200&location=39.408751,-104.917738&sensor=false

在此处输入图像描述

下面是显示在 Google 地图左侧面板中的同一位置的图像,

https://cbks0.google.com/cbk?output=thumbnail&cb_client=maps_sv&thumb=2&thumbfov=60&ll=39.408554,-104.917506&yaw=317.7&thumbpegman=1&w=300&h=118

在此处输入图像描述

有没有办法使用 API 获得“更好”的角度?

4

2 回答 2

4

如果您知道地址,并且 ROOFTOP 地理编码器结果可用,您可以找到道路上最近的位置,然后使用它来请求街景:

http://www.geocodezip.com/v3_Streetview_lookAtB.html?snaptoroad=5175%20Buena%20Vista%20Boulevard,%20Castle%20Rock,%20CO%2080109,%20USA

(如果您不知道地址,您可以像我在这里所做的那样对位置进行反向地理编码以获取它)

这个问题的工作示例:Using google street view with a marker, how do I point the POV at a marker?

工作小提琴

工作代码片段:

var geocoder = new google.maps.Geocoder();
var myStreetView = null;
var marker = null;

function geocodeAddress() {
  var address = document.getElementById('address').value;
  geocoder.geocode({
    'address': address
  }, function(results, status) {
    //alert (results);
    if (status == google.maps.GeocoderStatus.OK) {
      //alert(results[0].geometry.location);
      myStreetView = new google.maps.StreetViewPanorama(document.getElementById("map_canvas"));
      myStreetView.setPosition(results[0].geometry.location);
      google.maps.event.addListenerOnce(myStreetView, 'status_changed', function() {
        var SVstatus = myStreetView.getStatus()
        document.getElementById('info').innerHTML = "Street View Status="+SVstatus;
        var heading = google.maps.geometry.spherical.computeHeading(myStreetView.getLocation().latLng, results[0].geometry.location);
        myStreetView.setPov({
          heading: heading,
          pitch: 0
        });
        setTimeout(function() {
          marker = new google.maps.Marker({
            position: results[0].geometry.location,
            map: myStreetView,
            title: address
          });
          if (marker && marker.setMap) marker.setMap(myStreetView);
        }, 500);
      });

    } else {
      alert("Geocode was not successful for the following reason: " + status);
    }
  });
  google.maps.event.addDomListener(document.getElementById('geoBtn'), 'click', geocodeAddress);
}
google.maps.event.addDomListener(window, 'load', geocodeAddress);
html,
body,
#map_canvas {
  height: 100%;
  width: 100%;
}
<script src="http://maps.google.com/maps/api/js?libraries=geometry"></script>
<input id="address" type="text" value="5175 Buena Vista Boulevard, Castle Rock, CO 80109, USA" />
<input id="geoBtn" type="button" value="Go" />
<div id="info"></div>
<div id="map_canvas"></div>

于 2013-07-11T00:35:31.307 回答
4

我也注意到,谷歌似乎正在使用不同的算法在其网站上显示该图像(在左侧面板中),并且它更准确,因为它位于该位置的正面。

没有直接的方法可以通过他们的“街景图像 API”获得该角度,但您可以使用 javascript API 计算该角度并将其传递给图像 API。

这里的问题是我们怎么知道哪个是建筑物的前面?,前面通常是街道入口的位置。因此,您可以使用 DirectionService 获取最近的交通开始位置,通常是建筑物入口处的道路,使用此位置您现在可以使用其几何实用程序方法轻松计算航向并将其传递给您的 Image API。

于 2013-07-12T18:28:04.393 回答