У меня есть довольно хорошо интегрированная карта OpenLayers, которую я хочу добавить фотографии из API Panoramio. К сожалению, похоже, что оба API находятся под документом на эту тему. Я нашел один большой учебник здесь http://www.gisandchips.org/2010/05/04/openlayers-y-panoramio/, но поскольку я новичок во всем этом, возможно, поэтому я не могу это сделать сам по себе. Я чувствую, что даже используя этот урок, у меня много пробелов в голове, и не говоря уже о том, что на моей карте нет изображений: -/Добавление фотографий панорамы на карту OpenLayers
Вот моя часть кода, которая демонстрирует мое использование этого и что я пытался сделать до сих пор:
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
На мой взгляд, этот код должен работать отлично. Дайте мне результат некоторых миниатюр Panoramio на моей скучной карте. К сожалению, кажется, что слой есть, но пустой. Когда я смотрю текст ответа в Firebug, я вижу, что JSON возвращается с атрибутами фотографий из Panoramio в том месте, которое я указал (Тибет). Я ценю вашу помощь и время, чтобы рассмотреть мои проблемы.
Спасибо,
elshae
Спасибо за ваш ответ! Я действительно исправил проблему, а затем забыл опубликовать ответ здесь! Я считаю, 'var fpoint = new OpenLayers.Geometry.Point (долгота, широта); fpoint.transform (новый OpenLayers.Projection («EPSG: 4326»), новый OpenLayers.Projection («EPSG: 900913»)); ' сделал трюк. Проект OpenLayers не является недокументированным в целом, но когда дело доходит до использования API Panoramio вместе с OpenLayers, я все еще поддерживаю то, что я сказал. Если я ошибаюсь, прошу прощения, пожалуйста, покажите мне хорошие ресурсы, если вы их знаете. Эта ссылка, приведенная выше, является единственной, которую я смог найти для использования обоих. – elshae
Не говоря уже о том, что я знаю, что есть новый API для Panoramio, и здесь я использую старый. Я искал повсюду для какого-то руководства о том, как использовать их вместе и ничего не нашел. Для тех, у кого нет опыта использования этих API, очень сложно все это понять. Я не ожидаю, что все ответы будут написаны откровенно, но, конечно, какие-то базовые интро были бы очень приятными :). Спасибо. – elshae