javascript - 如何创建类似标记的 Google Latitude?

标签 javascript jquery google-maps google-maps-markers

在我的 HTML5 应用程序中,我使用 Google Map v3 并在 map 上添加了几个标记。放置新标记和更改图标很容易,但我希望能够构建类似于 Google Latitude 中使用的标记。这些标记设置有图标图像和漂亮的边框。
关于如何执行此操作的任何想法?

最佳答案

您可以在服务器端执行此操作,或者因为您使用的是 HTML 5 并假设您有可用的 Canvas ,您可以在客户端执行此操作。下面是一种使用 HTML 5 Canvas 在客户端执行此操作的方法。在服务器端执行此操作因您使用的语言而异,但技术是相似的。

下载这些图像并试用。图片需要与页面位于同一域中,以避免出现安全错误。它们也应该位于同一目录中,除非您更新 HTML 中的位置。

face1 face2 face3 frame

页面加载后,单击面孔,系统将使用提供的帧图像创建随机标记并将其添加到 Google map 。

enter image description here

<!DOCTYPE html>
<html>
    <head>
        <meta http-equiv="Content-Type" content="text/html; utf-8">
        <title>HTML 5 Canvas Image Processing</title>
    </head>
    <body>
        <img onclick="build(this)" id="face1" src="face1.png"/>
        <img onclick="build(this)" id="face2" src="face2.png"/>
        <img onclick="build(this)" id="face3" src="face3.png"/>
        <img id="frame" src="frame.png"/>
        <div id="map_canvas" style="width:640px;height:480px;">
        </div>
        <script type="text/javascript">

            function build(caller){
                var image = getMergedUrl(document.getElementById("frame"), caller);
                var myLatLng = getRndPos(map.getBounds());
                var myMarker = new google.maps.Marker({
                    position: myLatLng,
                    map: map,
                    icon: image
                });

            }

            function getRndPos(bounds) {
                var xDiff = Math.abs(bounds.getNorthEast().lng() - bounds.getSouthWest().lng());
                var yDiff = Math.abs(bounds.getNorthEast().lat() - bounds.getSouthWest().lat());
                var xMin = Math.min(bounds.getNorthEast().lng(),bounds.getSouthWest().lng());
                var yMin = Math.min(bounds.getNorthEast().lat(),bounds.getSouthWest().lat());
                var x = xMin + xDiff * Math.random();
                var y = yMin + yDiff * Math.random();
                var pos = new google.maps.LatLng(y,x);
                return pos;
            }

            function getMergedUrl(frame, pic){
                // Create an empty canvas element
                var canvas = document.createElement("canvas");
                canvas.width = frame.width;
                canvas.height = frame.height;

                // Copy the image contents to the canvas
                var ctx = canvas.getContext("2d");
                ctx.drawImage(frame, 0, 0);
                ctx.drawImage(pic, 4, 4);

                // Get the data-URL formatted image
                var dataURL = canvas.toDataURL("image/png");

                return dataURL;
            }

            function initialize(){
                var myLatlng = new google.maps.LatLng(-34.397, 150.644);
                var myOptions = {
                    zoom: 8,
                    center: myLatlng,
                    mapTypeId: google.maps.MapTypeId.ROADMAP
                }
                map = new google.maps.Map(document.getElementById("map_canvas"), myOptions);
            }

            function loadScript(){
                var script = document.createElement("script");
                script.type = "text/javascript";
                script.src = "http://maps.google.com/maps/api/js?sensor=false&callback=initialize";
                document.body.appendChild(script);
            }

            window.onload = loadScript;
        </script>
    </body>
</html>

感谢Matthew Crumley来自 here 的 toDataUrl 代码.

关于javascript - 如何创建类似标记的 Google Latitude?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5792533/

相关文章:

jquery - 如何停止 jQuery 淡入淡出/淡出连续循环?

jquery - 如何使用 jQuery 添加悬停类

javascript - jQuery - removeClass() 应用于除一个类之外的所有类

android - Google Map Tile Provider(GeoServer 和 WMS)

android - 多点映射 Intent

javascript - 如何在 google map api v3 javascript 中单击 map 时获取纬度、经度?

HTML 中的 Javascript 加载

javascript - 将 PHP DateTime 格式转换为 Moment.js

javascript - express.js 4.12 连接超时上限?

asp.net - 在.net onblur事件中在标签中显示消息,是否可能