采用gmaps v3以及指定到全屏高度并自动滚动

This commit is contained in:
wlx 2013-04-13 01:34:01 +00:00
parent 7845c99a92
commit af8fa13c61
1 changed files with 84 additions and 77 deletions

View File

@ -9,40 +9,54 @@ $this->breadcrumb('<a href="/data">'.$this->config->title->data.'</a>');
$this->breadcrumb('<a href="/data/timeline">时空导航</a>'); $this->breadcrumb('<a href="/data/timeline">时空导航</a>');
$this->breadcrumb()->setSeparator(' > '); $this->breadcrumb()->setSeparator(' > ');
//$this->headScript()->appendFile('http://maps.google.cN/maps?file=api&v=2&key='.$this->config->google->maps->api); //$this->headScript()->appendFile('http://maps.google.cN/maps?file=api&v=2&key='.$this->config->google->maps->api);
$this->headScript()->appendFile('http://maps.google.cN/maps/api/js?sensor=false');
$this->headScript()->appendFile('/js/timeline_var.js'); $this->headScript()->appendFile('/js/timeline_var.js');
$this->headScript()->appendFile('/js/timeline_js/timeline-api.js'); $this->headScript()->appendFile('/js/timeline_js/timeline-api.js');
$this->headScript()->appendFile('/js/jquery-1.7.min.js'); $this->headScript()->appendFile('/js/jquery-1.7.min.js');
$this->headScript()->appendFile('/js/timemap.2.0.1/lib/mxn/mxn.js?(google)'); $this->headScript()->appendFile('/js/timemap.2.0.1/lib/mxn/mxn.js?(googlev3)');
$this->headScript()->appendFile('/js/timemap.2.0.1/timemap.pack.js'); $this->headScript()->appendFile('/js/timemap.2.0.1/timemap.pack.js');
$this->headScript()->appendFile('/js/jquery.colorbox-min.js'); $this->headScript()->appendFile('/js/jquery.colorbox-min.js');
$this->headLink()->appendStylesheet('/css/colorbox.css'); $this->headLink()->appendStylesheet('/css/colorbox.css');
?> ?>
<div class="row-fluid"><?= $this->partial('data/tools.phtml'); ?></div> <div class="row-fluid"><?= $this->partial('data/tools.phtml'); ?></div>
<div id="timemap" style="clear:both;"> <div id="timemap">
<div id="timeline" style="height:300px;width:100%;"></div> <div id="map" style="height:500px;width:50%;float:right;"></div>
<div id="map" style="height:300px;"></div> <div id="timeline" style="height:500px;border-right:1px solid #abc;"></div>
</div>
<script type="text/javascript" charset="utf-8"> </div>
var tm; <script type="text/javascript" charset="utf-8">
$(window).bind("load", function() { var timeout = setTimeout(function() { initLoader(); }, 100);}); $('#map').height($(window).height());
//$(window).bind("load", function() { var timeout = setTimeout(function() { gmaploaded(); }, 1000);}); $('#timeline').height($(window).height());
function loadMaps() { $("html,body").animate({scrollTop:$('#timemap').offset().top},600);
google.load("maps", "2", {"callback" : tmloaded,"base_domain": "ditu.google.cn"}); var tm;
} $(function() {
// make a custom map style
var styledMapType = new google.maps.StyledMapType([
{
featureType: "water",
elementType: "all",
stylers: [
{ saturation: 0 },
{ lightness: 100 }
]
},
{
featureType: "all",
elementType: "all",
stylers: [
{ saturation: -100 }
]
}
], {
name: "white"
});
function initLoader() {
var script = document.createElement("script");
script.src = "https://www.google.com/jsapi?key=<?php echo $this->config->google->maps->api; ?>&callback=loadMaps";
script.type = "text/javascript";
document.getElementsByTagName("head")[0].appendChild(script);
}
function tmloaded() {
tm = TimeMap.init({ tm = TimeMap.init({
mapId: "map", // Id of map div element (required) mapId: "map", // Id of map div element (required)
timelineId: "timeline", // Id of timeline div element (required) timelineId: "timeline", // Id of timeline div element (required)
options: { options: {
eventIconPath: "../images/", eventIconPath: "../images/"
mapType:G_NORMAL_MAP
}, },
datasets: [ datasets: [
{ {
@ -60,28 +74,16 @@ function tmloaded() {
<?php if ($row['timeend']!='') : ?> <?php if ($row['timeend']!='') : ?>
"end" : "<?php echo $row['timeend']; ?>", "end" : "<?php echo $row['timeend']; ?>",
<?php endif; ?> <?php endif; ?>
"polygon" : [ "point" :
{ {
"lat" : <?php echo $row['south']; ?>, "lat" : <?php echo ($row['south']+$row['north'])/2; ?>,
"lon" : <?php echo $row['west']; ?> "lon" : <?php echo ($row['west']+$row['east'])/2; ?>
},{ },
"lat" : <?php echo $row['north']; ?>, "title" : "<?php echo htmlspecialchars($row['title']); ?>",
"lon" : <?php echo $row['west']; ?>
},{
"lat" : <?php echo $row['north']; ?>,
"lon" : <?php echo $row['east']; ?>
},{
"lat" : <?php echo $row['south']; ?>,
"lon" : <?php echo $row['east']; ?>
},{
"lat" : <?php echo $row['south']; ?>,
"lon" : <?php echo $row['west']; ?>
}
],
"title" : "<?php echo $row['title']; ?>",
"options" : { "options" : {
// set the full HTML for the info window // set the full HTML for the info window
"infoHtml": "<a href=/data/<?php echo $row['uuid']; ?>><?php echo $row['title']; ?></a><hr /><img src=/service/thumb/id/<?php echo $row['id']; ?> onclick='$.colorbox({photo:\"true\",href:\"/service/bigthumb/id/<?php echo $row['id']; ?>\"});' />" "infoHtml": "<div class='info'><a href=/heihe/view/uuid/<?php echo $row['uuid']; ?>><?php echo htmlspecialchars($row['title']); ?></a><hr /><img src=/service/thumb/id/<?php echo $row['id']; ?> onclick='$.colorbox({photo:\"true\",href:\"/service/bigthumb/id/<?php echo $row['id']; ?>\"});' /></div>",
"theme":"orange"
} }
}, },
<?php endforeach; ?> <?php endforeach; ?>
@ -94,6 +96,11 @@ function tmloaded() {
Timeline.DateTime.DECADE Timeline.DateTime.DECADE
] ]
}); });
// manipulate the timemap further here if you like
} // set the map to our custom style
var gmap = tm.getNativeMap();
gmap.mapTypes.set("white", styledMapType);
gmap.setMapTypeId("white");
});
</script> </script>