openlayers中实现自定冒泡的效果
自定义的Openlayers.Popup.FreshCloud继承自Openlayers.Popup.Framed,实现了比较简洁的冒泡效果,详细代码如下
/**
* Class: OpenLayers.Popup.FramedCloud
*
* Inherits from:
* - <OpenLayers.Popup.Framed>
*/
OpenLayers.Popup.FreshCloud =
OpenLayers.Class(OpenLayers.Popup.Framed, { /**
* Property: contentDisplayClass
* {String} The CSS class of the popup content div.
*/
contentDisplayClass: "olFreshCloudPopupContent", /**
* APIProperty: autoSize
* {Boolean} Framed Cloud is autosizing by default.
*/
autoSize: true, /**
* APIProperty: panMapIfOutOfView
* {Boolean} Framed Cloud does pan into view by default.
*/
panMapIfOutOfView: true, /**
* APIProperty: imageSize
* {<OpenLayers.Size>}
*/
imageSize: new OpenLayers.Size(1276, 736), /**
* APIProperty: isAlphaImage
* {Boolean} The FramedCloud does not use an alpha image (in honor of the
* good ie6 folk out there)
*/
isAlphaImage: false, /**
* APIProperty: fixedRelativePosition
* {Boolean} The Framed Cloud popup works in just one fixed position.
*/
fixedRelativePosition: false, /**
* Property: positionBlocks
* {Object} Hash of differen position blocks, keyed by relativePosition
* two-character code string (ie "tl", "tr", "bl", "br")
*/
positionBlocks: {
"tl": {
'offset': new OpenLayers.Pixel(55, 0),
'padding': new OpenLayers.Bounds(5, 35, 5, 5),
'blocks': [
{ // top-left
size: new OpenLayers.Size('auto', 'auto'),
anchor: new OpenLayers.Bounds(0, 35, 5, 0),
position: new OpenLayers.Pixel(0, 0)
},
{ //top-right
size: new OpenLayers.Size(5, 'auto'),
anchor: new OpenLayers.Bounds(null, 35, 0, 0),
position: new OpenLayers.Pixel(-1271, 0)
},
{ //bottom-left
size: new OpenLayers.Size('auto', 5),
anchor: new OpenLayers.Bounds(0, 30, 5, null),
position: new OpenLayers.Pixel(0, -641)
},
{ //bottom-right
size: new OpenLayers.Size(5, 5),
anchor: new OpenLayers.Bounds(null, 30, 0, null),
position: new OpenLayers.Pixel(-1271, -641)
},
{ // stem
size: new OpenLayers.Size(42, 33),
anchor: new OpenLayers.Bounds(null, 0, 30, null),
position: new OpenLayers.Pixel(-5, -699)
}
]
},
"tr": {
'offset': new OpenLayers.Pixel(-50,0),
'padding': new OpenLayers.Bounds(5, 35, 5, 5),
'blocks': [
{ // top-left
size: new OpenLayers.Size('auto', 'auto'),
anchor: new OpenLayers.Bounds(0, 35, 5, 0),
position: new OpenLayers.Pixel(0, 0)
},
{ //top-right
size: new OpenLayers.Size(5, 'auto'),
anchor: new OpenLayers.Bounds(null, 35, 0, 0),
position: new OpenLayers.Pixel(-1271, 0)
},
{ //bottom-left
size: new OpenLayers.Size('auto', 5),
anchor: new OpenLayers.Bounds(0, 30, 5, null),
position: new OpenLayers.Pixel(0, -641)
},
{ //bottom-right
size: new OpenLayers.Size(5, 5),
anchor: new OpenLayers.Bounds(null, 30, 0, null),
position: new OpenLayers.Pixel(-1271, -641)
},
{ // stem
size: new OpenLayers.Size(42, 33),
anchor: new OpenLayers.Bounds(33, 0, null, null),
position: new OpenLayers.Pixel(-5, -699)
}
]
},
"bl": {
'offset': new OpenLayers.Pixel(52, 0),
'padding': new OpenLayers.Bounds(4, 4, 4, 35),
'blocks': [
{ // top-left
size: new OpenLayers.Size('auto', 'auto'),
anchor: new OpenLayers.Bounds(0, 5, 5, 30),
position: new OpenLayers.Pixel(0, 0)
},
{ //top-right
size: new OpenLayers.Size(5, 'auto'),
anchor: new OpenLayers.Bounds(null, 5, 0, 30),
position: new OpenLayers.Pixel(-1271, 0)
},
{ //bottom-left
size: new OpenLayers.Size('auto', 5),
anchor: new OpenLayers.Bounds(0, 0, 5, null),
position: new OpenLayers.Pixel(0, -641)
},
{ //bottom-right
size: new OpenLayers.Size(5, 5),
anchor: new OpenLayers.Bounds(null, 0, 0, null),
position: new OpenLayers.Pixel(-1271, -641)
},
{ // stem
size: new OpenLayers.Size(42, 32),
anchor: new OpenLayers.Bounds(null, null, 30, 2),
position: new OpenLayers.Pixel(-52, -697)
}
]
},
"br": {
'offset': new OpenLayers.Pixel(-50, 5),
'padding': new OpenLayers.Bounds(5, 5, 0, 35),
'blocks': [
{ // top-left
size: new OpenLayers.Size('auto', 'auto'),
anchor: new OpenLayers.Bounds(0, 5, 5, 30),
position: new OpenLayers.Pixel(0, 0)
},
{ //top-right
size: new OpenLayers.Size(5, 'auto'),
anchor: new OpenLayers.Bounds(null, 5, 0, 30),
position: new OpenLayers.Pixel(-1271, 0)
},
{ //bottom-left
size: new OpenLayers.Size('auto', 5),
anchor: new OpenLayers.Bounds(0, 0, 5, null),
position: new OpenLayers.Pixel(0, -641)
},
{ //bottom-right
size: new OpenLayers.Size(5, 5),
anchor: new OpenLayers.Bounds(null, 0, 0, null),
position: new OpenLayers.Pixel(-1275, -641)
},
{ // stem
size: new OpenLayers.Size(42, 32),
anchor: new OpenLayers.Bounds(30, null, null, 2),
position: new OpenLayers.Pixel(-52, -697)
}
]
}
}, /**
* APIProperty: minSize
* {<OpenLayers.Size>}
*/
minSize: new OpenLayers.Size(105, 10), /**
* APIProperty: maxSize
* {<OpenLayers.Size>}
*/
maxSize: new OpenLayers.Size(1200, 660), /**
* Constructor: OpenLayers.Popup.FramedCloud
*
* Parameters:
* id - {String}
* lonlat - {<OpenLayers.LonLat>}
* contentSize - {<OpenLayers.Size>}
* contentHTML - {String}
* anchor - {Object} Object to which we'll anchor the popup. Must expose
* a 'size' (<OpenLayers.Size>) and 'offset' (<OpenLayers.Pixel>)
* (Note that this is generally an <OpenLayers.Icon>).
* closeBox - {Boolean}
* closeBoxCallback - {Function} Function to be called on closeBox click.
*/
initialize: function (id, lonlat, contentSize, contentHTML, anchor, closeBox,
closeBoxCallback) { this.imageSrc = OpenLayers.Util.getImageLocation('fresh-popup-relative.gif');
OpenLayers.Popup.Framed.prototype.initialize.apply(this, arguments);
this.contentDiv.className = this.contentDisplayClass;
}, CLASS_NAME: "OpenLayers.Popup.FreshCloud"
});
JS文件地址:http://files.cnblogs.com/wanfeng/FreshCloud.js
图片地址: http://files.cnblogs.com/wanfeng/fresh-popup-relative.gif
openlayers中实现自定冒泡的效果的更多相关文章
- OpenLayers中的图层
OpenLayers有多个不同的图层类,每一个都可以连接到不同的地图服务器.例如通过Layer.WMS类可以连接到WMS地图服务器,通过Layer.Google类可以连接到谷歌地图服务器.OpenLa ...
- 理解JavaScript中的事件处理 阻止冒泡event.stopPropagation();
原文地址:http://www.cnblogs.com/binyong/articles/1750263.html 这篇文章对于了解Javascript的事件处理机制非常好,将它全文转载于此,以备不时 ...
- 在WPF中使用PlaneProjection模拟动态3D效果
原文:在WPF中使用PlaneProjection模拟动态3D效果 虽然在WPF中也集成了3D呈现的功能,在简单的3D应用中,有时候并不需要真实光影的3D场景.毕竟使用3D引擎会消耗很多资源,有时候使 ...
- OpenLayers中的图层(转载)
作者:田念明出处:http://www.cnblogs.com/nianming/本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法 ...
- WPF中的事件及冒泡事件和隧道事件(预览事件)的区别
WPF快速指导10:WPF中的事件及冒泡事件和隧道事件(预览事件)的区别 WPF快速指导10:WPF中的事件及冒泡事件和隧道事件(预览事件)的区别 本文摘要: 1:什么是路由事件: 2:中断事件路 ...
- openlayers中单击获取要素
openlayers中单击获取要素 分类专栏: GIS 总结 OpenLayers 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接: ...
- Web 开发中很实用的10个效果【附源码下载】
在工作中,我们可能会用到各种交互效果.而这些效果在平常翻看文章的时候碰到很多,但是一时半会又想不起来在哪,所以养成知识整理的习惯是很有必要的.这篇文章给大家推荐10个在 Web 开发中很有用的效果,记 ...
- 在IE6、IE7中实现块元素的inline-block效果
在IE6.IE7中实现块元素的inline-block效果有以下两种方法: 1先使用display:inline-block属性触发layout,然后再定义display:inline让块元素呈现内联 ...
- bootstrap中table页面做省市区级联效果(级联库见前面级联编辑)(非select下拉框)
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...
随机推荐
- 2016年中国大学生程序设计竞赛(合肥)-重现赛1001 HDU 5961
传递 Time Limit: 12000/6000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total Submiss ...
- JSPatch心得
转载请注明来源 1 CGSize,CGPoint,CGRect的使用,直接调用x,y,width,height四个属性,而且不用加().例子defineClass('PZPhotoView', { z ...
- 【转】使用Eclipse搭建Python开发环境
因为要进行自动化测试,所以要搭建Python开发环境.这里将使用Eclipse+pyDev进行搭建,在此作为笔记记录下来. 需要的组件: 1.Eclipse SDK 3.7(这里将不再叙述Eclips ...
- google.GIS小例子
var map; var array = [[41.774166667, 85.943055556], [43.864052, 87.560499]];//经纬度 var array1 = [&quo ...
- angular2 - content projection-
angular2中的内容映射: App.component: <my-day> <my-lucky> </my-lucky> </my-day> MyD ...
- Android Volley gives me 400 error
本文来自:http://stackoverflow.com/questions/21739276/android-volley-gives-me-400-error 本人是根据文中的其中一方法: I ...
- cx_oracle 执行cur.execute(sql)提交数据出现 UnicodeEncodeError: 'ascii' codec can't encode character u'\u2122' in position 170
还是中文字符的问题, 解决方法见链接:http://www.oracle.com/technetwork/articles/tuininga-cx-oracle-084866.html import ...
- $.post() 传递多个参数.
$("#button").click(function() { /获取表单中id为idname和count的文本值付给property的两个属性 var property={&qu ...
- NOIP2016の遊記
看了cydiater的游记,我更加认识到我有多弱,大神有多强 剩余的时间不多了,NOIP前停的一周课又颓了相当多的时间,感觉NOIP真的药丸 最后一天复习模板,看一下错误,总结做题的经验,现在实力实在 ...
- Codeforces Round #341 Div.2 B. Wet Shark and Bishops
题意:处在同一对角线上的主教(是这么翻译没错吧= =)会相互攻击 求互相攻击对数 由于有正负对角线 因此用两个数组分别保存每个主教写的 x-y 和 x+y 然后每个数组中扫描重复数字k ans加上kC ...