博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
GIS(二)——在js版搜狗地图上添加brand标牌
阅读量:5957 次
发布时间:2019-06-19

本文共 1770 字,大约阅读时间需要 5 分钟。

hot3.png

       在上一篇博文中,我在搜狗地图上添加了Marker标记,但是在用户体验度上还是不够的,如果想了解某些信息,你得把鼠标指向marker,才能看到title里的值。有没有一种可以直接显示在marker上的东东呢?

       其实有很多方法可以做到。搜狗地图提供了,但是可以直接在页面上显示信息的,貌似只有InfoWindow、Label和Brand。一般InfoWindow是用来显示大量信息的。所以我们显示少量信息一般选用Label和Brand。但是Label显示的效果比较一般,四棱四角的,而Brand则是圆角矩形。所以我还是推荐使用Brand。当然这两个都是支持css的,如果你css技术过硬,也可以把Label整得跟Brand一样。

       今天我就与大家分享一下在js版搜狗地图上,添加Brand标牌。

       首先给大家一个官网的示例代码:点查看。我也先贴出我的代码来,让大家一睹为快吧:

       首先定义一个brand数组,来记录所有景点的brand信息。

var brands = [];//记录所有景点的Brand信息
       然后添加一个js function,来为所有景点设置一个Brand。

//加载标记牌  function addbrand(){    for(var i=0;i
城市:北京市" //是否可见,可缺省,缺省为true ,visible:true //指定内容区固定宽度为80,如果不指定,则会根据内容大小自动适应 //,fixSize:new sogou.maps.Size(80,0) //指定css,css要在样式表事先定义好 ,css:"brand" }); brands.push(brand);//将生成的brand,加入到brands数组中 //侦听对象是brand本身 //sogou.maps.event.addListener(brand,"mouseover",function() //{ //alert("发生mouseover事件,划过了"+this.getContent()) //}); } //侦听对象是map,只侦听一次即可 //sogou.maps.event.addListener(map,"brandclick",function(brand) //{ // alert("发生brandclick事件,点击了"+brand.getContent()) //}); }
       最后修改initialize方法,把刚写的js方法添加到这里面:

//初始化数据  function initialize() {    //此处省略以前的代码...        //加载景点标记    addmarker();        //添加景点标牌    addbrand();      }

       代码都有了,样式信息肯定是少不了的。在style中添加样式:

.brand{font-size:12px;color:#fff;white-space:nowrap;margin:12px 0 0;}

       效果图如下:

       效果看起来还不错吧。当然标牌之间有点项目遮挡,这个问题后面再解决。现在我来解释一下这段代码吧。

       想要创建Brand对象,请看说明。在构建Brand的时候,需要指定position,这个就是地图坐标,可以是搜狗地图坐标或者经纬度坐标。我的代码中把position设定成了每个景点的坐标。map就是当前创建的地图对象。content则是显示内容。css定义标牌中文本的样式的css class。spirit则是这个标牌所用到的背景图片。如果你不设定fixSize,那么这个brand会根据内容长度自动加长。是不是很贴心呀。快来试试吧。

       下一篇博文,我们要解决一下brand项目遮挡问题。如果有心的朋友可能已经发现了,我们要从spirit下手。敬请期待吧。

       

版权声明:本文为博主原创文章,未经博主允许不得转载。

转载于:https://my.oschina.net/u/2260184/blog/518484

你可能感兴趣的文章
广平县北方计算机第一届PS设计大赛
查看>>
深入理解Java的接口和抽象类
查看>>
java与xml
查看>>
Javascript异步数据的同步处理方法
查看>>
iis6 zencart1.39 伪静态规则
查看>>
SQL Server代理(3/12):代理警报和操作员
查看>>
Linux备份ifcfg-eth0文件导致的网络故障问题
查看>>
2018年尾总结——稳中成长
查看>>
JFreeChart开发_用JFreeChart增强JSP报表的用户体验
查看>>
度量时间差
查看>>
通过jsp请求Servlet来操作HBASE
查看>>
Shell编程基础
查看>>
Shell之Sed常用用法
查看>>
3.1
查看>>
校验表单如何摆脱 if else ?
查看>>
<气场>读书笔记
查看>>
web安全问题分析与防御总结
查看>>
Centos下基于Hadoop安装Spark(分布式)
查看>>
3D地图的定时高亮和点击事件(基于echarts)
查看>>
mysql开启binlog
查看>>