89 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			HTML
		
	
	
	
			
		
		
	
	
			89 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			HTML
		
	
	
	
| <!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> |