将全景照片添加到OpenLayers地图
-
11-10-2019 - |
题
我有一张相当合理的开放式套图,我想将全景API的照片添加到。不幸的是,这两个API似乎都在这一主题上进行了记录。我在这里找到了一个很棒的教程 http://www.gisandchips.org/2010/05/04/openlayers-ypanoramio/ 但是,由于我是所有这些的新手,这可能就是为什么我不能独自完成。我觉得即使使用本教程,我的脑海中有很多空白空间,更不用说这些照片没有出现在我的地图上: - /
这是我的一部分代码,证明了我对该教程的使用以及到目前为止尝试的内容:
var url = "http://www.panoramio.com/map/get_panoramas.php";
var parameters = {
order:'popularity',
set:'full',
from:0,
to:20,
minx: 84.05,
miny: 31.36,
maxx: 91.89,
maxy: 32.30,
size:'thumbnail'
}//end parameters
OpenLayers.loadURL(url, parameters, this, displayPhotos);
function displayPhotos(response) {
var json = new OpenLayers.Format.JSON();
var panoramio = json.read(response.responseText);
var features = new Array(panoramio.photos.length);
for (var i = 0; i < panoramio.photos.length; i++)
{
var upload_date = panoramio.photos[i].upload_date;
var owner_name = panoramio.photos[i].owner_name;
var photo_id = panoramio.photos[i].photo_id;
var longitude =panoramio.photos[i].longitude;
var latitude = panoramio.photos[i].latitude;
var pheight = panoramio.photos[i].height;
var pwidth = panoramio.photos[i].width;
var photo_title = panoramio.photos[i].photo_title;
var owner_url = panoramio.photos[i].owner_url;
var owner_id = panoramio.photos[i].owner_id;
var photo_file_url = panoramio.photos[i].photo_file_url;
var photo_url = panoramio.photos[i].photo_url;
var fpoint = new OpenLayers.Geometry.Point(longitude,latitude);
var attributes = {
'upload_date' : upload_date,
'owner_name':owner_name,
'photo_id':photo_id,
'longitude':longitude,
'latitude':latitude,
'pheight':pheight,
'pwidth':pwidth,
'pheight':pheight,
'photo_title':photo_title,
'owner_url':owner_url,
'owner_id':owner_id,
'photo_file_url':photo_file_url,
'photo_url':photo_url
}//end attributes
features[i] = new OpenLayers.Feature.Vector(fpoint,attributes);
}//end for
var panoramio_style2 = new OpenLayers.StyleMap(OpenLayers.Util.applyDefaults({
pointRadius: 7,
fillColor: "red",
fillOpacity: 1,
strokeColor: "black",
externalGraphic: "panoramio-marker.png"
}, OpenLayers.Feature.Vector.style["default"]));
var vectorPano = new OpenLayers.Layer.Vector("Panoramio Photos", {
styleMap: panoramio_style2
});
vectorPano.addFeatures(features);
map.addLayer(vectorPano);
}//end displayPhotos
在我看来,这个代码应该完美地工作。给我带来一些全景缩略图的结果。不幸的是,这层似乎在那里,但是空白..当我在Firebug中查看响应文本时,我可以看到JSON带有来自Panoramio的照片的属性,我指定的位置(西藏)。感谢您的帮助和时间来考虑我的问题。
谢谢,
Elshae
解决方案
我不知道您在OpenLayers中有多熟练,但是该项目肯定不会证明不足。有广泛的API文档,还有许多示例应帮助您入门。
但是现在回到您的问题:可能,这是一个投影问题。 Panoramio返回其发现的所有照片的WSG-84(GPS)坐标,并且地图的OpenStreetMap基本仪位于球形Mercator投影('EPSG:900913')中。因此,您必须使用诸如
var curPic = panoramio.photos[i];
var panLonLat = new OpenLayers.LonLat(curPic.longitude, curPic.latitude);
panLonLat.transform(new OpenLayers.Projection("EPSG:4326"), new OpenLayers.Projection('EPSG:900913'));
然后使用转换点进行几何形状
不隶属于 StackOverflow