2
A
回答
5
我已经做了一个小例子,可以帮助你。 它采用html2canvas.js和jquery.js和 我也分叉什么@mfirdaus did in another answer
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Capture map</title>
<style>
html,
body {
height: 100%;
margin: 0;
padding: 0;
}
#map {
float: left;
height: 640px;
width: 640px;
}
.myButton1 {
-moz-box-shadow: 0px 1px 0px 0px #fff6af;
-webkit-box-shadow: 0px 1px 0px 0px #fff6af;
box-shadow: 0px 1px 0px 0px #fff6af;
background: -webkit-gradient(linear, left top, left bottom, color-stop(0.05, #ffec64), color-stop(1, #ffab23));
background: -moz-linear-gradient(top, #ffec64 5%, #ffab23 100%);
background: -webkit-linear-gradient(top, #ffec64 5%, #ffab23 100%);
background: -o-linear-gradient(top, #ffec64 5%, #ffab23 100%);
background: -ms-linear-gradient(top, #ffec64 5%, #ffab23 100%);
background: linear-gradient(to bottom, #ffec64 5%, #ffab23 100%);
filter: progid: DXImageTransform.Microsoft.gradient(startColorstr='#ffec64', endColorstr='#ffab23', GradientType=0);
background-color: #ffec64;
-moz-border-radius: 6px;
-webkit-border-radius: 6px;
border-radius: 6px;
border: 1px solid #ffaa22;
display: inline-block;
cursor: pointer;
color: #333333;
font-family: Arial;
font-size: 15px;
font-weight: bold;
padding: 6px 24px;
text-decoration: none;
text-shadow: 0px 1px 0px #ffee66;
}
.myButton1:hover {
background: -webkit-gradient(linear, left top, left bottom, color-stop(0.05, #ffab23), color-stop(1, #ffec64));
background: -moz-linear-gradient(top, #ffab23 5%, #ffec64 100%);
background: -webkit-linear-gradient(top, #ffab23 5%, #ffec64 100%);
background: -o-linear-gradient(top, #ffab23 5%, #ffec64 100%);
background: -ms-linear-gradient(top, #ffab23 5%, #ffec64 100%);
background: linear-gradient(to bottom, #ffab23 5%, #ffec64 100%);
filter: progid: DXImageTransform.Microsoft.gradient(startColorstr='#ffab23', endColorstr='#ffec64', GradientType=0);
background-color: #ffab23;
}
.myButton1:active {
position: relative;
top: 1px;
}
</style>
<script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/html2canvas/0.4.1/html2canvas.js"></script>
<script src="https://code.jquery.com/jquery-3.0.0.min.js" integrity="sha256-JmvOoLtYsmqlsWxa7mDSLMwa6dZ9rrIdtrrVYRnDRH0=" crossorigin="anonymous"></script>
</head>
<body>
<div id="map"></div>
<a id="btnSave" class="myButton1">generate img</a>
<a id="togCtrl" class="myButton1">toggle controls</a>
<div id="img-out"></div>
<script>
var map;
var transform;
var toggler = true;
function initialize() {
var tokio = new google.maps.LatLng(35.6801453, 139.728792);
var agbar = new google.maps.LatLng(41.4035482, 2.1894355);
map = new google.maps.Map(document.getElementById('map'), {
center: agbar,
zoom: 18,
mapTypeId: google.maps.MapTypeId.SATELLITE
});
}
//forked of https://stackoverflow.com/a/24281734/4537906
//get transform value
$("#btnSave").click(function() {
console.log('btnSave');
var transform = $(".gm-style>div:first>div").css("transform");
var comp = transform.split(","); //split up the transform matrix
var mapleft = parseFloat(comp[4]); //get left value
var maptop = parseFloat(comp[5]); //get top value
$(".gm-style>div:first>div").css({ //get the map container.
"transform": "none",
"left": mapleft,
"top": maptop,
})
html2canvas($('#map'), {
useCORS: true,
onrendered: function(canvas) {
var dataUrl = canvas.toDataURL('image/png'); //ready to use with the below commented line
//location.href = dataUrl; //this opens the image as an url into your browser
$(".gm-style>div:first>div").css({
left: 0,
top: 0,
"transform": transform
})
$("#img-out").append(canvas);
}
});
});
$("#togCtrl").click(function() {
map.setOptions({
disableDefaultUI: toggler,
disableDoubleClickZoom: toggler,
draggable: !toggler,
scrollwheel: !toggler
});
toggler = !toggler;
})
</script>
<script async defer src="https://maps.googleapis.com/maps/api/js?callback=initialize">
</script>
</body>
</html>
+0
谢谢你的回答。我希望我已经错过了谷歌地图文档中的一些东西,以便直接做到这一点。但这是一个功能解决方法。 – Murcielago
相关问题
- 1. 如何获得静态谷歌地图的界限?
- 2. 谷歌静态地图没有使用谷歌地图API
- 3. 混合静态/动态谷歌地图
- 4. 在谷歌地图上设置边界和倾斜v2
- 5. 谷歌地图默认tiptool倾斜箭头造型
- 6. 如何改变只倾斜在谷歌地图API
- 7. 谷歌地图 - 不要显示,直到倾斜加载
- 8. 谷歌静态地图图像帮助
- 9. CSS:Google地图倾斜视图?
- 10. 谷歌街景+设备倾斜
- 11. 静态谷歌地图2针
- 12. 加载静态谷歌地图到UIImageView?
- 13. 谷歌静态地图API:移动
- 14. 谷歌静态地图403错误
- 15. 谷歌静态地图问题
- 16. 是静态谷歌地图API免费?
- 17. 谷歌地图静态API网:: ERR_CONNECTION_CLOSED
- 18. 谷歌静态地图不显示
- 19. 如何静态谷歌地图
- 20. 谷歌静态地图 - 画一个圆
- 21. 谷歌地图静态标记API与地址
- 22. 静态谷歌地图图像不会变得流动与媒体查询
- 23. 静态图像谷歌地图与路线
- 24. 谷歌地图静态地图:隐式定位地图
- 25. 如何获取动态谷歌地图网址(有静态地图网址)
- 26. 谷歌地图静态地图 - 自定义图标限制
- 27. 谷歌静态地图API:生成具有路径的静态地图
- 28. 我如何获得谷歌地图上的多个坐标静态API?
- 29. 使用的fancybox与谷歌静态地图
- 30. 与iPad倾斜
2跟进的问题:使用Google静态街景图像API,你可以与街道的变焦查询指定的视图?我忘了第二个问题是什么。 – Murcielago
为什么downvote? – Murcielago
我建议通过以下网址提交功能请求:https://code.google.com/p/gmaps-api-issues/issues/list?can=2&q=apitype:Static%20type:Enhancement&sort=-stars&colspec=ID%20Type %20Status%20Summary%20Internal%20Stars – miguev