首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Google Heatmap地图上没有指针

Google Heatmap地图上没有指针
EN

Stack Overflow用户
提问于 2014-01-28 21:39:11
回答 1查看 734关注 0票数 2

我正在使用谷歌热图,我试图在地图上加载超过1000个指针,但我不确定它是否有效。

这是我的代码:

代码语言:javascript
复制
        var map, pointarray, heatmap;

        var gradient = [
            'rgba(0, 255, 255, 0)',
            'rgba(0, 255, 255, 1)',
            'rgba(0, 191, 255, 1)',
            'rgba(0, 127, 255, 1)',
            'rgba(0, 63, 255, 1)',
            'rgba(0, 0, 255, 1)',
            'rgba(0, 0, 223, 1)',
            'rgba(0, 0, 191, 1)',
            'rgba(0, 0, 159, 1)',
            'rgba(0, 0, 127, 1)',
            'rgba(63, 0, 91, 1)',
            'rgba(127, 0, 63, 1)',
            'rgba(191, 0, 31, 1)',
            'rgba(255, 0, 0, 1)'
        ]

 var taxiData = [
new google.maps.LatLng(43.3128954, 10.5320177),
new google.maps.LatLng(43.4121300, 10.4157520),
....
new google.maps.LatLng(43.3116784, 10.5298907),
new google.maps.LatLng(43.3416850, 10.5290120) 
]

        function initialize() {
            var mapOptions = {
                zoom: 13,
                dissipating: false,
                center: new google.maps.LatLng(43.3128954, 10.5320177),
                mapTypeId: google.maps.MapTypeId.ROADMAP 
            };

            map = new google.maps.Map(document.getElementById('map-canvas'), mapOptions);

            pointArray = new google.maps.MVCArray(taxiData);

            heatmap = new google.maps.visualization.HeatmapLayer({
                data: pointArray
            });

            heatmap.setMap(map);
            heatmap.set('gradient', heatmap.get('gradient') ? null : gradient);
        }

        function toggleHeatmap() {
            heatmap.setMap(heatmap.getMap() ? null : map);
        }

        function changeGradient() {
            var gradient = [
                'rgba(0, 255, 255, 0)',
                'rgba(0, 255, 255, 1)',
                'rgba(0, 191, 255, 1)',
                'rgba(0, 127, 255, 1)',
                'rgba(0, 63, 255, 1)',
                'rgba(0, 0, 255, 1)',
                'rgba(0, 0, 223, 1)',
                'rgba(0, 0, 191, 1)',
                'rgba(0, 0, 159, 1)',
                'rgba(0, 0, 127, 1)',
                'rgba(63, 0, 91, 1)',
                'rgba(127, 0, 63, 1)',
                'rgba(191, 0, 31, 1)',
                'rgba(255, 0, 0, 1)'
            ]
            heatmap.set('gradient', heatmap.get('gradient') ? null : gradient);
        }

        function changeRadius() {
            heatmap.set('radius', heatmap.get('radius') ? null : 20);
        }

        function changeOpacity() {
            heatmap.set('opacity', heatmap.get('opacity') ? null : 0.2);
        }

        google.maps.event.addDomListener(window, 'load', initialize);

我已经在这个链接上创建了一个包含完整代码的演示:http://jsfiddle.net/8b85R/

fixed fiddle (按钮点击工作)

我不明白为什么我有很多蓝色区域,但只有2个指针!我期待的是更类似于谷歌演示( https://developers.google.com/maps/documentation/javascript/examples/layer-heatmap )的东西,在那里你可以找到所有的500个指针。

我需要你的帮助!谢谢!

EN

回答 1

Stack Overflow用户

发布于 2014-01-28 21:55:51

更像是这样:http://jsfiddle.net/6JSe7/1/

我所做的就是调低(或调高)不透明度,这些点在不断增加的缩放级别,但它们几乎看不见(我的意思是很好地看不到),并添加了消散选项:

代码语言:javascript
复制
heatmap = new google.maps.visualization.HeatmapLayer({
            data: pointArray,
            dissipating: true,
            radius: 35

        });

        heatmap.setMap(map);
        heatmap.set('gradient', heatmap.get('gradient') ? null : gradient);
        heatmap.set('opacity', '0.9');
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/21407123

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档