[OpenLayers-Commits] r11191 - in sandbox/bartvde/sencha/openlayers: . lib/OpenLayers lib/OpenLayers/Control lib/OpenLayers/Format/CSWGetDomain lib/OpenLayers/Format/WFST lib/OpenLayers/Handler lib/OpenLayers/Layer lib/OpenLayers/Renderer lib/OpenLayers/Tile/Image tests/Handler

commits-20090109 at openlayers.org commits-20090109 at openlayers.org
Mon Feb 21 10:16:37 EST 2011


Author: bartvde
Date: 2011-02-21 07:16:37 -0800 (Mon, 21 Feb 2011)
New Revision: 11191

Modified:
   sandbox/bartvde/sencha/openlayers/
   sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Control/LayerSwitcher.js
   sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Events.js
   sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Format/CSWGetDomain/v2_0_2.js
   sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Format/WFST/v1.js
   sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Handler/Drag.js
   sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Layer/Bing.js
   sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Layer/Vector.js
   sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Layer/WMS.js
   sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Layer/Zoomify.js
   sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Map.js
   sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Renderer/VML.js
   sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Tile/Image/IFrame.js
   sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Util.js
   sandbox/bartvde/sencha/openlayers/tests/Handler/Drag.html
Log:
merging sandbox with trunk


Property changes on: sandbox/bartvde/sencha/openlayers
___________________________________________________________________
Modified: svn:mergeinfo
   - /sandbox/roberthl/openlayers:9745-9748
   + /sandbox/roberthl/openlayers:9745-9748
/trunk/openlayers:11179-11190

Modified: sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Control/LayerSwitcher.js
===================================================================
--- sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Control/LayerSwitcher.js	2011-02-21 15:12:33 UTC (rev 11190)
+++ sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Control/LayerSwitcher.js	2011-02-21 15:16:37 UTC (rev 11191)
@@ -316,7 +316,7 @@
                 
                 // create span
                 var labelSpan = document.createElement("span");
-                OpenLayers.Element.addClass(labelSpan, "labelSpan")
+                OpenLayers.Element.addClass(labelSpan, "labelSpan");
                 if (!baseLayer && !layer.inRange) {
                     labelSpan.style.color = "gray";
                 }

Modified: sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Events.js
===================================================================
--- sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Events.js	2011-02-21 15:12:33 UTC (rev 11190)
+++ sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Events.js	2011-02-21 15:16:37 UTC (rev 11191)
@@ -91,6 +91,20 @@
     },
 
     /**
+     * Method: isSingleTouch
+     * Determine whether event was caused by a single touch
+     *
+     * Parameters:
+     * event - {Event}
+     *
+     * Returns:
+     * {Boolean}
+     */
+    isSingleTouch: function(event) {
+        return event.touches && event.touches.length == 1;
+    },
+
+    /**
      * Method: isLeftClick
      * Determine whether event was caused by a left click. 
      *
@@ -369,7 +383,8 @@
         "mouseover", "mouseout",
         "mousedown", "mouseup", "mousemove", 
         "click", "dblclick", "rightclick", "dblrightclick",
-        "resize", "focus", "blur"
+        "resize", "focus", "blur",
+        "touchstart", "touchmove", "touchend"
     ],
 
     /** 
@@ -846,10 +861,16 @@
         if (!this.element.offsets) {
             this.element.offsets = OpenLayers.Util.pagePosition(this.element);
         }
+        var clientX = evt.clientX;
+        var clientY = evt.clientY;
+        if (evt.touches && evt.touches.length > 0) {
+            clientX = evt.touches[0].clientX;
+            clientY = evt.touches[0].clientY;
+        }
         return new OpenLayers.Pixel(
-            (evt.clientX + this.element.scrolls[0]) - this.element.offsets[0]
+            (clientX + this.element.scrolls[0]) - this.element.offsets[0]
                          - this.element.lefttop[0], 
-            (evt.clientY + this.element.scrolls[1]) - this.element.offsets[1]
+            (clientY + this.element.scrolls[1]) - this.element.offsets[1]
                          - this.element.lefttop[1]
         ); 
     },

Modified: sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Format/CSWGetDomain/v2_0_2.js
===================================================================
--- sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Format/CSWGetDomain/v2_0_2.js	2011-02-21 15:12:33 UTC (rev 11190)
+++ sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Format/CSWGetDomain/v2_0_2.js	2011-02-21 15:16:37 UTC (rev 11191)
@@ -133,7 +133,7 @@
             },
             "Value": function(node, obj) {
                 var attrs = node.attributes;
-                var value = {}
+                var value = {};
                 for(var i=0, len=attrs.length; i<len; ++i) {
                     value[attrs[i].name] = attrs[i].nodeValue;
                 }
@@ -159,7 +159,7 @@
             },
             "MinValue": function(node, obj) {
                 var attrs = node.attributes;
-                var value = {}
+                var value = {};
                 for(var i=0, len=attrs.length; i<len; ++i) {
                     value[attrs[i].name] = attrs[i].nodeValue;
                 }
@@ -168,7 +168,7 @@
             },
             "MaxValue": function(node, obj) {
                 var attrs = node.attributes;
-                var value = {}
+                var value = {};
                 for(var i=0, len=attrs.length; i<len; ++i) {
                     value[attrs[i].name] = attrs[i].nodeValue;
                 }

Modified: sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Format/WFST/v1.js
===================================================================
--- sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Format/WFST/v1.js	2011-02-21 15:12:33 UTC (rev 11190)
+++ sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Format/WFST/v1.js	2011-02-21 15:16:37 UTC (rev 11191)
@@ -182,7 +182,7 @@
         if(value) {
             this.setAttributeNS(
                 node, this.namespaces["xsi"], "xsi:schemaLocation",  value
-            )
+            );
         }
         return OpenLayers.Format.XML.prototype.write.apply(this, [node]);
     },

Modified: sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Handler/Drag.js
===================================================================
--- sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Handler/Drag.js	2011-02-21 15:12:33 UTC (rev 11190)
+++ sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Handler/Drag.js	2011-02-21 15:16:37 UTC (rev 11191)
@@ -32,11 +32,11 @@
   
     /** 
      * Property: started
-     * {Boolean} When a mousedown event is received, we want to record it, but
-     *     not set 'dragging' until the mouse moves after starting. 
+     * {Boolean} When a mousedown or touchstart event is received, we want to
+     * record it, but not set 'dragging' until the mouse moves after starting.
      */
     started: false,
