创建行为类似谷歌地图的界面(客户端)

时间:2011-12-24 16:02:03

标签: google-maps gwt user-interface client-side

我正在尝试创建像谷歌地图这样的界面。 即我想在屏幕上显示图像,当我拖动时,我想根据需要加载图像的一部分。我的图像水平无限长,但其垂直高度固定为200像素。

服务器端准备就绪,并根据需要发回图像数据。

我的问题是,如何实现客户端图像拖动的事情?我正在尝试使用GWT。我无法弄清楚如何向用户显示图像,然后允许他向左/向右拖动它。我已经阅读了这个网站和所有谷歌地图相关的问题,但我仍然无法弄清楚如何实现客户端部分。

谢谢,

1 个答案:

答案 0 :(得分:1)

您没有自己实施拖动和缩放。

您可以调用Google Javascript API或其GWT包装的API。

该服务将可拖动和可缩放的地图提供给html页面dom上的画布。

指定地图框的坐标和要素。您的应用程序将与地图服务进行通信,以了解用户正在执行的操作。您不会直接控制用户在地图画布上执行的操作。您必须与地图服务进行沟通/请求。

http://code.google.com/p/gwt-google-apis/wiki/MapsGettingStarted

或者你可以直接使用Maps / Latitude Javascript API,很容易将你自己的gwt包装器放在持有地图画布的div周围。您将通过REST API传递和接收json或xml与地图服务进行通信。

确保您没有要求提供某个位置的图片。

例如,以下简单的html(我从地图api网站偷走)提供了一个可拖动/可缩放的地图。没有辛苦的工作。

注意div持有map_canvas id?您需要将其包装在GWT中。 将画布放在div上并将它们包装在gwt中是标准做法,即使是本地生成图像和图表实用程序,其中这些实用程序是用javascript编写的。 DOM.getElementById应该是你的好朋友。简单地将你的gwt rootpanel东西弄乱到地图画布周围。

<!DOCTYPE html>
<html>
<head>
<meta name="viewport" content="initial-scale=1.0, user-scalable=no" />
<style type="text/css">
  html { height: 100% }
  body { height: 100%; margin: 0; padding: 0 }
  #map_canvas { height: 100% }
</style>
<script type="text/javascript"
    src="http://maps.googleapis.com/maps/api/js?key=YOUR_API_KEY&sensor=true">
</script>
<script type="text/javascript">
  function initialize() {
    var latlng = new google.maps.LatLng(-34.397, 150.644);
    var myOptions = {
      zoom: 8,
      center: latlng,
      mapTypeId: google.maps.MapTypeId.ROADMAP
    };
    var map = new google.maps.Map(document.getElementById("map_canvas"),
        myOptions);
  }

</script>
</head>
<body onload="initialize()">
  <div id="map_canvas" style="width:100%; height:100%"></div>
</body>
</html>