You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
89 lines
4.0 KiB
89 lines
4.0 KiB
<!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> |