<!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>