-    
+
     /**
      * Property: stopDown
      * {Boolean} Stop propagation of mousedown events from getting to listeners
@@ -132,10 +132,123 @@
     },
     
     /**
+     * Method: dragstart
+     * This private method is factorized from mousedown and touchstart methods
+     *
+     * Parameters:
+     * evt - {Event} The event
+     *
+     * Returns:
+     * {Boolean} Let the event propagate.
+     */
+    dragstart: function (evt) {
+        var propagate = true;
+        this.dragging = false;
+        if (this.checkModifiers(evt) &&
+               (OpenLayers.Event.isLeftClick(evt) ||
+                OpenLayers.Event.isSingleTouch(evt))) {
+            this.started = true;
+            this.start = evt.xy;
+            this.last = evt.xy;
+            OpenLayers.Element.addClass(
+                this.map.viewPortDiv, "olDragDown"
+            );
+            this.down(evt);
+            this.callback("down", [evt.xy]);
+            OpenLayers.Event.stop(evt);
+
+            if(!this.oldOnselectstart) {
+                this.oldOnselectstart = document.onselectstart ?
+                    document.onselectstart : OpenLayers.Function.True;
+            }
+            document.onselectstart = OpenLayers.Function.False;
+
+            propagate = !this.stopDown;
+        } else {
+            this.started = false;
+            this.start = null;
+            this.last = null;
+        }
+        return propagate;
+    },
+
+    /**
+     * Method: dragmove
+     * This private method is factorized from mousemove and touchmove methods
+     *
+     * Parameters:
+     * evt - {Event} The event
+     *
+     * Returns:
+     * {Boolean} Let the event propagate.
+     */
+    dragmove: function (evt) {
+        if (this.started && !this.timeoutId && (evt.xy.x != this.last.x ||
+                                                evt.xy.y != this.last.y)) {
+            if(this.documentDrag === true && this.documentEvents) {
+                if(evt.element === document) {
+                    this.adjustXY(evt);
+                    // do setEvent manually because the documentEvents are not
+                    // registered with the map
+                    this.setEvent(evt);
+                } else {
+                    this.removeDocumentEvents();
+                }
+            }
+            if (this.interval > 0) {
+                this.timeoutId = setTimeout(
+                    OpenLayers.Function.bind(this.removeTimeout, this),
+                    this.interval);
+            }
+            this.dragging = true;
+            this.move(evt);
+            this.callback("move", [evt.xy]);
+            if(!this.oldOnselectstart) {
+                this.oldOnselectstart = document.onselectstart;
+                document.onselectstart = OpenLayers.Function.False;
+            }
+            this.last = this.evt.xy;
+        }
+        return true;
+    },
+
+    /**
+     * Method: dragend
+     * This private method is factorized from mouseup and touchend methods
+     *
+     * Parameters:
+     * evt - {Event} The event
+     *
+     * Returns:
+     * {Boolean} Let the event propagate.
+     */
+    dragend: function (evt) {
+        if (this.started) {
+            if(this.documentDrag === true && this.documentEvents) {
+                this.adjustXY(evt);
+                this.removeDocumentEvents();
+            }
+            var dragged = (this.start != this.last);
+            this.started = false;
+            this.dragging = false;
+            OpenLayers.Element.removeClass(
+                this.map.viewPortDiv, "olDragDown"
+            );
+            this.up(evt);
+            this.callback("up", [evt.xy]);
+            if(dragged) {
+                this.callback("done", [evt.xy]);
+            }
+            document.onselectstart = this.oldOnselectstart;
+        }
+        return true;
+    },
+
+    /**
      * The four methods below (down, move, up, and out) are used by subclasses
      *     to do their own processing related to these mouse events.
      */
