Blame view

static/ueditor/dialogs/gmap/gmap.html 4.04 KB
831eac332   zhuzhenchao   add file
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
  <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
          "http://www.w3.org/TR/html4/loose.dtd">
  <html>
  <head>
      <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
      <title></title>
      <script type="text/javascript" src="../internal.js"></script>
      <style type="text/css">
          .content{width:530px; height: 350px;margin: 10px auto;}
          .content table{width: 100%}
          .content table td{vertical-align: middle;}
          #address{width:220px;height:21px;background: #FFF;border:1px solid #d7d7d7; line-height: 21px;}
      </style>
      <script type="text/javascript" src="http://maps.googleapis.com/maps/api/js?sensor=false"></script>
  </head>
  <body>
  <div class="content">
      <table>
          <tr>
              <td><label for="address"><var id="lang_input_address"></var></label></td>
              <td><input id="address" type="text" /></td>
              <td><a id="doSearch" href="javascript:void(0)" class="button"><var id="lang_input_search"></var></a></td>
          </tr>
      </table>
      <div id="container" style="width: 100%; height: 340px;margin: 5px auto; border: 1px solid gray;"></div>
  </div>
  <script type="text/javascript">
      domUtils.on(window,"load",function(){
          var map = new google.maps.Map(document.getElementById('container'), {
                  zoom: 3,
                  streetViewControl: false,
                  scaleControl: true,
                  mapTypeId: google.maps.MapTypeId.ROADMAP
              });
              var imgcss;
              var marker = new google.maps.Marker({
                  map: map,
                  draggable: true
              });
              function doSearch(){
                  var address = document.getElementById('address').value;
                  var geocoder = new google.maps.Geocoder();
                  geocoder.geocode( { 'address': address}, function (results, status) {
                      if (status == google.maps.GeocoderStatus.OK) {
                          var bounds = results[0].geometry.viewport;
                          map.fitBounds(bounds);
                          marker.setPosition(results[0].geometry.location);
                          marker.setTitle(address);
                      } else alert(lang.searchError);
                  });
              }
              $G('address').onkeydown = function (evt){
                  evt = evt || event;
                  if (evt.keyCode == 13) {
                      doSearch();
                  }
              };
              $G("doSearch").onclick = doSearch;
              dialog.onok = function (){
                  var center = map.getCenter();
                  var point = marker.getPosition();
                  var url = "http://maps.googleapis.com/maps/api/staticmap?center=" + center.lat() + ',' + center.lng() + "&zoom=" + map.zoom + "&size=520x340&maptype=" + map.getMapTypeId() + "&markers=" + point.lat() + ',' + point.lng() + "&sensor=false";
                  editor.execCommand('inserthtml', '<img width="520" height="340" src="' + url + '"' + (imgcss ? ' style="' + imgcss + '"' :'') + '/>');
              };
  
              function getPars(str,par){
                  var reg = new RegExp(par+"=((\\d+|[.,])*)","g");
                  return reg.exec(str)[1];
              }
              var img = editor.selection.getRange().getClosedNode();
              if(img && img.src.indexOf("http://maps.googleapis.com/maps/api/staticmap")!=-1){
                  var url = img.getAttribute("src");
                  var centers = getPars(url,"center").split(",");
                  point = new google.maps.LatLng(Number(centers[0]),Number(centers[1]));
                  map.setCenter(point);
                  map.setZoom(Number(getPars(url,"zoom")));
                  centers = getPars(url,"markers").split(",");
                  marker.setPosition(new google.maps.LatLng(Number(centers[0]),Number(centers[1])));
                  imgcss = img.style.cssText;
              }else{
                  setTimeout(function(){
                      doSearch();
                  },30)
              }
      });
  
  </script>
  </body>
  </html>