OpenLayers项目分析——(八)地图表现(续)Gis 2008-07-17 08:31:41 阅读6 评论0 字号:大中小 订阅 (八)地图表现(续)
上一回说到OpenLayers.Map类,这回介绍组成Map的主体部分OpenLayers. Layer类,先从其实现细节上分析,看它是怎么设计出来的。关于它许许多多的子类,即各种图层,想单独写一篇。 OpenLayers. Layer提供了一个EVENT_TYPES常量,用于支持关于图层的应用事件类型,这些事件有"loadstart", "loadend", "loadcancel", "Visibilitychanged"。 它“固有”的3个属性:id,name,div。其中,id和name是layer的身份,在对图层进行操作的时候,就是用它们标志的。至于div,大家都制知道,DOM元素,用于存放图层。 定义的map、event属性,是图层对象对map、event对象的引用;projection属性,设置默认情况下,地图的投影,同时也设置maxExtent, maxResolution, 和units 。 来看看构造函数: * name - {String} The layer name * options - {Object} Hashtable of extra options to tag onto the layer */ initialize: function(name, options) {
this.addOptions(options);
this.name = name;
if (this.id == null) {
this.id = OpenLayers.Util.createUniqueID(this.CLASS_NAME + "_");
this.div = OpenLayers.Util.createDiv(); this.div.style.width = "100%"; this.div.style.height = "100%"; this.div.id = this.id;
this.events = new OpenLayers.Events(this, this.div, this.EVENT_TYPES); }
if (this.wrapDateLine) { this.displayOutsideMaxExtent = true; } } OpenLayers中每一个类的构造函数都是以initialize命名的。 再看看其成员函数: destroy函数,相当于析构函数; onMapResize,removeMap 虚函数,提供给子类继承; //移动函数 moveTo:function(bounds, zoomChanged, dragging) { var display = this.visibility; if (!this.isBaseLayer) { display = display && this.inRange; } this.display(display); } 下面一组函数是Baselayer Functions函数,就是layer是Baselayer 的话,所用的函数。 比如,initResolutions、getResolution、getExtent等。 通过这两次的分析,可以发现,Map和Layers的关系:它们是相互引用的。实际上是这样,OpenLayers的Map类主要包含了对每个图层的引用,对每个控件的引用,对事件的引用,对装载容器的引用(其实就是那些map上层的div)以及对pop的引用,而其自身又包含有大量的方法和属性。图层主要包含了对map的引用,对自身div容器的引用以及事件的引用,而图层自身又包含了大量的属性和方法。map引用了layer,而layer又引用了map,这里就直接形成了循环引用关系。 这样的组成和关联关系,每动一下,就会涉及到大量的对象,影响了性能。 |
|
来自: Java修炼馆 > 《openlayer》