123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106 |
- <!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: 600px;
- height: 412px;
- margin: 20px;
- }
- .content table{width: 100%}
- .content table td{vertical-align: middle;}
- #address{width:405px;height:28px;background: #FFF;border:1px solid #ccc; line-height: 28px;border-radius: 5px;margin-left: 10px;}
- #container {margin-top: 10px;}
- #doSearch {
- display: block;
- text-align: center;
- line-height: 30px;
- text-decoration: none;
- height: 30px;
- width: 78px;
- border: 0;
- background-color: #3498db;
- border-radius: 5px;
- color: #fff;
- }
- </style>
- <script type="text/javascript" src="https://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: 362px;margin-top: 20px;"></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 = "https://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("https://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>
|