-    
+
     /**
      * Method: down
      * This method is called during the handling of the mouse down event.
@@ -146,7 +259,7 @@
      */
     down: function(evt) {
     },
-    
+
     /**
      * Method: move
      * This method is called during the handling of the mouse move event.
@@ -192,77 +305,58 @@
      * Handle mousedown events
      *
      * Parameters:
-     * evt - {Event} 
+     * evt - {Event}
      *
      * Returns:
      * {Boolean} Let the event propagate.
      */
-    mousedown: function (evt) {
-        var propagate = true;
-        this.dragging = false;
-        if (this.checkModifiers(evt) && OpenLayers.Event.isLeftClick(evt)) {
-            this.started = true;
-            this.start = evt.xy;
-            this.last = evt.xy;
-            OpenLayers.Element.addClass(
-                this.map.viewPortDiv, "olDragDown"
-            );
-            this.down(evt);
-            this.callback("down", [evt.xy]);
-            OpenLayers.Event.stop(evt);
-            
-            if(!this.oldOnselectstart) {
-                this.oldOnselectstart = (document.onselectstart) ? document.onselectstart : OpenLayers.Function.True;
-            }
-            document.onselectstart = OpenLayers.Function.False;
-            
-            propagate = !this.stopDown;
-        } else {
-            this.started = false;
-            this.start = null;
-            this.last = null;
-        }
-        return propagate;
+    mousedown: function(evt) {
+        return this.dragstart(evt);
     },
 
     /**
+     * Method: touchstart
+     * Handle touchstart events
+     *
+     * Parameters:
+     * evt - {Event}
+     *
+     * Returns:
+     * {Boolean} Let the event propagate.
+     */
+    touchstart: function(evt) {
+        return this.dragstart(evt);
+    },
+
+    /**
      * Method: mousemove
      * Handle mousemove events
      *
      * Parameters:
-     * evt - {Event} 
+     * evt - {Event}
      *
      * Returns:
      * {Boolean} Let the event propagate.
      */
-    mousemove: function (evt) {
-        if (this.started && !this.timeoutId && (evt.xy.x != this.last.x || evt.xy.y != this.last.y)) {
-            if(this.documentDrag === true && this.documentEvents) {
-                if(evt.element === document) {
-                    this.adjustXY(evt);
-                    // do setEvent manually because the documentEvents are not
-                    // registered with the map
-                    this.setEvent(evt);
-                } else {
-                    this.removeDocumentEvents();
-                }
-            }
-            if (this.interval > 0) {
-                this.timeoutId = setTimeout(OpenLayers.Function.bind(this.removeTimeout, this), this.interval);
-            }
-            this.dragging = true;
-            this.move(evt);
-            this.callback("move", [evt.xy]);
-            if(!this.oldOnselectstart) {
-                this.oldOnselectstart = document.onselectstart;
-                document.onselectstart = OpenLayers.Function.False;
-            }
-            this.last = this.evt.xy;
-        }
-        return true;
+    mousemove: function(evt) {
+        return this.dragmove(evt);
     },
-    
+
     /**
+     * Method: touchmove
+     * Handle touchmove events
+     *
+     * Parameters:
+     * evt - {Event}
+     *
+     * Returns:
+     * {Boolean} Let the event propagate.
+     */
+    touchmove: function(evt) {
+        return this.dragmove(evt);
+    },
+
+    /**
      * Method: removeTimeout
      * Private. Called by mousemove() to remove the drag timeout.
      */
@@ -275,39 +369,38 @@
      * Handle mouseup events
      *
      * Parameters:
-     * evt - {Event} 
+     * evt - {Event}
      *
      * Returns:
      * {Boolean} Let the event propagate.
      */
-    mouseup: function (evt) {
-        if (this.started) {
-            if(this.documentDrag === true && this.documentEvents) {
-                this.adjustXY(evt);
-                this.removeDocumentEvents();
-            }
-            var dragged = (this.start != this.last);
-            this.started = false;
-            this.dragging = false;
-            OpenLayers.Element.removeClass(
-                this.map.viewPortDiv, "olDragDown"
-            );
-            this.up(evt);
-            this.callback("up", [evt.xy]);
-            if(dragged) {
-                this.callback("done", [evt.xy]);
-            }
-            document.onselectstart = this.oldOnselectstart;
-        }
-        return true;
+    mouseup: function(evt) {
+        return this.dragend(evt);
     },
 
     /**
+     * Method: touchend
+     * Handle touchend events
+     *
+     * Parameters:
+     * evt - {Event}
+     *
+     * Returns:
+     * {Boolean} Let the event propagate.
+     */
+    touchend: function(evt) {
+        // override evt.xy with last position since touchend does not have
+        // any touch position
+        evt.xy = this.last;
+        return this.dragend(evt);
+    },
+
+    /**
      * Method: mouseout
      * Handle mouseout events
      *
      * Parameters:
-     * evt - {Event} 
+     * evt - {Event}
      *
      * Returns:
      * {Boolean} Let the event propagate.

Modified: sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Layer/Bing.js
===================================================================
--- sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Layer/Bing.js	2011-02-21 15:12:33 UTC (rev 11190)
+++ sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Layer/Bing.js	2011-02-21 15:16:37 UTC (rev 11191)
@@ -79,7 +79,7 @@
         options = OpenLayers.Util.applyDefaults({
             restrictedMinZoom: 1,
             sphericalMercator: true
-        }, options)
+        }, options);
         var name = options.name || "Bing " + (options.type || this.type);
         
         var newArgs = [name, null, options];

Modified: sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Layer/Vector.js
===================================================================
--- sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Layer/Vector.js	2011-02-21 15:12:33 UTC (rev 11190)
+++ sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Layer/Vector.js	2011-02-21 15:16:37 UTC (rev 11191)
@@ -779,7 +779,7 @@
         // don't try to draw the feature with the renderer if the layer is not 
         // drawn itself
         if (!this.drawn) {
-            return
+            return;
         }
         if (typeof style != "object") {
             if(!style && feature.state === OpenLayers.State.DELETE) {

Modified: sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Layer/WMS.js
===================================================================
--- sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Layer/WMS.js	2011-02-21 15:12:33 UTC (rev 11190)
+++ sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Layer/WMS.js	2011-02-21 15:16:37 UTC (rev 11191)
@@ -256,7 +256,7 @@
         var projectionCode = this.projection.equals(mapProjection) ?
             this.projection.getCode() :
             mapProjection.getCode();
-        var value = (projectionCode == "none") ? null : projectionCode
+        var value = (projectionCode == "none") ? null : projectionCode;
         if (parseFloat(this.params.VERSION) >= 1.3) {
             this.params.CRS = value;
         } else {

Modified: sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Layer/Zoomify.js
===================================================================
--- sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Layer/Zoomify.js	2011-02-21 15:12:33 UTC (rev 11190)
+++ sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Layer/Zoomify.js	2011-02-21 15:16:37 UTC (rev 11191)
@@ -105,7 +105,7 @@
      */
     initializeZoomify: function( size ) {
 
-        var imageSize = size.clone()
+        var imageSize = size.clone();
         var tiles = new OpenLayers.Size(
             Math.ceil( imageSize.w / this.standardTileSize ),
             Math.ceil( imageSize.h / this.standardTileSize )
@@ -151,9 +151,9 @@
         OpenLayers.Layer.Grid.prototype.destroy.apply(this, arguments);
 
         // Remove from memory the Zoomify pyramid - is that enough?
-        this.tileCountUpToTier.length = 0
-        this.tierSizeInTiles.length = 0
-        this.tierImageSize.length = 0
+        this.tileCountUpToTier.length = 0;
+        this.tierSizeInTiles.length = 0;
+        this.tierImageSize.length = 0;
 
     },
 

Modified: sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Map.js
===================================================================
--- sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Map.js	2011-02-21 15:12:33 UTC (rev 11190)
+++ sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Map.js	2011-02-21 15:16:37 UTC (rev 11191)
@@ -1018,7 +1018,7 @@
         this.resetLayersZIndex();
 
         this.events.triggerEvent("removelayer", {layer: layer});
-        layer.events.triggerEvent("removed", {map: this, layer: layer})
+        layer.events.triggerEvent("removed", {map: this, layer: layer});
     },
 
     /**

Modified: sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Renderer/VML.js
===================================================================
--- sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Renderer/VML.js	2011-02-21 15:12:33 UTC (rev 11190)
+++ sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Renderer/VML.js	2011-02-21 15:16:37 UTC (rev 11191)
@@ -765,7 +765,7 @@
                 x = (comp.x / resolution - this.offset.x) | 0;
                 y = (comp.y / resolution - this.offset.y) | 0;
                 pathComp = " " + x + "," + y;
-                path.push(pathComp)
+                path.push(pathComp);
                 if (i==0) {
                     path.push(" l");
                 }

Modified: sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Tile/Image/IFrame.js
===================================================================
--- sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Tile/Image/IFrame.js	2011-02-21 15:12:33 UTC (rev 11190)
+++ sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Tile/Image/IFrame.js	2011-02-21 15:16:37 UTC (rev 11191)
@@ -42,7 +42,7 @@
                 delete iFrame;
             }
         } else {
-            OpenLayers.Tile.Image.prototype.clear.apply(this, arguments)
+            OpenLayers.Tile.Image.prototype.clear.apply(this, arguments);
         }
     },
 
@@ -221,4 +221,5 @@
 
         return form;
     }
-}
+};
+

Modified: sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Util.js
===================================================================
--- sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Util.js	2011-02-21 15:12:33 UTC (rev 11190)
+++ sandbox/bartvde/sencha/openlayers/lib/OpenLayers/Util.js	2011-02-21 15:16:37 UTC (rev 11191)
@@ -1038,7 +1038,7 @@
             }
             
             // follow OGC convention of comma delimited values
-            value = value.split(",")
+            value = value.split(",");
 
             //if there's only one value, do not return as array                    
             if (value.length == 1) {
@@ -1839,7 +1839,7 @@
     if (!dmsOption) {
         dmsOption = 'dms';    //default to show degree, minutes, seconds
     }
-    var abscoordinate = Math.abs(coordinate)
+    var abscoordinate = Math.abs(coordinate);
     var coordinatedegrees = Math.floor(abscoordinate);
 
     var coordinateminutes = (abscoordinate - coordinatedegrees)/(1/60);

Modified: sandbox/bartvde/sencha/openlayers/tests/Handler/Drag.html
===================================================================
--- sandbox/bartvde/sencha/openlayers/tests/Handler/Drag.html	2011-02-21 15:12:33 UTC (rev 11190)
+++ sandbox/bartvde/sencha/openlayers/tests/Handler/Drag.html	2011-02-21 15:16:37 UTC (rev 11191)
@@ -45,7 +45,7 @@
     }
     
     function test_Handler_Drag_events(t) {
-        t.plan(25);
+        t.plan(40);
         
         var map = new OpenLayers.Map('map');
         var control = new OpenLayers.Control();
@@ -54,7 +54,8 @@
 
         // list below events that should be handled (events) and those
         // that should not be handled (nonevents) by the handler
-        var events = ["mousedown", "mouseup", "mousemove", "mouseout", "click"];
+        var events = ["mousedown", "mouseup", "mousemove", "mouseout", "click",
+                      "touchstart", "touchmove", "touchend"];
         var nonevents = ["dblclick", "resize", "focus", "blur"];
         map.events.registerPriority = function(type, obj, func) {
             var r = func();



More information about the Commits mailing list