2

Panoramio API から写真を追加したい、かなりよく統合された OpenLayers マップがあります。残念ながら、この件に関しては両方の API が十分に文書化されていないようです。ここで素晴らしいチュートリアルを見つけましたhttp://www.gisandchips.org/2010/05/04/openlayers-y-panoramio/しかし、私はこれらすべてに慣れていないため、自分でこれを完了することができない理由かもしれません. このチュートリアルを使用しても、心にたくさんの空白があり、言うまでもなく、写真がマップに表示されない気がします:-/

これは、そのチュートリアルの使用とこれまでに試みたことを示すコードの一部です。

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 で応答テキストを見ると、指定した場所 (チベット) にある Panoramio からの写真の属性を含む JSON が返されていることがわかります。私の問題を検討するためのあなたの助けと時間に感謝します.

ありがとうございました、

エルシェ

4

1 に答える 1

2

あなたが OpenLayers にどれだけ精通しているかはわかりませんが、このプロジェクトは十分に文書化されているわけではありません。広範な API ドキュメントと、開始に役立つ多数の例があります。

しかし、問題に戻りましょう。おそらく、これはプロジェクションの問題です。Panoramio は、見つかったすべての写真の WSG-84 (GPS) 座標を返します。マップの openstreetmap ベースレイヤーは球状メルカトル図法 ('EPSG:900913') です。したがって、次のようなものを使用して座標を WSG-84 から球状メルカトルに変換する必要があります

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'));

次に、変換されたポイントをジオメトリに使用します

于 2010-12-02T10:50:20.510 に答える