diff --git a/PanoramicView/OpenLayers.js b/PanoramicView/OpenLayers.js
new file mode 100644
index 0000000000000000000000000000000000000000..7f880d55c2ef03d70ba87a6d8c69e37bc1c24e11
--- /dev/null
+++ b/PanoramicView/OpenLayers.js
@@ -0,0 +1,26176 @@
+
+var OpenLayers = {
+    VERSION_NUMBER: "Release 2.12",
+    singleFile: !0,
+    _getScriptLocation: function() {
+        for (var a = /(^|(.*?\/))(OpenLayers[^\/]*?\.js)(\?|$)/, b = document.getElementsByTagName("script"), c, d = "", e = 0, f = b.length; e < f; e++)
+            if (c = b[e].getAttribute("src"))
+                if (c = c.match(a)) {
+                    d = c[1];
+                    break
+                }
+        return function() {
+            return d
+        }
+    }(),
+    ImgPath: ""
+};
+OpenLayers.Class = function() {
+    var a = arguments.length,
+        b = arguments[0],
+        c = arguments[a - 1],
+        d = "function" == typeof c.initialize ? c.initialize : function() {
+            b.prototype.initialize.apply(this, arguments)
+        };
+    1 < a ? (a = [d, b].concat(Array.prototype.slice.call(arguments).slice(1, a - 1), c), OpenLayers.inherit.apply(null, a)) : d.prototype = c;
+    return d
+};
+OpenLayers.inherit = function(a, b) {
+    var c = function() {};
+    c.prototype = b.prototype;
+    a.prototype = new c;
+    var d, e, c = 2;
+    for (d = arguments.length; c < d; c++) e = arguments[c], "function" === typeof e && (e = e.prototype), OpenLayers.Util.extend(a.prototype, e)
+};
+OpenLayers.Util = OpenLayers.Util || {};
+OpenLayers.Util.extend = function(a, b) {
+    a = a || {};
+    if (b) {
+        for (var c in b) {
+            var d = b[c];
+            void 0 !== d && (a[c] = d)
+        }!("function" == typeof window.Event && b instanceof window.Event) && (b.hasOwnProperty && b.hasOwnProperty("toString")) && (a.toString = b.toString)
+    }
+    return a
+};
+OpenLayers.String = {
+    startsWith: function(a, b) {
+        return 0 == a.indexOf(b)
+    },
+    contains: function(a, b) {
+        return -1 != a.indexOf(b)
+    },
+    trim: function(a) {
+        return a.replace(/^\s\s*/, "").replace(/\s\s*$/, "")
+    },
+    camelize: function(a) {
+        for (var a = a.split("-"), b = a[0], c = 1, d = a.length; c < d; c++) var e = a[c],
+            b = b + (e.charAt(0).toUpperCase() + e.substring(1));
+        return b
+    },
+    format: function(a, b, c) {
+        b || (b = window);
+        return a.replace(OpenLayers.String.tokenRegEx, function(a, e) {
+            for (var f, g = e.split(/\.+/), h = 0; h < g.length; h++) 0 == h && (f = b), f = f[g[h]];
+            "function" ==
+            typeof f && (f = c ? f.apply(null, c) : f());
+            return "undefined" == typeof f ? "undefined" : f
+        })
+    },
+    tokenRegEx: /\$\{([\w.]+?)\}/g,
+    numberRegEx: /^([+-]?)(?=\d|\.\d)\d*(\.\d*)?([Ee]([+-]?\d+))?$/,
+    isNumeric: function(a) {
+        return OpenLayers.String.numberRegEx.test(a)
+    },
+    numericIf: function(a) {
+        return OpenLayers.String.isNumeric(a) ? parseFloat(a) : a
+    }
+};
+OpenLayers.Number = {
+    decimalSeparator: ".",
+    thousandsSeparator: ",",
+    limitSigDigs: function(a, b) {
+        var c = 0;
+        0 < b && (c = parseFloat(a.toPrecision(b)));
+        return c
+    },
+    format: function(a, b, c, d) {
+        b = "undefined" != typeof b ? b : 0;
+        c = "undefined" != typeof c ? c : OpenLayers.Number.thousandsSeparator;
+        d = "undefined" != typeof d ? d : OpenLayers.Number.decimalSeparator;
+        null != b && (a = parseFloat(a.toFixed(b)));
+        var e = a.toString().split(".");
+        1 == e.length && null == b && (b = 0);
+        a = e[0];
+        if (c)
+            for (var f = /(-?[0-9]+)([0-9]{3})/; f.test(a);) a = a.replace(f, "$1" + c + "$2");
+        0 == b ? b = a : (c = 1 < e.length ? e[1] : "0", null != b && (c += Array(b - c.length + 1).join("0")), b = a + d + c);
+        return b
+    }
+};
+OpenLayers.Function = {
+    bind: function(a, b) {
+        var c = Array.prototype.slice.apply(arguments, [2]);
+        return function() {
+            var d = c.concat(Array.prototype.slice.apply(arguments, [0]));
+            return a.apply(b, d)
+        }
+    },
+    bindAsEventListener: function(a, b) {
+        return function(c) {
+            return a.call(b, c || window.event)
+        }
+    },
+    False: function() {
+        return !1
+    },
+    True: function() {
+        return !0
+    },
+    Void: function() {}
+};
+OpenLayers.Array = {
+    filter: function(a, b, c) {
+        var d = [];
+        if (Array.prototype.filter) d = a.filter(b, c);
+        else {
+            var e = a.length;
+            if ("function" != typeof b) throw new TypeError;
+            for (var f = 0; f < e; f++)
+                if (f in a) {
+                    var g = a[f];
+                    b.call(c, g, f, a) && d.push(g)
+                }
+        }
+        return d
+    }
+};
+OpenLayers.Bounds = OpenLayers.Class({
+    left: null,
+    bottom: null,
+    right: null,
+    top: null,
+    centerLonLat: null,
+    initialize: function(a, b, c, d) {
+        OpenLayers.Util.isArray(a) && (d = a[3], c = a[2], b = a[1], a = a[0]);
+        null != a && (this.left = OpenLayers.Util.toFloat(a));
+        null != b && (this.bottom = OpenLayers.Util.toFloat(b));
+        null != c && (this.right = OpenLayers.Util.toFloat(c));
+        null != d && (this.top = OpenLayers.Util.toFloat(d))
+    },
+    clone: function() {
+        return new OpenLayers.Bounds(this.left, this.bottom, this.right, this.top)
+    },
+    equals: function(a) {
+        var b = !1;
+        null !=
+            a && (b = this.left == a.left && this.right == a.right && this.top == a.top && this.bottom == a.bottom);
+        return b
+    },
+    toString: function() {
+        return [this.left, this.bottom, this.right, this.top].join()
+    },
+    toArray: function(a) {
+        return !0 === a ? [this.bottom, this.left, this.top, this.right] : [this.left, this.bottom, this.right, this.top]
+    },
+    toBBOX: function(a, b) {
+        null == a && (a = 6);
+        var c = Math.pow(10, a),
+            d = Math.round(this.left * c) / c,
+            e = Math.round(this.bottom * c) / c,
+            f = Math.round(this.right * c) / c,
+            c = Math.round(this.top * c) / c;
+        return !0 === b ? e + "," + d + "," + c + "," + f : d +
+            "," + e + "," + f + "," + c
+    },
+    toGeometry: function() {
+        return new OpenLayers.Geometry.Polygon([new OpenLayers.Geometry.LinearRing([new OpenLayers.Geometry.Point(this.left, this.bottom), new OpenLayers.Geometry.Point(this.right, this.bottom), new OpenLayers.Geometry.Point(this.right, this.top), new OpenLayers.Geometry.Point(this.left, this.top)])])
+    },
+    getWidth: function() {
+        return this.right - this.left
+    },
+    getHeight: function() {
+        return this.top - this.bottom
+    },
+    getSize: function() {
+        return new OpenLayers.Size(this.getWidth(), this.getHeight())
+    },
+    getCenterPixel: function() {
+        return new OpenLayers.Pixel((this.left + this.right) / 2, (this.bottom + this.top) / 2)
+    },
+    getCenterLonLat: function() {
+        this.centerLonLat || (this.centerLonLat = new OpenLayers.LonLat((this.left + this.right) / 2, (this.bottom + this.top) / 2));
+        return this.centerLonLat
+    },
+    scale: function(a, b) {
+        null == b && (b = this.getCenterLonLat());
+        var c, d;
+        "OpenLayers.LonLat" == b.CLASS_NAME ? (c = b.lon, d = b.lat) : (c = b.x, d = b.y);
+        return new OpenLayers.Bounds((this.left - c) * a + c, (this.bottom - d) * a + d, (this.right - c) * a + c, (this.top - d) * a +
+            d)
+    },
+    add: function(a, b) {
+        if (null == a || null == b) throw new TypeError("Bounds.add cannot receive null values");
+        return new OpenLayers.Bounds(this.left + a, this.bottom + b, this.right + a, this.top + b)
+    },
+    extend: function(a) {
+        var b = null;
+        if (a) {
+            switch (a.CLASS_NAME) {
+                case "OpenLayers.LonLat":
+                    b = new OpenLayers.Bounds(a.lon, a.lat, a.lon, a.lat);
+                    break;
+                case "OpenLayers.Geometry.Point":
+                    b = new OpenLayers.Bounds(a.x, a.y, a.x, a.y);
+                    break;
+                case "OpenLayers.Bounds":
+                    b = a
+            }
+            if (b) {
+                this.centerLonLat = null;
+                if (null == this.left || b.left < this.left) this.left =
+                    b.left;
+                if (null == this.bottom || b.bottom < this.bottom) this.bottom = b.bottom;
+                if (null == this.right || b.right > this.right) this.right = b.right;
+                if (null == this.top || b.top > this.top) this.top = b.top
+            }
+        }
+    },
+    containsLonLat: function(a, b) {
+        "boolean" === typeof b && (b = {
+            inclusive: b
+        });
+        var b = b || {},
+            c = this.contains(a.lon, a.lat, b.inclusive),
+            d = b.worldBounds;
+        d && !c && (c = d.getWidth(), d = Math.round((a.lon - (d.left + d.right) / 2) / c), c = this.containsLonLat({
+            lon: a.lon - d * c,
+            lat: a.lat
+        }, {
+            inclusive: b.inclusive
+        }));
+        return c
+    },
+    containsPixel: function(a, b) {
+        return this.contains(a.x,
+            a.y, b)
+    },
+    contains: function(a, b, c) {
+        null == c && (c = !0);
+        if (null == a || null == b) return !1;
+        var a = OpenLayers.Util.toFloat(a),
+            b = OpenLayers.Util.toFloat(b),
+            d = !1;
+        return d = c ? a >= this.left && a <= this.right && b >= this.bottom && b <= this.top : a > this.left && a < this.right && b > this.bottom && b < this.top
+    },
+    intersectsBounds: function(a, b) {
+        "boolean" === typeof b && (b = {
+            inclusive: b
+        });
+        b = b || {};
+        if (b.worldBounds) var c = this.wrapDateLine(b.worldBounds),
+            a = a.wrapDateLine(b.worldBounds);
+        else c = this;
+        null == b.inclusive && (b.inclusive = !0);
+        var d = !1,
+            e = c.left ==
+            a.right || c.right == a.left || c.top == a.bottom || c.bottom == a.top;
+        if (b.inclusive || !e) var d = a.top >= c.bottom && a.top <= c.top || c.top > a.bottom && c.top < a.top,
+            e = a.left >= c.left && a.left <= c.right || c.left >= a.left && c.left <= a.right,
+            f = a.right >= c.left && a.right <= c.right || c.right >= a.left && c.right <= a.right,
+            d = (a.bottom >= c.bottom && a.bottom <= c.top || c.bottom >= a.bottom && c.bottom <= a.top || d) && (e || f);
+        if (b.worldBounds && !d) {
+            var g = b.worldBounds,
+                e = g.getWidth(),
+                f = !g.containsBounds(c),
+                g = !g.containsBounds(a);
+            f && !g ? (a = a.add(-e, 0), d = c.intersectsBounds(a, {
+                inclusive: b.inclusive
+            })) : g && !f && (c = c.add(-e, 0), d = a.intersectsBounds(c, {
+                inclusive: b.inclusive
+            }))
+        }
+        return d
+    },
+    containsBounds: function(a, b, c) {
+        null == b && (b = !1);
+        null == c && (c = !0);
+        var d = this.contains(a.left, a.bottom, c),
+            e = this.contains(a.right, a.bottom, c),
+            f = this.contains(a.left, a.top, c),
+            a = this.contains(a.right, a.top, c);
+        return b ? d || e || f || a : d && e && f && a
+    },
+    determineQuadrant: function(a) {
+        var b = "",
+            c = this.getCenterLonLat(),
+            b = b + (a.lat < c.lat ? "b" : "t");
+        return b += a.lon < c.lon ? "l" : "r"
+    },
+    transform: function(a, b) {
+        this.centerLonLat =
+            null;
+        var c = OpenLayers.Projection.transform({
+                x: this.left,
+                y: this.bottom
+            }, a, b),
+            d = OpenLayers.Projection.transform({
+                x: this.right,
+                y: this.bottom
+            }, a, b),
+            e = OpenLayers.Projection.transform({
+                x: this.left,
+                y: this.top
+            }, a, b),
+            f = OpenLayers.Projection.transform({
+                x: this.right,
+                y: this.top
+            }, a, b);
+        this.left = Math.min(c.x, e.x);
+        this.bottom = Math.min(c.y, d.y);
+        this.right = Math.max(d.x, f.x);
+        this.top = Math.max(e.y, f.y);
+        return this
+    },
+    wrapDateLine: function(a, b) {
+        var b = b || {},
+            c = b.leftTolerance || 0,
+            d = b.rightTolerance || 0,
+            e = this.clone();
+        if (a) {
+            for (var f =
+                    a.getWidth(); e.left < a.left && e.right - d <= a.left;) e = e.add(f, 0);
+            for (; e.left + c >= a.right && e.right > a.right;) e = e.add(-f, 0);
+            c = e.left + c;
+            c < a.right && (c > a.left && e.right - d > a.right) && (e = e.add(-f, 0))
+        }
+        return e
+    },
+    CLASS_NAME: "OpenLayers.Bounds"
+});
+OpenLayers.Bounds.fromString = function(a, b) {
+    var c = a.split(",");
+    return OpenLayers.Bounds.fromArray(c, b)
+};
+OpenLayers.Bounds.fromArray = function(a, b) {
+    return !0 === b ? new OpenLayers.Bounds(a[1], a[0], a[3], a[2]) : new OpenLayers.Bounds(a[0], a[1], a[2], a[3])
+};
+OpenLayers.Bounds.fromSize = function(a) {
+    return new OpenLayers.Bounds(0, a.h, a.w, 0)
+};
+OpenLayers.Bounds.oppositeQuadrant = function(a) {
+    var b;
+    b = "" + ("t" == a.charAt(0) ? "b" : "t");
+    return b += "l" == a.charAt(1) ? "r" : "l"
+};
+OpenLayers.Element = {
+    visible: function(a) {
+        return "none" != OpenLayers.Util.getElement(a).style.display
+    },
+    toggle: function() {
+        for (var a = 0, b = arguments.length; a < b; a++) {
+            var c = OpenLayers.Util.getElement(arguments[a]),
+                d = OpenLayers.Element.visible(c) ? "none" : "";
+            c.style.display = d
+        }
+    },
+    remove: function(a) {
+        a = OpenLayers.Util.getElement(a);
+        a.parentNode.removeChild(a)
+    },
+    getHeight: function(a) {
+        a = OpenLayers.Util.getElement(a);
+        return a.offsetHeight
+    },
+    hasClass: function(a, b) {
+        var c = a.className;
+        return !!c && RegExp("(^|\\s)" + b + "(\\s|$)").test(c)
+    },
+    addClass: function(a, b) {
+        OpenLayers.Element.hasClass(a, b) || (a.className += (a.className ? " " : "") + b);
+        return a
+    },
+    removeClass: function(a, b) {
+        var c = a.className;
+        c && (a.className = OpenLayers.String.trim(c.replace(RegExp("(^|\\s+)" + b + "(\\s+|$)"), " ")));
+        return a
+    },
+    toggleClass: function(a, b) {
+        OpenLayers.Element.hasClass(a, b) ? OpenLayers.Element.removeClass(a, b) : OpenLayers.Element.addClass(a, b);
+        return a
+    },
+    getStyle: function(a, b) {
+        var a = OpenLayers.Util.getElement(a),
+            c = null;
+        if (a && a.style) {
+            c = a.style[OpenLayers.String.camelize(b)];
+            c || (document.defaultView && document.defaultView.getComputedStyle ? c = (c = document.defaultView.getComputedStyle(a, null)) ? c.getPropertyValue(b) : null : a.currentStyle && (c = a.currentStyle[OpenLayers.String.camelize(b)]));
+            var d = ["left", "top", "right", "bottom"];
+            window.opera && (-1 != OpenLayers.Util.indexOf(d, b) && "static" == OpenLayers.Element.getStyle(a, "position")) && (c = "auto")
+        }
+        return "auto" == c ? null : c
+    }
+};
+OpenLayers.LonLat = OpenLayers.Class({
+//MOD ASTRO
+ori_lon:67.6027,
+ori_lat:2.22813,
+    lon: 0,
+    lat: 0,
+    initialize: function(a, b) {
+        OpenLayers.Util.isArray(a) && (b = a[1], a = a[0]);
+        this.lon = OpenLayers.Util.toFloat(a);//+this.ori_lon;
+        this.lat = OpenLayers.Util.toFloat(b);//+this.ori_lat
+    },
+    toString: function() {
+        return "lon=" + this.lon + ",lat=" + this.lat
+    },
+    toShortString: function() {
+        return this.lon + ", " + this.lat
+    },
+    clone: function() {
+        return new OpenLayers.LonLat(this.lon, this.lat)
+    },
+    add: function(a, b) {
+        if (null == a || null == b) throw new TypeError("LonLat.add cannot receive null values");
+        return new OpenLayers.LonLat(this.lon +
+            OpenLayers.Util.toFloat(a), this.lat + OpenLayers.Util.toFloat(b))
+    },
+    equals: function(a) {
+        var b = !1;
+        null != a && (b = this.lon == a.lon && this.lat == a.lat || isNaN(this.lon) && isNaN(this.lat) && isNaN(a.lon) && isNaN(a.lat));
+        return b
+    },
+    transform: function(a, b) {
+        var c = OpenLayers.Projection.transform({
+            x: this.lon,
+            y: this.lat
+        }, a, b);
+        this.lon = c.x;
+        this.lat = c.y;
+        return this
+    },
+    wrapDateLine: function(a) {
+        var b = this.clone();
+        if (a) {
+            for (; b.lon < a.left;) b.lon += a.getWidth();
+            for (; b.lon > a.right;) b.lon -= a.getWidth()
+        }
+        return b
+    },
+    CLASS_NAME: "OpenLayers.LonLat"
+});
+OpenLayers.LonLat.fromString = function(a) {
+    a = a.split(",");
+    return new OpenLayers.LonLat(a[0], a[1])
+};
+OpenLayers.LonLat.fromArray = function(a) {
+    var b = OpenLayers.Util.isArray(a);
+    return new OpenLayers.LonLat(b && a[0], b && a[1])
+};
+OpenLayers.Pixel = OpenLayers.Class({
+    x: 0,
+    y: 0,
+    initialize: function(a, b) {
+        this.x = parseFloat(a);
+        this.y = parseFloat(b)
+    },
+    toString: function() {
+        return "x=" + this.x + ",y=" + this.y
+    },
+    clone: function() {
+        return new OpenLayers.Pixel(this.x, this.y)
+    },
+    equals: function(a) {
+        var b = !1;
+        null != a && (b = this.x == a.x && this.y == a.y || isNaN(this.x) && isNaN(this.y) && isNaN(a.x) && isNaN(a.y));
+        return b
+    },
+    distanceTo: function(a) {
+        return Math.sqrt(Math.pow(this.x - a.x, 2) + Math.pow(this.y - a.y, 2))
+    },
+    add: function(a, b) {
+        if (null == a || null == b) throw new TypeError("Pixel.add cannot receive null values");
+        return new OpenLayers.Pixel(this.x + a, this.y + b)
+    },
+    offset: function(a) {
+        var b = this.clone();
+        a && (b = this.add(a.x, a.y));
+        return b
+    },
+    CLASS_NAME: "OpenLayers.Pixel"
+});
+OpenLayers.Size = OpenLayers.Class({
+    w: 0,
+    h: 0,
+    initialize: function(a, b) {
+        this.w = parseFloat(a);
+        this.h = parseFloat(b)
+    },
+    toString: function() {
+        return "w=" + this.w + ",h=" + this.h
+    },
+    clone: function() {
+        return new OpenLayers.Size(this.w, this.h)
+    },
+    equals: function(a) {
+        var b = !1;
+        null != a && (b = this.w == a.w && this.h == a.h || isNaN(this.w) && isNaN(this.h) && isNaN(a.w) && isNaN(a.h));
+        return b
+    },
+    CLASS_NAME: "OpenLayers.Size"
+});
+OpenLayers.Console = {
+    log: function() {},
+    debug: function() {},
+    info: function() {},
+    warn: function() {},
+    error: function() {},
+    userError: function(a) {
+        alert(a)
+    },
+    assert: function() {},
+    dir: function() {},
+    dirxml: function() {},
+    trace: function() {},
+    group: function() {},
+    groupEnd: function() {},
+    time: function() {},
+    timeEnd: function() {},
+    profile: function() {},
+    profileEnd: function() {},
+    count: function() {},
+    CLASS_NAME: "OpenLayers.Console"
+};
+(function() {
+    for (var a = document.getElementsByTagName("script"), b = 0, c = a.length; b < c; ++b)
+        if (-1 != a[b].src.indexOf("firebug.js") && console) {
+            OpenLayers.Util.extend(OpenLayers.Console, console);
+            break
+        }
+})();
+OpenLayers.Lang = {
+    code: null,
+    defaultCode: "en",
+    getCode: function() {
+        OpenLayers.Lang.code || OpenLayers.Lang.setCode();
+        return OpenLayers.Lang.code
+    },
+    setCode: function(a) {
+        var b;
+        a || (a = "msie" == OpenLayers.BROWSER_NAME ? navigator.userLanguage : navigator.language);
+        a = a.split("-");
+        a[0] = a[0].toLowerCase();
+        "object" == typeof OpenLayers.Lang[a[0]] && (b = a[0]);
+        if (a[1]) {
+            var c = a[0] + "-" + a[1].toUpperCase();
+            "object" == typeof OpenLayers.Lang[c] && (b = c)
+        }
+        b || (OpenLayers.Console.warn("Failed to find OpenLayers.Lang." + a.join("-") + " dictionary, falling back to default language"),
+            b = OpenLayers.Lang.defaultCode);
+        OpenLayers.Lang.code = b
+    },
+    translate: function(a, b) {
+        var c = OpenLayers.Lang[OpenLayers.Lang.getCode()];
+        (c = c && c[a]) || (c = a);
+        b && (c = OpenLayers.String.format(c, b));
+        return c
+    }
+};
+OpenLayers.i18n = OpenLayers.Lang.translate;
+OpenLayers.Util = OpenLayers.Util || {};
+OpenLayers.Util.getElement = function() {
+    for (var a = [], b = 0, c = arguments.length; b < c; b++) {
+        var d = arguments[b];
+        "string" == typeof d && (d = document.getElementById(d));
+        if (1 == arguments.length) return d;
+        a.push(d)
+    }
+    return a
+};
+OpenLayers.Util.isElement = function(a) {
+    return !!(a && 1 === a.nodeType)
+};
+OpenLayers.Util.isArray = function(a) {
+    return "[object Array]" === Object.prototype.toString.call(a)
+};
+"undefined" === typeof window.$ && (window.$ = OpenLayers.Util.getElement);
+OpenLayers.Util.removeItem = function(a, b) {
+    for (var c = a.length - 1; c >= 0; c--) a[c] == b && a.splice(c, 1);
+    return a
+};
+OpenLayers.Util.indexOf = function(a, b) {
+    if (typeof a.indexOf == "function") return a.indexOf(b);
+    for (var c = 0, d = a.length; c < d; c++)
+        if (a[c] == b) return c;
+    return -1
+};
+OpenLayers.Util.modifyDOMElement = function(a, b, c, d, e, f, g, h) {
+    if (b) a.id = b;
+    if (c) {
+        a.style.left = c.x + "px";
+        a.style.top = c.y + "px"
+    }
+    if (d) {
+        a.style.width = d.w + "px";
+        a.style.height = d.h + "px"
+    }
+    if (e) a.style.position = e;
+    if (f) a.style.border = f;
+    if (g) a.style.overflow = g;
+    if (parseFloat(h) >= 0 && parseFloat(h) < 1) {
+        a.style.filter = "alpha(opacity=" + h * 100 + ")";
+        a.style.opacity = h
+    } else if (parseFloat(h) == 1) {
+        a.style.filter = "";
+        a.style.opacity = ""
+    }
+};
+OpenLayers.Util.createDiv = function(a, b, c, d, e, f, g, h) {
+    var i = document.createElement("div");
+    if (d) i.style.backgroundImage = "url(" + d + ")";
+    a || (a = OpenLayers.Util.createUniqueID("OpenLayersDiv"));
+    e || (e = "absolute");
+    OpenLayers.Util.modifyDOMElement(i, a, b, c, e, f, g, h);
+    return i
+};
+OpenLayers.Util.createImage = function(a, b, c, d, e, f, g, h) {
+    var i = document.createElement("img");
+    a || (a = OpenLayers.Util.createUniqueID("OpenLayersDiv"));
+    e || (e = "relative");
+    OpenLayers.Util.modifyDOMElement(i, a, b, c, e, f, null, g);
+    if (h) {
+        i.style.display = "none";
+        b = function() {
+            i.style.display = "";
+            OpenLayers.Event.stopObservingElement(i)
+        };
+        OpenLayers.Event.observe(i, "load", b);
+        OpenLayers.Event.observe(i, "error", b)
+    }
+    i.style.alt = a;
+    i.galleryImg = "no";
+    if (d) i.src = d;
+    return i
+};
+OpenLayers.IMAGE_RELOAD_ATTEMPTS = 0;
+OpenLayers.Util.alphaHackNeeded = null;
+OpenLayers.Util.alphaHack = function() {
+    if (OpenLayers.Util.alphaHackNeeded == null) {
+        var a = navigator.appVersion.split("MSIE"),
+            a = parseFloat(a[1]),
+            b = false;
+        try {
+            b = !!document.body.filters
+        } catch (c) {}
+        OpenLayers.Util.alphaHackNeeded = b && a >= 5.5 && a < 7
+    }
+    return OpenLayers.Util.alphaHackNeeded
+};
+OpenLayers.Util.modifyAlphaImageDiv = function(a, b, c, d, e, f, g, h, i) {
+    OpenLayers.Util.modifyDOMElement(a, b, c, d, f, null, null, i);
+    b = a.childNodes[0];
+    if (e) b.src = e;
+    OpenLayers.Util.modifyDOMElement(b, a.id + "_innerImage", null, d, "relative", g);
+    if (OpenLayers.Util.alphaHack()) {
+        if (a.style.display != "none") a.style.display = "inline-block";
+        h == null && (h = "scale");
+        a.style.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(src='" + b.src + "', sizingMethod='" + h + "')";
+        if (parseFloat(a.style.opacity) >= 0 && parseFloat(a.style.opacity) <
+            1) a.style.filter = a.style.filter + (" alpha(opacity=" + a.style.opacity * 100 + ")");
+        b.style.filter = "alpha(opacity=0)"
+    }
+};
+OpenLayers.Util.createAlphaImageDiv = function(a, b, c, d, e, f, g, h, i) {
+    var j = OpenLayers.Util.createDiv(),
+        i = OpenLayers.Util.createImage(null, null, null, null, null, null, null, i);
+    i.className = "olAlphaImg";
+    j.appendChild(i);
+    OpenLayers.Util.modifyAlphaImageDiv(j, a, b, c, d, e, f, g, h);
+    return j
+};
+OpenLayers.Util.upperCaseObject = function(a) {
+    var b = {},
+        c;
+    for (c in a) b[c.toUpperCase()] = a[c];
+    return b
+};
+OpenLayers.Util.applyDefaults = function(a, b) {
+    var a = a || {},
+        c = typeof window.Event == "function" && b instanceof window.Event,
+        d;
+    for (d in b)
+        if (a[d] === void 0 || !c && b.hasOwnProperty && b.hasOwnProperty(d) && !a.hasOwnProperty(d)) a[d] = b[d];
+    if (!c && b && b.hasOwnProperty && b.hasOwnProperty("toString") && !a.hasOwnProperty("toString")) a.toString = b.toString;
+    return a
+};
+OpenLayers.Util.getParameterString = function(a) {
+    var b = [],
+        c;
+    for (c in a) {
+        var d = a[c];
+        if (d != null && typeof d != "function") {
+            if (typeof d == "object" && d.constructor == Array) {
+                for (var e = [], f, g = 0, h = d.length; g < h; g++) {
+                    f = d[g];
+                    e.push(encodeURIComponent(f === null || f === void 0 ? "" : f))
+                }
+                d = e.join(",")
+            } else d = encodeURIComponent(d);
+            b.push(encodeURIComponent(c) + "=" + d)
+        }
+    }
+    return b.join("&")
+};
+OpenLayers.Util.urlAppend = function(a, b) {
+    var c = a;
+    if (b) var d = (a + " ").split(/[?&]/),
+        c = c + (d.pop() === " " ? b : d.length ? "&" + b : "?" + b);
+    return c
+};
+OpenLayers.Util.getImagesLocation = function() {
+    return OpenLayers.ImgPath || OpenLayers._getScriptLocation() + "img/"
+};
+OpenLayers.Util.getImageLocation = function(a) {
+    return OpenLayers.Util.getImagesLocation() + a
+};
+OpenLayers.Util.Try = function() {
+    for (var a = null, b = 0, c = arguments.length; b < c; b++) {
+        var d = arguments[b];
+        try {
+            a = d();
+            break
+        } catch (e) {}
+    }
+    return a
+};
+OpenLayers.Util.getXmlNodeValue = function(a) {
+    var b = null;
+    OpenLayers.Util.Try(function() {
+        b = a.text;
+        if (!b) b = a.textContent;
+        if (!b) b = a.firstChild.nodeValue
+    }, function() {
+        b = a.textContent
+    });
+    return b
+};
+OpenLayers.Util.mouseLeft = function(a, b) {
+    for (var c = a.relatedTarget ? a.relatedTarget : a.toElement; c != b && c != null;) c = c.parentNode;
+    return c != b
+};
+OpenLayers.Util.DEFAULT_PRECISION = 14;
+OpenLayers.Util.toFloat = function(a, b) {
+    if (b == null) b = OpenLayers.Util.DEFAULT_PRECISION;
+    typeof a !== "number" && (a = parseFloat(a));
+    return b === 0 ? a : parseFloat(a.toPrecision(b))
+};
+OpenLayers.Util.rad = function(a) {
+    return a * Math.PI / 180
+};
+OpenLayers.Util.deg = function(a) {
+    return a * 180 / Math.PI
+};
+OpenLayers.Util.VincentyConstants = {
+    a: 6378137,
+    b: 6356752.3142,
+    f: 1 / 298.257223563
+};
+OpenLayers.Util.distVincenty = function(a, b) {
+    for (var c = OpenLayers.Util.VincentyConstants, d = c.a, e = c.b, c = c.f, f = OpenLayers.Util.rad(b.lon - a.lon), g = Math.atan((1 - c) * Math.tan(OpenLayers.Util.rad(a.lat))), h = Math.atan((1 - c) * Math.tan(OpenLayers.Util.rad(b.lat))), i = Math.sin(g), g = Math.cos(g), j = Math.sin(h), h = Math.cos(h), k = f, l = 2 * Math.PI, m = 20; Math.abs(k - l) > 1.0E-12 && --m > 0;) {
+        var n = Math.sin(k),
+            o = Math.cos(k),
+            p = Math.sqrt(h * n * h * n + (g * j - i * h * o) * (g * j - i * h * o));
+        if (p == 0) return 0;
+        var o = i * j + g * h * o,
+            q = Math.atan2(p, o),
+            r = Math.asin(g *
+                h * n / p),
+            s = Math.cos(r) * Math.cos(r),
+            n = o - 2 * i * j / s,
+            t = c / 16 * s * (4 + c * (4 - 3 * s)),
+            l = k,
+            k = f + (1 - t) * c * Math.sin(r) * (q + t * p * (n + t * o * (-1 + 2 * n * n)))
+    }
+    if (m == 0) return NaN;
+    d = s * (d * d - e * e) / (e * e);
+    c = d / 1024 * (256 + d * (-128 + d * (74 - 47 * d)));
+    return (e * (1 + d / 16384 * (4096 + d * (-768 + d * (320 - 175 * d)))) * (q - c * p * (n + c / 4 * (o * (-1 + 2 * n * n) - c / 6 * n * (-3 + 4 * p * p) * (-3 + 4 * n * n))))).toFixed(3) / 1E3
+};
+OpenLayers.Util.destinationVincenty = function(a, b, c) {
+    for (var d = OpenLayers.Util, e = d.VincentyConstants, f = e.a, g = e.b, h = e.f, e = a.lon, a = a.lat, i = d.rad(b), b = Math.sin(i), i = Math.cos(i), a = (1 - h) * Math.tan(d.rad(a)), j = 1 / Math.sqrt(1 + a * a), k = a * j, l = Math.atan2(a, i), a = j * b, m = 1 - a * a, f = m * (f * f - g * g) / (g * g), n = 1 + f / 16384 * (4096 + f * (-768 + f * (320 - 175 * f))), o = f / 1024 * (256 + f * (-128 + f * (74 - 47 * f))), f = c / (g * n), p = 2 * Math.PI; Math.abs(f - p) > 1.0E-12;) var q = Math.cos(2 * l + f),
+        r = Math.sin(f),
+        s = Math.cos(f),
+        t = o * r * (q + o / 4 * (s * (-1 + 2 * q * q) - o / 6 * q * (-3 + 4 * r * r) * (-3 + 4 *
+            q * q))),
+        p = f,
+        f = c / (g * n) + t;
+    c = k * r - j * s * i;
+    g = Math.atan2(k * s + j * r * i, (1 - h) * Math.sqrt(a * a + c * c));
+    b = Math.atan2(r * b, j * s - k * r * i);
+    i = h / 16 * m * (4 + h * (4 - 3 * m));
+    q = b - (1 - i) * h * a * (f + i * r * (q + i * s * (-1 + 2 * q * q)));
+    Math.atan2(a, -c);
+    return new OpenLayers.LonLat(e + d.deg(q), d.deg(g))
+};
+OpenLayers.Util.getParameters = function(a) {
+    var a = a === null || a === void 0 ? window.location.href : a,
+        b = "";
+    if (OpenLayers.String.contains(a, "?")) var b = a.indexOf("?") + 1,
+        c = OpenLayers.String.contains(a, "#") ? a.indexOf("#") : a.length,
+        b = a.substring(b, c);
+    for (var a = {}, b = b.split(/[&;]/), c = 0, d = b.length; c < d; ++c) {
+        var e = b[c].split("=");
+        if (e[0]) {
+            var f = e[0];
+            try {
+                f = decodeURIComponent(f)
+            } catch (g) {
+                f = unescape(f)
+            }
+            e = (e[1] || "").replace(/\+/g, " ");
+            try {
+                e = decodeURIComponent(e)
+            } catch (h) {
+                e = unescape(e)
+            }
+            e = e.split(",");
+            e.length == 1 && (e = e[0]);
+            a[f] = e
+        }
+    }
+    return a
+};
+OpenLayers.Util.lastSeqID = 0;
+OpenLayers.Util.createUniqueID = function(a) {
+    a == null && (a = "id_");
+    OpenLayers.Util.lastSeqID = OpenLayers.Util.lastSeqID + 1;
+    return a + OpenLayers.Util.lastSeqID
+};
+OpenLayers.INCHES_PER_UNIT = {
+    inches: 1,
+    ft: 12,
+    mi: 63360,
+    m: 39.3701,
+    km: 39370.1,
+    dd: 4374754,
+    yd: 36
+};
+OpenLayers.INCHES_PER_UNIT["in"] = OpenLayers.INCHES_PER_UNIT.inches;
+OpenLayers.INCHES_PER_UNIT.degrees = OpenLayers.INCHES_PER_UNIT.dd;
+OpenLayers.INCHES_PER_UNIT.nmi = 1852 * OpenLayers.INCHES_PER_UNIT.m;
+OpenLayers.METERS_PER_INCH = 0.0254000508001016;
+OpenLayers.Util.extend(OpenLayers.INCHES_PER_UNIT, {
+    Inch: OpenLayers.INCHES_PER_UNIT.inches,
+    Meter: 1 / OpenLayers.METERS_PER_INCH,
+    Foot: 0.3048006096012192 / OpenLayers.METERS_PER_INCH,
+    IFoot: 0.3048 / OpenLayers.METERS_PER_INCH,
+    ClarkeFoot: 0.3047972651151 / OpenLayers.METERS_PER_INCH,
+    SearsFoot: 0.30479947153867626 / OpenLayers.METERS_PER_INCH,
+    GoldCoastFoot: 0.3047997101815088 / OpenLayers.METERS_PER_INCH,
+    IInch: 0.0254 / OpenLayers.METERS_PER_INCH,
+    MicroInch: 2.54E-5 / OpenLayers.METERS_PER_INCH,
+    Mil: 2.54E-8 / OpenLayers.METERS_PER_INCH,
+    Centimeter: 0.01 / OpenLayers.METERS_PER_INCH,
+    Kilometer: 1E3 / OpenLayers.METERS_PER_INCH,
+    Yard: 0.9144018288036576 / OpenLayers.METERS_PER_INCH,
+    SearsYard: 0.914398414616029 / OpenLayers.METERS_PER_INCH,
+    IndianYard: 0.9143985307444408 / OpenLayers.METERS_PER_INCH,
+    IndianYd37: 0.91439523 / OpenLayers.METERS_PER_INCH,
+    IndianYd62: 0.9143988 / OpenLayers.METERS_PER_INCH,
+    IndianYd75: 0.9143985 / OpenLayers.METERS_PER_INCH,
+    IndianFoot: 0.30479951 / OpenLayers.METERS_PER_INCH,
+    IndianFt37: 0.30479841 / OpenLayers.METERS_PER_INCH,
+    IndianFt62: 0.3047996 /
+        OpenLayers.METERS_PER_INCH,
+    IndianFt75: 0.3047995 / OpenLayers.METERS_PER_INCH,
+    Mile: 1609.3472186944373 / OpenLayers.METERS_PER_INCH,
+    IYard: 0.9144 / OpenLayers.METERS_PER_INCH,
+    IMile: 1609.344 / OpenLayers.METERS_PER_INCH,
+    NautM: 1852 / OpenLayers.METERS_PER_INCH,
+    "Lat-66": 110943.31648893273 / OpenLayers.METERS_PER_INCH,
+    "Lat-83": 110946.25736872235 / OpenLayers.METERS_PER_INCH,
+    Decimeter: 0.1 / OpenLayers.METERS_PER_INCH,
+    Millimeter: 0.001 / OpenLayers.METERS_PER_INCH,
+    Dekameter: 10 / OpenLayers.METERS_PER_INCH,
+    Decameter: 10 / OpenLayers.METERS_PER_INCH,
+    Hectometer: 100 / OpenLayers.METERS_PER_INCH,
+    GermanMeter: 1.0000135965 / OpenLayers.METERS_PER_INCH,
+    CaGrid: 0.999738 / OpenLayers.METERS_PER_INCH,
+    ClarkeChain: 20.1166194976 / OpenLayers.METERS_PER_INCH,
+    GunterChain: 20.11684023368047 / OpenLayers.METERS_PER_INCH,
+    BenoitChain: 20.116782494375872 / OpenLayers.METERS_PER_INCH,
+    SearsChain: 20.11676512155 / OpenLayers.METERS_PER_INCH,
+    ClarkeLink: 0.201166194976 / OpenLayers.METERS_PER_INCH,
+    GunterLink: 0.2011684023368047 / OpenLayers.METERS_PER_INCH,
+    BenoitLink: 0.20116782494375873 / OpenLayers.METERS_PER_INCH,
+    SearsLink: 0.2011676512155 / OpenLayers.METERS_PER_INCH,
+    Rod: 5.02921005842012 / OpenLayers.METERS_PER_INCH,
+    IntnlChain: 20.1168 / OpenLayers.METERS_PER_INCH,
+    IntnlLink: 0.201168 / OpenLayers.METERS_PER_INCH,
+    Perch: 5.02921005842012 / OpenLayers.METERS_PER_INCH,
+    Pole: 5.02921005842012 / OpenLayers.METERS_PER_INCH,
+    Furlong: 201.1684023368046 / OpenLayers.METERS_PER_INCH,
+    Rood: 3.778266898 / OpenLayers.METERS_PER_INCH,
+    CapeFoot: 0.3047972615 / OpenLayers.METERS_PER_INCH,
+    Brealey: 375 / OpenLayers.METERS_PER_INCH,
+    ModAmFt: 0.304812252984506 /
+        OpenLayers.METERS_PER_INCH,
+    Fathom: 1.8288 / OpenLayers.METERS_PER_INCH,
+    "NautM-UK": 1853.184 / OpenLayers.METERS_PER_INCH,
+    "50kilometers": 5E4 / OpenLayers.METERS_PER_INCH,
+    "150kilometers": 15E4 / OpenLayers.METERS_PER_INCH
+});
+OpenLayers.Util.extend(OpenLayers.INCHES_PER_UNIT, {
+    mm: OpenLayers.INCHES_PER_UNIT.Meter / 1E3,
+    cm: OpenLayers.INCHES_PER_UNIT.Meter / 100,
+    dm: 100 * OpenLayers.INCHES_PER_UNIT.Meter,
+    km: 1E3 * OpenLayers.INCHES_PER_UNIT.Meter,
+    kmi: OpenLayers.INCHES_PER_UNIT.nmi,
+    fath: OpenLayers.INCHES_PER_UNIT.Fathom,
+    ch: OpenLayers.INCHES_PER_UNIT.IntnlChain,
+    link: OpenLayers.INCHES_PER_UNIT.IntnlLink,
+    "us-in": OpenLayers.INCHES_PER_UNIT.inches,
+    "us-ft": OpenLayers.INCHES_PER_UNIT.Foot,
+    "us-yd": OpenLayers.INCHES_PER_UNIT.Yard,
+    "us-ch": OpenLayers.INCHES_PER_UNIT.GunterChain,
+    "us-mi": OpenLayers.INCHES_PER_UNIT.Mile,
+    "ind-yd": OpenLayers.INCHES_PER_UNIT.IndianYd37,
+    "ind-ft": OpenLayers.INCHES_PER_UNIT.IndianFt37,
+    "ind-ch": 20.11669506 / OpenLayers.METERS_PER_INCH
+});
+OpenLayers.DOTS_PER_INCH = 72;
+OpenLayers.Util.normalizeScale = function(a) {
+    return a > 1 ? 1 / a : a
+};
+OpenLayers.Util.getResolutionFromScale = function(a, b) {
+    var c;
+    if (a) {
+        b == null && (b = "degrees");
+        c = 1 / (OpenLayers.Util.normalizeScale(a) * OpenLayers.INCHES_PER_UNIT[b] * OpenLayers.DOTS_PER_INCH)
+    }
+    return c
+};
+OpenLayers.Util.getScaleFromResolution = function(a, b) {
+    b == null && (b = "degrees");
+    return a * OpenLayers.INCHES_PER_UNIT[b] * OpenLayers.DOTS_PER_INCH
+};
+OpenLayers.Util.pagePosition = function(a) {
+    var b = [0, 0],
+        c = OpenLayers.Util.getViewportElement();
+    if (!a || a == window || a == c) return b;
+    var d = OpenLayers.IS_GECKO && document.getBoxObjectFor && OpenLayers.Element.getStyle(a, "position") == "absolute" && (a.style.top == "" || a.style.left == ""),
+        e = null;
+    if (a.getBoundingClientRect) {
+        a = a.getBoundingClientRect();
+        e = c.scrollTop;
+        b[0] = a.left + c.scrollLeft;
+        b[1] = a.top + e
+    } else if (document.getBoxObjectFor && !d) {
+        a = document.getBoxObjectFor(a);
+        c = document.getBoxObjectFor(c);
+        b[0] = a.screenX - c.screenX;
+        b[1] = a.screenY - c.screenY
+    } else {
+        b[0] = a.offsetLeft;
+        b[1] = a.offsetTop;
+        e = a.offsetParent;
+        if (e != a)
+            for (; e;) {
+                b[0] = b[0] + e.offsetLeft;
+                b[1] = b[1] + e.offsetTop;
+                e = e.offsetParent
+            }
+        c = OpenLayers.BROWSER_NAME;
+        if (c == "opera" || c == "safari" && OpenLayers.Element.getStyle(a, "position") == "absolute") b[1] = b[1] - document.body.offsetTop;
+        for (e = a.offsetParent; e && e != document.body;) {
+            b[0] = b[0] - e.scrollLeft;
+            if (c != "opera" || e.tagName != "TR") b[1] = b[1] - e.scrollTop;
+            e = e.offsetParent
+        }
+    }
+    return b
+};
+OpenLayers.Util.getViewportElement = function() {
+    var a = arguments.callee.viewportElement;
+    if (a == void 0) {
+        a = OpenLayers.BROWSER_NAME == "msie" && document.compatMode != "CSS1Compat" ? document.body : document.documentElement;
+        arguments.callee.viewportElement = a
+    }
+    return a
+};
+OpenLayers.Util.isEquivalentUrl = function(a, b, c) {
+    c = c || {};
+    OpenLayers.Util.applyDefaults(c, {
+        ignoreCase: true,
+        ignorePort80: true,
+        ignoreHash: true
+    });
+    var a = OpenLayers.Util.createUrlObject(a, c),
+        b = OpenLayers.Util.createUrlObject(b, c),
+        d;
+    for (d in a)
+        if (d !== "args" && a[d] != b[d]) return false;
+    for (d in a.args) {
+        if (a.args[d] != b.args[d]) return false;
+        delete b.args[d]
+    }
+    for (d in b.args) return false;
+    return true
+};
+OpenLayers.Util.createUrlObject = function(a, b) {
+    b = b || {};
+    if (!/^\w+:\/\//.test(a)) {
+        var c = window.location,
+            d = c.port ? ":" + c.port : "",
+            d = c.protocol + "//" + c.host.split(":").shift() + d;
+        if (a.indexOf("/") === 0) a = d + a;
+        else {
+            c = c.pathname.split("/");
+            c.pop();
+            a = d + c.join("/") + "/" + a
+        }
+    }
+    b.ignoreCase && (a = a.toLowerCase());
+    c = document.createElement("a");
+    c.href = a;
+    d = {};
+    d.host = c.host.split(":").shift();
+    d.protocol = c.protocol;
+    d.port = b.ignorePort80 ? c.port == "80" || c.port == "0" ? "" : c.port : c.port == "" || c.port == "0" ? "80" : c.port;
+    d.hash = b.ignoreHash ||
+        c.hash === "#" ? "" : c.hash;
+    var e = c.search;
+    if (!e) {
+        e = a.indexOf("?");
+        e = e != -1 ? a.substr(e) : ""
+    }
+    d.args = OpenLayers.Util.getParameters(e);
+    d.pathname = c.pathname.charAt(0) == "/" ? c.pathname : "/" + c.pathname;
+    return d
+};
+OpenLayers.Util.removeTail = function(a) {
+    var b = null,
+        b = a.indexOf("?"),
+        c = a.indexOf("#");
+    return b = b == -1 ? c != -1 ? a.substr(0, c) : a : c != -1 ? a.substr(0, Math.min(b, c)) : a.substr(0, b)
+};
+OpenLayers.IS_GECKO = function() {
+    var a = navigator.userAgent.toLowerCase();
+    return a.indexOf("webkit") == -1 && a.indexOf("gecko") != -1
+}();
+OpenLayers.CANVAS_SUPPORTED = function() {
+    var a = document.createElement("canvas");
+    return !(!a.getContext || !a.getContext("2d"))
+}();
+OpenLayers.BROWSER_NAME = function() {
+    var a = "",
+        b = navigator.userAgent.toLowerCase();
+    b.indexOf("opera") != -1 ? a = "opera" : b.indexOf("msie") != -1 ? a = "msie" : b.indexOf("safari") != -1 ? a = "safari" : b.indexOf("mozilla") != -1 && (a = b.indexOf("firefox") != -1 ? "firefox" : "mozilla");
+    return a
+}();
+OpenLayers.Util.getBrowserName = function() {
+    return OpenLayers.BROWSER_NAME
+};
+OpenLayers.Util.getRenderedDimensions = function(a, b, c) {
+    var d, e, f = document.createElement("div");
+    f.style.visibility = "hidden";
+    for (var g = c && c.containerElement ? c.containerElement : document.body, h = false, i = null, j = g; j && j.tagName.toLowerCase() != "body";) {
+        var k = OpenLayers.Element.getStyle(j, "position");
+        if (k == "absolute") {
+            h = true;
+            break
+        } else if (k && k != "static") break;
+        j = j.parentNode
+    }
+    if (h && (g.clientHeight === 0 || g.clientWidth === 0)) {
+        i = document.createElement("div");
+        i.style.visibility = "hidden";
+        i.style.position = "absolute";
+        i.style.overflow = "visible";
+        i.style.width = document.body.clientWidth + "px";
+        i.style.height = document.body.clientHeight + "px";
+        i.appendChild(f)
+    }
+    f.style.position = "absolute";
+    if (b)
+        if (b.w) {
+            d = b.w;
+            f.style.width = d + "px"
+        } else if (b.h) {
+        e = b.h;
+        f.style.height = e + "px"
+    }
+    if (c && c.displayClass) f.className = c.displayClass;
+    b = document.createElement("div");
+    b.innerHTML = a;
+    b.style.overflow = "visible";
+    if (b.childNodes) {
+        a = 0;
+        for (c = b.childNodes.length; a < c; a++)
+            if (b.childNodes[a].style) b.childNodes[a].style.overflow = "visible"
+    }
+    f.appendChild(b);
+    i ? g.appendChild(i) : g.appendChild(f);
+    if (!d) {
+        d = parseInt(b.scrollWidth);
+        f.style.width = d + "px"
+    }
+    e || (e = parseInt(b.scrollHeight));
+    f.removeChild(b);
+    if (i) {
+        i.removeChild(f);
+        g.removeChild(i)
+    } else g.removeChild(f);
+    return new OpenLayers.Size(d, e)
+};
+OpenLayers.Util.getScrollbarWidth = function() {
+    var a = OpenLayers.Util._scrollbarWidth;
+    if (a == null) {
+        var b = null,
+            c = null,
+            b = a = 0,
+            b = document.createElement("div");
+        b.style.position = "absolute";
+        b.style.top = "-1000px";
+        b.style.left = "-1000px";
+        b.style.width = "100px";
+        b.style.height = "50px";
+        b.style.overflow = "hidden";
+        c = document.createElement("div");
+        c.style.width = "100%";
+        c.style.height = "200px";
+        b.appendChild(c);
+        document.body.appendChild(b);
+        a = c.offsetWidth;
+        b.style.overflow = "scroll";
+        b = c.offsetWidth;
+        document.body.removeChild(document.body.lastChild);
+        OpenLayers.Util._scrollbarWidth = a - b;
+        a = OpenLayers.Util._scrollbarWidth
+    }
+    return a
+};
+OpenLayers.Util.getFormattedLonLat = function(a, b, c) {
+    c || (c = "dms");
+    var a = (a + 540) % 360 - 180,
+        d = Math.abs(a),
+        e = Math.floor(d),
+        f = d = (d - e) / (1 / 60),
+        d = Math.floor(d),
+        f = Math.round((f - d) / (1 / 60) * 10),
+        f = f / 10;
+    if (f >= 60) {
+        f = f - 60;
+        d = d + 1;
+        if (d >= 60) {
+            d = d - 60;
+            e = e + 1
+        }
+    }
+    e < 10 && (e = "0" + e);
+    e = e + "\u00b0";
+    if (c.indexOf("dm") >= 0) {
+        d < 10 && (d = "0" + d);
+        e = e + (d + "'");
+        if (c.indexOf("dms") >= 0) {
+            f < 10 && (f = "0" + f);
+            e = e + (f + '"')
+        }
+    }
+    return e = b == "lon" ? e + (a < 0 ? OpenLayers.i18n("W") : OpenLayers.i18n("E")) : e + (a < 0 ? OpenLayers.i18n("S") : OpenLayers.i18n("N"))
+};
+OpenLayers.Format = OpenLayers.Class({
+    options: null,
+    externalProjection: null,
+    internalProjection: null,
+    data: null,
+    keepData: !1,
+    initialize: function(a) {
+        OpenLayers.Util.extend(this, a);
+        this.options = a
+    },
+    destroy: function() {},
+    read: function() {
+        throw Error("Read not implemented.");
+    },
+    write: function() {
+        throw Error("Write not implemented.");
+    },
+    CLASS_NAME: "OpenLayers.Format"
+});
+OpenLayers.Format.CSWGetRecords = function(a) {
+    var a = OpenLayers.Util.applyDefaults(a, OpenLayers.Format.CSWGetRecords.DEFAULTS),
+        b = OpenLayers.Format.CSWGetRecords["v" + a.version.replace(/\./g, "_")];
+    if (!b) throw "Unsupported CSWGetRecords version: " + a.version;
+    return new b(a)
+};
+OpenLayers.Format.CSWGetRecords.DEFAULTS = {
+    version: "2.0.2"
+};
+OpenLayers.Control = OpenLayers.Class({
+    id: null,
+    map: null,
+    div: null,
+    type: null,
+    allowSelection: !1,
+    displayClass: "",
+    title: "",
+    autoActivate: !1,
+    active: null,
+    handler: null,
+    eventListeners: null,
+    events: null,
+    initialize: function(a) {
+        this.displayClass = this.CLASS_NAME.replace("OpenLayers.", "ol").replace(/\./g, "");
+        OpenLayers.Util.extend(this, a);
+        this.events = new OpenLayers.Events(this);
+        if (this.eventListeners instanceof Object) this.events.on(this.eventListeners);
+        null == this.id && (this.id = OpenLayers.Util.createUniqueID(this.CLASS_NAME +
+            "_"))
+    },
+    destroy: function() {
+        this.events && (this.eventListeners && this.events.un(this.eventListeners), this.events.destroy(), this.events = null);
+        this.eventListeners = null;
+        this.handler && (this.handler.destroy(), this.handler = null);
+        if (this.handlers) {
+            for (var a in this.handlers) this.handlers.hasOwnProperty(a) && "function" == typeof this.handlers[a].destroy && this.handlers[a].destroy();
+            this.handlers = null
+        }
+        this.map && (this.map.removeControl(this), this.map = null);
+        this.div = null
+    },
+    setMap: function(a) {
+        this.map = a;
+        this.handler &&
+            this.handler.setMap(a)
+    },
+    draw: function(a) {
+        if (null == this.div && (this.div = OpenLayers.Util.createDiv(this.id), this.div.className = this.displayClass, this.allowSelection || (this.div.className += " olControlNoSelect", this.div.setAttribute("unselectable", "on", 0), this.div.onselectstart = OpenLayers.Function.False), "" != this.title)) this.div.title = this.title;
+        null != a && (this.position = a.clone());
+        this.moveTo(this.position);
+        return this.div
+    },
+    moveTo: function(a) {
+        null != a && null != this.div && (this.div.style.left = a.x + "px", this.div.style.top =
+            a.y + "px")
+    },
+    activate: function() {
+        if (this.active) return !1;
+        this.handler && this.handler.activate();
+        this.active = !0;
+        this.map && OpenLayers.Element.addClass(this.map.viewPortDiv, this.displayClass.replace(/ /g, "") + "Active");
+        this.events.triggerEvent("activate");
+        return !0
+    },
+    deactivate: function() {
+        return this.active ? (this.handler && this.handler.deactivate(), this.active = !1, this.map && OpenLayers.Element.removeClass(this.map.viewPortDiv, this.displayClass.replace(/ /g, "") + "Active"), this.events.triggerEvent("deactivate"), !0) : !1
+    },
+    CLASS_NAME: "OpenLayers.Control"
+});
+OpenLayers.Control.TYPE_BUTTON = 1;
+OpenLayers.Control.TYPE_TOGGLE = 2;
+OpenLayers.Control.TYPE_TOOL = 3;
+OpenLayers.Event = {
+    observers: !1,
+    KEY_SPACE: 32,
+    KEY_BACKSPACE: 8,
+    KEY_TAB: 9,
+    KEY_RETURN: 13,
+    KEY_ESC: 27,
+    KEY_LEFT: 37,
+    KEY_UP: 38,
+    KEY_RIGHT: 39,
+    KEY_DOWN: 40,
+    KEY_DELETE: 46,
+    element: function(a) {
+        return a.target || a.srcElement
+    },
+    isSingleTouch: function(a) {
+        return a.touches && 1 == a.touches.length
+    },
+    isMultiTouch: function(a) {
+        return a.touches && 1 < a.touches.length
+    },
+    isLeftClick: function(a) {
+        return a.which && 1 == a.which || a.button && 1 == a.button
+    },
+    isRightClick: function(a) {
+        return a.which && 3 == a.which || a.button && 2 == a.button
+    },
+    stop: function(a,
+        b) {
+        b || (a.preventDefault ? a.preventDefault() : a.returnValue = !1);
+        a.stopPropagation ? a.stopPropagation() : a.cancelBubble = !0
+    },
+    findElement: function(a, b) {
+        for (var c = OpenLayers.Event.element(a); c.parentNode && (!c.tagName || c.tagName.toUpperCase() != b.toUpperCase());) c = c.parentNode;
+        return c
+    },
+    observe: function(a, b, c, d) {
+        a = OpenLayers.Util.getElement(a);
+        d = d || !1;
+        if ("keypress" == b && (navigator.appVersion.match(/Konqueror|Safari|KHTML/) || a.attachEvent)) b = "keydown";
+        this.observers || (this.observers = {});
+        if (!a._eventCacheID) {
+            var e =
+                "eventCacheID_";
+            a.id && (e = a.id + "_" + e);
+            a._eventCacheID = OpenLayers.Util.createUniqueID(e)
+        }
+        e = a._eventCacheID;
+        this.observers[e] || (this.observers[e] = []);
+        this.observers[e].push({
+            element: a,
+            name: b,
+            observer: c,
+            useCapture: d
+        });
+        a.addEventListener ? a.addEventListener(b, c, d) : a.attachEvent && a.attachEvent("on" + b, c)
+    },
+    stopObservingElement: function(a) {
+        a = OpenLayers.Util.getElement(a)._eventCacheID;
+        this._removeElementObservers(OpenLayers.Event.observers[a])
+    },
+    _removeElementObservers: function(a) {
+        if (a)
+            for (var b = a.length - 1; 0 <=
+                b; b--) {
+                var c = a[b];
+                OpenLayers.Event.stopObserving.apply(this, [c.element, c.name, c.observer, c.useCapture])
+            }
+    },
+    stopObserving: function(a, b, c, d) {
+        var d = d || !1,
+            a = OpenLayers.Util.getElement(a),
+            e = a._eventCacheID;
+        if ("keypress" == b && (navigator.appVersion.match(/Konqueror|Safari|KHTML/) || a.detachEvent)) b = "keydown";
+        var f = !1,
+            g = OpenLayers.Event.observers[e];
+        if (g)
+            for (var h = 0; !f && h < g.length;) {
+                var i = g[h];
+                if (i.name == b && i.observer == c && i.useCapture == d) {
+                    g.splice(h, 1);
+                    0 == g.length && delete OpenLayers.Event.observers[e];
+                    f = !0;
+                    break
+                }
+                h++
+            }
+        f && (a.removeEventListener ? a.removeEventListener(b, c, d) : a && a.detachEvent && a.detachEvent("on" + b, c));
+        return f
+    },
+    unloadCache: function() {
+        if (OpenLayers.Event && OpenLayers.Event.observers) {
+            for (var a in OpenLayers.Event.observers) OpenLayers.Event._removeElementObservers.apply(this, [OpenLayers.Event.observers[a]]);
+            OpenLayers.Event.observers = !1
+        }
+    },
+    CLASS_NAME: "OpenLayers.Event"
+};
+OpenLayers.Event.observe(window, "unload", OpenLayers.Event.unloadCache, !1);
+OpenLayers.Events = OpenLayers.Class({
+    BROWSER_EVENTS: "mouseover mouseout mousedown mouseup mousemove click dblclick rightclick dblrightclick resize focus blur touchstart touchmove touchend keydown".split(" "),
+    listeners: null,
+    object: null,
+    element: null,
+    eventHandler: null,
+    fallThrough: null,
+    includeXY: !1,
+    extensions: null,
+    extensionCount: null,
+    clearMouseListener: null,
+    initialize: function(a, b, c, d, e) {
+        OpenLayers.Util.extend(this, e);
+        this.object = a;
+        this.fallThrough = d;
+        this.listeners = {};
+        this.extensions = {};
+        this.extensionCount = {};
+        null != b && this.attachToElement(b)
+    },
+    destroy: function() {
+        for (var a in this.extensions) "boolean" !== typeof this.extensions[a] && this.extensions[a].destroy();
+        this.extensions = null;
+        this.element && (OpenLayers.Event.stopObservingElement(this.element), this.element.hasScrollEvent && OpenLayers.Event.stopObserving(window, "scroll", this.clearMouseListener));
+        this.eventHandler = this.fallThrough = this.object = this.listeners = this.element = null
+    },
+    addEventType: function() {},
+    attachToElement: function(a) {
+        this.element ? OpenLayers.Event.stopObservingElement(this.element) :
+            (this.eventHandler = OpenLayers.Function.bindAsEventListener(this.handleBrowserEvent, this), this.clearMouseListener = OpenLayers.Function.bind(this.clearMouseCache, this));
+        this.element = a;
+        for (var b = 0, c = this.BROWSER_EVENTS.length; b < c; b++) OpenLayers.Event.observe(a, this.BROWSER_EVENTS[b], this.eventHandler);
+        OpenLayers.Event.observe(a, "dragstart", OpenLayers.Event.stop)
+    },
+    on: function(a) {
+        for (var b in a) "scope" != b && a.hasOwnProperty(b) && this.register(b, a.scope, a[b])
+    },
+    register: function(a, b, c, d) {
+        a in OpenLayers.Events &&
+            !this.extensions[a] && (this.extensions[a] = new OpenLayers.Events[a](this));
+        if (null != c) {
+            null == b && (b = this.object);
+            var e = this.listeners[a];
+            e || (e = [], this.listeners[a] = e, this.extensionCount[a] = 0);
+            b = {
+                obj: b,
+                func: c
+            };
+            d ? (e.splice(this.extensionCount[a], 0, b), "object" === typeof d && d.extension && this.extensionCount[a]++) : e.push(b)
+        }
+    },
+    registerPriority: function(a, b, c) {
+        this.register(a, b, c, !0)
+    },
+    un: function(a) {
+        for (var b in a) "scope" != b && a.hasOwnProperty(b) && this.unregister(b, a.scope, a[b])
+    },
+    unregister: function(a, b, c) {
+        null ==
+            b && (b = this.object);
+        a = this.listeners[a];
+        if (null != a)
+            for (var d = 0, e = a.length; d < e; d++)
+                if (a[d].obj == b && a[d].func == c) {
+                    a.splice(d, 1);
+                    break
+                }
+    },
+    remove: function(a) {
+        null != this.listeners[a] && (this.listeners[a] = [])
+    },
+    triggerEvent: function(a, b) {
+        var c = this.listeners[a];
+        if (c && 0 != c.length) {
+            null == b && (b = {});
+            b.object = this.object;
+            b.element = this.element;
+            b.type || (b.type = a);
+            for (var c = c.slice(), d, e = 0, f = c.length; e < f && !(d = c[e], d = d.func.apply(d.obj, [b]), void 0 != d && !1 == d); e++);
+            this.fallThrough || OpenLayers.Event.stop(b, !0);
+            return d
+        }
+    },
+    handleBrowserEvent: function(a) {
+        var b = a.type,
+            c = this.listeners[b];
+        if (c && 0 != c.length) {
+            if ((c = a.touches) && c[0]) {
+                for (var d = 0, e = 0, f = c.length, g, h = 0; h < f; ++h) g = c[h], d += g.clientX, e += g.clientY;
+                a.clientX = d / f;
+                a.clientY = e / f
+            }
+            this.includeXY && (a.xy = this.getMousePosition(a));
+            this.triggerEvent(b, a)
+        }
+    },
+    clearMouseCache: function() {
+        this.element.scrolls = null;
+        this.element.lefttop = null;
+        var a = document.body;
+        if (a && (!(0 != a.scrollTop || 0 != a.scrollLeft) || !navigator.userAgent.match(/iPhone/i))) this.element.offsets = null
+    },
+    getMousePosition: function(a) {
+        this.includeXY ?
+            this.element.hasScrollEvent || (OpenLayers.Event.observe(window, "scroll", this.clearMouseListener), this.element.hasScrollEvent = !0) : this.clearMouseCache();
+        if (!this.element.scrolls) {
+            var b = OpenLayers.Util.getViewportElement();
+            this.element.scrolls = [b.scrollLeft, b.scrollTop]
+        }
+        this.element.lefttop || (this.element.lefttop = [document.documentElement.clientLeft || 0, document.documentElement.clientTop || 0]);
+        this.element.offsets || (this.element.offsets = OpenLayers.Util.pagePosition(this.element));
+        return new OpenLayers.Pixel(a.clientX +
+            this.element.scrolls[0] - this.element.offsets[0] - this.element.lefttop[0], a.clientY + this.element.scrolls[1] - this.element.offsets[1] - this.element.lefttop[1])
+    },
+    CLASS_NAME: "OpenLayers.Events"
+});
+OpenLayers.Events.buttonclick = OpenLayers.Class({
+    target: null,
+    events: "mousedown mouseup click dblclick touchstart touchmove touchend keydown".split(" "),
+    startRegEx: /^mousedown|touchstart$/,
+    cancelRegEx: /^touchmove$/,
+    completeRegEx: /^mouseup|touchend$/,
+    initialize: function(a) {
+        this.target = a;
+        for (a = this.events.length - 1; 0 <= a; --a) this.target.register(this.events[a], this, this.buttonClick, {
+            extension: !0
+        })
+    },
+    destroy: function() {
+        for (var a = this.events.length - 1; 0 <= a; --a) this.target.unregister(this.events[a], this, this.buttonClick);
+        delete this.target
+    },
+    getPressedButton: function(a) {
+        var b = 3,
+            c;
+        do {
+            if (OpenLayers.Element.hasClass(a, "olButton")) {
+                c = a;
+                break
+            }
+            a = a.parentNode
+        } while (0 < --b && a);
+        return c
+    },
+    buttonClick: function(a) {
+        var b = !0,
+            c = OpenLayers.Event.element(a);
+        if (c && (OpenLayers.Event.isLeftClick(a) || !~a.type.indexOf("mouse")))
+            if (c = this.getPressedButton(c)) {
+                if ("keydown" === a.type) switch (a.keyCode) {
+                    case OpenLayers.Event.KEY_RETURN:
+                    case OpenLayers.Event.KEY_SPACE:
+                        this.target.triggerEvent("buttonclick", {
+                                buttonElement: c
+                            }), OpenLayers.Event.stop(a),
+                            b = !1
+                } else this.startEvt && (this.completeRegEx.test(a.type) && (b = OpenLayers.Util.pagePosition(c), this.target.triggerEvent("buttonclick", {
+                    buttonElement: c,
+                    buttonXY: {
+                        x: this.startEvt.clientX - b[0],
+                        y: this.startEvt.clientY - b[1]
+                    }
+                })), this.cancelRegEx.test(a.type) && delete this.startEvt, OpenLayers.Event.stop(a), b = !1);
+                this.startRegEx.test(a.type) && (this.startEvt = a, OpenLayers.Event.stop(a), b = !1)
+            } else delete this.startEvt;
+        return b
+    }
+});
+OpenLayers.Control.OverviewMap = OpenLayers.Class(OpenLayers.Control, {
+    element: null,
+    ovmap: null,
+    size: {
+        w: 180,
+        h: 90
+    },
+    layers: null,
+    minRectSize: 15,
+    minRectDisplayClass: "RectReplacement",
+    minRatio: 8,
+    maxRatio: 32,
+    mapOptions: null,
+    autoPan: !1,
+    handlers: null,
+    resolutionFactor: 1,
+    maximized: !1,
+    initialize: function(a) {
+        this.layers = [];
+        this.handlers = {};
+        OpenLayers.Control.prototype.initialize.apply(this, [a])
+    },
+    destroy: function() {
+        this.mapDiv && (this.handlers.click && this.handlers.click.destroy(), this.handlers.drag && this.handlers.drag.destroy(),
+            this.ovmap && this.ovmap.viewPortDiv.removeChild(this.extentRectangle), this.extentRectangle = null, this.rectEvents && (this.rectEvents.destroy(), this.rectEvents = null), this.ovmap && (this.ovmap.destroy(), this.ovmap = null), this.element.removeChild(this.mapDiv), this.mapDiv = null, this.div.removeChild(this.element), this.element = null, this.maximizeDiv && (this.div.removeChild(this.maximizeDiv), this.maximizeDiv = null), this.minimizeDiv && (this.div.removeChild(this.minimizeDiv), this.minimizeDiv = null), this.map.events.un({
+                buttonclick: this.onButtonClick,
+                moveend: this.update,
+                changebaselayer: this.baseLayerDraw,
+                scope: this
+            }), OpenLayers.Control.prototype.destroy.apply(this, arguments))
+    },
+    draw: function() {
+        OpenLayers.Control.prototype.draw.apply(this, arguments);
+        if (0 === this.layers.length)
+            if (this.map.baseLayer) this.layers = [this.map.baseLayer.clone()];
+            else return this.map.events.register("changebaselayer", this, this.baseLayerDraw), this.div;
+        this.element = document.createElement("div");
+        this.element.className = this.displayClass + "Element";
+        this.element.style.display = "none";
+        this.mapDiv = document.createElement("div");
+        this.mapDiv.style.width = this.size.w + "px";
+        this.mapDiv.style.height = this.size.h + "px";
+        this.mapDiv.style.position = "relative";
+        this.mapDiv.style.overflow = "hidden";
+        this.mapDiv.id = OpenLayers.Util.createUniqueID("overviewMap");
+        this.extentRectangle = document.createElement("div");
+        this.extentRectangle.style.position = "absolute";
+        this.extentRectangle.style.zIndex = 1E3;
+        this.extentRectangle.className = this.displayClass + "ExtentRectangle";
+        this.element.appendChild(this.mapDiv);
+        this.div.appendChild(this.element);
+        if (this.outsideViewport) this.element.style.display = "";
+        else {
+            this.div.className += " " + this.displayClass + "Container";
+            var a = OpenLayers.Util.getImageLocation("layer-switcher-maximize.png");
+            this.maximizeDiv = OpenLayers.Util.createAlphaImageDiv(this.displayClass + "MaximizeButton", null, null, a, "absolute");
+            this.maximizeDiv.style.display = "none";
+            this.maximizeDiv.className = this.displayClass + "MaximizeButton olButton";
+            this.div.appendChild(this.maximizeDiv);
+            a = OpenLayers.Util.getImageLocation("layer-switcher-minimize.png");
+            this.minimizeDiv = OpenLayers.Util.createAlphaImageDiv("OpenLayers_Control_minimizeDiv", null, null, a, "absolute");
+            this.minimizeDiv.style.display = "none";
+            this.minimizeDiv.className = this.displayClass + "MinimizeButton olButton";
+            this.div.appendChild(this.minimizeDiv);
+            this.minimizeControl()
+        }
+        this.map.getExtent() && this.update();
+        this.map.events.on({
+            buttonclick: this.onButtonClick,
+            moveend: this.update,
+            scope: this
+        });
+        this.maximized && this.maximizeControl();
+        return this.div
+    },
+    baseLayerDraw: function() {
+        this.draw();
+        this.map.events.unregister("changebaselayer",
+            this, this.baseLayerDraw)
+    },
+    rectDrag: function(a) {
+        var b = this.handlers.drag.last.x - a.x,
+            c = this.handlers.drag.last.y - a.y;
+        if (0 != b || 0 != c) {
+            var d = this.rectPxBounds.top,
+                e = this.rectPxBounds.left,
+                a = Math.abs(this.rectPxBounds.getHeight()),
+                f = this.rectPxBounds.getWidth(),
+                c = Math.max(0, d - c),
+                c = Math.min(c, this.ovmap.size.h - this.hComp - a),
+                b = Math.max(0, e - b),
+                b = Math.min(b, this.ovmap.size.w - this.wComp - f);
+            this.setRectPxBounds(new OpenLayers.Bounds(b, c + a, b + f, c))
+        }
+    },
+    mapDivClick: function(a) {
+        var b = this.rectPxBounds.getCenterPixel(),
+            c = a.xy.x - b.x,
+            d = a.xy.y - b.y,
+            e = this.rectPxBounds.top,
+            f = this.rectPxBounds.left,
+            a = Math.abs(this.rectPxBounds.getHeight()),
+            b = this.rectPxBounds.getWidth(),
+            d = Math.max(0, e + d),
+            d = Math.min(d, this.ovmap.size.h - a),
+            c = Math.max(0, f + c),
+            c = Math.min(c, this.ovmap.size.w - b);
+        this.setRectPxBounds(new OpenLayers.Bounds(c, d + a, c + b, d));
+        this.updateMapToRect()
+    },
+    onButtonClick: function(a) {
+        a.buttonElement === this.minimizeDiv ? this.minimizeControl() : a.buttonElement === this.maximizeDiv && this.maximizeControl()
+    },
+    maximizeControl: function(a) {
+        this.element.style.display =
+            "";
+        this.showToggle(!1);
+        null != a && OpenLayers.Event.stop(a)
+    },
+    minimizeControl: function(a) {
+        this.element.style.display = "none";
+        this.showToggle(!0);
+        null != a && OpenLayers.Event.stop(a)
+    },
+    showToggle: function(a) {
+        this.maximizeDiv.style.display = a ? "" : "none";
+        this.minimizeDiv.style.display = a ? "none" : ""
+    },
+    update: function() {
+        null == this.ovmap && this.createMap();
+        (this.autoPan || !this.isSuitableOverview()) && this.updateOverview();
+        this.updateRectToMap()
+    },
+    isSuitableOverview: function() {
+        var a = this.map.getExtent(),
+            b = this.map.maxExtent,
+            a = new OpenLayers.Bounds(Math.max(a.left, b.left), Math.max(a.bottom, b.bottom), Math.min(a.right, b.right), Math.min(a.top, b.top));
+        this.ovmap.getProjection() != this.map.getProjection() && (a = a.transform(this.map.getProjectionObject(), this.ovmap.getProjectionObject()));
+        b = this.ovmap.getResolution() / this.map.getResolution();
+        return b > this.minRatio && b <= this.maxRatio && this.ovmap.getExtent().containsBounds(a)
+    },
+    updateOverview: function() {
+        var a = this.map.getResolution(),
+            b = this.ovmap.getResolution(),
+            c = b / a;
+        c > this.maxRatio ?
+            b = this.minRatio * a : c <= this.minRatio && (b = this.maxRatio * a);
+        this.ovmap.getProjection() != this.map.getProjection() ? (a = this.map.center.clone(), a.transform(this.map.getProjectionObject(), this.ovmap.getProjectionObject())) : a = this.map.center;
+        this.ovmap.setCenter(a, this.ovmap.getZoomForResolution(b * this.resolutionFactor));
+        this.updateRectToMap()
+    },
+    createMap: function() {
+        var a = OpenLayers.Util.extend({
+            controls: [],
+            maxResolution: "auto",
+            fallThrough: !1
+        }, this.mapOptions);
+        this.ovmap = new OpenLayers.Map(this.mapDiv, a);
+        this.ovmap.viewPortDiv.appendChild(this.extentRectangle);
+        OpenLayers.Event.stopObserving(window, "unload", this.ovmap.unloadDestroy);
+        this.ovmap.addLayers(this.layers);
+        this.ovmap.zoomToMaxExtent();
+        this.wComp = (this.wComp = parseInt(OpenLayers.Element.getStyle(this.extentRectangle, "border-left-width")) + parseInt(OpenLayers.Element.getStyle(this.extentRectangle, "border-right-width"))) ? this.wComp : 2;
+        this.hComp = (this.hComp = parseInt(OpenLayers.Element.getStyle(this.extentRectangle, "border-top-width")) + parseInt(OpenLayers.Element.getStyle(this.extentRectangle, "border-bottom-width"))) ?
+            this.hComp : 2;
+        this.handlers.drag = new OpenLayers.Handler.Drag(this, {
+            move: this.rectDrag,
+            done: this.updateMapToRect
+        }, {
+            map: this.ovmap
+        });
+        this.handlers.click = new OpenLayers.Handler.Click(this, {
+            click: this.mapDivClick
+        }, {
+            single: !0,
+            "double": !1,
+            stopSingle: !0,
+            stopDouble: !0,
+            pixelTolerance: 1,
+            map: this.ovmap
+        });
+        this.handlers.click.activate();
+        this.rectEvents = new OpenLayers.Events(this, this.extentRectangle, null, !0);
+        this.rectEvents.register("mouseover", this, function() {
+            !this.handlers.drag.active && !this.map.dragging && this.handlers.drag.activate()
+        });
+        this.rectEvents.register("mouseout", this, function() {
+            this.handlers.drag.dragging || this.handlers.drag.deactivate()
+        });
+        if (this.ovmap.getProjection() != this.map.getProjection()) {
+            var a = this.map.getProjectionObject().getUnits() || this.map.units || this.map.baseLayer.units,
+                b = this.ovmap.getProjectionObject().getUnits() || this.ovmap.units || this.ovmap.baseLayer.units;
+            this.resolutionFactor = a && b ? OpenLayers.INCHES_PER_UNIT[a] / OpenLayers.INCHES_PER_UNIT[b] : 1
+        }
+    },
+    updateRectToMap: function() {
+        var a = this.getRectBoundsFromMapBounds(this.ovmap.getProjection() !=
+            this.map.getProjection() ? this.map.getExtent().transform(this.map.getProjectionObject(), this.ovmap.getProjectionObject()) : this.map.getExtent());
+        a && this.setRectPxBounds(a)
+    },
+    updateMapToRect: function() {
+        var a = this.getMapBoundsFromRectBounds(this.rectPxBounds);
+        this.ovmap.getProjection() != this.map.getProjection() && (a = a.transform(this.ovmap.getProjectionObject(), this.map.getProjectionObject()));
+        this.map.panTo(a.getCenterLonLat())
+    },
+    setRectPxBounds: function(a) {
+        var b = Math.max(a.top, 0),
+            c = Math.max(a.left, 0),
+            d =
+            Math.min(a.top + Math.abs(a.getHeight()), this.ovmap.size.h - this.hComp),
+            a = Math.min(a.left + a.getWidth(), this.ovmap.size.w - this.wComp),
+            e = Math.max(a - c, 0),
+            f = Math.max(d - b, 0);
+        e < this.minRectSize || f < this.minRectSize ? (this.extentRectangle.className = this.displayClass + this.minRectDisplayClass, e = c + e / 2 - this.minRectSize / 2, this.extentRectangle.style.top = Math.round(b + f / 2 - this.minRectSize / 2) + "px", this.extentRectangle.style.left = Math.round(e) + "px", this.extentRectangle.style.height = this.minRectSize + "px", this.extentRectangle.style.width =
+            this.minRectSize + "px") : (this.extentRectangle.className = this.displayClass + "ExtentRectangle", this.extentRectangle.style.top = Math.round(b) + "px", this.extentRectangle.style.left = Math.round(c) + "px", this.extentRectangle.style.height = Math.round(f) + "px", this.extentRectangle.style.width = Math.round(e) + "px");
+        this.rectPxBounds = new OpenLayers.Bounds(Math.round(c), Math.round(d), Math.round(a), Math.round(b))
+    },
+    getRectBoundsFromMapBounds: function(a) {
+        var b = this.getOverviewPxFromLonLat({
+                lon: a.left,
+                lat: a.bottom
+            }),
+            a = this.getOverviewPxFromLonLat({
+                lon: a.right,
+                lat: a.top
+            }),
+            c = null;
+        b && a && (c = new OpenLayers.Bounds(b.x, b.y, a.x, a.y));
+        return c
+    },
+    getMapBoundsFromRectBounds: function(a) {
+        var b = this.getLonLatFromOverviewPx({
+                x: a.left,
+                y: a.bottom
+            }),
+            a = this.getLonLatFromOverviewPx({
+                x: a.right,
+                y: a.top
+            });
+        return new OpenLayers.Bounds(b.lon, b.lat, a.lon, a.lat)
+    },
+    getLonLatFromOverviewPx: function(a) {
+        var b = this.ovmap.size,
+            c = this.ovmap.getResolution(),
+            d = this.ovmap.getExtent().getCenterLonLat();
+        return {
+            lon: d.lon + (a.x - b.w / 2) * c,
+            lat: d.lat - (a.y - b.h / 2) * c
+        }
+    },
+    getOverviewPxFromLonLat: function(a) {
+        var b =
+            this.ovmap.getResolution(),
+            c = this.ovmap.getExtent();
+        if (c) return {
+            x: Math.round(1 / b * (a.lon - c.left)),
+            y: Math.round(1 / b * (c.top - a.lat))
+        }
+    },
+    CLASS_NAME: "OpenLayers.Control.OverviewMap"
+});
+OpenLayers.Animation = function(a) {
+    var b = !(!a.requestAnimationFrame && !a.webkitRequestAnimationFrame && !a.mozRequestAnimationFrame && !a.oRequestAnimationFrame && !a.msRequestAnimationFrame),
+        c = function() {
+            var b = a.requestAnimationFrame || a.webkitRequestAnimationFrame || a.mozRequestAnimationFrame || a.oRequestAnimationFrame || a.msRequestAnimationFrame || function(b) {
+                a.setTimeout(b, 16)
+            };
+            return function(c, d) {
+                b.apply(a, [c, d])
+            }
+        }(),
+        d = 0,
+        e = {};
+    return {
+        isNative: b,
+        requestFrame: c,
+        start: function(a, b, h) {
+            var b = 0 < b ? b : Number.POSITIVE_INFINITY,
+                i = ++d,
+                j = +new Date;
+            e[i] = function() {
+                e[i] && +new Date - j <= b ? (a(), e[i] && c(e[i], h)) : delete e[i]
+            };
+            c(e[i], h);
+            return i
+        },
+        stop: function(a) {
+            delete e[a]
+        }
+    }
+}(window);
+OpenLayers.Tween = OpenLayers.Class({
+    easing: null,
+    begin: null,
+    finish: null,
+    duration: null,
+    callbacks: null,
+    time: null,
+    animationId: null,
+    playing: !1,
+    initialize: function(a) {
+        this.easing = a ? a : OpenLayers.Easing.Expo.easeOut
+    },
+    start: function(a, b, c, d) {
+        this.playing = !0;
+        this.begin = a;
+        this.finish = b;
+        this.duration = c;
+        this.callbacks = d.callbacks;
+        this.time = 0;
+        OpenLayers.Animation.stop(this.animationId);
+        this.animationId = null;
+        this.callbacks && this.callbacks.start && this.callbacks.start.call(this, this.begin);
+        this.animationId = OpenLayers.Animation.start(OpenLayers.Function.bind(this.play,
+            this))
+    },
+    stop: function() {
+        this.playing && (this.callbacks && this.callbacks.done && this.callbacks.done.call(this, this.finish), OpenLayers.Animation.stop(this.animationId), this.animationId = null, this.playing = !1)
+    },
+    play: function() {
+        var a = {},
+            b;
+        for (b in this.begin) {
+            var c = this.begin[b],
+                d = this.finish[b];
+            if (null == c || null == d || isNaN(c) || isNaN(d)) throw new TypeError("invalid value for Tween");
+            a[b] = this.easing.apply(this, [this.time, c, d - c, this.duration])
+        }
+        this.time++;
+        this.callbacks && this.callbacks.eachStep && this.callbacks.eachStep.call(this,
+            a);
+        this.time > this.duration && this.stop()
+    },
+    CLASS_NAME: "OpenLayers.Tween"
+});
+OpenLayers.Easing = {
+    CLASS_NAME: "OpenLayers.Easing"
+};
+OpenLayers.Easing.Linear = {
+    easeIn: function(a, b, c, d) {
+        return c * a / d + b
+    },
+    easeOut: function(a, b, c, d) {
+        return c * a / d + b
+    },
+    easeInOut: function(a, b, c, d) {
+        return c * a / d + b
+    },
+    CLASS_NAME: "OpenLayers.Easing.Linear"
+};
+OpenLayers.Easing.Expo = {
+    easeIn: function(a, b, c, d) {
+        return 0 == a ? b : c * Math.pow(2, 10 * (a / d - 1)) + b
+    },
+    easeOut: function(a, b, c, d) {
+        return a == d ? b + c : c * (-Math.pow(2, -10 * a / d) + 1) + b
+    },
+    easeInOut: function(a, b, c, d) {
+        return 0 == a ? b : a == d ? b + c : 1 > (a /= d / 2) ? c / 2 * Math.pow(2, 10 * (a - 1)) + b : c / 2 * (-Math.pow(2, -10 * --a) + 2) + b
+    },
+    CLASS_NAME: "OpenLayers.Easing.Expo"
+};
+OpenLayers.Easing.Quad = {
+    easeIn: function(a, b, c, d) {
+        return c * (a /= d) * a + b
+    },
+    easeOut: function(a, b, c, d) {
+        return -c * (a /= d) * (a - 2) + b
+    },
+    easeInOut: function(a, b, c, d) {
+        return 1 > (a /= d / 2) ? c / 2 * a * a + b : -c / 2 * (--a * (a - 2) - 1) + b
+    },
+    CLASS_NAME: "OpenLayers.Easing.Quad"
+};
+OpenLayers.Projection = OpenLayers.Class({
+    proj: null,
+    projCode: null,
+    titleRegEx: /\+title=[^\+]*/,
+    initialize: function(a, b) {
+        OpenLayers.Util.extend(this, b);
+        this.projCode = a;
+        window.Proj4js && (this.proj = new Proj4js.Proj(a))
+    },
+    getCode: function() {
+        return this.proj ? this.proj.srsCode : this.projCode
+    },
+    getUnits: function() {
+        return this.proj ? this.proj.units : null
+    },
+    toString: function() {
+        return this.getCode()
+    },
+    equals: function(a) {
+        var b = !1;
+        a && (a instanceof OpenLayers.Projection || (a = new OpenLayers.Projection(a)), window.Proj4js &&
+            this.proj.defData && a.proj.defData ? b = this.proj.defData.replace(this.titleRegEx, "") == a.proj.defData.replace(this.titleRegEx, "") : a.getCode && (b = this.getCode(), a = a.getCode(), b = b == a || !!OpenLayers.Projection.transforms[b] && OpenLayers.Projection.transforms[b][a] === OpenLayers.Projection.nullTransform));
+        return b
+    },
+    destroy: function() {
+        delete this.proj;
+        delete this.projCode
+    },
+    CLASS_NAME: "OpenLayers.Projection"
+});
+OpenLayers.Projection.transforms = {};
+OpenLayers.Projection.defaults = {
+    "EPSG:4326": {
+        units: "degrees",
+        maxExtent: [-180, -90, 180, 90],
+        yx: !0
+    },
+    "CRS:84": {
+        units: "degrees",
+        maxExtent: [-180, -90, 180, 90]
+    },
+    "EPSG:900913": {
+        units: "m",
+        maxExtent: [-2.003750834E7, -2.003750834E7, 2.003750834E7, 2.003750834E7]
+    }
+};
+OpenLayers.Projection.addTransform = function(a, b, c) {
+    if (c === OpenLayers.Projection.nullTransform) {
+        var d = OpenLayers.Projection.defaults[a];
+        d && !OpenLayers.Projection.defaults[b] && (OpenLayers.Projection.defaults[b] = d)
+    }
+    OpenLayers.Projection.transforms[a] || (OpenLayers.Projection.transforms[a] = {});
+    OpenLayers.Projection.transforms[a][b] = c
+};
+OpenLayers.Projection.transform = function(a, b, c) {
+    if (b && c)
+        if (b instanceof OpenLayers.Projection || (b = new OpenLayers.Projection(b)), c instanceof OpenLayers.Projection || (c = new OpenLayers.Projection(c)), b.proj && c.proj) a = Proj4js.transform(b.proj, c.proj, a);
+        else {
+            var b = b.getCode(),
+                c = c.getCode(),
+                d = OpenLayers.Projection.transforms;
+            if (d[b] && d[b][c]) d[b][c](a)
+        }
+    return a
+};
+OpenLayers.Projection.nullTransform = function(a) {
+    return a
+};
+(function() {
+    function a(a) {
+        a.x = 180 * a.x / d;
+        a.y = 180 / Math.PI * (2 * Math.atan(Math.exp(a.y / d * Math.PI)) - Math.PI / 2);
+        return a
+    }
+
+    function b(a) {
+        a.x = a.x * d / 180;
+        a.y = Math.log(Math.tan((90 + a.y) * Math.PI / 360)) / Math.PI * d;
+        return a
+    }
+
+    function c(c, d) {
+        var e = OpenLayers.Projection.addTransform,
+            f = OpenLayers.Projection.nullTransform,
+            g, m, n, o, p;
+        g = 0;
+        for (m = d.length; g < m; ++g) {
+            n = d[g];
+            e(c, n, b);
+            e(n, c, a);
+            for (p = g + 1; p < m; ++p) o = d[p], e(n, o, f), e(o, n, f)
+        }
+    }
+    var d = 2.003750834E7,
+        e = ["EPSG:900913", "EPSG:3857", "EPSG:102113", "EPSG:102100"],
+        f = ["CRS:84", "urn:ogc:def:crs:EPSG:6.6:4326",
+            "EPSG:4326"
+        ],
+        g;
+    for (g = e.length - 1; 0 <= g; --g) c(e[g], f);
+    for (g = f.length - 1; 0 <= g; --g) c(f[g], e)
+})();
+OpenLayers.Map = OpenLayers.Class({
+    Z_INDEX_BASE: {
+        BaseLayer: 100,
+        Overlay: 325,
+        Feature: 725,
+        Popup: 750,
+        Control: 1E3
+    },
+    id: null,
+    fractionalZoom: !1,
+    events: null,
+    allOverlays: !1,
+    div: null,
+    dragging: !1,
+    size: null,
+    viewPortDiv: null,
+    layerContainerOrigin: null,
+    layerContainerDiv: null,
+    layers: null,
+    controls: null,
+    popups: null,
+    baseLayer: null,
+    center: null,
+    resolution: null,
+    zoom: 0,
+    panRatio: 1.5,
+    options: null,
+    tileSize: null,
+    projection: "EPSG:4326",
+    units: null,
+    resolutions: null,
+    maxResolution: null,
+    minResolution: null,
+    maxScale: null,
+    minScale: null,
+    maxExtent: null,
+    minExtent: null,
+    restrictedExtent: null,
+    numZoomLevels: 16,
+    theme: null,
+    displayProjection: null,
+    fallThrough: !0,
+    panTween: null,
+    eventListeners: null,
+    panMethod: OpenLayers.Easing.Expo.easeOut,
+    panDuration: 50,
+    paddingForPopups: null,
+    minPx: null,
+    maxPx: null,
+    initialize: function(a, b) {
+        1 === arguments.length && "object" === typeof a && (a = (b = a) && b.div);
+        this.tileSize = new OpenLayers.Size(OpenLayers.Map.TILE_WIDTH, OpenLayers.Map.TILE_HEIGHT);
+        this.paddingForPopups = new OpenLayers.Bounds(15, 15, 15, 15);
+        this.theme = OpenLayers._getScriptLocation() +
+            "style.css";
+        this.options = OpenLayers.Util.extend({}, b);
+        OpenLayers.Util.extend(this, b);
+        OpenLayers.Util.applyDefaults(this, OpenLayers.Projection.defaults[this.projection instanceof OpenLayers.Projection ? this.projection.projCode : this.projection]);
+        this.maxExtent && !(this.maxExtent instanceof OpenLayers.Bounds) && (this.maxExtent = new OpenLayers.Bounds(this.maxExtent));
+        this.minExtent && !(this.minExtent instanceof OpenLayers.Bounds) && (this.minExtent = new OpenLayers.Bounds(this.minExtent));
+        this.restrictedExtent &&
+            !(this.restrictedExtent instanceof OpenLayers.Bounds) && (this.restrictedExtent = new OpenLayers.Bounds(this.restrictedExtent));
+        this.center && !(this.center instanceof OpenLayers.LonLat) && (this.center = new OpenLayers.LonLat(this.center));
+        this.layers = [];
+        this.id = OpenLayers.Util.createUniqueID("OpenLayers.Map_");
+        this.div = OpenLayers.Util.getElement(a);
+        this.div || (this.div = document.createElement("div"), this.div.style.height = "1px", this.div.style.width = "1px");
+        OpenLayers.Element.addClass(this.div, "olMap");
+        var c =
+            this.id + "_OpenLayers_ViewPort";
+        this.viewPortDiv = OpenLayers.Util.createDiv(c, null, null, null, "relative", null, "hidden");
+        this.viewPortDiv.style.width = "100%";
+        this.viewPortDiv.style.height = "100%";
+        this.viewPortDiv.className = "olMapViewport";
+        this.div.appendChild(this.viewPortDiv);
+        this.events = new OpenLayers.Events(this, this.viewPortDiv, null, this.fallThrough, {
+            includeXY: !0
+        });
+        c = this.id + "_OpenLayers_Container";
+        this.layerContainerDiv = OpenLayers.Util.createDiv(c);
+        this.layerContainerDiv.style.width = "100px";
+        this.layerContainerDiv.style.height =
+            "100px";
+        this.layerContainerDiv.style.zIndex = this.Z_INDEX_BASE.Popup - 1;
+        this.viewPortDiv.appendChild(this.layerContainerDiv);
+        this.updateSize();
+        if (this.eventListeners instanceof Object) this.events.on(this.eventListeners);
+        9 > parseFloat(navigator.appVersion.split("MSIE")[1]) ? this.events.register("resize", this, this.updateSize) : (this.updateSizeDestroy = OpenLayers.Function.bind(this.updateSize, this), OpenLayers.Event.observe(window, "resize", this.updateSizeDestroy));
+        if (this.theme) {
+            for (var c = !0, d = document.getElementsByTagName("link"),
+                    e = 0, f = d.length; e < f; ++e)
+                if (OpenLayers.Util.isEquivalentUrl(d.item(e).href, this.theme)) {
+                    c = !1;
+                    break
+                }
+            c && (c = document.createElement("link"), c.setAttribute("rel", "stylesheet"), c.setAttribute("type", "text/css"), c.setAttribute("href", this.theme), document.getElementsByTagName("head")[0].appendChild(c))
+        }
+        null == this.controls && (this.controls = [], null != OpenLayers.Control && (OpenLayers.Control.Navigation ? this.controls.push(new OpenLayers.Control.Navigation) : OpenLayers.Control.TouchNavigation && this.controls.push(new OpenLayers.Control.TouchNavigation),
+            OpenLayers.Control.Zoom ? this.controls.push(new OpenLayers.Control.Zoom) : OpenLayers.Control.PanZoom && this.controls.push(new OpenLayers.Control.PanZoom), OpenLayers.Control.ArgParser && this.controls.push(new OpenLayers.Control.ArgParser), OpenLayers.Control.Attribution && this.controls.push(new OpenLayers.Control.Attribution)));
+        e = 0;
+        for (f = this.controls.length; e < f; e++) this.addControlToMap(this.controls[e]);
+        this.popups = [];
+        this.unloadDestroy = OpenLayers.Function.bind(this.destroy, this);
+        OpenLayers.Event.observe(window,
+            "unload", this.unloadDestroy);
+        b && b.layers && (delete this.center, this.addLayers(b.layers), b.center && !this.getCenter() && this.setCenter(b.center, b.zoom))
+    },
+    getViewport: function() {
+        return this.viewPortDiv
+    },
+    render: function(a) {
+        this.div = OpenLayers.Util.getElement(a);
+        OpenLayers.Element.addClass(this.div, "olMap");
+        this.viewPortDiv.parentNode.removeChild(this.viewPortDiv);
+        this.div.appendChild(this.viewPortDiv);
+        this.updateSize()
+    },
+    unloadDestroy: null,
+    updateSizeDestroy: null,
+    destroy: function() {
+        if (!this.unloadDestroy) return !1;
+        this.panTween && (this.panTween.stop(), this.panTween = null);
+        OpenLayers.Event.stopObserving(window, "unload", this.unloadDestroy);
+        this.unloadDestroy = null;
+        this.updateSizeDestroy ? OpenLayers.Event.stopObserving(window, "resize", this.updateSizeDestroy) : this.events.unregister("resize", this, this.updateSize);
+        this.paddingForPopups = null;
+        if (null != this.controls) {
+            for (var a = this.controls.length - 1; 0 <= a; --a) this.controls[a].destroy();
+            this.controls = null
+        }
+        if (null != this.layers) {
+            for (a = this.layers.length - 1; 0 <= a; --a) this.layers[a].destroy(!1);
+            this.layers = null
+        }
+        this.viewPortDiv && this.div.removeChild(this.viewPortDiv);
+        this.viewPortDiv = null;
+        this.eventListeners && (this.events.un(this.eventListeners), this.eventListeners = null);
+        this.events.destroy();
+        this.options = this.events = null
+    },
+    setOptions: function(a) {
+        var b = this.minPx && a.restrictedExtent != this.restrictedExtent;
+        OpenLayers.Util.extend(this, a);
+        b && this.moveTo(this.getCachedCenter(), this.zoom, {
+            forceZoomChange: !0
+        })
+    },
+    getTileSize: function() {
+        return this.tileSize
+    },
+    getBy: function(a, b, c) {
+        var d = "function" ==
+            typeof c.test;
+        return OpenLayers.Array.filter(this[a], function(a) {
+            return a[b] == c || d && c.test(a[b])
+        })
+    },
+    getLayersBy: function(a, b) {
+        return this.getBy("layers", a, b)
+    },
+    getLayersByName: function(a) {
+        return this.getLayersBy("name", a)
+    },
+    getLayersByClass: function(a) {
+        return this.getLayersBy("CLASS_NAME", a)
+    },
+    getControlsBy: function(a, b) {
+        return this.getBy("controls", a, b)
+    },
+    getControlsByClass: function(a) {
+        return this.getControlsBy("CLASS_NAME", a)
+    },
+    getLayer: function(a) {
+        for (var b = null, c = 0, d = this.layers.length; c < d; c++) {
+            var e =
+                this.layers[c];
+            if (e.id == a) {
+                b = e;
+                break
+            }
+        }
+        return b
+    },
+    setLayerZIndex: function(a, b) {
+        a.setZIndex(this.Z_INDEX_BASE[a.isBaseLayer ? "BaseLayer" : "Overlay"] + 5 * b)
+    },
+    resetLayersZIndex: function() {
+        for (var a = 0, b = this.layers.length; a < b; a++) this.setLayerZIndex(this.layers[a], a)
+    },
+    addLayer: function(a) {
+        for (var b = 0, c = this.layers.length; b < c; b++)
+            if (this.layers[b] == a) return !1;
+        if (!1 === this.events.triggerEvent("preaddlayer", {
+                layer: a
+            })) return !1;
+        this.allOverlays && (a.isBaseLayer = !1);
+        a.div.className = "olLayerDiv";
+        a.div.style.overflow =
+            "";
+        this.setLayerZIndex(a, this.layers.length);
+        a.isFixed ? this.viewPortDiv.appendChild(a.div) : this.layerContainerDiv.appendChild(a.div);
+        this.layers.push(a);
+        a.setMap(this);
+        a.isBaseLayer || this.allOverlays && !this.baseLayer ? null == this.baseLayer ? this.setBaseLayer(a) : a.setVisibility(!1) : a.redraw();
+        this.events.triggerEvent("addlayer", {
+            layer: a
+        });
+        a.events.triggerEvent("added", {
+            map: this,
+            layer: a
+        });
+        a.afterAdd();
+        return !0
+    },
+    addLayers: function(a) {
+        for (var b = 0, c = a.length; b < c; b++) this.addLayer(a[b])
+    },
+    removeLayer: function(a,
+        b) {
+        if (!1 !== this.events.triggerEvent("preremovelayer", {
+                layer: a
+            })) {
+            null == b && (b = !0);
+            a.isFixed ? this.viewPortDiv.removeChild(a.div) : this.layerContainerDiv.removeChild(a.div);
+            OpenLayers.Util.removeItem(this.layers, a);
+            a.removeMap(this);
+            a.map = null;
+            if (this.baseLayer == a && (this.baseLayer = null, b))
+                for (var c = 0, d = this.layers.length; c < d; c++) {
+                    var e = this.layers[c];
+                    if (e.isBaseLayer || this.allOverlays) {
+                        this.setBaseLayer(e);
+                        break
+                    }
+                }
+            this.resetLayersZIndex();
+            this.events.triggerEvent("removelayer", {
+                layer: a
+            });
+            a.events.triggerEvent("removed", {
+                map: this,
+                layer: a
+            })
+        }
+    },
+    getNumLayers: function() {
+        return this.layers.length
+    },
+    getLayerIndex: function(a) {
+        return OpenLayers.Util.indexOf(this.layers, a)
+    },
+    setLayerIndex: function(a, b) {
+        var c = this.getLayerIndex(a);
+        0 > b ? b = 0 : b > this.layers.length && (b = this.layers.length);
+        if (c != b) {
+            this.layers.splice(c, 1);
+            this.layers.splice(b, 0, a);
+            for (var c = 0, d = this.layers.length; c < d; c++) this.setLayerZIndex(this.layers[c], c);
+            this.events.triggerEvent("changelayer", {
+                layer: a,
+                property: "order"
+            });
+            this.allOverlays && (0 === b ? this.setBaseLayer(a) :
+                this.baseLayer !== this.layers[0] && this.setBaseLayer(this.layers[0]))
+        }
+    },
+    raiseLayer: function(a, b) {
+        var c = this.getLayerIndex(a) + b;
+        this.setLayerIndex(a, c)
+    },
+    setBaseLayer: function(a) {
+        if (a != this.baseLayer && -1 != OpenLayers.Util.indexOf(this.layers, a)) {
+            var b = this.getCachedCenter(),
+                c = OpenLayers.Util.getResolutionFromScale(this.getScale(), a.units);
+            null != this.baseLayer && !this.allOverlays && this.baseLayer.setVisibility(!1);
+            this.baseLayer = a;
+            if (!this.allOverlays || this.baseLayer.visibility) this.baseLayer.setVisibility(!0), !1 === this.baseLayer.inRange && this.baseLayer.redraw();
+            null != b && (a = this.getZoomForResolution(c || this.resolution, !0), this.setCenter(b, a, !1, !0));
+            this.events.triggerEvent("changebaselayer", {
+                layer: this.baseLayer
+            })
+        }
+    },
+    addControl: function(a, b) {
+        this.controls.push(a);
+        this.addControlToMap(a, b)
+    },
+    addControls: function(a, b) {
+        for (var c = 1 === arguments.length ? [] : b, d = 0, e = a.length; d < e; d++) this.addControl(a[d], c[d] ? c[d] : null)
+    },
+    addControlToMap: function(a, b) {
+        a.outsideViewport = null != a.div;
+        this.displayProjection && !a.displayProjection &&
+            (a.displayProjection = this.displayProjection);
+        a.setMap(this);
+        var c = a.draw(b);
+        c && !a.outsideViewport && (c.style.zIndex = this.Z_INDEX_BASE.Control + this.controls.length, this.viewPortDiv.appendChild(c));
+        a.autoActivate && a.activate()
+    },
+    getControl: function(a) {
+        for (var b = null, c = 0, d = this.controls.length; c < d; c++) {
+            var e = this.controls[c];
+            if (e.id == a) {
+                b = e;
+                break
+            }
+        }
+        return b
+    },
+    removeControl: function(a) {
+        a && a == this.getControl(a.id) && (a.div && a.div.parentNode == this.viewPortDiv && this.viewPortDiv.removeChild(a.div), OpenLayers.Util.removeItem(this.controls,
+            a))
+    },
+    addPopup: function(a, b) {
+        if (b)
+            for (var c = this.popups.length - 1; 0 <= c; --c) this.removePopup(this.popups[c]);
+        a.map = this;
+        this.popups.push(a);
+        if (c = a.draw()) c.style.zIndex = this.Z_INDEX_BASE.Popup + this.popups.length, this.layerContainerDiv.appendChild(c)
+    },
+    removePopup: function(a) {
+        OpenLayers.Util.removeItem(this.popups, a);
+        if (a.div) try {
+            this.layerContainerDiv.removeChild(a.div)
+        } catch (b) {}
+        a.map = null
+    },
+    getSize: function() {
+        var a = null;
+        null != this.size && (a = this.size.clone());
+        return a
+    },
+    updateSize: function() {
+        var a = this.getCurrentSize();
+        if (a && !isNaN(a.h) && !isNaN(a.w)) {
+            this.events.clearMouseCache();
+            var b = this.getSize();
+            null == b && (this.size = b = a);
+            if (!a.equals(b)) {
+                this.size = a;
+                a = 0;
+                for (b = this.layers.length; a < b; a++) this.layers[a].onMapResize();
+                a = this.getCachedCenter();
+                null != this.baseLayer && null != a && (b = this.getZoom(), this.zoom = null, this.setCenter(a, b))
+            }
+        }
+    },
+    getCurrentSize: function() {
+        var a = new OpenLayers.Size(this.div.clientWidth, this.div.clientHeight);
+        if (0 == a.w && 0 == a.h || isNaN(a.w) && isNaN(a.h)) a.w = this.div.offsetWidth, a.h = this.div.offsetHeight;
+        if (0 == a.w && 0 == a.h || isNaN(a.w) && isNaN(a.h)) a.w = parseInt(this.div.style.width), a.h = parseInt(this.div.style.height);
+        return a
+    },
+    calculateBounds: function(a, b) {
+        var c = null;
+        null == a && (a = this.getCachedCenter());
+        null == b && (b = this.getResolution());
+        if (null != a && null != b) var c = this.size.w * b / 2,
+            d = this.size.h * b / 2,
+            c = new OpenLayers.Bounds(a.lon - c, a.lat - d, a.lon + c, a.lat + d);
+        return c
+    },
+    getCenter: function() {
+        var a = null,
+            b = this.getCachedCenter();
+        b && (a = b.clone());
+        return a
+    },
+    getCachedCenter: function() {
+        !this.center && this.size && (this.center =
+            this.getLonLatFromViewPortPx({
+                x: this.size.w / 2,
+                y: this.size.h / 2
+            }));
+        return this.center
+    },
+    getZoom: function() {
+        return this.zoom
+    },
+    pan: function(a, b, c) {
+        c = OpenLayers.Util.applyDefaults(c, {
+            animate: !0,
+            dragging: !1
+        });
+        if (c.dragging)(0 != a || 0 != b) && this.moveByPx(a, b);
+        else {
+            var d = this.getViewPortPxFromLonLat(this.getCachedCenter()),
+                a = d.add(a, b);
+            if (this.dragging || !a.equals(d)) d = this.getLonLatFromViewPortPx(a), c.animate ? this.panTo(d) : (this.moveTo(d), this.dragging && (this.dragging = !1, this.events.triggerEvent("moveend")))
+        }
+    },
+    panTo: function(a) {
+        if (this.panMethod && this.getExtent().scale(this.panRatio).containsLonLat(a)) {
+            this.panTween || (this.panTween = new OpenLayers.Tween(this.panMethod));
+            var b = this.getCachedCenter();
+            if (!a.equals(b)) {
+                var b = this.getPixelFromLonLat(b),
+                    c = this.getPixelFromLonLat(a),
+                    d = 0,
+                    e = 0;
+                this.panTween.start({
+                    x: 0,
+                    y: 0
+                }, {
+                    x: c.x - b.x,
+                    y: c.y - b.y
+                }, this.panDuration, {
+                    callbacks: {
+                        eachStep: OpenLayers.Function.bind(function(a) {
+                            this.moveByPx(a.x - d, a.y - e);
+                            d = Math.round(a.x);
+                            e = Math.round(a.y)
+                        }, this),
+                        done: OpenLayers.Function.bind(function() {
+                            this.moveTo(a);
+                            this.dragging = false;
+                            this.events.triggerEvent("moveend")
+                        }, this)
+                    }
+                })
+            }
+        } else this.setCenter(a)
+    },
+    setCenter: function(a, b, c, d) {
+        this.panTween && this.panTween.stop();
+        this.moveTo(a, b, {
+            dragging: c,
+            forceZoomChange: d
+        })
+    },
+    moveByPx: function(a, b) {
+        var c = this.size.w / 2,
+            d = this.size.h / 2,
+            e = c + a,
+            f = d + b,
+            g = this.baseLayer.wrapDateLine,
+            h = 0,
+            i = 0;
+        this.restrictedExtent && (h = c, i = d, g = !1);
+        a = g || e <= this.maxPx.x - h && e >= this.minPx.x + h ? Math.round(a) : 0;
+        b = f <= this.maxPx.y - i && f >= this.minPx.y + i ? Math.round(b) : 0;
+        if (a || b) {
+            this.dragging || (this.dragging = !0, this.events.triggerEvent("movestart"));
+            this.center = null;
+            a && (this.layerContainerDiv.style.left = parseInt(this.layerContainerDiv.style.left) - a + "px", this.minPx.x -= a, this.maxPx.x -= a);
+            b && (this.layerContainerDiv.style.top = parseInt(this.layerContainerDiv.style.top) - b + "px", this.minPx.y -= b, this.maxPx.y -= b);
+            d = 0;
+            for (e = this.layers.length; d < e; ++d)
+                if (c = this.layers[d], c.visibility && (c === this.baseLayer || c.inRange)) c.moveByPx(a, b), c.events.triggerEvent("move");
+            this.events.triggerEvent("move")
+        }
+    },
+    adjustZoom: function(a) {
+        var b =
+            this.baseLayer.resolutions,
+            c = this.getMaxExtent().getWidth() / this.size.w;
+        if (this.getResolutionForZoom(a) > c)
+            for (var d = a | 0, e = b.length; d < e; ++d)
+                if (b[d] <= c) {
+                    a = d;
+                    break
+                }
+        return a
+    },
+    moveTo: function(a, b, c) {
+        null != a && !(a instanceof OpenLayers.LonLat) && (a = new OpenLayers.LonLat(a));
+        c || (c = {});
+        null != b && (b = parseFloat(b), this.fractionalZoom || (b = Math.round(b)));
+        if (this.baseLayer.wrapDateLine) {
+            var d = b,
+                b = this.adjustZoom(b);
+            b !== d && (a = this.getCenter())
+        }
+        var d = c.dragging || this.dragging,
+            e = c.forceZoomChange;
+        !this.getCachedCenter() &&
+            !this.isValidLonLat(a) && (a = this.maxExtent.getCenterLonLat(), this.center = a.clone());
+        if (null != this.restrictedExtent) {
+            null == a && (a = this.center);
+            null == b && (b = this.getZoom());
+            var f = this.getResolutionForZoom(b),
+                f = this.calculateBounds(a, f);
+            if (!this.restrictedExtent.containsBounds(f)) {
+                var g = this.restrictedExtent.getCenterLonLat();
+                f.getWidth() > this.restrictedExtent.getWidth() ? a = new OpenLayers.LonLat(g.lon, a.lat) : f.left < this.restrictedExtent.left ? a = a.add(this.restrictedExtent.left - f.left, 0) : f.right > this.restrictedExtent.right &&
+                    (a = a.add(this.restrictedExtent.right - f.right, 0));
+                f.getHeight() > this.restrictedExtent.getHeight() ? a = new OpenLayers.LonLat(a.lon, g.lat) : f.bottom < this.restrictedExtent.bottom ? a = a.add(0, this.restrictedExtent.bottom - f.bottom) : f.top > this.restrictedExtent.top && (a = a.add(0, this.restrictedExtent.top - f.top))
+            }
+        }
+        e = e || this.isValidZoomLevel(b) && b != this.getZoom();
+        f = this.isValidLonLat(a) && !a.equals(this.center);
+        if (e || f || d) {
+            d || this.events.triggerEvent("movestart");
+            f && (!e && this.center && this.centerLayerContainer(a), this.center =
+                a.clone());
+            a = e ? this.getResolutionForZoom(b) : this.getResolution();
+            if (e || null == this.layerContainerOrigin) {
+                this.layerContainerOrigin = this.getCachedCenter();
+                this.layerContainerDiv.style.left = "0px";
+                this.layerContainerDiv.style.top = "0px";
+                var f = this.getMaxExtent({
+                        restricted: !0
+                    }),
+                    h = f.getCenterLonLat(),
+                    g = this.center.lon - h.lon,
+                    h = h.lat - this.center.lat,
+                    i = Math.round(f.getWidth() / a),
+                    j = Math.round(f.getHeight() / a);
+                this.minPx = {
+                    x: (this.size.w - i) / 2 - g / a,
+                    y: (this.size.h - j) / 2 - h / a
+                };
+                this.maxPx = {
+                    x: this.minPx.x + Math.round(f.getWidth() /
+                        a),
+                    y: this.minPx.y + Math.round(f.getHeight() / a)
+                }
+            }
+            e && (this.zoom = b, this.resolution = a);
+            a = this.getExtent();
+            this.baseLayer.visibility && (this.baseLayer.moveTo(a, e, c.dragging), c.dragging || this.baseLayer.events.triggerEvent("moveend", {
+                zoomChanged: e
+            }));
+            a = this.baseLayer.getExtent();
+            for (b = this.layers.length - 1; 0 <= b; --b)
+                if (f = this.layers[b], f !== this.baseLayer && !f.isBaseLayer && (g = f.calculateInRange(), f.inRange != g && ((f.inRange = g) || f.display(!1), this.events.triggerEvent("changelayer", {
+                            layer: f,
+                            property: "visibility"
+                        })),
+                        g && f.visibility)) f.moveTo(a, e, c.dragging), c.dragging || f.events.triggerEvent("moveend", {
+                    zoomChanged: e
+                });
+            this.events.triggerEvent("move");
+            d || this.events.triggerEvent("moveend");
+            if (e) {
+                b = 0;
+                for (c = this.popups.length; b < c; b++) this.popups[b].updatePosition();
+                this.events.triggerEvent("zoomend")
+            }
+        }
+    },
+    centerLayerContainer: function(a) {
+        var b = this.getViewPortPxFromLonLat(this.layerContainerOrigin),
+            c = this.getViewPortPxFromLonLat(a);
+        if (null != b && null != c) {
+            var d = parseInt(this.layerContainerDiv.style.left),
+                a = parseInt(this.layerContainerDiv.style.top),
+                e = Math.round(b.x - c.x),
+                b = Math.round(b.y - c.y);
+            this.layerContainerDiv.style.left = e + "px";
+            this.layerContainerDiv.style.top = b + "px";
+            d -= e;
+            a -= b;
+            this.minPx.x -= d;
+            this.maxPx.x -= d;
+            this.minPx.y -= a;
+            this.maxPx.y -= a
+        }
+    },
+    isValidZoomLevel: function(a) {
+        return null != a && 0 <= a && a < this.getNumZoomLevels()
+    },
+    isValidLonLat: function(a) {
+        var b = !1;
+        null != a && (b = this.getMaxExtent(), b = b.containsLonLat(a, {
+            worldBounds: this.baseLayer.wrapDateLine && b
+        }));
+        return b
+    },
+    getProjection: function() {
+        var a = this.getProjectionObject();
+        return a ? a.getCode() :
+            null
+    },
+    getProjectionObject: function() {
+        var a = null;
+        null != this.baseLayer && (a = this.baseLayer.projection);
+        return a
+    },
+    getMaxResolution: function() {
+        var a = null;
+        null != this.baseLayer && (a = this.baseLayer.maxResolution);
+        return a
+    },
+    getMaxExtent: function(a) {
+        var b = null;
+        a && a.restricted && this.restrictedExtent ? b = this.restrictedExtent : null != this.baseLayer && (b = this.baseLayer.maxExtent);
+        return b
+    },
+    getNumZoomLevels: function() {
+        var a = null;
+        null != this.baseLayer && (a = this.baseLayer.numZoomLevels);
+        return a
+    },
+    getExtent: function() {
+        var a =
+            null;
+        null != this.baseLayer && (a = this.baseLayer.getExtent());
+        return a
+    },
+    getResolution: function() {
+        var a = null;
+        null != this.baseLayer ? a = this.baseLayer.getResolution() : !0 === this.allOverlays && 0 < this.layers.length && (a = this.layers[0].getResolution());
+        return a
+    },
+    getUnits: function() {
+        var a = null;
+        null != this.baseLayer && (a = this.baseLayer.units);
+        return a
+    },
+    getScale: function() {
+        var a = null;
+        null != this.baseLayer && (a = this.getResolution(), a = OpenLayers.Util.getScaleFromResolution(a, this.baseLayer.units));
+        return a
+    },
+    getZoomForExtent: function(a,
+        b) {
+        var c = null;
+        null != this.baseLayer && (c = this.baseLayer.getZoomForExtent(a, b));
+        return c
+    },
+    getResolutionForZoom: function(a) {
+        var b = null;
+        this.baseLayer && (b = this.baseLayer.getResolutionForZoom(a));
+        return b
+    },
+    getZoomForResolution: function(a, b) {
+        var c = null;
+        null != this.baseLayer && (c = this.baseLayer.getZoomForResolution(a, b));
+        return c
+    },
+    zoomTo: function(a) {
+        this.isValidZoomLevel(a) && this.setCenter(null, a)
+    },
+    zoomIn: function() {
+        this.zoomTo(this.getZoom() + 1)
+    },
+    zoomOut: function() {
+        this.zoomTo(this.getZoom() - 1)
+    },
+    zoomToExtent: function(a,
+        b) {
+        a instanceof OpenLayers.Bounds || (a = new OpenLayers.Bounds(a));
+        var c = a.getCenterLonLat();
+        if (this.baseLayer.wrapDateLine) {
+            c = this.getMaxExtent();
+            for (a = a.clone(); a.right < a.left;) a.right += c.getWidth();
+            c = a.getCenterLonLat().wrapDateLine(c)
+        }
+        this.setCenter(c, this.getZoomForExtent(a, b))
+    },
+    zoomToMaxExtent: function(a) {
+        this.zoomToExtent(this.getMaxExtent({
+            restricted: a ? a.restricted : !0
+        }))
+    },
+    zoomToScale: function(a, b) {
+        var c = OpenLayers.Util.getResolutionFromScale(a, this.baseLayer.units),
+            d = this.size.w * c / 2,
+            c = this.size.h *
+            c / 2,
+            e = this.getCachedCenter();
+        this.zoomToExtent(new OpenLayers.Bounds(e.lon - d, e.lat - c, e.lon + d, e.lat + c), b)
+    },
+    getLonLatFromViewPortPx: function(a) {
+        var b = null;
+        null != this.baseLayer && (b = this.baseLayer.getLonLatFromViewPortPx(a));
+        return b
+    },
+    getViewPortPxFromLonLat: function(a) {
+        var b = null;
+        null != this.baseLayer && (b = this.baseLayer.getViewPortPxFromLonLat(a));
+        return b
+    },
+    getLonLatFromPixel: function(a) {
+        return this.getLonLatFromViewPortPx(a)
+    },
+    getPixelFromLonLat: function(a) {
+        a = this.getViewPortPxFromLonLat(a);
+        a.x = Math.round(a.x);
+        a.y = Math.round(a.y);
+        return a
+    },
+    getGeodesicPixelSize: function(a) {
+        var b = a ? this.getLonLatFromPixel(a) : this.getCachedCenter() || new OpenLayers.LonLat(0, 0),
+            c = this.getResolution(),
+            a = b.add(-c / 2, 0),
+            d = b.add(c / 2, 0),
+            e = b.add(0, -c / 2),
+            b = b.add(0, c / 2),
+            c = new OpenLayers.Projection("EPSG:4326"),
+            f = this.getProjectionObject() || c;
+        f.equals(c) || (a.transform(f, c), d.transform(f, c), e.transform(f, c), b.transform(f, c));
+        return new OpenLayers.Size(OpenLayers.Util.distVincenty(a, d), OpenLayers.Util.distVincenty(e, b))
+    },
+    getViewPortPxFromLayerPx: function(a) {
+        var b =
+            null;
+        if (null != a) var b = parseInt(this.layerContainerDiv.style.left),
+            c = parseInt(this.layerContainerDiv.style.top),
+            b = a.add(b, c);
+        return b
+    },
+    getLayerPxFromViewPortPx: function(a) {
+        var b = null;
+        if (null != a) {
+            var b = -parseInt(this.layerContainerDiv.style.left),
+                c = -parseInt(this.layerContainerDiv.style.top),
+                b = a.add(b, c);
+            if (isNaN(b.x) || isNaN(b.y)) b = null
+        }
+        return b
+    },
+    getLonLatFromLayerPx: function(a) {
+        a = this.getViewPortPxFromLayerPx(a);
+        return this.getLonLatFromViewPortPx(a)
+    },
+    getLayerPxFromLonLat: function(a) {
+        return this.getLayerPxFromViewPortPx(this.getPixelFromLonLat(a))
+    },
+    CLASS_NAME: "OpenLayers.Map"
+});
+OpenLayers.Map.TILE_WIDTH = 256;
+OpenLayers.Map.TILE_HEIGHT = 256;
+OpenLayers.Layer = OpenLayers.Class({
+    id: null,
+    name: null,
+    div: null,
+    opacity: 1,
+    alwaysInRange: null,
+    RESOLUTION_PROPERTIES: "scales resolutions maxScale minScale maxResolution minResolution numZoomLevels maxZoomLevel".split(" "),
+    events: null,
+    map: null,
+    isBaseLayer: !1,
+    alpha: !1,
+    displayInLayerSwitcher: !0,
+    visibility: !0,
+    attribution: null,
+    inRange: !1,
+    imageSize: null,
+    options: null,
+    eventListeners: null,
+    gutter: 0,
+    projection: null,
+    units: null,
+    scales: null,
+    resolutions: null,
+    maxExtent: null,
+    minExtent: null,
+    maxResolution: null,
+    minResolution: null,
+    numZoomLevels: null,
+    minScale: null,
+    maxScale: null,
+    displayOutsideMaxExtent: !1,
+    wrapDateLine: !1,
+    metadata: null,
+    initialize: function(a, b) {
+        this.metadata = {};
+        this.addOptions(b);
+        this.name = a;
+        if (null == this.id && (this.id = OpenLayers.Util.createUniqueID(this.CLASS_NAME + "_"), this.div = OpenLayers.Util.createDiv(this.id), this.div.style.width = "100%", this.div.style.height = "100%", this.div.dir = "ltr", this.events = new OpenLayers.Events(this, this.div), this.eventListeners instanceof Object)) this.events.on(this.eventListeners)
+    },
+    destroy: function(a) {
+        null == a && (a = !0);
+        null != this.map && this.map.removeLayer(this, a);
+        this.options = this.div = this.name = this.map = this.projection = null;
+        this.events && (this.eventListeners && this.events.un(this.eventListeners), this.events.destroy());
+        this.events = this.eventListeners = null
+    },
+    clone: function(a) {
+        null == a && (a = new OpenLayers.Layer(this.name, this.getOptions()));
+        OpenLayers.Util.applyDefaults(a, this);
+        a.map = null;
+        return a
+    },
+    getOptions: function() {
+        var a = {},
+            b;
+        for (b in this.options) a[b] = this[b];
+        return a
+    },
+    setName: function(a) {
+        a !=
+            this.name && (this.name = a, null != this.map && this.map.events.triggerEvent("changelayer", {
+                layer: this,
+                property: "name"
+            }))
+    },
+    addOptions: function(a, b) {
+        null == this.options && (this.options = {});
+        if (a && ("string" == typeof a.projection && (a.projection = new OpenLayers.Projection(a.projection)), a.projection && OpenLayers.Util.applyDefaults(a, OpenLayers.Projection.defaults[a.projection.getCode()]), a.maxExtent && !(a.maxExtent instanceof OpenLayers.Bounds) && (a.maxExtent = new OpenLayers.Bounds(a.maxExtent)), a.minExtent && !(a.minExtent instanceof OpenLayers.Bounds))) a.minExtent = new OpenLayers.Bounds(a.minExtent);
+        OpenLayers.Util.extend(this.options, a);
+        OpenLayers.Util.extend(this, a);
+        this.projection && this.projection.getUnits() && (this.units = this.projection.getUnits());
+        if (this.map) {
+            var c = this.map.getResolution(),
+                d = this.RESOLUTION_PROPERTIES.concat(["projection", "units", "minExtent", "maxExtent"]),
+                e;
+            for (e in a)
+                if (a.hasOwnProperty(e) && 0 <= OpenLayers.Util.indexOf(d, e)) {
+                    this.initResolutions();
+                    b && this.map.baseLayer === this && (this.map.setCenter(this.map.getCenter(),
+                        this.map.getZoomForResolution(c), !1, !0), this.map.events.triggerEvent("changebaselayer", {
+                        layer: this
+                    }));
+                    break
+                }
+        }
+    },
+    onMapResize: function() {},
+    redraw: function() {
+        var a = !1;
+        if (this.map) {
+            this.inRange = this.calculateInRange();
+            var b = this.getExtent();
+            b && (this.inRange && this.visibility) && (this.moveTo(b, !0, !1), this.events.triggerEvent("moveend", {
+                zoomChanged: !0
+            }), a = !0)
+        }
+        return a
+    },
+    moveTo: function() {
+        var a = this.visibility;
+        this.isBaseLayer || (a = a && this.inRange);
+        this.display(a)
+    },
+    moveByPx: function() {},
+    setMap: function(a) {
+        null ==
+            this.map && (this.map = a, this.maxExtent = this.maxExtent || this.map.maxExtent, this.minExtent = this.minExtent || this.map.minExtent, this.projection = this.projection || this.map.projection, "string" == typeof this.projection && (this.projection = new OpenLayers.Projection(this.projection)), this.units = this.projection.getUnits() || this.units || this.map.units, this.initResolutions(), this.isBaseLayer || (this.inRange = this.calculateInRange(), this.div.style.display = this.visibility && this.inRange ? "" : "none"), this.setTileSize())
+    },
+    afterAdd: function() {},
+    removeMap: function() {},
+    getImageSize: function() {
+        return this.imageSize || this.tileSize
+    },
+    setTileSize: function(a) {
+        this.tileSize = a = a ? a : this.tileSize ? this.tileSize : this.map.getTileSize();
+        this.gutter && (this.imageSize = new OpenLayers.Size(a.w + 2 * this.gutter, a.h + 2 * this.gutter))
+    },
+    getVisibility: function() {
+        return this.visibility
+    },
+    setVisibility: function(a) {
+        a != this.visibility && (this.visibility = a, this.display(a), this.redraw(), null != this.map && this.map.events.triggerEvent("changelayer", {
+                layer: this,
+                property: "visibility"
+            }),
+            this.events.triggerEvent("visibilitychanged"))
+    },
+    display: function(a) {
+        a != ("none" != this.div.style.display) && (this.div.style.display = a && this.calculateInRange() ? "block" : "none")
+    },
+    calculateInRange: function() {
+        var a = !1;
+        this.alwaysInRange ? a = !0 : this.map && (a = this.map.getResolution(), a = a >= this.minResolution && a <= this.maxResolution);
+        return a
+    },
+    setIsBaseLayer: function(a) {
+        a != this.isBaseLayer && (this.isBaseLayer = a, null != this.map && this.map.events.triggerEvent("changebaselayer", {
+            layer: this
+        }))
+    },
+    initResolutions: function() {
+        var a,
+            b, c, d = {},
+            e = !0;
+        a = 0;
+        for (b = this.RESOLUTION_PROPERTIES.length; a < b; a++) c = this.RESOLUTION_PROPERTIES[a], d[c] = this.options[c], e && this.options[c] && (e = !1);
+        null == this.alwaysInRange && (this.alwaysInRange = e);
+        null == d.resolutions && (d.resolutions = this.resolutionsFromScales(d.scales));
+        null == d.resolutions && (d.resolutions = this.calculateResolutions(d));
+        if (null == d.resolutions) {
+            a = 0;
+            for (b = this.RESOLUTION_PROPERTIES.length; a < b; a++) c = this.RESOLUTION_PROPERTIES[a], d[c] = null != this.options[c] ? this.options[c] : this.map[c];
+            null ==
+                d.resolutions && (d.resolutions = this.resolutionsFromScales(d.scales));
+            null == d.resolutions && (d.resolutions = this.calculateResolutions(d))
+        }
+        var f;
+        this.options.maxResolution && "auto" !== this.options.maxResolution && (f = this.options.maxResolution);
+        this.options.minScale && (f = OpenLayers.Util.getResolutionFromScale(this.options.minScale, this.units));
+        var g;
+        this.options.minResolution && "auto" !== this.options.minResolution && (g = this.options.minResolution);
+        this.options.maxScale && (g = OpenLayers.Util.getResolutionFromScale(this.options.maxScale,
+            this.units));
+        d.resolutions && (d.resolutions.sort(function(a, b) {
+            return b - a
+        }), f || (f = d.resolutions[0]), g || (g = d.resolutions[d.resolutions.length - 1]));
+        if (this.resolutions = d.resolutions) {
+            b = this.resolutions.length;
+            this.scales = Array(b);
+            for (a = 0; a < b; a++) this.scales[a] = OpenLayers.Util.getScaleFromResolution(this.resolutions[a], this.units);
+            this.numZoomLevels = b
+        }
+        if (this.minResolution = g) this.maxScale = OpenLayers.Util.getScaleFromResolution(g, this.units);
+        if (this.maxResolution = f) this.minScale = OpenLayers.Util.getScaleFromResolution(f,
+            this.units)
+    },
+    resolutionsFromScales: function(a) {
+        if (null != a) {
+            var b, c, d;
+            d = a.length;
+            b = Array(d);
+            for (c = 0; c < d; c++) b[c] = OpenLayers.Util.getResolutionFromScale(a[c], this.units);
+            return b
+        }
+    },
+    calculateResolutions: function(a) {
+        var b, c, d = a.maxResolution;
+        null != a.minScale ? d = OpenLayers.Util.getResolutionFromScale(a.minScale, this.units) : "auto" == d && null != this.maxExtent && (b = this.map.getSize(), c = this.maxExtent.getWidth() / b.w, b = this.maxExtent.getHeight() / b.h, d = Math.max(c, b));
+        c = a.minResolution;
+        null != a.maxScale ? c = OpenLayers.Util.getResolutionFromScale(a.maxScale,
+            this.units) : "auto" == a.minResolution && null != this.minExtent && (b = this.map.getSize(), c = this.minExtent.getWidth() / b.w, b = this.minExtent.getHeight() / b.h, c = Math.max(c, b));
+        "number" !== typeof d && ("number" !== typeof c && null != this.maxExtent) && (d = this.map.getTileSize(), d = Math.max(this.maxExtent.getWidth() / d.w, this.maxExtent.getHeight() / d.h));
+        b = a.maxZoomLevel;
+        a = a.numZoomLevels;
+        "number" === typeof c && "number" === typeof d && void 0 === a ? a = Math.floor(Math.log(d / c) / Math.log(2)) + 1 : void 0 === a && null != b && (a = b + 1);
+        if (!("number" !==
+                typeof a || 0 >= a || "number" !== typeof d && "number" !== typeof c)) {
+            b = Array(a);
+            var e = 2;
+            "number" == typeof c && "number" == typeof d && (e = Math.pow(d / c, 1 / (a - 1)));
+            var f;
+            if ("number" === typeof d)
+                for (f = 0; f < a; f++) b[f] = d / Math.pow(e, f);
+            else
+                for (f = 0; f < a; f++) b[a - 1 - f] = c * Math.pow(e, f);
+            return b
+        }
+    },
+    getResolution: function() {
+        return this.getResolutionForZoom(this.map.getZoom())
+    },
+    getExtent: function() {
+        return this.map.calculateBounds()
+    },
+    getZoomForExtent: function(a, b) {
+        var c = this.map.getSize();
+        return this.getZoomForResolution(Math.max(a.getWidth() /
+            c.w, a.getHeight() / c.h), b)
+    },
+    getDataExtent: function() {},
+    getResolutionForZoom: function(a) {
+        a = Math.max(0, Math.min(a, this.resolutions.length - 1));
+        if (this.map.fractionalZoom) var b = Math.floor(a),
+            c = Math.ceil(a),
+            a = this.resolutions[b] - (a - b) * (this.resolutions[b] - this.resolutions[c]);
+        else a = this.resolutions[Math.round(a)];
+        return a
+    },
+    getZoomForResolution: function(a, b) {
+        var c, d;
+        if (this.map.fractionalZoom) {
+            var e = 0,
+                f = this.resolutions[e],
+                g = this.resolutions[this.resolutions.length - 1],
+                h;
+            c = 0;
+            for (d = this.resolutions.length; c <
+                d; ++c)
+                if (h = this.resolutions[c], h >= a && (f = h, e = c), h <= a) {
+                    g = h;
+                    break
+                }
+            c = f - g;
+            c = 0 < c ? e + (f - a) / c : e
+        } else {
+            f = Number.POSITIVE_INFINITY;
+            c = 0;
+            for (d = this.resolutions.length; c < d; c++)
+                if (b) {
+                    e = Math.abs(this.resolutions[c] - a);
+                    if (e > f) break;
+                    f = e
+                } else if (this.resolutions[c] < a) break;
+            c = Math.max(0, c - 1)
+        }
+        return c
+    },
+    getLonLatFromViewPortPx: function(a) {
+        var b = null,
+            c = this.map;
+        if (null != a && c.minPx) {
+            var b = c.getResolution(),
+                d = c.getMaxExtent({
+                    restricted: !0
+                }),
+                b = new OpenLayers.LonLat( (a.x - c.minPx.x) * b + d.left, (c.minPx.y - a.y) * b + d.top);
+                
+                //MOD PER COORDINATE ASTRO - MOD ASTRO
+                step_x=-0.000888889;
+                step_y=0.000888889;
+         //     b = new OpenLayers.LonLat( ((a.x - c.minPx.x) * b + d.left)*step_x, ((c.minPx.y - a.y) * b + d.top)*step_y);
+/*
+                 Coordinata1 = X*step + offset_X ;
+                 Coordinata 2= Y*step + offset_Y
+                 */
+            this.wrapDateLine &&
+                (b = b.wrapDateLine(this.maxExtent))
+        }
+
+        return b
+    },
+    getViewPortPxFromLonLat: function(a, b) {
+        var c = null;
+        null != a && (b = b || this.map.getResolution(), c = this.map.calculateBounds(null, b), c = new OpenLayers.Pixel(1 / b * (a.lon - c.left), 1 / b * (c.top - a.lat)));
+        return c
+    },
+    setOpacity: function(a) {
+        if (a != this.opacity) {
+            this.opacity = a;
+            for (var b = this.div.childNodes, c = 0, d = b.length; c < d; ++c) {
+                var e = b[c].firstChild || b[c],
+                    f = b[c].lastChild;
+                f && "iframe" === f.nodeName.toLowerCase() && (e = f.parentNode);
+                OpenLayers.Util.modifyDOMElement(e, null, null, null,
+                    null, null, null, a)
+            }
+            null != this.map && this.map.events.triggerEvent("changelayer", {
+                layer: this,
+                property: "opacity"
+            })
+        }
+    },
+    getZIndex: function() {
+        return this.div.style.zIndex
+    },
+    setZIndex: function(a) {
+        this.div.style.zIndex = a
+    },
+    adjustBounds: function(a) {
+        if (this.gutter) var b = this.gutter * this.map.getResolution(),
+            a = new OpenLayers.Bounds(a.left - b, a.bottom - b, a.right + b, a.top + b);
+        this.wrapDateLine && (b = {
+            rightTolerance: this.getResolution(),
+            leftTolerance: this.getResolution()
+        }, a = a.wrapDateLine(this.maxExtent, b));
+        return a
+    },
+    CLASS_NAME: "OpenLayers.Layer"
+});
+OpenLayers.Layer.SphericalMercator = {
+    getExtent: function() {
+        var a = null;
+        return a = this.sphericalMercator ? this.map.calculateBounds() : OpenLayers.Layer.FixedZoomLevels.prototype.getExtent.apply(this)
+    },
+    getLonLatFromViewPortPx: function(a) {
+        return OpenLayers.Layer.prototype.getLonLatFromViewPortPx.apply(this, arguments)
+    },
+    getViewPortPxFromLonLat: function(a) {
+        return OpenLayers.Layer.prototype.getViewPortPxFromLonLat.apply(this, arguments)
+    },
+    initMercatorParameters: function() {
+        this.RESOLUTIONS = [];
+        for (var a = 0; a <= this.MAX_ZOOM_LEVEL; ++a) this.RESOLUTIONS[a] =
+            156543.03390625 / Math.pow(2, a);
+        this.units = "m";
+        this.projection = this.projection || "EPSG:900913"
+    },
+    forwardMercator: function() {
+        var a = new OpenLayers.Projection("EPSG:4326"),
+            b = new OpenLayers.Projection("EPSG:900913");
+        return function(c, d) {
+            var e = OpenLayers.Projection.transform({
+                x: c,
+                y: d
+            }, a, b);
+            return new OpenLayers.LonLat(e.x, e.y)
+        }
+    }(),
+    inverseMercator: function() {
+        var a = new OpenLayers.Projection("EPSG:4326"),
+            b = new OpenLayers.Projection("EPSG:900913");
+        return function(c, d) {
+            var e = OpenLayers.Projection.transform({
+                x: c,
+                y: d
+            }, b, a);
+            return new OpenLayers.LonLat(e.x, e.y)
+        }
+    }()
+};
+OpenLayers.Layer.EventPane = OpenLayers.Class(OpenLayers.Layer, {
+    smoothDragPan: !0,
+    isBaseLayer: !0,
+    isFixed: !0,
+    pane: null,
+    mapObject: null,
+    initialize: function(a, b) {
+        OpenLayers.Layer.prototype.initialize.apply(this, arguments);
+        null == this.pane && (this.pane = OpenLayers.Util.createDiv(this.div.id + "_EventPane"))
+    },
+    destroy: function() {
+        this.pane = this.mapObject = null;
+        OpenLayers.Layer.prototype.destroy.apply(this, arguments)
+    },
+    setMap: function(a) {
+        OpenLayers.Layer.prototype.setMap.apply(this, arguments);
+        this.pane.style.zIndex =
+            parseInt(this.div.style.zIndex) + 1;
+        this.pane.style.display = this.div.style.display;
+        this.pane.style.width = "100%";
+        this.pane.style.height = "100%";
+        "msie" == OpenLayers.BROWSER_NAME && (this.pane.style.background = "url(" + OpenLayers.Util.getImageLocation("blank.gif") + ")");
+        this.isFixed ? this.map.viewPortDiv.appendChild(this.pane) : this.map.layerContainerDiv.appendChild(this.pane);
+        this.loadMapObject();
+        null == this.mapObject && this.loadWarningMessage()
+    },
+    removeMap: function(a) {
+        this.pane && this.pane.parentNode && this.pane.parentNode.removeChild(this.pane);
+        OpenLayers.Layer.prototype.removeMap.apply(this, arguments)
+    },
+    loadWarningMessage: function() {
+        this.div.style.backgroundColor = "darkblue";
+        var a = this.map.getSize(),
+            b = Math.min(a.w, 300),
+            c = Math.min(a.h, 200),
+            b = new OpenLayers.Size(b, c),
+            a = (new OpenLayers.Pixel(a.w / 2, a.h / 2)).add(-b.w / 2, -b.h / 2),
+            a = OpenLayers.Util.createDiv(this.name + "_warning", a, b, null, null, null, "auto");
+        a.style.padding = "7px";
+        a.style.backgroundColor = "yellow";
+        a.innerHTML = this.getWarningHTML();
+        this.div.appendChild(a)
+    },
+    getWarningHTML: function() {
+        return ""
+    },
+    display: function(a) {
+        OpenLayers.Layer.prototype.display.apply(this, arguments);
+        this.pane.style.display = this.div.style.display
+    },
+    setZIndex: function(a) {
+        OpenLayers.Layer.prototype.setZIndex.apply(this, arguments);
+        this.pane.style.zIndex = parseInt(this.div.style.zIndex) + 1
+    },
+    moveByPx: function(a, b) {
+        OpenLayers.Layer.prototype.moveByPx.apply(this, arguments);
+        this.dragPanMapObject ? this.dragPanMapObject(a, -b) : this.moveTo(this.map.getCachedCenter())
+    },
+    moveTo: function(a, b, c) {
+        OpenLayers.Layer.prototype.moveTo.apply(this,
+            arguments);
+        if (null != this.mapObject) {
+            var d = this.map.getCenter(),
+                e = this.map.getZoom();
+            if (null != d) {
+                var f = this.getOLLonLatFromMapObjectLonLat(this.getMapObjectCenter()),
+                    g = this.getOLZoomFromMapObjectZoom(this.getMapObjectZoom());
+                if (!d.equals(f) || e != g) !b && f && this.dragPanMapObject && this.smoothDragPan ? (e = this.map.getViewPortPxFromLonLat(f), d = this.map.getViewPortPxFromLonLat(d), this.dragPanMapObject(d.x - e.x, e.y - d.y)) : (d = this.getMapObjectLonLatFromOLLonLat(d), e = this.getMapObjectZoomFromOLZoom(e), this.setMapObjectCenter(d,
+                    e, c))
+            }
+        }
+    },
+    getLonLatFromViewPortPx: function(a) {
+        var b = null;
+        null != this.mapObject && null != this.getMapObjectCenter() && (b = this.getOLLonLatFromMapObjectLonLat(this.getMapObjectLonLatFromMapObjectPixel(this.getMapObjectPixelFromOLPixel(a))));
+        return b
+    },
+    getViewPortPxFromLonLat: function(a) {
+        var b = null;
+        null != this.mapObject && null != this.getMapObjectCenter() && (b = this.getOLPixelFromMapObjectPixel(this.getMapObjectPixelFromMapObjectLonLat(this.getMapObjectLonLatFromOLLonLat(a))));
+        return b
+    },
+    getOLLonLatFromMapObjectLonLat: function(a) {
+        var b =
+            null;
+        null != a && (b = this.getLongitudeFromMapObjectLonLat(a), a = this.getLatitudeFromMapObjectLonLat(a), b = new OpenLayers.LonLat(b, a));
+        return b
+    },
+    getMapObjectLonLatFromOLLonLat: function(a) {
+        var b = null;
+        null != a && (b = this.getMapObjectLonLatFromLonLat(a.lon, a.lat));
+        return b
+    },
+    getOLPixelFromMapObjectPixel: function(a) {
+        var b = null;
+        null != a && (b = this.getXFromMapObjectPixel(a), a = this.getYFromMapObjectPixel(a), b = new OpenLayers.Pixel(b, a));
+        return b
+    },
+    getMapObjectPixelFromOLPixel: function(a) {
+        var b = null;
+        null != a && (b = this.getMapObjectPixelFromXY(a.x,
+            a.y));
+        return b
+    },
+    CLASS_NAME: "OpenLayers.Layer.EventPane"
+});
+OpenLayers.Layer.FixedZoomLevels = OpenLayers.Class({
+    initialize: function() {},
+    initResolutions: function() {
+        for (var a = ["minZoomLevel", "maxZoomLevel", "numZoomLevels"], b = 0, c = a.length; b < c; b++) {
+            var d = a[b];
+            this[d] = null != this.options[d] ? this.options[d] : this.map[d]
+        }
+        if (null == this.minZoomLevel || this.minZoomLevel < this.MIN_ZOOM_LEVEL) this.minZoomLevel = this.MIN_ZOOM_LEVEL;
+        a = this.MAX_ZOOM_LEVEL - this.minZoomLevel + 1;
+        b = null == this.options.numZoomLevels && null != this.options.maxZoomLevel || null == this.numZoomLevels && null != this.maxZoomLevel ?
+            this.maxZoomLevel - this.minZoomLevel + 1 : this.numZoomLevels;
+        this.numZoomLevels = null != b ? Math.min(b, a) : a;
+        this.maxZoomLevel = this.minZoomLevel + this.numZoomLevels - 1;
+        if (null != this.RESOLUTIONS) {
+            a = 0;
+            this.resolutions = [];
+            for (b = this.minZoomLevel; b <= this.maxZoomLevel; b++) this.resolutions[a++] = this.RESOLUTIONS[b];
+            this.maxResolution = this.resolutions[0];
+            this.minResolution = this.resolutions[this.resolutions.length - 1]
+        }
+    },
+    getResolution: function() {
+        if (null != this.resolutions) return OpenLayers.Layer.prototype.getResolution.apply(this,
+            arguments);
+        var a = null,
+            b = this.map.getSize(),
+            c = this.getExtent();
+        null != b && null != c && (a = Math.max(c.getWidth() / b.w, c.getHeight() / b.h));
+        return a
+    },
+    getExtent: function() {
+        var a = this.map.getSize(),
+            b = this.getLonLatFromViewPortPx({
+                x: 0,
+                y: 0
+            }),
+            a = this.getLonLatFromViewPortPx({
+                x: a.w,
+                y: a.h
+            });
+        return null != b && null != a ? new OpenLayers.Bounds(b.lon, a.lat, a.lon, b.lat) : null
+    },
+    getZoomForResolution: function(a) {
+        return null != this.resolutions ? OpenLayers.Layer.prototype.getZoomForResolution.apply(this, arguments) : this.getZoomForExtent(OpenLayers.Layer.prototype.getExtent.apply(this, []))
+    },
+    getOLZoomFromMapObjectZoom: function(a) {
+        var b = null;
+        null != a && (b = a - this.minZoomLevel, this.map.baseLayer !== this && (b = this.map.baseLayer.getZoomForResolution(this.getResolutionForZoom(b))));
+        return b
+    },
+    getMapObjectZoomFromOLZoom: function(a) {
+        var b = null;
+        null != a && (b = a + this.minZoomLevel, this.map.baseLayer !== this && (b = this.getZoomForResolution(this.map.baseLayer.getResolutionForZoom(b))));
+        return b
+    },
+    CLASS_NAME: "OpenLayers.Layer.FixedZoomLevels"
+});
+OpenLayers.Layer.Google = OpenLayers.Class(OpenLayers.Layer.EventPane, OpenLayers.Layer.FixedZoomLevels, {
+    MIN_ZOOM_LEVEL: 0,
+    MAX_ZOOM_LEVEL: 21,
+    RESOLUTIONS: [1.40625, 0.703125, 0.3515625, 0.17578125, 0.087890625, 0.0439453125, 0.02197265625, 0.010986328125, 0.0054931640625, 0.00274658203125, 0.001373291015625, 6.866455078125E-4, 3.4332275390625E-4, 1.71661376953125E-4, 8.58306884765625E-5, 4.291534423828125E-5, 2.145767211914062E-5, 1.072883605957031E-5, 5.36441802978515E-6, 2.68220901489257E-6, 1.341104507446289E-6, 6.705522537231445E-7],
+    type: null,
+    wrapDateLine: !0,
+    sphericalMercator: !1,
+    version: null,
+    initialize: function(a, b) {
+        b = b || {};
+        b.version || (b.version = "function" === typeof GMap2 ? "2" : "3");
+        var c = OpenLayers.Layer.Google["v" + b.version.replace(/\./g, "_")];
+        if (c) OpenLayers.Util.applyDefaults(b, c);
+        else throw "Unsupported Google Maps API version: " + b.version;
+        OpenLayers.Util.applyDefaults(b, c.DEFAULTS);
+        b.maxExtent && (b.maxExtent = b.maxExtent.clone());
+        OpenLayers.Layer.EventPane.prototype.initialize.apply(this, [a, b]);
+        OpenLayers.Layer.FixedZoomLevels.prototype.initialize.apply(this, [a, b]);
+        this.sphericalMercator && (OpenLayers.Util.extend(this, OpenLayers.Layer.SphericalMercator), this.initMercatorParameters())
+    },
+    clone: function() {
+        return new OpenLayers.Layer.Google(this.name, this.getOptions())
+    },
+    setVisibility: function(a) {
+        var b = null == this.opacity ? 1 : this.opacity;
+        OpenLayers.Layer.EventPane.prototype.setVisibility.apply(this, arguments);
+        this.setOpacity(b)
+    },
+    display: function(a) {
+        this._dragging || this.setGMapVisibility(a);
+        OpenLayers.Layer.EventPane.prototype.display.apply(this, arguments)
+    },
+    moveTo: function(a,
+        b, c) {
+        this._dragging = c;
+        OpenLayers.Layer.EventPane.prototype.moveTo.apply(this, arguments);
+        delete this._dragging
+    },
+    setOpacity: function(a) {
+        a !== this.opacity && (null != this.map && this.map.events.triggerEvent("changelayer", {
+            layer: this,
+            property: "opacity"
+        }), this.opacity = a);
+        if (this.getVisibility()) {
+            var b = this.getMapContainer();
+            OpenLayers.Util.modifyDOMElement(b, null, null, null, null, null, null, a)
+        }
+    },
+    destroy: function() {
+        if (this.map) {
+            this.setGMapVisibility(!1);
+            var a = OpenLayers.Layer.Google.cache[this.map.id];
+            a && 1 >= a.count &&
+                this.removeGMapElements()
+        }
+        OpenLayers.Layer.EventPane.prototype.destroy.apply(this, arguments)
+    },
+    removeGMapElements: function() {
+        var a = OpenLayers.Layer.Google.cache[this.map.id];
+        if (a) {
+            var b = this.mapObject && this.getMapContainer();
+            b && b.parentNode && b.parentNode.removeChild(b);
+            (b = a.termsOfUse) && b.parentNode && b.parentNode.removeChild(b);
+            (a = a.poweredBy) && a.parentNode && a.parentNode.removeChild(a)
+        }
+    },
+    removeMap: function(a) {
+        this.visibility && this.mapObject && this.setGMapVisibility(!1);
+        var b = OpenLayers.Layer.Google.cache[a.id];
+        b && (1 >= b.count ? (this.removeGMapElements(), delete OpenLayers.Layer.Google.cache[a.id]) : --b.count);
+        delete this.termsOfUse;
+        delete this.poweredBy;
+        delete this.mapObject;
+        delete this.dragObject;
+        OpenLayers.Layer.EventPane.prototype.removeMap.apply(this, arguments)
+    },
+    getOLBoundsFromMapObjectBounds: function(a) {
+        var b = null;
+        null != a && (b = a.getSouthWest(), a = a.getNorthEast(), this.sphericalMercator ? (b = this.forwardMercator(b.lng(), b.lat()), a = this.forwardMercator(a.lng(), a.lat())) : (b = new OpenLayers.LonLat(b.lng(), b.lat()),
+            a = new OpenLayers.LonLat(a.lng(), a.lat())), b = new OpenLayers.Bounds(b.lon, b.lat, a.lon, a.lat));
+        return b
+    },
+    getWarningHTML: function() {
+        return OpenLayers.i18n("googleWarning")
+    },
+    getMapObjectCenter: function() {
+        return this.mapObject.getCenter()
+    },
+    getMapObjectZoom: function() {
+        return this.mapObject.getZoom()
+    },
+    getLongitudeFromMapObjectLonLat: function(a) {
+        return this.sphericalMercator ? this.forwardMercator(a.lng(), a.lat()).lon : a.lng()
+    },
+    getLatitudeFromMapObjectLonLat: function(a) {
+        return this.sphericalMercator ? this.forwardMercator(a.lng(),
+            a.lat()).lat : a.lat()
+    },
+    getXFromMapObjectPixel: function(a) {
+        return a.x
+    },
+    getYFromMapObjectPixel: function(a) {
+        return a.y
+    },
+    CLASS_NAME: "OpenLayers.Layer.Google"
+});
+OpenLayers.Layer.Google.cache = {};
+OpenLayers.Layer.Google.v2 = {
+    termsOfUse: null,
+    poweredBy: null,
+    dragObject: null,
+    loadMapObject: function() {
+        this.type || (this.type = G_NORMAL_MAP);
+        var a, b, c, d = OpenLayers.Layer.Google.cache[this.map.id];
+        if (d) a = d.mapObject, b = d.termsOfUse, c = d.poweredBy, ++d.count;
+        else {
+            var d = this.map.viewPortDiv,
+                e = document.createElement("div");
+            e.id = this.map.id + "_GMap2Container";
+            e.style.position = "absolute";
+            e.style.width = "100%";
+            e.style.height = "100%";
+            d.appendChild(e);
+            try {
+                a = new GMap2(e), b = e.lastChild, d.appendChild(b), b.style.zIndex =
+                    "1100", b.style.right = "", b.style.bottom = "", b.className = "olLayerGoogleCopyright", c = e.lastChild, d.appendChild(c), c.style.zIndex = "1100", c.style.right = "", c.style.bottom = "", c.className = "olLayerGooglePoweredBy gmnoprint"
+            } catch (f) {
+                throw f;
+            }
+            OpenLayers.Layer.Google.cache[this.map.id] = {
+                mapObject: a,
+                termsOfUse: b,
+                poweredBy: c,
+                count: 1
+            }
+        }
+        this.mapObject = a;
+        this.termsOfUse = b;
+        this.poweredBy = c; - 1 === OpenLayers.Util.indexOf(this.mapObject.getMapTypes(), this.type) && this.mapObject.addMapType(this.type);
+        "function" == typeof a.getDragObject ?
+            this.dragObject = a.getDragObject() : this.dragPanMapObject = null;
+        !1 === this.isBaseLayer && this.setGMapVisibility("none" !== this.div.style.display)
+    },
+    onMapResize: function() {
+        if (this.visibility && this.mapObject.isLoaded()) this.mapObject.checkResize();
+        else {
+            if (!this._resized) var a = this,
+                b = GEvent.addListener(this.mapObject, "load", function() {
+                    GEvent.removeListener(b);
+                    delete a._resized;
+                    a.mapObject.checkResize();
+                    a.moveTo(a.map.getCenter(), a.map.getZoom())
+                });
+            this._resized = !0
+        }
+    },
+    setGMapVisibility: function(a) {
+        var b = OpenLayers.Layer.Google.cache[this.map.id];
+        if (b) {
+            var c = this.mapObject.getContainer();
+            !0 === a ? (this.mapObject.setMapType(this.type), c.style.display = "", this.termsOfUse.style.left = "", this.termsOfUse.style.display = "", this.poweredBy.style.display = "", b.displayed = this.id) : (b.displayed === this.id && delete b.displayed, b.displayed || (c.style.display = "none", this.termsOfUse.style.display = "none", this.termsOfUse.style.left = "-9999px", this.poweredBy.style.display = "none"))
+        }
+    },
+    getMapContainer: function() {
+        return this.mapObject.getContainer()
+    },
+    getMapObjectBoundsFromOLBounds: function(a) {
+        var b =
+            null;
+        null != a && (b = this.sphericalMercator ? this.inverseMercator(a.bottom, a.left) : new OpenLayers.LonLat(a.bottom, a.left), a = this.sphericalMercator ? this.inverseMercator(a.top, a.right) : new OpenLayers.LonLat(a.top, a.right), b = new GLatLngBounds(new GLatLng(b.lat, b.lon), new GLatLng(a.lat, a.lon)));
+        return b
+    },
+    setMapObjectCenter: function(a, b) {
+        this.mapObject.setCenter(a, b)
+    },
+    dragPanMapObject: function(a, b) {
+        this.dragObject.moveBy(new GSize(-a, b))
+    },
+    getMapObjectLonLatFromMapObjectPixel: function(a) {
+        return this.mapObject.fromContainerPixelToLatLng(a)
+    },
+    getMapObjectPixelFromMapObjectLonLat: function(a) {
+        return this.mapObject.fromLatLngToContainerPixel(a)
+    },
+    getMapObjectZoomFromMapObjectBounds: function(a) {
+        return this.mapObject.getBoundsZoomLevel(a)
+    },
+    getMapObjectLonLatFromLonLat: function(a, b) {
+        var c;
+        this.sphericalMercator ? (c = this.inverseMercator(a, b), c = new GLatLng(c.lat, c.lon)) : c = new GLatLng(b, a);
+        return c
+    },
+    getMapObjectPixelFromXY: function(a, b) {
+        return new GPoint(a, b)
+    }
+};
+OpenLayers.Format.XML = OpenLayers.Class(OpenLayers.Format, {
+    namespaces: null,
+    namespaceAlias: null,
+    defaultPrefix: null,
+    readers: {},
+    writers: {},
+    xmldom: null,
+    initialize: function(a) {
+        window.ActiveXObject && (this.xmldom = new ActiveXObject("Microsoft.XMLDOM"));
+        OpenLayers.Format.prototype.initialize.apply(this, [a]);
+        this.namespaces = OpenLayers.Util.extend({}, this.namespaces);
+        this.namespaceAlias = {};
+        for (var b in this.namespaces) this.namespaceAlias[this.namespaces[b]] = b
+    },
+    destroy: function() {
+        this.xmldom = null;
+        OpenLayers.Format.prototype.destroy.apply(this,
+            arguments)
+    },
+    setNamespace: function(a, b) {
+        this.namespaces[a] = b;
+        this.namespaceAlias[b] = a
+    },
+    read: function(a) {
+        var b = a.indexOf("<");
+        0 < b && (a = a.substring(b));
+        b = OpenLayers.Util.Try(OpenLayers.Function.bind(function() {
+            var b;
+            b = window.ActiveXObject && !this.xmldom ? new ActiveXObject("Microsoft.XMLDOM") : this.xmldom;
+            b.loadXML(a);
+            return b
+        }, this), function() {
+            return (new DOMParser).parseFromString(a, "text/xml")
+        }, function() {
+            var b = new XMLHttpRequest;
+            b.open("GET", "data:text/xml;charset=utf-8," + encodeURIComponent(a), !1);
+            b.overrideMimeType &&
+                b.overrideMimeType("text/xml");
+            b.send(null);
+            return b.responseXML
+        });
+        this.keepData && (this.data = b);
+        return b
+    },
+    write: function(a) {
+        if (this.xmldom) a = a.xml;
+        else {
+            var b = new XMLSerializer;
+            if (1 == a.nodeType) {
+                var c = document.implementation.createDocument("", "", null);
+                c.importNode && (a = c.importNode(a, !0));
+                c.appendChild(a);
+                a = b.serializeToString(c)
+            } else a = b.serializeToString(a)
+        }
+        return a
+    },
+    createElementNS: function(a, b) {
+        return this.xmldom ? "string" == typeof a ? this.xmldom.createNode(1, b, a) : this.xmldom.createNode(1, b, "") : document.createElementNS(a,
+            b)
+    },
+    createTextNode: function(a) {
+        "string" !== typeof a && (a = "" + a);
+        return this.xmldom ? this.xmldom.createTextNode(a) : document.createTextNode(a)
+    },
+    getElementsByTagNameNS: function(a, b, c) {
+        var d = [];
+        if (a.getElementsByTagNameNS) d = a.getElementsByTagNameNS(b, c);
+        else
+            for (var a = a.getElementsByTagName("*"), e, f, g = 0, h = a.length; g < h; ++g)
+                if (e = a[g], f = e.prefix ? e.prefix + ":" + c : c, "*" == c || f == e.nodeName)("*" == b || b == e.namespaceURI) && d.push(e); return d
+    },
+    getAttributeNodeNS: function(a, b, c) {
+        var d = null;
+        if (a.getAttributeNodeNS) d = a.getAttributeNodeNS(b,
+            c);
+        else
+            for (var a = a.attributes, e, f, g = 0, h = a.length; g < h; ++g)
+                if (e = a[g], e.namespaceURI == b && (f = e.prefix ? e.prefix + ":" + c : c, f == e.nodeName)) {
+                    d = e;
+                    break
+                } return d
+    },
+    getAttributeNS: function(a, b, c) {
+        var d = "";
+        if (a.getAttributeNS) d = a.getAttributeNS(b, c) || "";
+        else if (a = this.getAttributeNodeNS(a, b, c)) d = a.nodeValue;
+        return d
+    },
+    getChildValue: function(a, b) {
+        var c = b || "";
+        if (a)
+            for (var d = a.firstChild; d; d = d.nextSibling) switch (d.nodeType) {
+                case 3:
+                case 4:
+                    c += d.nodeValue
+            }
+        return c
+    },
+    isSimpleContent: function(a) {
+        for (var b = !0, a = a.firstChild; a; a =
+            a.nextSibling)
+            if (1 === a.nodeType) {
+                b = !1;
+                break
+            }
+        return b
+    },
+    contentType: function(a) {
+        for (var b = !1, c = !1, d = OpenLayers.Format.XML.CONTENT_TYPE.EMPTY, a = a.firstChild; a; a = a.nextSibling) {
+            switch (a.nodeType) {
+                case 1:
+                    c = !0;
+                    break;
+                case 8:
+                    break;
+                default:
+                    b = !0
+            }
+            if (c && b) break
+        }
+        if (c && b) d = OpenLayers.Format.XML.CONTENT_TYPE.MIXED;
+        else {
+            if (c) return OpenLayers.Format.XML.CONTENT_TYPE.COMPLEX;
+            if (b) return OpenLayers.Format.XML.CONTENT_TYPE.SIMPLE
+        }
+        return d
+    },
+    hasAttributeNS: function(a, b, c) {
+        var d = !1;
+        return d = a.hasAttributeNS ? a.hasAttributeNS(b,
+            c) : !!this.getAttributeNodeNS(a, b, c)
+    },
+    setAttributeNS: function(a, b, c, d) {
+        if (a.setAttributeNS) a.setAttributeNS(b, c, d);
+        else if (this.xmldom) b ? (b = a.ownerDocument.createNode(2, c, b), b.nodeValue = d, a.setAttributeNode(b)) : a.setAttribute(c, d);
+        else throw "setAttributeNS not implemented";
+    },
+    createElementNSPlus: function(a, b) {
+        var b = b || {},
+            c = b.uri || this.namespaces[b.prefix];
+        c || (c = a.indexOf(":"), c = this.namespaces[a.substring(0, c)]);
+        c || (c = this.namespaces[this.defaultPrefix]);
+        c = this.createElementNS(c, a);
+        b.attributes && this.setAttributes(c,
+            b.attributes);
+        var d = b.value;
+        null != d && c.appendChild(this.createTextNode(d));
+        return c
+    },
+    setAttributes: function(a, b) {
+        var c, d, e;
+        for (e in b) null != b[e] && b[e].toString && (c = b[e].toString(), d = this.namespaces[e.substring(0, e.indexOf(":"))] || null, this.setAttributeNS(a, d, e, c))
+    },
+    readNode: function(a, b) {
+        b || (b = {});
+        var c = this.readers[a.namespaceURI ? this.namespaceAlias[a.namespaceURI] : this.defaultPrefix];
+        if (c) {
+            var d = a.localName || a.nodeName.split(":").pop();
+            (c = c[d] || c["*"]) && c.apply(this, [a, b])
+        }
+        return b
+    },
+    readChildNodes: function(a,
+        b) {
+        b || (b = {});
+        for (var c = a.childNodes, d, e = 0, f = c.length; e < f; ++e) d = c[e], 1 == d.nodeType && this.readNode(d, b);
+        return b
+    },
+    writeNode: function(a, b, c) {
+        var d, e = a.indexOf(":");
+        0 < e ? (d = a.substring(0, e), a = a.substring(e + 1)) : d = c ? this.namespaceAlias[c.namespaceURI] : this.defaultPrefix;
+        b = this.writers[d][a].apply(this, [b]);
+        c && c.appendChild(b);
+        return b
+    },
+    getChildEl: function(a, b, c) {
+        return a && this.getThisOrNextEl(a.firstChild, b, c)
+    },
+    getNextEl: function(a, b, c) {
+        return a && this.getThisOrNextEl(a.nextSibling, b, c)
+    },
+    getThisOrNextEl: function(a,
+        b, c) {
+        a: for (; a; a = a.nextSibling) switch (a.nodeType) {
+            case 1:
+                if ((!b || b === (a.localName || a.nodeName.split(":").pop())) && (!c || c === a.namespaceURI)) break a;
+                a = null;
+                break a;
+            case 3:
+                if (/^\s*$/.test(a.nodeValue)) break;
+            case 4:
+            case 6:
+            case 12:
+            case 10:
+            case 11:
+                a = null;
+                break a
+        }
+        return a || null
+    },
+    lookupNamespaceURI: function(a, b) {
+        var c = null;
+        if (a)
+            if (a.lookupNamespaceURI) c = a.lookupNamespaceURI(b);
+            else a: switch (a.nodeType) {
+                case 1:
+                    if (null !== a.namespaceURI && a.prefix === b) {
+                        c = a.namespaceURI;
+                        break a
+                    }
+                    if (c = a.attributes.length)
+                        for (var d,
+                                e = 0; e < c; ++e)
+                            if (d = a.attributes[e], "xmlns" === d.prefix && d.name === "xmlns:" + b) {
+                                c = d.value || null;
+                                break a
+                            } else if ("xmlns" === d.name && null === b) {
+                        c = d.value || null;
+                        break a
+                    }
+                    c = this.lookupNamespaceURI(a.parentNode, b);
+                    break a;
+                case 2:
+                    c = this.lookupNamespaceURI(a.ownerElement, b);
+                    break a;
+                case 9:
+                    c = this.lookupNamespaceURI(a.documentElement, b);
+                    break a;
+                case 6:
+                case 12:
+                case 10:
+                case 11:
+                    break a;
+                default:
+                    c = this.lookupNamespaceURI(a.parentNode, b)
+            }
+            return c
+    },
+    getXMLDoc: function() {
+        !OpenLayers.Format.XML.document && !this.xmldom && (document.implementation &&
+            document.implementation.createDocument ? OpenLayers.Format.XML.document = document.implementation.createDocument("", "", null) : !this.xmldom && window.ActiveXObject && (this.xmldom = new ActiveXObject("Microsoft.XMLDOM")));
+        return OpenLayers.Format.XML.document || this.xmldom
+    },
+    CLASS_NAME: "OpenLayers.Format.XML"
+});
+OpenLayers.Format.XML.CONTENT_TYPE = {
+    EMPTY: 0,
+    SIMPLE: 1,
+    COMPLEX: 2,
+    MIXED: 3
+};
+OpenLayers.Format.XML.lookupNamespaceURI = OpenLayers.Function.bind(OpenLayers.Format.XML.prototype.lookupNamespaceURI, OpenLayers.Format.XML.prototype);
+OpenLayers.Format.XML.document = null;
+OpenLayers.Format.WFST = function(a) {
+    var a = OpenLayers.Util.applyDefaults(a, OpenLayers.Format.WFST.DEFAULTS),
+        b = OpenLayers.Format.WFST["v" + a.version.replace(/\./g, "_")];
+    if (!b) throw "Unsupported WFST version: " + a.version;
+    return new b(a)
+};
+OpenLayers.Format.WFST.DEFAULTS = {
+    version: "1.0.0"
+};
+OpenLayers.Format.WFST.v1 = OpenLayers.Class(OpenLayers.Format.XML, {
+    namespaces: {
+        xlink: "http://www.w3.org/1999/xlink",
+        xsi: "http://www.w3.org/2001/XMLSchema-instance",
+        wfs: "http://www.opengis.net/wfs",
+        gml: "http://www.opengis.net/gml",
+        ogc: "http://www.opengis.net/ogc",
+        ows: "http://www.opengis.net/ows"
+    },
+    defaultPrefix: "wfs",
+    version: null,
+    schemaLocations: null,
+    srsName: null,
+    extractAttributes: !0,
+    xy: !0,
+    stateName: null,
+    initialize: function(a) {
+        this.stateName = {};
+        this.stateName[OpenLayers.State.INSERT] = "wfs:Insert";
+        this.stateName[OpenLayers.State.UPDATE] =
+            "wfs:Update";
+        this.stateName[OpenLayers.State.DELETE] = "wfs:Delete";
+        OpenLayers.Format.XML.prototype.initialize.apply(this, [a])
+    },
+    getSrsName: function(a, b) {
+        var c = b && b.srsName;
+        c || (c = a && a.layer ? a.layer.projection.getCode() : this.srsName);
+        return c
+    },
+    read: function(a, b) {
+        b = b || {};
+        OpenLayers.Util.applyDefaults(b, {
+            output: "features"
+        });
+        "string" == typeof a && (a = OpenLayers.Format.XML.prototype.read.apply(this, [a]));
+        a && 9 == a.nodeType && (a = a.documentElement);
+        var c = {};
+        a && this.readNode(a, c, !0);
+        c.features && "features" === b.output &&
+            (c = c.features);
+        return c
+    },
+    readers: {
+        wfs: {
+            FeatureCollection: function(a, b) {
+                b.features = [];
+                this.readChildNodes(a, b)
+            }
+        }
+    },
+    write: function(a, b) {
+        var c = this.writeNode("wfs:Transaction", {
+                features: a,
+                options: b
+            }),
+            d = this.schemaLocationAttr();
+        d && this.setAttributeNS(c, this.namespaces.xsi, "xsi:schemaLocation", d);
+        return OpenLayers.Format.XML.prototype.write.apply(this, [c])
+    },
+    writers: {
+        wfs: {
+            GetFeature: function(a) {
+                var b = this.createElementNSPlus("wfs:GetFeature", {
+                    attributes: {
+                        service: "WFS",
+                        version: this.version,
+                        handle: a && a.handle,
+                        outputFormat: a && a.outputFormat,
+                        maxFeatures: a && a.maxFeatures,
+                        "xsi:schemaLocation": this.schemaLocationAttr(a)
+                    }
+                });
+                if ("string" == typeof this.featureType) this.writeNode("Query", a, b);
+                else
+                    for (var c = 0, d = this.featureType.length; c < d; c++) a.featureType = this.featureType[c], this.writeNode("Query", a, b);
+                return b
+            },
+            Transaction: function(a) {
+                var a = a || {},
+                    b = a.options || {},
+                    c = this.createElementNSPlus("wfs:Transaction", {
+                        attributes: {
+                            service: "WFS",
+                            version: this.version,
+                            handle: b.handle
+                        }
+                    }),
+                    d, e = a.features;
+                if (e) {
+                    !0 === b.multi && OpenLayers.Util.extend(this.geometryTypes, {
+                        "OpenLayers.Geometry.Point": "MultiPoint",
+                        "OpenLayers.Geometry.LineString": !0 === this.multiCurve ? "MultiCurve" : "MultiLineString",
+                        "OpenLayers.Geometry.Polygon": !0 === this.multiSurface ? "MultiSurface" : "MultiPolygon"
+                    });
+                    var f, g, a = 0;
+                    for (d = e.length; a < d; ++a) g = e[a], (f = this.stateName[g.state]) && this.writeNode(f, {
+                        feature: g,
+                        options: b
+                    }, c);
+                    !0 === b.multi && this.setGeometryTypes()
+                }
+                if (b.nativeElements) {
+                    a = 0;
+                    for (d = b.nativeElements.length; a < d; ++a) this.writeNode("wfs:Native", b.nativeElements[a], c)
+                }
+                return c
+            },
+            Native: function(a) {
+                return this.createElementNSPlus("wfs:Native", {
+                    attributes: {
+                        vendorId: a.vendorId,
+                        safeToIgnore: a.safeToIgnore
+                    },
+                    value: a.value
+                })
+            },
+            Insert: function(a) {
+                var b = a.feature,
+                    a = a.options,
+                    a = this.createElementNSPlus("wfs:Insert", {
+                        attributes: {
+                            handle: a && a.handle
+                        }
+                    });
+                this.srsName = this.getSrsName(b);
+                this.writeNode("feature:_typeName", b, a);
+                return a
+            },
+            Update: function(a) {
+                var b = a.feature,
+                    a = a.options,
+                    a = this.createElementNSPlus("wfs:Update", {
+                        attributes: {
+                            handle: a && a.handle,
+                            typeName: (this.featureNS ? this.featurePrefix + ":" : "") + this.featureType
+                        }
+                    });
+                this.featureNS && a.setAttribute("xmlns:" +
+                    this.featurePrefix, this.featureNS);
+                var c = b.modified;
+                if (null !== this.geometryName && (!c || void 0 !== c.geometry)) this.srsName = this.getSrsName(b), this.writeNode("Property", {
+                    name: this.geometryName,
+                    value: b.geometry
+                }, a);
+                for (var d in b.attributes) void 0 !== b.attributes[d] && (!c || !c.attributes || c.attributes && void 0 !== c.attributes[d]) && this.writeNode("Property", {
+                    name: d,
+                    value: b.attributes[d]
+                }, a);
+                this.writeNode("ogc:Filter", new OpenLayers.Filter.FeatureId({
+                    fids: [b.fid]
+                }), a);
+                return a
+            },
+            Property: function(a) {
+                var b = this.createElementNSPlus("wfs:Property");
+                this.writeNode("Name", a.name, b);
+                null !== a.value && this.writeNode("Value", a.value, b);
+                return b
+            },
+            Name: function(a) {
+                return this.createElementNSPlus("wfs:Name", {
+                    value: a
+                })
+            },
+            Value: function(a) {
+                var b;
+                a instanceof OpenLayers.Geometry ? (b = this.createElementNSPlus("wfs:Value"), a = this.writeNode("feature:_geometry", a).firstChild, b.appendChild(a)) : b = this.createElementNSPlus("wfs:Value", {
+                    value: a
+                });
+                return b
+            },
+            Delete: function(a) {
+                var b = a.feature,
+                    a = a.options,
+                    a = this.createElementNSPlus("wfs:Delete", {
+                        attributes: {
+                            handle: a &&
+                                a.handle,
+                            typeName: (this.featureNS ? this.featurePrefix + ":" : "") + this.featureType
+                        }
+                    });
+                this.featureNS && a.setAttribute("xmlns:" + this.featurePrefix, this.featureNS);
+                this.writeNode("ogc:Filter", new OpenLayers.Filter.FeatureId({
+                    fids: [b.fid]
+                }), a);
+                return a
+            }
+        }
+    },
+    schemaLocationAttr: function(a) {
+        var a = OpenLayers.Util.extend({
+                featurePrefix: this.featurePrefix,
+                schema: this.schema
+            }, a),
+            b = OpenLayers.Util.extend({}, this.schemaLocations);
+        a.schema && (b[a.featurePrefix] = a.schema);
+        var a = [],
+            c, d;
+        for (d in b)(c = this.namespaces[d]) &&
+            a.push(c + " " + b[d]);
+        return a.join(" ") || void 0
+    },
+    setFilterProperty: function(a) {
+        if (a.filters)
+            for (var b = 0, c = a.filters.length; b < c; ++b) OpenLayers.Format.WFST.v1.prototype.setFilterProperty.call(this, a.filters[b]);
+        else a instanceof OpenLayers.Filter.Spatial && !a.property && (a.property = this.geometryName)
+    },
+    CLASS_NAME: "OpenLayers.Format.WFST.v1"
+});
+OpenLayers.Format.OGCExceptionReport = OpenLayers.Class(OpenLayers.Format.XML, {
+    namespaces: {
+        ogc: "http://www.opengis.net/ogc"
+    },
+    regExes: {
+        trimSpace: /^\s*|\s*$/g,
+        removeSpace: /\s*/g,
+        splitSpace: /\s+/,
+        trimComma: /\s*,\s*/g
+    },
+    defaultPrefix: "ogc",
+    read: function(a) {
+        "string" == typeof a && (a = OpenLayers.Format.XML.prototype.read.apply(this, [a]));
+        var b = {
+            exceptionReport: null
+        };
+        a.documentElement && (this.readChildNodes(a, b), null === b.exceptionReport && (b = (new OpenLayers.Format.OWSCommon).read(a)));
+        return b
+    },
+    readers: {
+        ogc: {
+            ServiceExceptionReport: function(a,
+                b) {
+                b.exceptionReport = {
+                    exceptions: []
+                };
+                this.readChildNodes(a, b.exceptionReport)
+            },
+            ServiceException: function(a, b) {
+                var c = {
+                    code: a.getAttribute("code"),
+                    locator: a.getAttribute("locator"),
+                    text: this.getChildValue(a)
+                };
+                b.exceptions.push(c)
+            }
+        }
+    },
+    CLASS_NAME: "OpenLayers.Format.OGCExceptionReport"
+});
+OpenLayers.Format.XML.VersionedOGC = OpenLayers.Class(OpenLayers.Format.XML, {
+    defaultVersion: null,
+    version: null,
+    profile: null,
+    errorProperty: null,
+    name: null,
+    stringifyOutput: !1,
+    parser: null,
+    initialize: function(a) {
+        OpenLayers.Format.XML.prototype.initialize.apply(this, [a]);
+        a = this.CLASS_NAME;
+        this.name = a.substring(a.lastIndexOf(".") + 1)
+    },
+    getVersion: function(a, b) {
+        var c;
+        a ? (c = this.version, c || (c = a.getAttribute("version"), c || (c = this.defaultVersion))) : c = b && b.version || this.version || this.defaultVersion;
+        return c
+    },
+    getParser: function(a) {
+        var a =
+            a || this.defaultVersion,
+            b = this.profile ? "_" + this.profile : "";
+        if (!this.parser || this.parser.VERSION != a) {
+            var c = OpenLayers.Format[this.name]["v" + a.replace(/\./g, "_") + b];
+            if (!c) throw "Can't find a " + this.name + " parser for version " + a + b;
+            this.parser = new c(this.options)
+        }
+        return this.parser
+    },
+    write: function(a, b) {
+        this.parser = this.getParser(this.getVersion(null, b));
+        var c = this.parser.write(a, b);
+        return !1 === this.stringifyOutput ? c : OpenLayers.Format.XML.prototype.write.apply(this, [c])
+    },
+    read: function(a, b) {
+        "string" == typeof a &&
+            (a = OpenLayers.Format.XML.prototype.read.apply(this, [a]));
+        var c = this.getVersion(a.documentElement);
+        this.parser = this.getParser(c);
+        var d = this.parser.read(a, b);
+        if (null !== this.errorProperty && void 0 === d[this.errorProperty]) {
+            var e = new OpenLayers.Format.OGCExceptionReport;
+            d.error = e.read(a)
+        }
+        d.version = c;
+        return d
+    },
+    CLASS_NAME: "OpenLayers.Format.XML.VersionedOGC"
+});
+OpenLayers.Feature = OpenLayers.Class({
+    layer: null,
+    id: null,
+    lonlat: null,
+    data: null,
+    marker: null,
+    popupClass: null,
+    popup: null,
+    initialize: function(a, b, c) {
+        this.layer = a;
+        this.lonlat = b;
+        this.data = null != c ? c : {};
+        this.id = OpenLayers.Util.createUniqueID(this.CLASS_NAME + "_")
+    },
+    destroy: function() {
+        null != this.layer && null != this.layer.map && null != this.popup && this.layer.map.removePopup(this.popup);
+        null != this.layer && null != this.marker && this.layer.removeMarker(this.marker);
+        this.data = this.lonlat = this.id = this.layer = null;
+        null != this.marker &&
+            (this.destroyMarker(this.marker), this.marker = null);
+        null != this.popup && (this.destroyPopup(this.popup), this.popup = null)
+    },
+    onScreen: function() {
+        var a = !1;
+        null != this.layer && null != this.layer.map && (a = this.layer.map.getExtent().containsLonLat(this.lonlat));
+        return a
+    },
+    createMarker: function() {
+        null != this.lonlat && (this.marker = new OpenLayers.Marker(this.lonlat, this.data.icon));
+        return this.marker
+    },
+    destroyMarker: function() {
+        this.marker.destroy()
+    },
+    createPopup: function(a) {
+        null != this.lonlat && (this.popup || (this.popup = new(this.popupClass ?
+            this.popupClass : OpenLayers.Popup.Anchored)(this.id + "_popup", this.lonlat, this.data.popupSize, this.data.popupContentHTML, this.marker ? this.marker.icon : null, a)), null != this.data.overflow && (this.popup.contentDiv.style.overflow = this.data.overflow), this.popup.feature = this);
+        return this.popup
+    },
+    destroyPopup: function() {
+        this.popup && (this.popup.feature = null, this.popup.destroy(), this.popup = null)
+    },
+    CLASS_NAME: "OpenLayers.Feature"
+});
+OpenLayers.State = {
+    UNKNOWN: "Unknown",
+    INSERT: "Insert",
+    UPDATE: "Update",
+    DELETE: "Delete"
+};
+OpenLayers.Feature.Vector = OpenLayers.Class(OpenLayers.Feature, {
+    fid: null,
+    geometry: null,
+    attributes: null,
+    bounds: null,
+    state: null,
+    style: null,
+    url: null,
+    renderIntent: "default",
+    modified: null,
+    initialize: function(a, b, c) {
+        OpenLayers.Feature.prototype.initialize.apply(this, [null, null, b]);
+        this.lonlat = null;
+        this.geometry = a ? a : null;
+        this.state = null;
+        this.attributes = {};
+        b && (this.attributes = OpenLayers.Util.extend(this.attributes, b));
+        this.style = c ? c : null
+    },
+    destroy: function() {
+        this.layer && (this.layer.removeFeatures(this), this.layer =
+            null);
+        this.modified = this.geometry = null;
+        OpenLayers.Feature.prototype.destroy.apply(this, arguments)
+    },
+    clone: function() {
+        return new OpenLayers.Feature.Vector(this.geometry ? this.geometry.clone() : null, this.attributes, this.style)
+    },
+    onScreen: function(a) {
+        var b = !1;
+        this.layer && this.layer.map && (b = this.layer.map.getExtent(), a ? (a = this.geometry.getBounds(), b = b.intersectsBounds(a)) : b = b.toGeometry().intersects(this.geometry));
+        return b
+    },
+    getVisibility: function() {
+        return !(this.style && "none" == this.style.display || !this.layer ||
+            this.layer && this.layer.styleMap && "none" == this.layer.styleMap.createSymbolizer(this, this.renderIntent).display || this.layer && !this.layer.getVisibility())
+    },
+    createMarker: function() {
+        return null
+    },
+    destroyMarker: function() {},
+    createPopup: function() {
+        return null
+    },
+    atPoint: function(a, b, c) {
+        var d = !1;
+        this.geometry && (d = this.geometry.atPoint(a, b, c));
+        return d
+    },
+    destroyPopup: function() {},
+    move: function(a) {
+        if (this.layer && this.geometry.move) {
+            var a = "OpenLayers.LonLat" == a.CLASS_NAME ? this.layer.getViewPortPxFromLonLat(a) : a,
+                b = this.layer.getViewPortPxFromLonLat(this.geometry.getBounds().getCenterLonLat()),
+                c = this.layer.map.getResolution();
+            this.geometry.move(c * (a.x - b.x), c * (b.y - a.y));
+            this.layer.drawFeature(this);
+            return b
+        }
+    },
+    toState: function(a) {
+        if (a == OpenLayers.State.UPDATE) switch (this.state) {
+            case OpenLayers.State.UNKNOWN:
+            case OpenLayers.State.DELETE:
+                this.state = a
+        } else if (a == OpenLayers.State.INSERT) switch (this.state) {
+            case OpenLayers.State.UNKNOWN:
+                break;
+            default:
+                this.state = a
+        } else if (a == OpenLayers.State.DELETE) switch (this.state) {
+            case OpenLayers.State.UNKNOWN:
+            case OpenLayers.State.UPDATE:
+                this.state =
+                    a
+        } else a == OpenLayers.State.UNKNOWN && (this.state = a)
+    },
+    CLASS_NAME: "OpenLayers.Feature.Vector"
+});
+OpenLayers.Feature.Vector.style = {
+    "default": {
+        fillColor: "#ee9900",
+        fillOpacity: 0.4,
+        hoverFillColor: "white",
+        hoverFillOpacity: 0.8,
+        strokeColor: "#ee9900",
+        strokeOpacity: 1,
+        strokeWidth: 1,
+        strokeLinecap: "round",
+        strokeDashstyle: "solid",
+        hoverStrokeColor: "red",
+        hoverStrokeOpacity: 1,
+        hoverStrokeWidth: 0.2,
+        pointRadius: 6,
+        hoverPointRadius: 1,
+        hoverPointUnit: "%",
+        pointerEvents: "visiblePainted",
+        cursor: "inherit",
+        fontColor: "#000000",
+        labelAlign: "cm",
+        labelOutlineColor: "white",
+        labelOutlineWidth: 3
+    },
+    select: {
+        fillColor: "blue",
+        fillOpacity: 0.4,
+        hoverFillColor: "white",
+        hoverFillOpacity: 0.8,
+        strokeColor: "blue",
+        strokeOpacity: 1,
+        strokeWidth: 2,
+        strokeLinecap: "round",
+        strokeDashstyle: "solid",
+        hoverStrokeColor: "red",
+        hoverStrokeOpacity: 1,
+        hoverStrokeWidth: 0.2,
+        pointRadius: 6,
+        hoverPointRadius: 1,
+        hoverPointUnit: "%",
+        pointerEvents: "visiblePainted",
+        cursor: "pointer",
+        fontColor: "#000000",
+        labelAlign: "cm",
+        labelOutlineColor: "white",
+        labelOutlineWidth: 3
+    },
+    temporary: {
+        fillColor: "#66cccc",
+        fillOpacity: 0.2,
+        hoverFillColor: "white",
+        hoverFillOpacity: 0.8,
+        strokeColor: "#66cccc",
+        strokeOpacity: 1,
+        strokeLinecap: "round",
+        strokeWidth: 2,
+        strokeDashstyle: "solid",
+        hoverStrokeColor: "red",
+        hoverStrokeOpacity: 1,
+        hoverStrokeWidth: 0.2,
+        pointRadius: 6,
+        hoverPointRadius: 1,
+        hoverPointUnit: "%",
+        pointerEvents: "visiblePainted",
+        cursor: "inherit",
+        fontColor: "#000000",
+        labelAlign: "cm",
+        labelOutlineColor: "white",
+        labelOutlineWidth: 3
+    },
+    "delete": {
+        display: "none"
+    }
+};
+OpenLayers.Style = OpenLayers.Class({
+    id: null,
+    name: null,
+    title: null,
+    description: null,
+    layerName: null,
+    isDefault: !1,
+    rules: null,
+    context: null,
+    defaultStyle: null,
+    defaultsPerSymbolizer: !1,
+    propertyStyles: null,
+    initialize: function(a, b) {
+        OpenLayers.Util.extend(this, b);
+        this.rules = [];
+        b && b.rules && this.addRules(b.rules);
+        this.setDefaultStyle(a || OpenLayers.Feature.Vector.style["default"]);
+        this.id = OpenLayers.Util.createUniqueID(this.CLASS_NAME + "_")
+    },
+    destroy: function() {
+        for (var a = 0, b = this.rules.length; a < b; a++) this.rules[a].destroy(),
+            this.rules[a] = null;
+        this.defaultStyle = this.rules = null
+    },
+    createSymbolizer: function(a) {
+        for (var b = this.defaultsPerSymbolizer ? {} : this.createLiterals(OpenLayers.Util.extend({}, this.defaultStyle), a), c = this.rules, d, e = [], f = !1, g = 0, h = c.length; g < h; g++) d = c[g], d.evaluate(a) && (d instanceof OpenLayers.Rule && d.elseFilter ? e.push(d) : (f = !0, this.applySymbolizer(d, b, a)));
+        if (!1 == f && 0 < e.length) {
+            f = !0;
+            g = 0;
+            for (h = e.length; g < h; g++) this.applySymbolizer(e[g], b, a)
+        }
+        0 < c.length && !1 == f && (b.display = "none");
+        null != b.label && "string" !== typeof b.label &&
+            (b.label = "" + b.label);
+        return b
+    },
+    applySymbolizer: function(a, b, c) {
+        var d = c.geometry ? this.getSymbolizerPrefix(c.geometry) : OpenLayers.Style.SYMBOLIZER_PREFIXES[0],
+            a = a.symbolizer[d] || a.symbolizer;
+        !0 === this.defaultsPerSymbolizer && (d = this.defaultStyle, OpenLayers.Util.applyDefaults(a, {
+            pointRadius: d.pointRadius
+        }), (!0 === a.stroke || !0 === a.graphic) && OpenLayers.Util.applyDefaults(a, {
+            strokeWidth: d.strokeWidth,
+            strokeColor: d.strokeColor,
+            strokeOpacity: d.strokeOpacity,
+            strokeDashstyle: d.strokeDashstyle,
+            strokeLinecap: d.strokeLinecap
+        }), (!0 === a.fill || !0 === a.graphic) && OpenLayers.Util.applyDefaults(a, {
+            fillColor: d.fillColor,
+            fillOpacity: d.fillOpacity
+        }), !0 === a.graphic && OpenLayers.Util.applyDefaults(a, {
+            pointRadius: this.defaultStyle.pointRadius,
+            externalGraphic: this.defaultStyle.externalGraphic,
+            graphicName: this.defaultStyle.graphicName,
+            graphicOpacity: this.defaultStyle.graphicOpacity,
+            graphicWidth: this.defaultStyle.graphicWidth,
+            graphicHeight: this.defaultStyle.graphicHeight,
+            graphicXOffset: this.defaultStyle.graphicXOffset,
+            graphicYOffset: this.defaultStyle.graphicYOffset
+        }));
+        return this.createLiterals(OpenLayers.Util.extend(b, a), c)
+    },
+    createLiterals: function(a, b) {
+        var c = OpenLayers.Util.extend({}, b.attributes || b.data);
+        OpenLayers.Util.extend(c, this.context);
+        for (var d in this.propertyStyles) a[d] = OpenLayers.Style.createLiteral(a[d], c, b, d);
+        return a
+    },
+    findPropertyStyles: function() {
+        var a = {};
+        this.addPropertyStyles(a, this.defaultStyle);
+        for (var b = this.rules, c, d, e = 0, f = b.length; e < f; e++) {
+            c = b[e].symbolizer;
+            for (var g in c)
+                if (d = c[g], "object" == typeof d) this.addPropertyStyles(a, d);
+                else {
+                    this.addPropertyStyles(a,
+                        c);
+                    break
+                }
+        }
+        return a
+    },
+    addPropertyStyles: function(a, b) {
+        var c, d;
+        for (d in b) c = b[d], "string" == typeof c && c.match(/\$\{\w+\}/) && (a[d] = !0);
+        return a
+    },
+    addRules: function(a) {
+        Array.prototype.push.apply(this.rules, a);
+        this.propertyStyles = this.findPropertyStyles()
+    },
+    setDefaultStyle: function(a) {
+        this.defaultStyle = a;
+        this.propertyStyles = this.findPropertyStyles()
+    },
+    getSymbolizerPrefix: function(a) {
+        for (var b = OpenLayers.Style.SYMBOLIZER_PREFIXES, c = 0, d = b.length; c < d; c++)
+            if (-1 != a.CLASS_NAME.indexOf(b[c])) return b[c]
+    },
+    clone: function() {
+        var a =
+            OpenLayers.Util.extend({}, this);
+        if (this.rules) {
+            a.rules = [];
+            for (var b = 0, c = this.rules.length; b < c; ++b) a.rules.push(this.rules[b].clone())
+        }
+        a.context = this.context && OpenLayers.Util.extend({}, this.context);
+        b = OpenLayers.Util.extend({}, this.defaultStyle);
+        return new OpenLayers.Style(b, a)
+    },
+    CLASS_NAME: "OpenLayers.Style"
+});
+OpenLayers.Style.createLiteral = function(a, b, c, d) {
+    "string" == typeof a && -1 != a.indexOf("${") && (a = OpenLayers.String.format(a, b, [c, d]), a = isNaN(a) || !a ? a : parseFloat(a));
+    return a
+};
+OpenLayers.Style.SYMBOLIZER_PREFIXES = ["Point", "Line", "Polygon", "Text", "Raster"];
+OpenLayers.Filter = OpenLayers.Class({
+    initialize: function(a) {
+        OpenLayers.Util.extend(this, a)
+    },
+    destroy: function() {},
+    evaluate: function() {
+        return !0
+    },
+    clone: function() {
+        return null
+    },
+    toString: function() {
+        return OpenLayers.Format && OpenLayers.Format.CQL ? OpenLayers.Format.CQL.prototype.write(this) : Object.prototype.toString.call(this)
+    },
+    CLASS_NAME: "OpenLayers.Filter"
+});
+OpenLayers.Filter.FeatureId = OpenLayers.Class(OpenLayers.Filter, {
+    fids: null,
+    type: "FID",
+    initialize: function(a) {
+        this.fids = [];
+        OpenLayers.Filter.prototype.initialize.apply(this, [a])
+    },
+    evaluate: function(a) {
+        for (var b = 0, c = this.fids.length; b < c; b++)
+            if ((a.fid || a.id) == this.fids[b]) return !0;
+        return !1
+    },
+    clone: function() {
+        var a = new OpenLayers.Filter.FeatureId;
+        OpenLayers.Util.extend(a, this);
+        a.fids = this.fids.slice();
+        return a
+    },
+    CLASS_NAME: "OpenLayers.Filter.FeatureId"
+});
+OpenLayers.Filter.Logical = OpenLayers.Class(OpenLayers.Filter, {
+    filters: null,
+    type: null,
+    initialize: function(a) {
+        this.filters = [];
+        OpenLayers.Filter.prototype.initialize.apply(this, [a])
+    },
+    destroy: function() {
+        this.filters = null;
+        OpenLayers.Filter.prototype.destroy.apply(this)
+    },
+    evaluate: function(a) {
+        var b, c;
+        switch (this.type) {
+            case OpenLayers.Filter.Logical.AND:
+                b = 0;
+                for (c = this.filters.length; b < c; b++)
+                    if (!1 == this.filters[b].evaluate(a)) return !1;
+                return !0;
+            case OpenLayers.Filter.Logical.OR:
+                b = 0;
+                for (c = this.filters.length; b <
+                    c; b++)
+                    if (!0 == this.filters[b].evaluate(a)) return !0;
+                return !1;
+            case OpenLayers.Filter.Logical.NOT:
+                return !this.filters[0].evaluate(a)
+        }
+    },
+    clone: function() {
+        for (var a = [], b = 0, c = this.filters.length; b < c; ++b) a.push(this.filters[b].clone());
+        return new OpenLayers.Filter.Logical({
+            type: this.type,
+            filters: a
+        })
+    },
+    CLASS_NAME: "OpenLayers.Filter.Logical"
+});
+OpenLayers.Filter.Logical.AND = "&&";
+OpenLayers.Filter.Logical.OR = "||";
+OpenLayers.Filter.Logical.NOT = "!";
+OpenLayers.Filter.Comparison = OpenLayers.Class(OpenLayers.Filter, {
+    type: null,
+    property: null,
+    value: null,
+    matchCase: !0,
+    lowerBoundary: null,
+    upperBoundary: null,
+    initialize: function(a) {
+        OpenLayers.Filter.prototype.initialize.apply(this, [a]);
+        this.type === OpenLayers.Filter.Comparison.LIKE && void 0 === a.matchCase && (this.matchCase = null)
+    },
+    evaluate: function(a) {
+        a instanceof OpenLayers.Feature.Vector && (a = a.attributes);
+        var b = !1,
+            a = a[this.property];
+        switch (this.type) {
+            case OpenLayers.Filter.Comparison.EQUAL_TO:
+                b = this.value;
+                b = !this.matchCase && "string" == typeof a && "string" == typeof b ? a.toUpperCase() == b.toUpperCase() : a == b;
+                break;
+            case OpenLayers.Filter.Comparison.NOT_EQUAL_TO:
+                b = this.value;
+                b = !this.matchCase && "string" == typeof a && "string" == typeof b ? a.toUpperCase() != b.toUpperCase() : a != b;
+                break;
+            case OpenLayers.Filter.Comparison.LESS_THAN:
+                b = a < this.value;
+                break;
+            case OpenLayers.Filter.Comparison.GREATER_THAN:
+                b = a > this.value;
+                break;
+            case OpenLayers.Filter.Comparison.LESS_THAN_OR_EQUAL_TO:
+                b = a <= this.value;
+                break;
+            case OpenLayers.Filter.Comparison.GREATER_THAN_OR_EQUAL_TO:
+                b =
+                    a >= this.value;
+                break;
+            case OpenLayers.Filter.Comparison.BETWEEN:
+                b = a >= this.lowerBoundary && a <= this.upperBoundary;
+                break;
+            case OpenLayers.Filter.Comparison.LIKE:
+                b = RegExp(this.value, "gi").test(a)
+        }
+        return b
+    },
+    value2regex: function(a, b, c) {
+        if ("." == a) throw Error("'.' is an unsupported wildCard character for OpenLayers.Filter.Comparison");
+        a = a ? a : "*";
+        b = b ? b : ".";
+        this.value = this.value.replace(RegExp("\\" + (c ? c : "!") + "(.|$)", "g"), "\\$1");
+        this.value = this.value.replace(RegExp("\\" + b, "g"), ".");
+        this.value = this.value.replace(RegExp("\\" +
+            a, "g"), ".*");
+        this.value = this.value.replace(RegExp("\\\\.\\*", "g"), "\\" + a);
+        return this.value = this.value.replace(RegExp("\\\\\\.", "g"), "\\" + b)
+    },
+    regex2value: function() {
+        var a = this.value,
+            a = a.replace(/!/g, "!!"),
+            a = a.replace(/(\\)?\\\./g, function(a, c) {
+                return c ? a : "!."
+            }),
+            a = a.replace(/(\\)?\\\*/g, function(a, c) {
+                return c ? a : "!*"
+            }),
+            a = a.replace(/\\\\/g, "\\");
+        return a = a.replace(/\.\*/g, "*")
+    },
+    clone: function() {
+        return OpenLayers.Util.extend(new OpenLayers.Filter.Comparison, this)
+    },
+    CLASS_NAME: "OpenLayers.Filter.Comparison"
+});
+OpenLayers.Filter.Comparison.EQUAL_TO = "==";
+OpenLayers.Filter.Comparison.NOT_EQUAL_TO = "!=";
+OpenLayers.Filter.Comparison.LESS_THAN = "<";
+OpenLayers.Filter.Comparison.GREATER_THAN = ">";
+OpenLayers.Filter.Comparison.LESS_THAN_OR_EQUAL_TO = "<=";
+OpenLayers.Filter.Comparison.GREATER_THAN_OR_EQUAL_TO = ">=";
+OpenLayers.Filter.Comparison.BETWEEN = "..";
+OpenLayers.Filter.Comparison.LIKE = "~";
+OpenLayers.Format.Filter = OpenLayers.Class(OpenLayers.Format.XML.VersionedOGC, {
+    defaultVersion: "1.0.0",
+    CLASS_NAME: "OpenLayers.Format.Filter"
+});
+OpenLayers.Filter.Function = OpenLayers.Class(OpenLayers.Filter, {
+    name: null,
+    params: null,
+    CLASS_NAME: "OpenLayers.Filter.Function"
+});
+OpenLayers.Format.Filter.v1 = OpenLayers.Class(OpenLayers.Format.XML, {
+    namespaces: {
+        ogc: "http://www.opengis.net/ogc",
+        gml: "http://www.opengis.net/gml",
+        xlink: "http://www.w3.org/1999/xlink",
+        xsi: "http://www.w3.org/2001/XMLSchema-instance"
+    },
+    defaultPrefix: "ogc",
+    schemaLocation: null,
+    initialize: function(a) {
+        OpenLayers.Format.XML.prototype.initialize.apply(this, [a])
+    },
+    read: function(a) {
+        var b = {};
+        this.readers.ogc.Filter.apply(this, [a, b]);
+        return b.filter
+    },
+    readers: {
+        ogc: {
+            _expression: function(a) {
+                for (var b = "", c = a.firstChild; c; c =
+                    c.nextSibling) switch (c.nodeType) {
+                    case 1:
+                        a = this.readNode(c);
+                        a.property ? b += "${" + a.property + "}" : void 0 !== a.value && (b += a.value);
+                        break;
+                    case 3:
+                    case 4:
+                        b += c.nodeValue
+                }
+                return b
+            },
+            Filter: function(a, b) {
+                var c = {
+                    fids: [],
+                    filters: []
+                };
+                this.readChildNodes(a, c);
+                0 < c.fids.length ? b.filter = new OpenLayers.Filter.FeatureId({
+                    fids: c.fids
+                }) : 0 < c.filters.length && (b.filter = c.filters[0])
+            },
+            FeatureId: function(a, b) {
+                var c = a.getAttribute("fid");
+                c && b.fids.push(c)
+            },
+            And: function(a, b) {
+                var c = new OpenLayers.Filter.Logical({
+                    type: OpenLayers.Filter.Logical.AND
+                });
+                this.readChildNodes(a, c);
+                b.filters.push(c)
+            },
+            Or: function(a, b) {
+                var c = new OpenLayers.Filter.Logical({
+                    type: OpenLayers.Filter.Logical.OR
+                });
+                this.readChildNodes(a, c);
+                b.filters.push(c)
+            },
+            Not: function(a, b) {
+                var c = new OpenLayers.Filter.Logical({
+                    type: OpenLayers.Filter.Logical.NOT
+                });
+                this.readChildNodes(a, c);
+                b.filters.push(c)
+            },
+            PropertyIsLessThan: function(a, b) {
+                var c = new OpenLayers.Filter.Comparison({
+                    type: OpenLayers.Filter.Comparison.LESS_THAN
+                });
+                this.readChildNodes(a, c);
+                b.filters.push(c)
+            },
+            PropertyIsGreaterThan: function(a,
+                b) {
+                var c = new OpenLayers.Filter.Comparison({
+                    type: OpenLayers.Filter.Comparison.GREATER_THAN
+                });
+                this.readChildNodes(a, c);
+                b.filters.push(c)
+            },
+            PropertyIsLessThanOrEqualTo: function(a, b) {
+                var c = new OpenLayers.Filter.Comparison({
+                    type: OpenLayers.Filter.Comparison.LESS_THAN_OR_EQUAL_TO
+                });
+                this.readChildNodes(a, c);
+                b.filters.push(c)
+            },
+            PropertyIsGreaterThanOrEqualTo: function(a, b) {
+                var c = new OpenLayers.Filter.Comparison({
+                    type: OpenLayers.Filter.Comparison.GREATER_THAN_OR_EQUAL_TO
+                });
+                this.readChildNodes(a, c);
+                b.filters.push(c)
+            },
+            PropertyIsBetween: function(a, b) {
+                var c = new OpenLayers.Filter.Comparison({
+                    type: OpenLayers.Filter.Comparison.BETWEEN
+                });
+                this.readChildNodes(a, c);
+                b.filters.push(c)
+            },
+            Literal: function(a, b) {
+                b.value = OpenLayers.String.numericIf(this.getChildValue(a))
+            },
+            PropertyName: function(a, b) {
+                b.property = this.getChildValue(a)
+            },
+            LowerBoundary: function(a, b) {
+                b.lowerBoundary = OpenLayers.String.numericIf(this.readers.ogc._expression.call(this, a))
+            },
+            UpperBoundary: function(a, b) {
+                b.upperBoundary = OpenLayers.String.numericIf(this.readers.ogc._expression.call(this,
+                    a))
+            },
+            Intersects: function(a, b) {
+                this.readSpatial(a, b, OpenLayers.Filter.Spatial.INTERSECTS)
+            },
+            Within: function(a, b) {
+                this.readSpatial(a, b, OpenLayers.Filter.Spatial.WITHIN)
+            },
+            Contains: function(a, b) {
+                this.readSpatial(a, b, OpenLayers.Filter.Spatial.CONTAINS)
+            },
+            DWithin: function(a, b) {
+                this.readSpatial(a, b, OpenLayers.Filter.Spatial.DWITHIN)
+            },
+            Distance: function(a, b) {
+                b.distance = parseInt(this.getChildValue(a));
+                b.distanceUnits = a.getAttribute("units")
+            },
+            Function: function() {}
+        }
+    },
+    readSpatial: function(a, b, c) {
+        c = new OpenLayers.Filter.Spatial({
+            type: c
+        });
+        this.readChildNodes(a, c);
+        c.value = c.components[0];
+        delete c.components;
+        b.filters.push(c)
+    },
+    writeOgcExpression: function(a, b) {
+        if (a instanceof OpenLayers.Filter.Function) {
+            var c = this.writeNode("Function", a, b);
+            b.appendChild(c)
+        } else this.writeNode("Literal", a, b);
+        return b
+    },
+    write: function(a) {
+        return this.writers.ogc.Filter.apply(this, [a])
+    },
+    writeFeatureIdNodes: function(a, b) {
+        for (var c = 0, d = a.fids.length; c < d; ++c) this.writeNode("FeatureId", a.fids[c], b)
+    },
+    writers: {
+        ogc: {
+            Filter: function(a) {
+                var b = this.createElementNSPlus("ogc:Filter");
+                "FID" === a.type ? OpenLayers.Format.Filter.v1.prototype.writeFeatureIdNodes.call(this, a, b) : this.writeNode(this.getFilterType(a), a, b);
+                return b
+            },
+            FeatureId: function(a) {
+                return this.createElementNSPlus("ogc:FeatureId", {
+                    attributes: {
+                        fid: a
+                    }
+                })
+            },
+            And: function(a) {
+                for (var b = this.createElementNSPlus("ogc:And"), c, d = 0, e = a.filters.length; d < e; ++d) c = a.filters[d], "FID" === c.type ? OpenLayers.Format.Filter.v1.prototype.writeFeatureIdNodes.call(this, c, b) : this.writeNode(this.getFilterType(c), c, b);
+                return b
+            },
+            Or: function(a) {
+                for (var b =
+                        this.createElementNSPlus("ogc:Or"), c, d = 0, e = a.filters.length; d < e; ++d) c = a.filters[d], "FID" === c.type ? OpenLayers.Format.Filter.v1.prototype.writeFeatureIdNodes.call(this, c, b) : this.writeNode(this.getFilterType(c), c, b);
+                return b
+            },
+            Not: function(a) {
+                var b = this.createElementNSPlus("ogc:Not"),
+                    a = a.filters[0];
+                "FID" === a.type ? OpenLayers.Format.Filter.v1.prototype.writeFeatureIdNodes.call(this, a, b) : this.writeNode(this.getFilterType(a), a, b);
+                return b
+            },
+            PropertyIsLessThan: function(a) {
+                var b = this.createElementNSPlus("ogc:PropertyIsLessThan");
+                this.writeNode("PropertyName", a, b);
+                this.writeOgcExpression(a.value, b);
+                return b
+            },
+            PropertyIsGreaterThan: function(a) {
+                var b = this.createElementNSPlus("ogc:PropertyIsGreaterThan");
+                this.writeNode("PropertyName", a, b);
+                this.writeOgcExpression(a.value, b);
+                return b
+            },
+            PropertyIsLessThanOrEqualTo: function(a) {
+                var b = this.createElementNSPlus("ogc:PropertyIsLessThanOrEqualTo");
+                this.writeNode("PropertyName", a, b);
+                this.writeOgcExpression(a.value, b);
+                return b
+            },
+            PropertyIsGreaterThanOrEqualTo: function(a) {
+                var b = this.createElementNSPlus("ogc:PropertyIsGreaterThanOrEqualTo");
+                this.writeNode("PropertyName", a, b);
+                this.writeOgcExpression(a.value, b);
+                return b
+            },
+            PropertyIsBetween: function(a) {
+                var b = this.createElementNSPlus("ogc:PropertyIsBetween");
+                this.writeNode("PropertyName", a, b);
+                this.writeNode("LowerBoundary", a, b);
+                this.writeNode("UpperBoundary", a, b);
+                return b
+            },
+            PropertyName: function(a) {
+                return this.createElementNSPlus("ogc:PropertyName", {
+                    value: a.property
+                })
+            },
+            Literal: function(a) {
+                return this.createElementNSPlus("ogc:Literal", {
+                    value: a
+                })
+            },
+            LowerBoundary: function(a) {
+                var b = this.createElementNSPlus("ogc:LowerBoundary");
+                this.writeOgcExpression(a.lowerBoundary, b);
+                return b
+            },
+            UpperBoundary: function(a) {
+                var b = this.createElementNSPlus("ogc:UpperBoundary");
+                this.writeNode("Literal", a.upperBoundary, b);
+                return b
+            },
+            INTERSECTS: function(a) {
+                return this.writeSpatial(a, "Intersects")
+            },
+            WITHIN: function(a) {
+                return this.writeSpatial(a, "Within")
+            },
+            CONTAINS: function(a) {
+                return this.writeSpatial(a, "Contains")
+            },
+            DWITHIN: function(a) {
+                var b = this.writeSpatial(a, "DWithin");
+                this.writeNode("Distance", a, b);
+                return b
+            },
+            Distance: function(a) {
+                return this.createElementNSPlus("ogc:Distance", {
+                    attributes: {
+                        units: a.distanceUnits
+                    },
+                    value: a.distance
+                })
+            },
+            Function: function(a) {
+                for (var b = this.createElementNSPlus("ogc:Function", {
+                        attributes: {
+                            name: a.name
+                        }
+                    }), a = a.params, c = 0, d = a.length; c < d; c++) this.writeOgcExpression(a[c], b);
+                return b
+            }
+        }
+    },
+    getFilterType: function(a) {
+        var b = this.filterMap[a.type];
+        if (!b) throw "Filter writing not supported for rule type: " + a.type;
+        return b
+    },
+    filterMap: {
+        "&&": "And",
+        "||": "Or",
+        "!": "Not",
+        "==": "PropertyIsEqualTo",
+        "!=": "PropertyIsNotEqualTo",
+        "<": "PropertyIsLessThan",
+        ">": "PropertyIsGreaterThan",
+        "<=": "PropertyIsLessThanOrEqualTo",
+        ">=": "PropertyIsGreaterThanOrEqualTo",
+        "..": "PropertyIsBetween",
+        "~": "PropertyIsLike",
+        BBOX: "BBOX",
+        DWITHIN: "DWITHIN",
+        WITHIN: "WITHIN",
+        CONTAINS: "CONTAINS",
+        INTERSECTS: "INTERSECTS",
+        FID: "FeatureId"
+    },
+    CLASS_NAME: "OpenLayers.Format.Filter.v1"
+});
+OpenLayers.Geometry = OpenLayers.Class({
+    id: null,
+    parent: null,
+    bounds: null,
+    initialize: function() {
+        this.id = OpenLayers.Util.createUniqueID(this.CLASS_NAME + "_")
+    },
+    destroy: function() {
+        this.bounds = this.id = null
+    },
+    clone: function() {
+        return new OpenLayers.Geometry
+    },
+    setBounds: function(a) {
+        a && (this.bounds = a.clone())
+    },
+    clearBounds: function() {
+        this.bounds = null;
+        this.parent && this.parent.clearBounds()
+    },
+    extendBounds: function(a) {
+        this.getBounds() ? this.bounds.extend(a) : this.setBounds(a)
+    },
+    getBounds: function() {
+        null == this.bounds && this.calculateBounds();
+        return this.bounds
+    },
+    calculateBounds: function() {},
+    distanceTo: function() {},
+    getVertices: function() {},
+    atPoint: function(a, b, c) {
+        var d = !1;
+        null != this.getBounds() && null != a && (b = null != b ? b : 0, c = null != c ? c : 0, d = (new OpenLayers.Bounds(this.bounds.left - b, this.bounds.bottom - c, this.bounds.right + b, this.bounds.top + c)).containsLonLat(a));
+        return d
+    },
+    getLength: function() {
+        return 0
+    },
+    getArea: function() {
+        return 0
+    },
+    getCentroid: function() {
+        return null
+    },
+    toString: function() {
+        return OpenLayers.Format && OpenLayers.Format.WKT ? OpenLayers.Format.WKT.prototype.write(new OpenLayers.Feature.Vector(this)) :
+            Object.prototype.toString.call(this)
+    },
+    CLASS_NAME: "OpenLayers.Geometry"
+});
+OpenLayers.Geometry.fromWKT = function(a) {
+    var b;
+    if (OpenLayers.Format && OpenLayers.Format.WKT) {
+        var c = OpenLayers.Geometry.fromWKT.format;
+        c || (c = new OpenLayers.Format.WKT, OpenLayers.Geometry.fromWKT.format = c);
+        a = c.read(a);
+        if (a instanceof OpenLayers.Feature.Vector) b = a.geometry;
+        else if (OpenLayers.Util.isArray(a)) {
+            b = a.length;
+            for (var c = Array(b), d = 0; d < b; ++d) c[d] = a[d].geometry;
+            b = new OpenLayers.Geometry.Collection(c)
+        }
+    }
+    return b
+};
+OpenLayers.Geometry.segmentsIntersect = function(a, b, c) {
+    var d = c && c.point,
+        c = c && c.tolerance,
+        e = !1,
+        f = a.x1 - b.x1,
+        g = a.y1 - b.y1,
+        h = a.x2 - a.x1,
+        i = a.y2 - a.y1,
+        j = b.y2 - b.y1,
+        k = b.x2 - b.x1,
+        l = j * h - k * i,
+        j = k * g - j * f,
+        g = h * g - i * f;
+    0 == l ? 0 == j && 0 == g && (e = !0) : (f = j / l, l = g / l, 0 <= f && (1 >= f && 0 <= l && 1 >= l) && (d ? (h = a.x1 + f * h, l = a.y1 + f * i, e = new OpenLayers.Geometry.Point(h, l)) : e = !0));
+    if (c)
+        if (e) {
+            if (d) {
+                a = [a, b];
+                b = 0;
+                a: for (; 2 > b; ++b) {
+                    f = a[b];
+                    for (i = 1; 3 > i; ++i)
+                        if (h = f["x" + i], l = f["y" + i], d = Math.sqrt(Math.pow(h - e.x, 2) + Math.pow(l - e.y, 2)), d < c) {
+                            e.x = h;
+                            e.y = l;
+                            break a
+                        }
+                }
+            }
+        } else {
+            a = [a, b];
+            b = 0;
+            a: for (; 2 > b; ++b) {
+                h = a[b];
+                l = a[(b + 1) % 2];
+                for (i = 1; 3 > i; ++i)
+                    if (f = {
+                            x: h["x" + i],
+                            y: h["y" + i]
+                        }, g = OpenLayers.Geometry.distanceToSegment(f, l), g.distance < c) {
+                        e = d ? new OpenLayers.Geometry.Point(f.x, f.y) : !0;
+                        break a
+                    }
+            }
+        }
+    return e
+};
+OpenLayers.Geometry.distanceToSegment = function(a, b) {
+    var c = a.x,
+        d = a.y,
+        e = b.x1,
+        f = b.y1,
+        g = b.x2,
+        h = b.y2,
+        i = g - e,
+        j = h - f,
+        k = (i * (c - e) + j * (d - f)) / (Math.pow(i, 2) + Math.pow(j, 2));
+    0 >= k || (1 <= k ? (e = g, f = h) : (e += k * i, f += k * j));
+    return {
+        distance: Math.sqrt(Math.pow(e - c, 2) + Math.pow(f - d, 2)),
+        x: e,
+        y: f
+    }
+};
+OpenLayers.Geometry.Point = OpenLayers.Class(OpenLayers.Geometry, {
+    x: null,
+    y: null,
+    initialize: function(a, b) {
+        OpenLayers.Geometry.prototype.initialize.apply(this, arguments);
+        this.x = parseFloat(a);
+        this.y = parseFloat(b)
+    },
+    clone: function(a) {
+        null == a && (a = new OpenLayers.Geometry.Point(this.x, this.y));
+        OpenLayers.Util.applyDefaults(a, this);
+        return a
+    },
+    calculateBounds: function() {
+        this.bounds = new OpenLayers.Bounds(this.x, this.y, this.x, this.y)
+    },
+    distanceTo: function(a, b) {
+        var c = !(b && !1 === b.edge) && b && b.details,
+            d, e, f, g, h;
+        a instanceof
+        OpenLayers.Geometry.Point ? (e = this.x, f = this.y, g = a.x, h = a.y, d = Math.sqrt(Math.pow(e - g, 2) + Math.pow(f - h, 2)), d = !c ? d : {
+            x0: e,
+            y0: f,
+            x1: g,
+            y1: h,
+            distance: d
+        }) : (d = a.distanceTo(this, b), c && (d = {
+            x0: d.x1,
+            y0: d.y1,
+            x1: d.x0,
+            y1: d.y0,
+            distance: d.distance
+        }));
+        return d
+    },
+    equals: function(a) {
+        var b = !1;
+        null != a && (b = this.x == a.x && this.y == a.y || isNaN(this.x) && isNaN(this.y) && isNaN(a.x) && isNaN(a.y));
+        return b
+    },
+    toShortString: function() {
+        return this.x + ", " + this.y
+    },
+    move: function(a, b) {
+        this.x += a;
+        this.y += b;
+        this.clearBounds()
+    },
+    rotate: function(a, b) {
+        var a =
+            a * (Math.PI / 180),
+            c = this.distanceTo(b),
+            d = a + Math.atan2(this.y - b.y, this.x - b.x);
+        this.x = b.x + c * Math.cos(d);
+        this.y = b.y + c * Math.sin(d);
+        this.clearBounds()
+    },
+    getCentroid: function() {
+        return new OpenLayers.Geometry.Point(this.x, this.y)
+    },
+    resize: function(a, b, c) {
+        this.x = b.x + a * (void 0 == c ? 1 : c) * (this.x - b.x);
+        this.y = b.y + a * (this.y - b.y);
+        this.clearBounds();
+        return this
+    },
+    intersects: function(a) {
+        var b = !1;
+        return b = "OpenLayers.Geometry.Point" == a.CLASS_NAME ? this.equals(a) : a.intersects(this)
+    },
+    transform: function(a, b) {
+        a && b && (OpenLayers.Projection.transform(this,
+            a, b), this.bounds = null);
+        return this
+    },
+    getVertices: function() {
+        return [this]
+    },
+    CLASS_NAME: "OpenLayers.Geometry.Point"
+});
+OpenLayers.Geometry.Collection = OpenLayers.Class(OpenLayers.Geometry, {
+    components: null,
+    componentTypes: null,
+    initialize: function(a) {
+        OpenLayers.Geometry.prototype.initialize.apply(this, arguments);
+        this.components = [];
+        null != a && this.addComponents(a)
+    },
+    destroy: function() {
+        this.components.length = 0;
+        this.components = null;
+        OpenLayers.Geometry.prototype.destroy.apply(this, arguments)
+    },
+    clone: function() {
+        for (var a = eval("new " + this.CLASS_NAME + "()"), b = 0, c = this.components.length; b < c; b++) a.addComponent(this.components[b].clone());
+        OpenLayers.Util.applyDefaults(a, this);
+        return a
+    },
+    getComponentsString: function() {
+        for (var a = [], b = 0, c = this.components.length; b < c; b++) a.push(this.components[b].toShortString());
+        return a.join(",")
+    },
+    calculateBounds: function() {
+        this.bounds = null;
+        var a = new OpenLayers.Bounds,
+            b = this.components;
+        if (b)
+            for (var c = 0, d = b.length; c < d; c++) a.extend(b[c].getBounds());
+        null != a.left && (null != a.bottom && null != a.right && null != a.top) && this.setBounds(a)
+    },
+    addComponents: function(a) {
+        OpenLayers.Util.isArray(a) || (a = [a]);
+        for (var b = 0, c = a.length; b <
+            c; b++) this.addComponent(a[b])
+    },
+    addComponent: function(a, b) {
+        var c = !1;
+        if (a && (null == this.componentTypes || -1 < OpenLayers.Util.indexOf(this.componentTypes, a.CLASS_NAME))) {
+            if (null != b && b < this.components.length) {
+                var c = this.components.slice(0, b),
+                    d = this.components.slice(b, this.components.length);
+                c.push(a);
+                this.components = c.concat(d)
+            } else this.components.push(a);
+            a.parent = this;
+            this.clearBounds();
+            c = !0
+        }
+        return c
+    },
+    removeComponents: function(a) {
+        var b = !1;
+        OpenLayers.Util.isArray(a) || (a = [a]);
+        for (var c = a.length - 1; 0 <= c; --c) b =
+            this.removeComponent(a[c]) || b;
+        return b
+    },
+    removeComponent: function(a) {
+        OpenLayers.Util.removeItem(this.components, a);
+        this.clearBounds();
+        return !0
+    },
+    getLength: function() {
+        for (var a = 0, b = 0, c = this.components.length; b < c; b++) a += this.components[b].getLength();
+        return a
+    },
+    getArea: function() {
+        for (var a = 0, b = 0, c = this.components.length; b < c; b++) a += this.components[b].getArea();
+        return a
+    },
+    getGeodesicArea: function(a) {
+        for (var b = 0, c = 0, d = this.components.length; c < d; c++) b += this.components[c].getGeodesicArea(a);
+        return b
+    },
+    getCentroid: function(a) {
+        if (!a) return this.components.length &&
+            this.components[0].getCentroid();
+        a = this.components.length;
+        if (!a) return !1;
+        for (var b = [], c = [], d = 0, e = Number.MAX_VALUE, f, g = 0; g < a; ++g) {
+            f = this.components[g];
+            var h = f.getArea();
+            f = f.getCentroid(!0);
+            !isNaN(h) && (!isNaN(f.x) && !isNaN(f.y)) && (b.push(h), d += h, e = h < e && 0 < h ? h : e, c.push(f))
+        }
+        a = b.length;
+        if (0 === d) {
+            for (g = 0; g < a; ++g) b[g] = 1;
+            d = b.length
+        } else {
+            for (g = 0; g < a; ++g) b[g] /= e;
+            d /= e
+        }
+        for (var i = e = 0, g = 0; g < a; ++g) f = c[g], h = b[g], e += f.x * h, i += f.y * h;
+        return new OpenLayers.Geometry.Point(e / d, i / d)
+    },
+    getGeodesicLength: function(a) {
+        for (var b =
+                0, c = 0, d = this.components.length; c < d; c++) b += this.components[c].getGeodesicLength(a);
+        return b
+    },
+    move: function(a, b) {
+        for (var c = 0, d = this.components.length; c < d; c++) this.components[c].move(a, b)
+    },
+    rotate: function(a, b) {
+        for (var c = 0, d = this.components.length; c < d; ++c) this.components[c].rotate(a, b)
+    },
+    resize: function(a, b, c) {
+        for (var d = 0; d < this.components.length; ++d) this.components[d].resize(a, b, c);
+        return this
+    },
+    distanceTo: function(a, b) {
+        for (var c = !(b && !1 === b.edge) && b && b.details, d, e, f, g = Number.POSITIVE_INFINITY, h = 0, i = this.components.length; h <
+            i && !(d = this.components[h].distanceTo(a, b), f = c ? d.distance : d, f < g && (g = f, e = d, 0 == g)); ++h);
+        return e
+    },
+    equals: function(a) {
+        var b = !0;
+        if (!a || !a.CLASS_NAME || this.CLASS_NAME != a.CLASS_NAME) b = !1;
+        else if (!OpenLayers.Util.isArray(a.components) || a.components.length != this.components.length) b = !1;
+        else
+            for (var c = 0, d = this.components.length; c < d; ++c)
+                if (!this.components[c].equals(a.components[c])) {
+                    b = !1;
+                    break
+                } return b
+    },
+    transform: function(a, b) {
+        if (a && b) {
+            for (var c = 0, d = this.components.length; c < d; c++) this.components[c].transform(a,
+                b);
+            this.bounds = null
+        }
+        return this
+    },
+    intersects: function(a) {
+        for (var b = !1, c = 0, d = this.components.length; c < d && !(b = a.intersects(this.components[c])); ++c);
+        return b
+    },
+    getVertices: function(a) {
+        for (var b = [], c = 0, d = this.components.length; c < d; ++c) Array.prototype.push.apply(b, this.components[c].getVertices(a));
+        return b
+    },
+    CLASS_NAME: "OpenLayers.Geometry.Collection"
+});
+OpenLayers.Geometry.MultiPoint = OpenLayers.Class(OpenLayers.Geometry.Collection, {
+    componentTypes: ["OpenLayers.Geometry.Point"],
+    addPoint: function(a, b) {
+        this.addComponent(a, b)
+    },
+    removePoint: function(a) {
+        this.removeComponent(a)
+    },
+    CLASS_NAME: "OpenLayers.Geometry.MultiPoint"
+});
+OpenLayers.Geometry.Curve = OpenLayers.Class(OpenLayers.Geometry.MultiPoint, {
+    componentTypes: ["OpenLayers.Geometry.Point"],
+    getLength: function() {
+        var a = 0;
+        if (this.components && 1 < this.components.length)
+            for (var b = 1, c = this.components.length; b < c; b++) a += this.components[b - 1].distanceTo(this.components[b]);
+        return a
+    },
+    getGeodesicLength: function(a) {
+        var b = this;
+        if (a) {
+            var c = new OpenLayers.Projection("EPSG:4326");
+            c.equals(a) || (b = this.clone().transform(a, c))
+        }
+        a = 0;
+        if (b.components && 1 < b.components.length)
+            for (var d, e = 1, f = b.components.length; e <
+                f; e++) c = b.components[e - 1], d = b.components[e], a += OpenLayers.Util.distVincenty({
+                lon: c.x,
+                lat: c.y
+            }, {
+                lon: d.x,
+                lat: d.y
+            });
+        return 1E3 * a
+    },
+    CLASS_NAME: "OpenLayers.Geometry.Curve"
+});
+OpenLayers.Geometry.LineString = OpenLayers.Class(OpenLayers.Geometry.Curve, {
+    removeComponent: function(a) {
+        var b = this.components && 2 < this.components.length;
+        b && OpenLayers.Geometry.Collection.prototype.removeComponent.apply(this, arguments);
+        return b
+    },
+    intersects: function(a) {
+        var b = !1,
+            c = a.CLASS_NAME;
+        if ("OpenLayers.Geometry.LineString" == c || "OpenLayers.Geometry.LinearRing" == c || "OpenLayers.Geometry.Point" == c) {
+            var d = this.getSortedSegments(),
+                a = "OpenLayers.Geometry.Point" == c ? [{
+                    x1: a.x,
+                    y1: a.y,
+                    x2: a.x,
+                    y2: a.y
+                }] : a.getSortedSegments(),
+                e, f, g, h, i, j, k, l = 0,
+                m = d.length;
+            a: for (; l < m; ++l) {
+                c = d[l];
+                e = c.x1;
+                f = c.x2;
+                g = c.y1;
+                h = c.y2;
+                var n = 0,
+                    o = a.length;
+                for (; n < o; ++n) {
+                    i = a[n];
+                    if (i.x1 > f) break;
+                    if (!(i.x2 < e) && (j = i.y1, k = i.y2, !(Math.min(j, k) > Math.max(g, h)) && !(Math.max(j, k) < Math.min(g, h)) && OpenLayers.Geometry.segmentsIntersect(c, i))) {
+                        b = !0;
+                        break a
+                    }
+                }
+            }
+        } else b = a.intersects(this);
+        return b
+    },
+    getSortedSegments: function() {
+        for (var a = this.components.length - 1, b = Array(a), c, d, e = 0; e < a; ++e) c = this.components[e], d = this.components[e + 1], b[e] = c.x < d.x ? {
+            x1: c.x,
+            y1: c.y,
+            x2: d.x,
+            y2: d.y
+        } : {
+            x1: d.x,
+            y1: d.y,
+            x2: c.x,
+            y2: c.y
+        };
+        return b.sort(function(a, b) {
+            return a.x1 - b.x1
+        })
+    },
+    splitWithSegment: function(a, b) {
+        for (var c = !(b && !1 === b.edge), d = b && b.tolerance, e = [], f = this.getVertices(), g = [], h = [], i = !1, j, k, l, m = {
+                point: !0,
+                tolerance: d
+            }, n = null, o = 0, p = f.length - 2; o <= p; ++o)
+            if (d = f[o], g.push(d.clone()), j = f[o + 1], k = {
+                    x1: d.x,
+                    y1: d.y,
+                    x2: j.x,
+                    y2: j.y
+                }, k = OpenLayers.Geometry.segmentsIntersect(a, k, m), k instanceof OpenLayers.Geometry.Point && ((l = k.x === a.x1 && k.y === a.y1 || k.x === a.x2 && k.y === a.y2 || k.equals(d) || k.equals(j) ? !0 : !1) || c)) k.equals(h[h.length -
+                1]) || h.push(k.clone()), !(0 === o && k.equals(d)) && !k.equals(j) && (i = !0, k.equals(d) || g.push(k), e.push(new OpenLayers.Geometry.LineString(g)), g = [k.clone()]);
+        i && (g.push(j.clone()), e.push(new OpenLayers.Geometry.LineString(g)));
+        if (0 < h.length) var q = a.x1 < a.x2 ? 1 : -1,
+            r = a.y1 < a.y2 ? 1 : -1,
+            n = {
+                lines: e,
+                points: h.sort(function(a, b) {
+                    return q * a.x - q * b.x || r * a.y - r * b.y
+                })
+            };
+        return n
+    },
+    split: function(a, b) {
+        var c = null,
+            d = b && b.mutual,
+            e, f, g, h;
+        if (a instanceof OpenLayers.Geometry.LineString) {
+            var i = this.getVertices(),
+                j, k, l, m, n, o = [];
+            g = [];
+            for (var p = 0, q = i.length - 2; p <= q; ++p) {
+                j = i[p];
+                k = i[p + 1];
+                l = {
+                    x1: j.x,
+                    y1: j.y,
+                    x2: k.x,
+                    y2: k.y
+                };
+                h = h || [a];
+                d && o.push(j.clone());
+                for (var r = 0; r < h.length; ++r)
+                    if (m = h[r].splitWithSegment(l, b))
+                        if (n = m.lines, 0 < n.length && (n.unshift(r, 1), Array.prototype.splice.apply(h, n), r += n.length - 2), d)
+                            for (var s = 0, t = m.points.length; s < t; ++s) n = m.points[s], n.equals(j) || (o.push(n), g.push(new OpenLayers.Geometry.LineString(o)), o = n.equals(k) ? [] : [n.clone()])
+            }
+            d && (0 < g.length && 0 < o.length) && (o.push(k.clone()), g.push(new OpenLayers.Geometry.LineString(o)))
+        } else c =
+            a.splitWith(this, b);
+        h && 1 < h.length ? f = !0 : h = [];
+        g && 1 < g.length ? e = !0 : g = [];
+        if (f || e) c = d ? [g, h] : h;
+        return c
+    },
+    splitWith: function(a, b) {
+        return a.split(this, b)
+    },
+    getVertices: function(a) {
+        return !0 === a ? [this.components[0], this.components[this.components.length - 1]] : !1 === a ? this.components.slice(1, this.components.length - 1) : this.components.slice()
+    },
+    distanceTo: function(a, b) {
+        var c = !(b && !1 === b.edge) && b && b.details,
+            d, e = {},
+            f = Number.POSITIVE_INFINITY;
+        if (a instanceof OpenLayers.Geometry.Point) {
+            for (var g = this.getSortedSegments(),
+                    h = a.x, i = a.y, j, k = 0, l = g.length; k < l; ++k)
+                if (j = g[k], d = OpenLayers.Geometry.distanceToSegment(a, j), d.distance < f) {
+                    if (f = d.distance, e = d, 0 === f) break
+                } else if (j.x2 > h && (i > j.y1 && i < j.y2 || i < j.y1 && i > j.y2)) break;
+            e = c ? {
+                distance: e.distance,
+                x0: e.x,
+                y0: e.y,
+                x1: h,
+                y1: i
+            } : e.distance
+        } else if (a instanceof OpenLayers.Geometry.LineString) {
+            var g = this.getSortedSegments(),
+                h = a.getSortedSegments(),
+                m, n, o = h.length,
+                p = {
+                    point: !0
+                },
+                k = 0,
+                l = g.length;
+            a: for (; k < l; ++k) {
+                i = g[k];
+                j = i.x1;
+                n = i.y1;
+                for (var q = 0; q < o; ++q)
+                    if (d = h[q], m = OpenLayers.Geometry.segmentsIntersect(i,
+                            d, p)) {
+                        f = 0;
+                        e = {
+                            distance: 0,
+                            x0: m.x,
+                            y0: m.y,
+                            x1: m.x,
+                            y1: m.y
+                        };
+                        break a
+                    } else d = OpenLayers.Geometry.distanceToSegment({
+                        x: j,
+                        y: n
+                    }, d), d.distance < f && (f = d.distance, e = {
+                        distance: f,
+                        x0: j,
+                        y0: n,
+                        x1: d.x,
+                        y1: d.y
+                    })
+            }
+            c || (e = e.distance);
+            0 !== f && i && (d = a.distanceTo(new OpenLayers.Geometry.Point(i.x2, i.y2), b), k = c ? d.distance : d, k < f && (e = c ? {
+                distance: f,
+                x0: d.x1,
+                y0: d.y1,
+                x1: d.x0,
+                y1: d.y0
+            } : k))
+        } else e = a.distanceTo(this, b), c && (e = {
+            distance: e.distance,
+            x0: e.x1,
+            y0: e.y1,
+            x1: e.x0,
+            y1: e.y0
+        });
+        return e
+    },
+    simplify: function(a) {
+        if (this && null !== this) {
+            var b = this.getVertices();
+            if (3 > b.length) return this;
+            var c = function(a, b, d, i) {
+                    for (var j = 0, k = 0, l = b, m; l < d; l++) {
+                        m = a[b];
+                        var n = a[d],
+                            o = a[l],
+                            o = Math.abs(0.5 * (m.x * n.y + n.x * o.y + o.x * m.y - n.x * m.y - o.x * n.y - m.x * o.y));
+                        m = Math.sqrt(Math.pow(m.x - n.x, 2) + Math.pow(m.y - n.y, 2));
+                        m = 2 * (o / m);
+                        m > j && (j = m, k = l)
+                    }
+                    j > i && k != b && (e.push(k), c(a, b, k, i), c(a, k, d, i))
+                },
+                d = b.length - 1,
+                e = [];
+            e.push(0);
+            for (e.push(d); b[0].equals(b[d]);) d--, e.push(d);
+            c(b, 0, d, a);
+            a = [];
+            e.sort(function(a, b) {
+                return a - b
+            });
+            for (d = 0; d < e.length; d++) a.push(b[e[d]]);
+            return new OpenLayers.Geometry.LineString(a)
+        }
+        return this
+    },
+    CLASS_NAME: "OpenLayers.Geometry.LineString"
+});
+OpenLayers.Geometry.MultiLineString = OpenLayers.Class(OpenLayers.Geometry.Collection, {
+    componentTypes: ["OpenLayers.Geometry.LineString"],
+    split: function(a, b) {
+        for (var c = null, d = b && b.mutual, e, f, g, h, i = [], j = [a], k = 0, l = this.components.length; k < l; ++k) {
+            f = this.components[k];
+            g = !1;
+            for (var m = 0; m < j.length; ++m)
+                if (e = f.split(j[m], b)) {
+                    if (d) {
+                        g = e[0];
+                        for (var n = 0, o = g.length; n < o; ++n) 0 === n && i.length ? i[i.length - 1].addComponent(g[n]) : i.push(new OpenLayers.Geometry.MultiLineString([g[n]]));
+                        g = !0;
+                        e = e[1]
+                    }
+                    if (e.length) {
+                        e.unshift(m,
+                            1);
+                        Array.prototype.splice.apply(j, e);
+                        break
+                    }
+                }
+            g || (i.length ? i[i.length - 1].addComponent(f.clone()) : i = [new OpenLayers.Geometry.MultiLineString(f.clone())])
+        }
+        i && 1 < i.length ? g = !0 : i = [];
+        j && 1 < j.length ? h = !0 : j = [];
+        if (g || h) c = d ? [i, j] : j;
+        return c
+    },
+    splitWith: function(a, b) {
+        var c = null,
+            d = b && b.mutual,
+            e, f, g, h, i, j;
+        if (a instanceof OpenLayers.Geometry.LineString) {
+            j = [];
+            i = [a];
+            for (var k = 0, l = this.components.length; k < l; ++k) {
+                g = !1;
+                f = this.components[k];
+                for (var m = 0; m < i.length; ++m)
+                    if (e = i[m].split(f, b)) {
+                        d && (g = e[0], g.length && (g.unshift(m,
+                            1), Array.prototype.splice.apply(i, g), m += g.length - 2), e = e[1], 0 === e.length && (e = [f.clone()]));
+                        g = 0;
+                        for (var n = e.length; g < n; ++g) 0 === g && j.length ? j[j.length - 1].addComponent(e[g]) : j.push(new OpenLayers.Geometry.MultiLineString([e[g]]));
+                        g = !0
+                    }
+                g || (j.length ? j[j.length - 1].addComponent(f.clone()) : j = [new OpenLayers.Geometry.MultiLineString([f.clone()])])
+            }
+        } else c = a.split(this);
+        i && 1 < i.length ? h = !0 : i = [];
+        j && 1 < j.length ? g = !0 : j = [];
+        if (h || g) c = d ? [i, j] : j;
+        return c
+    },
+    CLASS_NAME: "OpenLayers.Geometry.MultiLineString"
+});
+OpenLayers.Geometry.LinearRing = OpenLayers.Class(OpenLayers.Geometry.LineString, {
+    componentTypes: ["OpenLayers.Geometry.Point"],
+    addComponent: function(a, b) {
+        var c = !1,
+            d = this.components.pop();
+        if (null != b || !a.equals(d)) c = OpenLayers.Geometry.Collection.prototype.addComponent.apply(this, arguments);
+        OpenLayers.Geometry.Collection.prototype.addComponent.apply(this, [this.components[0]]);
+        return c
+    },
+    removeComponent: function(a) {
+        var b = this.components && 3 < this.components.length;
+        b && (this.components.pop(), OpenLayers.Geometry.Collection.prototype.removeComponent.apply(this,
+            arguments), OpenLayers.Geometry.Collection.prototype.addComponent.apply(this, [this.components[0]]));
+        return b
+    },
+    move: function(a, b) {
+        for (var c = 0, d = this.components.length; c < d - 1; c++) this.components[c].move(a, b)
+    },
+    rotate: function(a, b) {
+        for (var c = 0, d = this.components.length; c < d - 1; ++c) this.components[c].rotate(a, b)
+    },
+    resize: function(a, b, c) {
+        for (var d = 0, e = this.components.length; d < e - 1; ++d) this.components[d].resize(a, b, c);
+        return this
+    },
+    transform: function(a, b) {
+        if (a && b) {
+            for (var c = 0, d = this.components.length; c < d - 1; c++) this.components[c].transform(a,
+                b);
+            this.bounds = null
+        }
+        return this
+    },
+    getCentroid: function() {
+        if (this.components && 2 < this.components.length) {
+            for (var a = 0, b = 0, c = 0; c < this.components.length - 1; c++) var d = this.components[c],
+                e = this.components[c + 1],
+                a = a + (d.x + e.x) * (d.x * e.y - e.x * d.y),
+                b = b + (d.y + e.y) * (d.x * e.y - e.x * d.y);
+            c = -1 * this.getArea();
+            return new OpenLayers.Geometry.Point(a / (6 * c), b / (6 * c))
+        }
+        return null
+    },
+    getArea: function() {
+        var a = 0;
+        if (this.components && 2 < this.components.length) {
+            for (var b = a = 0, c = this.components.length; b < c - 1; b++) var d = this.components[b],
+                e =
+                this.components[b + 1],
+                a = a + (d.x + e.x) * (e.y - d.y);
+            a = -a / 2
+        }
+        return a
+    },
+    getGeodesicArea: function(a) {
+        var b = this;
+        if (a) {
+            var c = new OpenLayers.Projection("EPSG:4326");
+            c.equals(a) || (b = this.clone().transform(a, c))
+        }
+        a = 0;
+        c = b.components && b.components.length;
+        if (2 < c) {
+            for (var d, e, f = 0; f < c - 1; f++) d = b.components[f], e = b.components[f + 1], a += OpenLayers.Util.rad(e.x - d.x) * (2 + Math.sin(OpenLayers.Util.rad(d.y)) + Math.sin(OpenLayers.Util.rad(e.y)));
+            a = 40680631590769 * a / 2
+        }
+        return a
+    },
+    containsPoint: function(a) {
+        for (var b = OpenLayers.Number.limitSigDigs,
+                c = b(a.x, 14), a = b(a.y, 14), d = this.components.length - 1, e, f, g, h, i, j = 0, k = 0; k < d; ++k)
+            if (e = this.components[k], g = b(e.x, 14), e = b(e.y, 14), f = this.components[k + 1], h = b(f.x, 14), f = b(f.y, 14), e == f) {
+                if (a == e && (g <= h && c >= g && c <= h || g >= h && c <= g && c >= h)) {
+                    j = -1;
+                    break
+                }
+            } else {
+                i = b((a - f) * ((h - g) / (f - e)) + h, 14);
+                if (i == c && (e < f && a >= e && a <= f || e > f && a <= e && a >= f)) {
+                    j = -1;
+                    break
+                }
+                i <= c || g != h && (i < Math.min(g, h) || i > Math.max(g, h)) || (e < f && a >= e && a < f || e > f && a < e && a >= f) && ++j
+            }
+        return -1 == j ? 1 : !!(j & 1)
+    },
+    intersects: function(a) {
+        var b = !1;
+        if ("OpenLayers.Geometry.Point" ==
+            a.CLASS_NAME) b = this.containsPoint(a);
+        else if ("OpenLayers.Geometry.LineString" == a.CLASS_NAME) b = a.intersects(this);
+        else if ("OpenLayers.Geometry.LinearRing" == a.CLASS_NAME) b = OpenLayers.Geometry.LineString.prototype.intersects.apply(this, [a]);
+        else
+            for (var c = 0, d = a.components.length; c < d && !(b = a.components[c].intersects(this)); ++c);
+        return b
+    },
+    getVertices: function(a) {
+        return !0 === a ? [] : this.components.slice(0, this.components.length - 1)
+    },
+    CLASS_NAME: "OpenLayers.Geometry.LinearRing"
+});
+OpenLayers.Geometry.Polygon = OpenLayers.Class(OpenLayers.Geometry.Collection, {
+    componentTypes: ["OpenLayers.Geometry.LinearRing"],
+    getArea: function() {
+        var a = 0;
+        if (this.components && 0 < this.components.length)
+            for (var a = a + Math.abs(this.components[0].getArea()), b = 1, c = this.components.length; b < c; b++) a -= Math.abs(this.components[b].getArea());
+        return a
+    },
+    getGeodesicArea: function(a) {
+        var b = 0;
+        if (this.components && 0 < this.components.length)
+            for (var b = b + Math.abs(this.components[0].getGeodesicArea(a)), c = 1, d = this.components.length; c <
+                d; c++) b -= Math.abs(this.components[c].getGeodesicArea(a));
+        return b
+    },
+    containsPoint: function(a) {
+        var b = this.components.length,
+            c = !1;
+        if (0 < b && (c = this.components[0].containsPoint(a), 1 !== c && c && 1 < b))
+            for (var d, e = 1; e < b; ++e)
+                if (d = this.components[e].containsPoint(a)) {
+                    c = 1 === d ? 1 : !1;
+                    break
+                }
+        return c
+    },
+    intersects: function(a) {
+        var b = !1,
+            c, d;
+        if ("OpenLayers.Geometry.Point" == a.CLASS_NAME) b = this.containsPoint(a);
+        else if ("OpenLayers.Geometry.LineString" == a.CLASS_NAME || "OpenLayers.Geometry.LinearRing" == a.CLASS_NAME) {
+            c = 0;
+            for (d =
+                this.components.length; c < d && !(b = a.intersects(this.components[c])); ++c);
+            if (!b) {
+                c = 0;
+                for (d = a.components.length; c < d && !(b = this.containsPoint(a.components[c])); ++c);
+            }
+        } else {
+            c = 0;
+            for (d = a.components.length; c < d && !(b = this.intersects(a.components[c])); ++c);
+        }
+        if (!b && "OpenLayers.Geometry.Polygon" == a.CLASS_NAME) {
+            var e = this.components[0];
+            c = 0;
+            for (d = e.components.length; c < d && !(b = a.containsPoint(e.components[c])); ++c);
+        }
+        return b
+    },
+    distanceTo: function(a, b) {
+        return b && !1 === b.edge && this.intersects(a) ? 0 : OpenLayers.Geometry.Collection.prototype.distanceTo.apply(this, [a, b])
+    },
+    CLASS_NAME: "OpenLayers.Geometry.Polygon"
+});
+OpenLayers.Geometry.Polygon.createRegularPolygon = function(a, b, c, d) {
+    var e = Math.PI * (1 / c - 0.5);
+    d && (e += d / 180 * Math.PI);
+    for (var f, g = [], h = 0; h < c; ++h) f = e + 2 * h * Math.PI / c, d = a.x + b * Math.cos(f), f = a.y + b * Math.sin(f), g.push(new OpenLayers.Geometry.Point(d, f));
+    a = new OpenLayers.Geometry.LinearRing(g);
+    return new OpenLayers.Geometry.Polygon([a])
+};
+OpenLayers.Geometry.MultiPolygon = OpenLayers.Class(OpenLayers.Geometry.Collection, {
+    componentTypes: ["OpenLayers.Geometry.Polygon"],
+    CLASS_NAME: "OpenLayers.Geometry.MultiPolygon"
+});
+OpenLayers.Format.GML = OpenLayers.Class(OpenLayers.Format.XML, {
+    featureNS: "http://mapserver.gis.umn.edu/mapserver",
+    featurePrefix: "feature",
+    featureName: "featureMember",
+    layerName: "features",
+    geometryName: "geometry",
+    collectionName: "FeatureCollection",
+    gmlns: "http://www.opengis.net/gml",
+    extractAttributes: !0,
+    xy: !0,
+    initialize: function(a) {
+        this.regExes = {
+            trimSpace: /^\s*|\s*$/g,
+            removeSpace: /\s*/g,
+            splitSpace: /\s+/,
+            trimComma: /\s*,\s*/g
+        };
+        OpenLayers.Format.XML.prototype.initialize.apply(this, [a])
+    },
+    read: function(a) {
+        "string" ==
+        typeof a && (a = OpenLayers.Format.XML.prototype.read.apply(this, [a]));
+        for (var a = this.getElementsByTagNameNS(a.documentElement, this.gmlns, this.featureName), b = [], c = 0; c < a.length; c++) {
+            var d = this.parseFeature(a[c]);
+            d && b.push(d)
+        }
+        return b
+    },
+    parseFeature: function(a) {
+        for (var b = "MultiPolygon Polygon MultiLineString LineString MultiPoint Point Envelope".split(" "), c, d, e, f = 0; f < b.length; ++f)
+            if (c = b[f], d = this.getElementsByTagNameNS(a, this.gmlns, c), 0 < d.length) {
+                if (e = this.parseGeometry[c.toLowerCase()]) e = e.apply(this, [d[0]]), this.internalProjection && this.externalProjection && e.transform(this.externalProjection, this.internalProjection);
+                else throw new TypeError("Unsupported geometry type: " + c);
+                break
+            }
+        var g;
+        c = this.getElementsByTagNameNS(a, this.gmlns, "Box");
+        for (f = 0; f < c.length; ++f) b = c[f], d = this.parseGeometry.box.apply(this, [b]), b = b.parentNode, "boundedBy" === (b.localName || b.nodeName.split(":").pop()) ? g = d : e = d.toGeometry();
+        var h;
+        this.extractAttributes && (h = this.parseAttributes(a));
+        h = new OpenLayers.Feature.Vector(e, h);
+        h.bounds =
+            g;
+        h.gml = {
+            featureType: a.firstChild.nodeName.split(":")[1],
+            featureNS: a.firstChild.namespaceURI,
+            featureNSPrefix: a.firstChild.prefix
+        };
+        for (var a = a.firstChild, i; a && !(1 == a.nodeType && (i = a.getAttribute("fid") || a.getAttribute("id")));) a = a.nextSibling;
+        h.fid = i;
+        return h
+    },
+    parseGeometry: {
+        point: function(a) {
+            var b, c;
+            c = [];
+            b = this.getElementsByTagNameNS(a, this.gmlns, "pos");
+            0 < b.length && (c = b[0].firstChild.nodeValue, c = c.replace(this.regExes.trimSpace, ""), c = c.split(this.regExes.splitSpace));
+            0 == c.length && (b = this.getElementsByTagNameNS(a,
+                this.gmlns, "coordinates"), 0 < b.length && (c = b[0].firstChild.nodeValue, c = c.replace(this.regExes.removeSpace, ""), c = c.split(",")));
+            0 == c.length && (b = this.getElementsByTagNameNS(a, this.gmlns, "coord"), 0 < b.length && (a = this.getElementsByTagNameNS(b[0], this.gmlns, "X"), b = this.getElementsByTagNameNS(b[0], this.gmlns, "Y"), 0 < a.length && 0 < b.length && (c = [a[0].firstChild.nodeValue, b[0].firstChild.nodeValue])));
+            2 == c.length && (c[2] = null);
+            return this.xy ? new OpenLayers.Geometry.Point(c[0], c[1], c[2]) : new OpenLayers.Geometry.Point(c[1],
+                c[0], c[2])
+        },
+        multipoint: function(a) {
+            var a = this.getElementsByTagNameNS(a, this.gmlns, "Point"),
+                b = [];
+            if (0 < a.length)
+                for (var c, d = 0; d < a.length; ++d)(c = this.parseGeometry.point.apply(this, [a[d]])) && b.push(c);
+            return new OpenLayers.Geometry.MultiPoint(b)
+        },
+        linestring: function(a, b) {
+            var c, d;
+            d = [];
+            var e = [];
+            c = this.getElementsByTagNameNS(a, this.gmlns, "posList");
+            if (0 < c.length) {
+                d = this.getChildValue(c[0]);
+                d = d.replace(this.regExes.trimSpace, "");
+                d = d.split(this.regExes.splitSpace);
+                var f = parseInt(c[0].getAttribute("dimension")),
+                    g, h, i;
+                for (c = 0; c < d.length / f; ++c) g = c * f, h = d[g], i = d[g + 1], g = 2 == f ? null : d[g + 2], this.xy ? e.push(new OpenLayers.Geometry.Point(h, i, g)) : e.push(new OpenLayers.Geometry.Point(i, h, g))
+            }
+            if (0 == d.length && (c = this.getElementsByTagNameNS(a, this.gmlns, "coordinates"), 0 < c.length)) {
+                d = this.getChildValue(c[0]);
+                d = d.replace(this.regExes.trimSpace, "");
+                d = d.replace(this.regExes.trimComma, ",");
+                f = d.split(this.regExes.splitSpace);
+                for (c = 0; c < f.length; ++c) d = f[c].split(","), 2 == d.length && (d[2] = null), this.xy ? e.push(new OpenLayers.Geometry.Point(d[0],
+                    d[1], d[2])) : e.push(new OpenLayers.Geometry.Point(d[1], d[0], d[2]))
+            }
+            d = null;
+            0 != e.length && (d = b ? new OpenLayers.Geometry.LinearRing(e) : new OpenLayers.Geometry.LineString(e));
+            return d
+        },
+        multilinestring: function(a) {
+            var a = this.getElementsByTagNameNS(a, this.gmlns, "LineString"),
+                b = [];
+            if (0 < a.length)
+                for (var c, d = 0; d < a.length; ++d)(c = this.parseGeometry.linestring.apply(this, [a[d]])) && b.push(c);
+            return new OpenLayers.Geometry.MultiLineString(b)
+        },
+        polygon: function(a) {
+            var a = this.getElementsByTagNameNS(a, this.gmlns, "LinearRing"),
+                b = [];
+            if (0 < a.length)
+                for (var c, d = 0; d < a.length; ++d)(c = this.parseGeometry.linestring.apply(this, [a[d], !0])) && b.push(c);
+            return new OpenLayers.Geometry.Polygon(b)
+        },
+        multipolygon: function(a) {
+            var a = this.getElementsByTagNameNS(a, this.gmlns, "Polygon"),
+                b = [];
+            if (0 < a.length)
+                for (var c, d = 0; d < a.length; ++d)(c = this.parseGeometry.polygon.apply(this, [a[d]])) && b.push(c);
+            return new OpenLayers.Geometry.MultiPolygon(b)
+        },
+        envelope: function(a) {
+            var b = [],
+                c, d, e = this.getElementsByTagNameNS(a, this.gmlns, "lowerCorner");
+            if (0 < e.length) {
+                c = [];
+                0 < e.length && (c = e[0].firstChild.nodeValue, c = c.replace(this.regExes.trimSpace, ""), c = c.split(this.regExes.splitSpace));
+                2 == c.length && (c[2] = null);
+                var f = this.xy ? new OpenLayers.Geometry.Point(c[0], c[1], c[2]) : new OpenLayers.Geometry.Point(c[1], c[0], c[2])
+            }
+            a = this.getElementsByTagNameNS(a, this.gmlns, "upperCorner");
+            if (0 < a.length) {
+                c = [];
+                0 < a.length && (c = a[0].firstChild.nodeValue, c = c.replace(this.regExes.trimSpace, ""), c = c.split(this.regExes.splitSpace));
+                2 == c.length && (c[2] = null);
+                var g = this.xy ? new OpenLayers.Geometry.Point(c[0],
+                    c[1], c[2]) : new OpenLayers.Geometry.Point(c[1], c[0], c[2])
+            }
+            f && g && (b.push(new OpenLayers.Geometry.Point(f.x, f.y)), b.push(new OpenLayers.Geometry.Point(g.x, f.y)), b.push(new OpenLayers.Geometry.Point(g.x, g.y)), b.push(new OpenLayers.Geometry.Point(f.x, g.y)), b.push(new OpenLayers.Geometry.Point(f.x, f.y)), b = new OpenLayers.Geometry.LinearRing(b), d = new OpenLayers.Geometry.Polygon([b]));
+            return d
+        },
+        box: function(a) {
+            var b = this.getElementsByTagNameNS(a, this.gmlns, "coordinates"),
+                c = a = null;
+            0 < b.length && (b = b[0].firstChild.nodeValue,
+                b = b.split(" "), 2 == b.length && (a = b[0].split(","), c = b[1].split(",")));
+            if (null !== a && null !== c) return new OpenLayers.Bounds(parseFloat(a[0]), parseFloat(a[1]), parseFloat(c[0]), parseFloat(c[1]))
+        }
+    },
+    parseAttributes: function(a) {
+        for (var b = {}, a = a.firstChild, c, d, e; a;) {
+            if (1 == a.nodeType) {
+                a = a.childNodes;
+                for (c = 0; c < a.length; ++c)
+                    if (d = a[c], 1 == d.nodeType)
+                        if (e = d.childNodes, 1 == e.length) {
+                            if (e = e[0], 3 == e.nodeType || 4 == e.nodeType) d = d.prefix ? d.nodeName.split(":")[1] : d.nodeName, e = e.nodeValue.replace(this.regExes.trimSpace, ""),
+                                b[d] = e
+                        } else b[d.nodeName.split(":").pop()] = null;
+                break
+            }
+            a = a.nextSibling
+        }
+        return b
+    },
+    write: function(a) {
+        OpenLayers.Util.isArray(a) || (a = [a]);
+        for (var b = this.createElementNS("http://www.opengis.net/wfs", "wfs:" + this.collectionName), c = 0; c < a.length; c++) b.appendChild(this.createFeatureXML(a[c]));
+        return OpenLayers.Format.XML.prototype.write.apply(this, [b])
+    },
+    createFeatureXML: function(a) {
+        var b = this.buildGeometryNode(a.geometry),
+            c = this.createElementNS(this.featureNS, this.featurePrefix + ":" + this.geometryName);
+        c.appendChild(b);
+        var b = this.createElementNS(this.gmlns, "gml:" + this.featureName),
+            d = this.createElementNS(this.featureNS, this.featurePrefix + ":" + this.layerName);
+        d.setAttribute("fid", a.fid || a.id);
+        d.appendChild(c);
+        for (var e in a.attributes) {
+            var c = this.createTextNode(a.attributes[e]),
+                f = this.createElementNS(this.featureNS, this.featurePrefix + ":" + e.substring(e.lastIndexOf(":") + 1));
+            f.appendChild(c);
+            d.appendChild(f)
+        }
+        b.appendChild(d);
+        return b
+    },
+    buildGeometryNode: function(a) {
+        this.externalProjection && this.internalProjection && (a =
+            a.clone(), a.transform(this.internalProjection, this.externalProjection));
+        var b = a.CLASS_NAME;
+        return this.buildGeometry[b.substring(b.lastIndexOf(".") + 1).toLowerCase()].apply(this, [a])
+    },
+    buildGeometry: {
+        point: function(a) {
+            var b = this.createElementNS(this.gmlns, "gml:Point");
+            b.appendChild(this.buildCoordinatesNode(a));
+            return b
+        },
+        multipoint: function(a) {
+            for (var b = this.createElementNS(this.gmlns, "gml:MultiPoint"), a = a.components, c, d, e = 0; e < a.length; e++) c = this.createElementNS(this.gmlns, "gml:pointMember"), d = this.buildGeometry.point.apply(this, [a[e]]), c.appendChild(d), b.appendChild(c);
+            return b
+        },
+        linestring: function(a) {
+            var b = this.createElementNS(this.gmlns, "gml:LineString");
+            b.appendChild(this.buildCoordinatesNode(a));
+            return b
+        },
+        multilinestring: function(a) {
+            for (var b = this.createElementNS(this.gmlns, "gml:MultiLineString"), a = a.components, c, d, e = 0; e < a.length; ++e) c = this.createElementNS(this.gmlns, "gml:lineStringMember"), d = this.buildGeometry.linestring.apply(this, [a[e]]), c.appendChild(d), b.appendChild(c);
+            return b
+        },
+        linearring: function(a) {
+            var b = this.createElementNS(this.gmlns,
+                "gml:LinearRing");
+            b.appendChild(this.buildCoordinatesNode(a));
+            return b
+        },
+        polygon: function(a) {
+            for (var b = this.createElementNS(this.gmlns, "gml:Polygon"), a = a.components, c, d, e = 0; e < a.length; ++e) c = 0 == e ? "outerBoundaryIs" : "innerBoundaryIs", c = this.createElementNS(this.gmlns, "gml:" + c), d = this.buildGeometry.linearring.apply(this, [a[e]]), c.appendChild(d), b.appendChild(c);
+            return b
+        },
+        multipolygon: function(a) {
+            for (var b = this.createElementNS(this.gmlns, "gml:MultiPolygon"), a = a.components, c, d, e = 0; e < a.length; ++e) c = this.createElementNS(this.gmlns,
+                "gml:polygonMember"), d = this.buildGeometry.polygon.apply(this, [a[e]]), c.appendChild(d), b.appendChild(c);
+            return b
+        },
+        bounds: function(a) {
+            var b = this.createElementNS(this.gmlns, "gml:Box");
+            b.appendChild(this.buildCoordinatesNode(a));
+            return b
+        }
+    },
+    buildCoordinatesNode: function(a) {
+        var b = this.createElementNS(this.gmlns, "gml:coordinates");
+        b.setAttribute("decimal", ".");
+        b.setAttribute("cs", ",");
+        b.setAttribute("ts", " ");
+        var c = [];
+        if (a instanceof OpenLayers.Bounds) c.push(a.left + "," + a.bottom), c.push(a.right + "," + a.top);
+        else
+            for (var a = a.components ? a.components : [a], d = 0; d < a.length; d++) c.push(a[d].x + "," + a[d].y);
+        c = this.createTextNode(c.join(" "));
+        b.appendChild(c);
+        return b
+    },
+    CLASS_NAME: "OpenLayers.Format.GML"
+});
+OpenLayers.Format.GML || (OpenLayers.Format.GML = {});
+OpenLayers.Format.GML.Base = OpenLayers.Class(OpenLayers.Format.XML, {
+    namespaces: {
+        gml: "http://www.opengis.net/gml",
+        xlink: "http://www.w3.org/1999/xlink",
+        xsi: "http://www.w3.org/2001/XMLSchema-instance",
+        wfs: "http://www.opengis.net/wfs"
+    },
+    defaultPrefix: "gml",
+    schemaLocation: null,
+    featureType: null,
+    featureNS: null,
+    geometryName: "geometry",
+    extractAttributes: !0,
+    srsName: null,
+    xy: !0,
+    geometryTypes: null,
+    singleFeatureType: null,
+    regExes: {
+        trimSpace: /^\s*|\s*$/g,
+        removeSpace: /\s*/g,
+        splitSpace: /\s+/,
+        trimComma: /\s*,\s*/g,
+        featureMember: /^(.*:)?featureMembers?$/
+    },
+    initialize: function(a) {
+        OpenLayers.Format.XML.prototype.initialize.apply(this, [a]);
+        this.setGeometryTypes();
+        a && a.featureNS && this.setNamespace("feature", a.featureNS);
+        this.singleFeatureType = !a || typeof a.featureType === "string"
+    },
+    read: function(a) {
+        typeof a == "string" && (a = OpenLayers.Format.XML.prototype.read.apply(this, [a]));
+        if (a && a.nodeType == 9) a = a.documentElement;
+        var b = [];
+        this.readNode(a, {
+            features: b
+        }, true);
+        if (b.length == 0) {
+            var c = this.getElementsByTagNameNS(a, this.namespaces.gml, "featureMember");
+            if (c.length)
+                for (var a =
+                        0, d = c.length; a < d; ++a) this.readNode(c[a], {
+                    features: b
+                }, true);
+            else {
+                c = this.getElementsByTagNameNS(a, this.namespaces.gml, "featureMembers");
+                c.length && this.readNode(c[0], {
+                    features: b
+                }, true)
+            }
+        }
+        return b
+    },
+    readNode: function(a, b, c) {
+        if (c === true && this.autoConfig === true) {
+            this.featureType = null;
+            delete this.namespaceAlias[this.featureNS];
+            delete this.namespaces.feature;
+            this.featureNS = null
+        }
+        if (!this.featureNS && !(a.prefix in this.namespaces) && a.parentNode.namespaceURI == this.namespaces.gml && this.regExes.featureMember.test(a.parentNode.nodeName)) {
+            this.featureType =
+                a.nodeName.split(":").pop();
+            this.setNamespace("feature", a.namespaceURI);
+            this.featureNS = a.namespaceURI;
+            this.autoConfig = true
+        }
+        return OpenLayers.Format.XML.prototype.readNode.apply(this, [a, b])
+    },
+    readers: {
+        gml: {
+            featureMember: function(a, b) {
+                this.readChildNodes(a, b)
+            },
+            featureMembers: function(a, b) {
+                this.readChildNodes(a, b)
+            },
+            name: function(a, b) {
+                b.name = this.getChildValue(a)
+            },
+            boundedBy: function(a, b) {
+                var c = {};
+                this.readChildNodes(a, c);
+                if (c.components && c.components.length > 0) b.bounds = c.components[0]
+            },
+            Point: function(a,
+                b) {
+                var c = {
+                    points: []
+                };
+                this.readChildNodes(a, c);
+                if (!b.components) b.components = [];
+                b.components.push(c.points[0])
+            },
+            coordinates: function(a, b) {
+                for (var c = this.getChildValue(a).replace(this.regExes.trimSpace, ""), c = c.replace(this.regExes.trimComma, ","), c = c.split(this.regExes.splitSpace), d, e = c.length, f = Array(e), g = 0; g < e; ++g) {
+                    d = c[g].split(",");
+                    f[g] = this.xy ? new OpenLayers.Geometry.Point(d[0], d[1], d[2]) : new OpenLayers.Geometry.Point(d[1], d[0], d[2])
+                }
+                b.points = f
+            },
+            coord: function(a, b) {
+                var c = {};
+                this.readChildNodes(a,
+                    c);
+                if (!b.points) b.points = [];
+                b.points.push(new OpenLayers.Geometry.Point(c.x, c.y, c.z))
+            },
+            X: function(a, b) {
+                b.x = this.getChildValue(a)
+            },
+            Y: function(a, b) {
+                b.y = this.getChildValue(a)
+            },
+            Z: function(a, b) {
+                b.z = this.getChildValue(a)
+            },
+            MultiPoint: function(a, b) {
+                var c = {
+                    components: []
+                };
+                this.readChildNodes(a, c);
+                b.components = [new OpenLayers.Geometry.MultiPoint(c.components)]
+            },
+            pointMember: function(a, b) {
+                this.readChildNodes(a, b)
+            },
+            LineString: function(a, b) {
+                var c = {};
+                this.readChildNodes(a, c);
+                if (!b.components) b.components = [];
+                b.components.push(new OpenLayers.Geometry.LineString(c.points))
+            },
+            MultiLineString: function(a, b) {
+                var c = {
+                    components: []
+                };
+                this.readChildNodes(a, c);
+                b.components = [new OpenLayers.Geometry.MultiLineString(c.components)]
+            },
+            lineStringMember: function(a, b) {
+                this.readChildNodes(a, b)
+            },
+            Polygon: function(a, b) {
+                var c = {
+                    outer: null,
+                    inner: []
+                };
+                this.readChildNodes(a, c);
+                c.inner.unshift(c.outer);
+                if (!b.components) b.components = [];
+                b.components.push(new OpenLayers.Geometry.Polygon(c.inner))
+            },
+            LinearRing: function(a, b) {
+                var c = {};
+                this.readChildNodes(a, c);
+                b.components = [new OpenLayers.Geometry.LinearRing(c.points)]
+            },
+            MultiPolygon: function(a, b) {
+                var c = {
+                    components: []
+                };
+                this.readChildNodes(a, c);
+                b.components = [new OpenLayers.Geometry.MultiPolygon(c.components)]
+            },
+            polygonMember: function(a, b) {
+                this.readChildNodes(a, b)
+            },
+            GeometryCollection: function(a, b) {
+                var c = {
+                    components: []
+                };
+                this.readChildNodes(a, c);
+                b.components = [new OpenLayers.Geometry.Collection(c.components)]
+            },
+            geometryMember: function(a, b) {
+                this.readChildNodes(a, b)
+            }
+        },
+        feature: {
+            "*": function(a, b) {
+                var c, d = a.localName || a.nodeName.split(":").pop();
+                b.features ? !this.singleFeatureType &&
+                    OpenLayers.Util.indexOf(this.featureType, d) !== -1 ? c = "_typeName" : d === this.featureType && (c = "_typeName") : a.childNodes.length == 0 || a.childNodes.length == 1 && a.firstChild.nodeType == 3 ? this.extractAttributes && (c = "_attribute") : c = "_geometry";
+                c && this.readers.feature[c].apply(this, [a, b])
+            },
+            _typeName: function(a, b) {
+                var c = {
+                    components: [],
+                    attributes: {}
+                };
+                this.readChildNodes(a, c);
+                if (c.name) c.attributes.name = c.name;
+                var d = new OpenLayers.Feature.Vector(c.components[0], c.attributes);
+                if (!this.singleFeatureType) {
+                    d.type = a.nodeName.split(":").pop();
+                    d.namespace = a.namespaceURI
+                }
+                var e = a.getAttribute("fid") || this.getAttributeNS(a, this.namespaces.gml, "id");
+                if (e) d.fid = e;
+                this.internalProjection && (this.externalProjection && d.geometry) && d.geometry.transform(this.externalProjection, this.internalProjection);
+                if (c.bounds) d.bounds = c.bounds;
+                b.features.push(d)
+            },
+            _geometry: function(a, b) {
+                if (!this.geometryName) this.geometryName = a.nodeName.split(":").pop();
+                this.readChildNodes(a, b)
+            },
+            _attribute: function(a, b) {
+                var c = a.localName || a.nodeName.split(":").pop(),
+                    d = this.getChildValue(a);
+                b.attributes[c] = d
+            }
+        },
+        wfs: {
+            FeatureCollection: function(a, b) {
+                this.readChildNodes(a, b)
+            }
+        }
+    },
+    write: function(a) {
+        a = this.writeNode("gml:" + (OpenLayers.Util.isArray(a) ? "featureMembers" : "featureMember"), a);
+        this.setAttributeNS(a, this.namespaces.xsi, "xsi:schemaLocation", this.schemaLocation);
+        return OpenLayers.Format.XML.prototype.write.apply(this, [a])
+    },
+    writers: {
+        gml: {
+            featureMember: function(a) {
+                var b = this.createElementNSPlus("gml:featureMember");
+                this.writeNode("feature:_typeName", a, b);
+                return b
+            },
+            MultiPoint: function(a) {
+                for (var b =
+                        this.createElementNSPlus("gml:MultiPoint"), a = a.components || [a], c = 0, d = a.length; c < d; ++c) this.writeNode("pointMember", a[c], b);
+                return b
+            },
+            pointMember: function(a) {
+                var b = this.createElementNSPlus("gml:pointMember");
+                this.writeNode("Point", a, b);
+                return b
+            },
+            MultiLineString: function(a) {
+                for (var b = this.createElementNSPlus("gml:MultiLineString"), a = a.components || [a], c = 0, d = a.length; c < d; ++c) this.writeNode("lineStringMember", a[c], b);
+                return b
+            },
+            lineStringMember: function(a) {
+                var b = this.createElementNSPlus("gml:lineStringMember");
+                this.writeNode("LineString", a, b);
+                return b
+            },
+            MultiPolygon: function(a) {
+                for (var b = this.createElementNSPlus("gml:MultiPolygon"), a = a.components || [a], c = 0, d = a.length; c < d; ++c) this.writeNode("polygonMember", a[c], b);
+                return b
+            },
+            polygonMember: function(a) {
+                var b = this.createElementNSPlus("gml:polygonMember");
+                this.writeNode("Polygon", a, b);
+                return b
+            },
+            GeometryCollection: function(a) {
+                for (var b = this.createElementNSPlus("gml:GeometryCollection"), c = 0, d = a.components.length; c < d; ++c) this.writeNode("geometryMember", a.components[c],
+                    b);
+                return b
+            },
+            geometryMember: function(a) {
+                var b = this.createElementNSPlus("gml:geometryMember"),
+                    a = this.writeNode("feature:_geometry", a);
+                b.appendChild(a.firstChild);
+                return b
+            }
+        },
+        feature: {
+            _typeName: function(a) {
+                var b = this.createElementNSPlus("feature:" + this.featureType, {
+                    attributes: {
+                        fid: a.fid
+                    }
+                });
+                a.geometry && this.writeNode("feature:_geometry", a.geometry, b);
+                for (var c in a.attributes) {
+                    var d = a.attributes[c];
+                    d != null && this.writeNode("feature:_attribute", {
+                        name: c,
+                        value: d
+                    }, b)
+                }
+                return b
+            },
+            _geometry: function(a) {
+                this.externalProjection &&
+                    this.internalProjection && (a = a.clone().transform(this.internalProjection, this.externalProjection));
+                var b = this.createElementNSPlus("feature:" + this.geometryName),
+                    a = this.writeNode("gml:" + this.geometryTypes[a.CLASS_NAME], a, b);
+                this.srsName && a.setAttribute("srsName", this.srsName);
+                return b
+            },
+            _attribute: function(a) {
+                return this.createElementNSPlus("feature:" + a.name, {
+                    value: a.value
+                })
+            }
+        },
+        wfs: {
+            FeatureCollection: function(a) {
+                for (var b = this.createElementNSPlus("wfs:FeatureCollection"), c = 0, d = a.length; c < d; ++c) this.writeNode("gml:featureMember",
+                    a[c], b);
+                return b
+            }
+        }
+    },
+    setGeometryTypes: function() {
+        this.geometryTypes = {
+            "OpenLayers.Geometry.Point": "Point",
+            "OpenLayers.Geometry.MultiPoint": "MultiPoint",
+            "OpenLayers.Geometry.LineString": "LineString",
+            "OpenLayers.Geometry.MultiLineString": "MultiLineString",
+            "OpenLayers.Geometry.Polygon": "Polygon",
+            "OpenLayers.Geometry.MultiPolygon": "MultiPolygon",
+            "OpenLayers.Geometry.Collection": "GeometryCollection"
+        }
+    },
+    CLASS_NAME: "OpenLayers.Format.GML.Base"
+});
+OpenLayers.Format.GML.v3 = OpenLayers.Class(OpenLayers.Format.GML.Base, {
+    schemaLocation: "http://www.opengis.net/gml http://schemas.opengis.net/gml/3.1.1/profiles/gmlsfProfile/1.0.0/gmlsf.xsd",
+    curve: !1,
+    multiCurve: !0,
+    surface: !1,
+    multiSurface: !0,
+    initialize: function(a) {
+        OpenLayers.Format.GML.Base.prototype.initialize.apply(this, [a])
+    },
+    readers: {
+        gml: OpenLayers.Util.applyDefaults({
+            featureMembers: function(a, b) {
+                this.readChildNodes(a, b)
+            },
+            Curve: function(a, b) {
+                var c = {
+                    points: []
+                };
+                this.readChildNodes(a, c);
+                b.components ||
+                    (b.components = []);
+                b.components.push(new OpenLayers.Geometry.LineString(c.points))
+            },
+            segments: function(a, b) {
+                this.readChildNodes(a, b)
+            },
+            LineStringSegment: function(a, b) {
+                var c = {};
+                this.readChildNodes(a, c);
+                c.points && Array.prototype.push.apply(b.points, c.points)
+            },
+            pos: function(a, b) {
+                var c = this.getChildValue(a).replace(this.regExes.trimSpace, "").split(this.regExes.splitSpace),
+                    c = this.xy ? new OpenLayers.Geometry.Point(c[0], c[1], c[2]) : new OpenLayers.Geometry.Point(c[1], c[0], c[2]);
+                b.points = [c]
+            },
+            posList: function(a,
+                b) {
+                for (var c = this.getChildValue(a).replace(this.regExes.trimSpace, "").split(this.regExes.splitSpace), d = parseInt(a.getAttribute("dimension")) || 2, e, f, g, h = Array(c.length / d), i = 0, j = c.length; i < j; i += d) e = c[i], f = c[i + 1], g = 2 == d ? void 0 : c[i + 2], h[i / d] = this.xy ? new OpenLayers.Geometry.Point(e, f, g) : new OpenLayers.Geometry.Point(f, e, g);
+                b.points = h
+            },
+            Surface: function(a, b) {
+                this.readChildNodes(a, b)
+            },
+            patches: function(a, b) {
+                this.readChildNodes(a, b)
+            },
+            PolygonPatch: function(a, b) {
+                this.readers.gml.Polygon.apply(this, [a, b])
+            },
+            exterior: function(a,
+                b) {
+                var c = {};
+                this.readChildNodes(a, c);
+                b.outer = c.components[0]
+            },
+            interior: function(a, b) {
+                var c = {};
+                this.readChildNodes(a, c);
+                b.inner.push(c.components[0])
+            },
+            MultiCurve: function(a, b) {
+                var c = {
+                    components: []
+                };
+                this.readChildNodes(a, c);
+                0 < c.components.length && (b.components = [new OpenLayers.Geometry.MultiLineString(c.components)])
+            },
+            curveMember: function(a, b) {
+                this.readChildNodes(a, b)
+            },
+            MultiSurface: function(a, b) {
+                var c = {
+                    components: []
+                };
+                this.readChildNodes(a, c);
+                0 < c.components.length && (b.components = [new OpenLayers.Geometry.MultiPolygon(c.components)])
+            },
+            surfaceMember: function(a, b) {
+                this.readChildNodes(a, b)
+            },
+            surfaceMembers: function(a, b) {
+                this.readChildNodes(a, b)
+            },
+            pointMembers: function(a, b) {
+                this.readChildNodes(a, b)
+            },
+            lineStringMembers: function(a, b) {
+                this.readChildNodes(a, b)
+            },
+            polygonMembers: function(a, b) {
+                this.readChildNodes(a, b)
+            },
+            geometryMembers: function(a, b) {
+                this.readChildNodes(a, b)
+            },
+            Envelope: function(a, b) {
+                var c = {
+                    points: Array(2)
+                };
+                this.readChildNodes(a, c);
+                b.components || (b.components = []);
+                var d = c.points[0],
+                    c = c.points[1];
+                b.components.push(new OpenLayers.Bounds(d.x,
+                    d.y, c.x, c.y))
+            },
+            lowerCorner: function(a, b) {
+                var c = {};
+                this.readers.gml.pos.apply(this, [a, c]);
+                b.points[0] = c.points[0]
+            },
+            upperCorner: function(a, b) {
+                var c = {};
+                this.readers.gml.pos.apply(this, [a, c]);
+                b.points[1] = c.points[0]
+            }
+        }, OpenLayers.Format.GML.Base.prototype.readers.gml),
+        feature: OpenLayers.Format.GML.Base.prototype.readers.feature,
+        wfs: OpenLayers.Format.GML.Base.prototype.readers.wfs
+    },
+    write: function(a) {
+        a = this.writeNode("gml:" + (OpenLayers.Util.isArray(a) ? "featureMembers" : "featureMember"), a);
+        this.setAttributeNS(a,
+            this.namespaces.xsi, "xsi:schemaLocation", this.schemaLocation);
+        return OpenLayers.Format.XML.prototype.write.apply(this, [a])
+    },
+    writers: {
+        gml: OpenLayers.Util.applyDefaults({
+            featureMembers: function(a) {
+                for (var b = this.createElementNSPlus("gml:featureMembers"), c = 0, d = a.length; c < d; ++c) this.writeNode("feature:_typeName", a[c], b);
+                return b
+            },
+            Point: function(a) {
+                var b = this.createElementNSPlus("gml:Point");
+                this.writeNode("pos", a, b);
+                return b
+            },
+            pos: function(a) {
+                return this.createElementNSPlus("gml:pos", {
+                    value: this.xy ? a.x +
+                        " " + a.y : a.y + " " + a.x
+                })
+            },
+            LineString: function(a) {
+                var b = this.createElementNSPlus("gml:LineString");
+                this.writeNode("posList", a.components, b);
+                return b
+            },
+            Curve: function(a) {
+                var b = this.createElementNSPlus("gml:Curve");
+                this.writeNode("segments", a, b);
+                return b
+            },
+            segments: function(a) {
+                var b = this.createElementNSPlus("gml:segments");
+                this.writeNode("LineStringSegment", a, b);
+                return b
+            },
+            LineStringSegment: function(a) {
+                var b = this.createElementNSPlus("gml:LineStringSegment");
+                this.writeNode("posList", a.components, b);
+                return b
+            },
+            posList: function(a) {
+                for (var b = a.length, c = Array(b), d, e = 0; e < b; ++e) d = a[e], c[e] = this.xy ? d.x + " " + d.y : d.y + " " + d.x;
+                return this.createElementNSPlus("gml:posList", {
+                    value: c.join(" ")
+                })
+            },
+            Surface: function(a) {
+                var b = this.createElementNSPlus("gml:Surface");
+                this.writeNode("patches", a, b);
+                return b
+            },
+            patches: function(a) {
+                var b = this.createElementNSPlus("gml:patches");
+                this.writeNode("PolygonPatch", a, b);
+                return b
+            },
+            PolygonPatch: function(a) {
+                var b = this.createElementNSPlus("gml:PolygonPatch", {
+                    attributes: {
+                        interpolation: "planar"
+                    }
+                });
+                this.writeNode("exterior", a.components[0], b);
+                for (var c = 1, d = a.components.length; c < d; ++c) this.writeNode("interior", a.components[c], b);
+                return b
+            },
+            Polygon: function(a) {
+                var b = this.createElementNSPlus("gml:Polygon");
+                this.writeNode("exterior", a.components[0], b);
+                for (var c = 1, d = a.components.length; c < d; ++c) this.writeNode("interior", a.components[c], b);
+                return b
+            },
+            exterior: function(a) {
+                var b = this.createElementNSPlus("gml:exterior");
+                this.writeNode("LinearRing", a, b);
+                return b
+            },
+            interior: function(a) {
+                var b = this.createElementNSPlus("gml:interior");
+                this.writeNode("LinearRing", a, b);
+                return b
+            },
+            LinearRing: function(a) {
+                var b = this.createElementNSPlus("gml:LinearRing");
+                this.writeNode("posList", a.components, b);
+                return b
+            },
+            MultiCurve: function(a) {
+                for (var b = this.createElementNSPlus("gml:MultiCurve"), a = a.components || [a], c = 0, d = a.length; c < d; ++c) this.writeNode("curveMember", a[c], b);
+                return b
+            },
+            curveMember: function(a) {
+                var b = this.createElementNSPlus("gml:curveMember");
+                this.curve ? this.writeNode("Curve", a, b) : this.writeNode("LineString", a, b);
+                return b
+            },
+            MultiSurface: function(a) {
+                for (var b =
+                        this.createElementNSPlus("gml:MultiSurface"), a = a.components || [a], c = 0, d = a.length; c < d; ++c) this.writeNode("surfaceMember", a[c], b);
+                return b
+            },
+            surfaceMember: function(a) {
+                var b = this.createElementNSPlus("gml:surfaceMember");
+                this.surface ? this.writeNode("Surface", a, b) : this.writeNode("Polygon", a, b);
+                return b
+            },
+            Envelope: function(a) {
+                var b = this.createElementNSPlus("gml:Envelope");
+                this.writeNode("lowerCorner", a, b);
+                this.writeNode("upperCorner", a, b);
+                this.srsName && b.setAttribute("srsName", this.srsName);
+                return b
+            },
+            lowerCorner: function(a) {
+                return this.createElementNSPlus("gml:lowerCorner", {
+                    value: this.xy ? a.left + " " + a.bottom : a.bottom + " " + a.left
+                })
+            },
+            upperCorner: function(a) {
+                return this.createElementNSPlus("gml:upperCorner", {
+                    value: this.xy ? a.right + " " + a.top : a.top + " " + a.right
+                })
+            }
+        }, OpenLayers.Format.GML.Base.prototype.writers.gml),
+        feature: OpenLayers.Format.GML.Base.prototype.writers.feature,
+        wfs: OpenLayers.Format.GML.Base.prototype.writers.wfs
+    },
+    setGeometryTypes: function() {
+        this.geometryTypes = {
+            "OpenLayers.Geometry.Point": "Point",
+            "OpenLayers.Geometry.MultiPoint": "MultiPoint",
+            "OpenLayers.Geometry.LineString": !0 ===
+                this.curve ? "Curve" : "LineString",
+            "OpenLayers.Geometry.MultiLineString": !1 === this.multiCurve ? "MultiLineString" : "MultiCurve",
+            "OpenLayers.Geometry.Polygon": !0 === this.surface ? "Surface" : "Polygon",
+            "OpenLayers.Geometry.MultiPolygon": !1 === this.multiSurface ? "MultiPolygon" : "MultiSurface",
+            "OpenLayers.Geometry.Collection": "GeometryCollection"
+        }
+    },
+    CLASS_NAME: "OpenLayers.Format.GML.v3"
+});
+OpenLayers.Format.Filter.v1_1_0 = OpenLayers.Class(OpenLayers.Format.GML.v3, OpenLayers.Format.Filter.v1, {
+    VERSION: "1.1.0",
+    schemaLocation: "http://www.opengis.net/ogc/filter/1.1.0/filter.xsd",
+    initialize: function(a) {
+        OpenLayers.Format.GML.v3.prototype.initialize.apply(this, [a])
+    },
+    readers: {
+        ogc: OpenLayers.Util.applyDefaults({
+            PropertyIsEqualTo: function(a, b) {
+                var c = a.getAttribute("matchCase"),
+                    c = new OpenLayers.Filter.Comparison({
+                        type: OpenLayers.Filter.Comparison.EQUAL_TO,
+                        matchCase: !("false" === c || "0" === c)
+                    });
+                this.readChildNodes(a,
+                    c);
+                b.filters.push(c)
+            },
+            PropertyIsNotEqualTo: function(a, b) {
+                var c = a.getAttribute("matchCase"),
+                    c = new OpenLayers.Filter.Comparison({
+                        type: OpenLayers.Filter.Comparison.NOT_EQUAL_TO,
+                        matchCase: !("false" === c || "0" === c)
+                    });
+                this.readChildNodes(a, c);
+                b.filters.push(c)
+            },
+            PropertyIsLike: function(a, b) {
+                var c = new OpenLayers.Filter.Comparison({
+                    type: OpenLayers.Filter.Comparison.LIKE
+                });
+                this.readChildNodes(a, c);
+                var d = a.getAttribute("wildCard"),
+                    e = a.getAttribute("singleChar"),
+                    f = a.getAttribute("escapeChar");
+                c.value2regex(d, e,
+                    f);
+                b.filters.push(c)
+            }
+        }, OpenLayers.Format.Filter.v1.prototype.readers.ogc),
+        gml: OpenLayers.Format.GML.v3.prototype.readers.gml,
+        feature: OpenLayers.Format.GML.v3.prototype.readers.feature
+    },
+    writers: {
+        ogc: OpenLayers.Util.applyDefaults({
+                PropertyIsEqualTo: function(a) {
+                    var b = this.createElementNSPlus("ogc:PropertyIsEqualTo", {
+                        attributes: {
+                            matchCase: a.matchCase
+                        }
+                    });
+                    this.writeNode("PropertyName", a, b);
+                    this.writeOgcExpression(a.value, b);
+                    return b
+                },
+                PropertyIsNotEqualTo: function(a) {
+                    var b = this.createElementNSPlus("ogc:PropertyIsNotEqualTo", {
+                        attributes: {
+                            matchCase: a.matchCase
+                        }
+                    });
+                    this.writeNode("PropertyName", a, b);
+                    this.writeOgcExpression(a.value, b);
+                    return b
+                },
+                PropertyIsLike: function(a) {
+                    var b = this.createElementNSPlus("ogc:PropertyIsLike", {
+                        attributes: {
+                            matchCase: a.matchCase,
+                            wildCard: "*",
+                            singleChar: ".",
+                            escapeChar: "!"
+                        }
+                    });
+                    this.writeNode("PropertyName", a, b);
+                    this.writeNode("Literal", a.regex2value(), b);
+                    return b
+                },
+                BBOX: function(a) {
+                    var b = this.createElementNSPlus("ogc:BBOX");
+                    a.property && this.writeNode("PropertyName", a, b);
+                    var c = this.writeNode("gml:Envelope",
+                        a.value);
+                    a.projection && c.setAttribute("srsName", a.projection);
+                    b.appendChild(c);
+                    return b
+                },
+                SortBy: function(a) {
+                    for (var b = this.createElementNSPlus("ogc:SortBy"), c = 0, d = a.length; c < d; c++) this.writeNode("ogc:SortProperty", a[c], b);
+                    return b
+                },
+                SortProperty: function(a) {
+                    var b = this.createElementNSPlus("ogc:SortProperty");
+                    this.writeNode("ogc:PropertyName", a, b);
+                    this.writeNode("ogc:SortOrder", "DESC" == a.order ? "DESC" : "ASC", b);
+                    return b
+                },
+                SortOrder: function(a) {
+                    return this.createElementNSPlus("ogc:SortOrder", {
+                        value: a
+                    })
+                }
+            },
+            OpenLayers.Format.Filter.v1.prototype.writers.ogc),
+        gml: OpenLayers.Format.GML.v3.prototype.writers.gml,
+        feature: OpenLayers.Format.GML.v3.prototype.writers.feature
+    },
+    writeSpatial: function(a, b) {
+        var c = this.createElementNSPlus("ogc:" + b);
+        this.writeNode("PropertyName", a, c);
+        if (a.value instanceof OpenLayers.Filter.Function) this.writeNode("Function", a.value, c);
+        else {
+            var d;
+            d = a.value instanceof OpenLayers.Geometry ? this.writeNode("feature:_geometry", a.value).firstChild : this.writeNode("gml:Envelope", a.value);
+            a.projection &&
+                d.setAttribute("srsName", a.projection);
+            c.appendChild(d)
+        }
+        return c
+    },
+    CLASS_NAME: "OpenLayers.Format.Filter.v1_1_0"
+});
+OpenLayers.Format.OWSCommon = OpenLayers.Class(OpenLayers.Format.XML.VersionedOGC, {
+    defaultVersion: "1.0.0",
+    getVersion: function(a) {
+        var b = this.version;
+        b || ((a = a.getAttribute("xmlns:ows")) && "1.1" === a.substring(a.lastIndexOf("/") + 1) && (b = "1.1.0"), b || (b = this.defaultVersion));
+        return b
+    },
+    CLASS_NAME: "OpenLayers.Format.OWSCommon"
+});
+OpenLayers.Format.OWSCommon.v1 = OpenLayers.Class(OpenLayers.Format.XML, {
+    regExes: {
+        trimSpace: /^\s*|\s*$/g,
+        removeSpace: /\s*/g,
+        splitSpace: /\s+/,
+        trimComma: /\s*,\s*/g
+    },
+    read: function(a, b) {
+        OpenLayers.Util.applyDefaults(b, this.options);
+        var c = {};
+        this.readChildNodes(a, c);
+        return c
+    },
+    readers: {
+        ows: {
+            Exception: function(a, b) {
+                var c = {
+                    code: a.getAttribute("exceptionCode"),
+                    locator: a.getAttribute("locator"),
+                    texts: []
+                };
+                b.exceptions.push(c);
+                this.readChildNodes(a, c)
+            },
+            ExceptionText: function(a, b) {
+                var c = this.getChildValue(a);
+                b.texts.push(c)
+            },
+            ServiceIdentification: function(a, b) {
+                b.serviceIdentification = {};
+                this.readChildNodes(a, b.serviceIdentification)
+            },
+            Title: function(a, b) {
+                b.title = this.getChildValue(a)
+            },
+            Abstract: function(a, b) {
+                b["abstract"] = this.getChildValue(a)
+            },
+            Keywords: function(a, b) {
+                b.keywords = {};
+                this.readChildNodes(a, b.keywords)
+            },
+            Keyword: function(a, b) {
+                b[this.getChildValue(a)] = !0
+            },
+            ServiceType: function(a, b) {
+                b.serviceType = {
+                    codeSpace: a.getAttribute("codeSpace"),
+                    value: this.getChildValue(a)
+                }
+            },
+            ServiceTypeVersion: function(a, b) {
+                b.serviceTypeVersion =
+                    this.getChildValue(a)
+            },
+            Fees: function(a, b) {
+                b.fees = this.getChildValue(a)
+            },
+            AccessConstraints: function(a, b) {
+                b.accessConstraints = this.getChildValue(a)
+            },
+            ServiceProvider: function(a, b) {
+                b.serviceProvider = {};
+                this.readChildNodes(a, b.serviceProvider)
+            },
+            ProviderName: function(a, b) {
+                b.providerName = this.getChildValue(a)
+            },
+            ProviderSite: function(a, b) {
+                b.providerSite = this.getAttributeNS(a, this.namespaces.xlink, "href")
+            },
+            ServiceContact: function(a, b) {
+                b.serviceContact = {};
+                this.readChildNodes(a, b.serviceContact)
+            },
+            IndividualName: function(a,
+                b) {
+                b.individualName = this.getChildValue(a)
+            },
+            PositionName: function(a, b) {
+                b.positionName = this.getChildValue(a)
+            },
+            ContactInfo: function(a, b) {
+                b.contactInfo = {};
+                this.readChildNodes(a, b.contactInfo)
+            },
+            Phone: function(a, b) {
+                b.phone = {};
+                this.readChildNodes(a, b.phone)
+            },
+            Voice: function(a, b) {
+                b.voice = this.getChildValue(a)
+            },
+            Address: function(a, b) {
+                b.address = {};
+                this.readChildNodes(a, b.address)
+            },
+            DeliveryPoint: function(a, b) {
+                b.deliveryPoint = this.getChildValue(a)
+            },
+            City: function(a, b) {
+                b.city = this.getChildValue(a)
+            },
+            AdministrativeArea: function(a,
+                b) {
+                b.administrativeArea = this.getChildValue(a)
+            },
+            PostalCode: function(a, b) {
+                b.postalCode = this.getChildValue(a)
+            },
+            Country: function(a, b) {
+                b.country = this.getChildValue(a)
+            },
+            ElectronicMailAddress: function(a, b) {
+                b.electronicMailAddress = this.getChildValue(a)
+            },
+            Role: function(a, b) {
+                b.role = this.getChildValue(a)
+            },
+            OperationsMetadata: function(a, b) {
+                b.operationsMetadata = {};
+                this.readChildNodes(a, b.operationsMetadata)
+            },
+            Operation: function(a, b) {
+                var c = a.getAttribute("name");
+                b[c] = {};
+                this.readChildNodes(a, b[c])
+            },
+            DCP: function(a,
+                b) {
+                b.dcp = {};
+                this.readChildNodes(a, b.dcp)
+            },
+            HTTP: function(a, b) {
+                b.http = {};
+                this.readChildNodes(a, b.http)
+            },
+            Get: function(a, b) {
+                b.get || (b.get = []);
+                var c = {
+                    url: this.getAttributeNS(a, this.namespaces.xlink, "href")
+                };
+                this.readChildNodes(a, c);
+                b.get.push(c)
+            },
+            Post: function(a, b) {
+                b.post || (b.post = []);
+                var c = {
+                    url: this.getAttributeNS(a, this.namespaces.xlink, "href")
+                };
+                this.readChildNodes(a, c);
+                b.post.push(c)
+            },
+            Parameter: function(a, b) {
+                b.parameters || (b.parameters = {});
+                var c = a.getAttribute("name");
+                b.parameters[c] = {};
+                this.readChildNodes(a,
+                    b.parameters[c])
+            },
+            Constraint: function(a, b) {
+                b.constraints || (b.constraints = {});
+                var c = a.getAttribute("name");
+                b.constraints[c] = {};
+                this.readChildNodes(a, b.constraints[c])
+            },
+            Value: function(a, b) {
+                b[this.getChildValue(a)] = !0
+            },
+            OutputFormat: function(a, b) {
+                b.formats.push({
+                    value: this.getChildValue(a)
+                });
+                this.readChildNodes(a, b)
+            },
+            WGS84BoundingBox: function(a, b) {
+                var c = {};
+                c.crs = a.getAttribute("crs");
+                b.BoundingBox ? b.BoundingBox.push(c) : (b.projection = c.crs, c = b);
+                this.readChildNodes(a, c)
+            },
+            BoundingBox: function(a, b) {
+                this.readers.ows.WGS84BoundingBox.apply(this, [a, b])
+            },
+            LowerCorner: function(a, b) {
+                var c = this.getChildValue(a).replace(this.regExes.trimSpace, ""),
+                    c = c.replace(this.regExes.trimComma, ","),
+                    c = c.split(this.regExes.splitSpace);
+                b.left = c[0];
+                b.bottom = c[1]
+            },
+            UpperCorner: function(a, b) {
+                var c = this.getChildValue(a).replace(this.regExes.trimSpace, ""),
+                    c = c.replace(this.regExes.trimComma, ","),
+                    c = c.split(this.regExes.splitSpace);
+                b.right = c[0];
+                b.top = c[1];
+                b.bounds = new OpenLayers.Bounds(b.left, b.bottom, b.right, b.top);
+                delete b.left;
+                delete b.bottom;
+                delete b.right;
+                delete b.top
+            },
+            Language: function(a, b) {
+                b.language = this.getChildValue(a)
+            }
+        }
+    },
+    writers: {
+        ows: {
+            BoundingBox: function(a) {
+                var b = this.createElementNSPlus("ows:BoundingBox", {
+                    attributes: {
+                        crs: a.projection
+                    }
+                });
+                this.writeNode("ows:LowerCorner", a, b);
+                this.writeNode("ows:UpperCorner", a, b);
+                return b
+            },
+            LowerCorner: function(a) {
+                return this.createElementNSPlus("ows:LowerCorner", {
+                    value: a.bounds.left + " " + a.bounds.bottom
+                })
+            },
+            UpperCorner: function(a) {
+                return this.createElementNSPlus("ows:UpperCorner", {
+                    value: a.bounds.right + " " + a.bounds.top
+                })
+            },
+            Identifier: function(a) {
+                return this.createElementNSPlus("ows:Identifier", {
+                    value: a
+                })
+            },
+            Title: function(a) {
+                return this.createElementNSPlus("ows:Title", {
+                    value: a
+                })
+            },
+            Abstract: function(a) {
+                return this.createElementNSPlus("ows:Abstract", {
+                    value: a
+                })
+            },
+            OutputFormat: function(a) {
+                return this.createElementNSPlus("ows:OutputFormat", {
+                    value: a
+                })
+            }
+        }
+    },
+    CLASS_NAME: "OpenLayers.Format.OWSCommon.v1"
+});
+OpenLayers.Format.OWSCommon.v1_0_0 = OpenLayers.Class(OpenLayers.Format.OWSCommon.v1, {
+    namespaces: {
+        ows: "http://www.opengis.net/ows",
+        xlink: "http://www.w3.org/1999/xlink"
+    },
+    readers: {
+        ows: OpenLayers.Util.applyDefaults({
+            ExceptionReport: function(a, b) {
+                b.success = !1;
+                b.exceptionReport = {
+                    version: a.getAttribute("version"),
+                    language: a.getAttribute("language"),
+                    exceptions: []
+                };
+                this.readChildNodes(a, b.exceptionReport)
+            }
+        }, OpenLayers.Format.OWSCommon.v1.prototype.readers.ows)
+    },
+    writers: {
+        ows: OpenLayers.Format.OWSCommon.v1.prototype.writers.ows
+    },
+    CLASS_NAME: "OpenLayers.Format.OWSCommon.v1_0_0"
+});
+OpenLayers.Format.WFST.v1_1_0 = OpenLayers.Class(OpenLayers.Format.Filter.v1_1_0, OpenLayers.Format.WFST.v1, {
+    version: "1.1.0",
+    schemaLocations: {
+        wfs: "http://schemas.opengis.net/wfs/1.1.0/wfs.xsd"
+    },
+    initialize: function(a) {
+        OpenLayers.Format.Filter.v1_1_0.prototype.initialize.apply(this, [a]);
+        OpenLayers.Format.WFST.v1.prototype.initialize.apply(this, [a])
+    },
+    readNode: function(a, b) {
+        return OpenLayers.Format.GML.v3.prototype.readNode.apply(this, [a, b])
+    },
+    readers: {
+        wfs: OpenLayers.Util.applyDefaults({
+            FeatureCollection: function(a,
+                b) {
+                b.numberOfFeatures = parseInt(a.getAttribute("numberOfFeatures"));
+                OpenLayers.Format.WFST.v1.prototype.readers.wfs.FeatureCollection.apply(this, arguments)
+            },
+            TransactionResponse: function(a, b) {
+                b.insertIds = [];
+                b.success = !1;
+                this.readChildNodes(a, b)
+            },
+            TransactionSummary: function(a, b) {
+                b.success = !0
+            },
+            InsertResults: function(a, b) {
+                this.readChildNodes(a, b)
+            },
+            Feature: function(a, b) {
+                var c = {
+                    fids: []
+                };
+                this.readChildNodes(a, c);
+                b.insertIds.push(c.fids[0])
+            }
+        }, OpenLayers.Format.WFST.v1.prototype.readers.wfs),
+        gml: OpenLayers.Format.GML.v3.prototype.readers.gml,
+        feature: OpenLayers.Format.GML.v3.prototype.readers.feature,
+        ogc: OpenLayers.Format.Filter.v1_1_0.prototype.readers.ogc,
+        ows: OpenLayers.Format.OWSCommon.v1_0_0.prototype.readers.ows
+    },
+    writers: {
+        wfs: OpenLayers.Util.applyDefaults({
+            GetFeature: function(a) {
+                var b = OpenLayers.Format.WFST.v1.prototype.writers.wfs.GetFeature.apply(this, arguments);
+                a && this.setAttributes(b, {
+                    resultType: a.resultType,
+                    startIndex: a.startIndex,
+                    count: a.count
+                });
+                return b
+            },
+            Query: function(a) {
+                var a = OpenLayers.Util.extend({
+                        featureNS: this.featureNS,
+                        featurePrefix: this.featurePrefix,
+                        featureType: this.featureType,
+                        srsName: this.srsName
+                    }, a),
+                    b = a.featurePrefix,
+                    c = this.createElementNSPlus("wfs:Query", {
+                        attributes: {
+                            typeName: (b ? b + ":" : "") + a.featureType,
+                            srsName: a.srsName
+                        }
+                    });
+                a.featureNS && c.setAttribute("xmlns:" + b, a.featureNS);
+                if (a.propertyNames)
+                    for (var b = 0, d = a.propertyNames.length; b < d; b++) this.writeNode("wfs:PropertyName", {
+                        property: a.propertyNames[b]
+                    }, c);
+                a.filter && (OpenLayers.Format.WFST.v1_1_0.prototype.setFilterProperty.call(this, a.filter), this.writeNode("ogc:Filter",
+                    a.filter, c));
+                return c
+            },
+            PropertyName: function(a) {
+                return this.createElementNSPlus("wfs:PropertyName", {
+                    value: a.property
+                })
+            }
+        }, OpenLayers.Format.WFST.v1.prototype.writers.wfs),
+        gml: OpenLayers.Format.GML.v3.prototype.writers.gml,
+        feature: OpenLayers.Format.GML.v3.prototype.writers.feature,
+        ogc: OpenLayers.Format.Filter.v1_1_0.prototype.writers.ogc
+    },
+    CLASS_NAME: "OpenLayers.Format.WFST.v1_1_0"
+});
+OpenLayers.Protocol = OpenLayers.Class({
+    format: null,
+    options: null,
+    autoDestroy: !0,
+    defaultFilter: null,
+    initialize: function(a) {
+        a = a || {};
+        OpenLayers.Util.extend(this, a);
+        this.options = a
+    },
+    mergeWithDefaultFilter: function(a) {
+        return a && this.defaultFilter ? new OpenLayers.Filter.Logical({
+            type: OpenLayers.Filter.Logical.AND,
+            filters: [this.defaultFilter, a]
+        }) : a || this.defaultFilter || void 0
+    },
+    destroy: function() {
+        this.format = this.options = null
+    },
+    read: function(a) {
+        a = a || {};
+        a.filter = this.mergeWithDefaultFilter(a.filter)
+    },
+    create: function() {},
+    update: function() {},
+    "delete": function() {},
+    commit: function() {},
+    abort: function() {},
+    createCallback: function(a, b, c) {
+        return OpenLayers.Function.bind(function() {
+            a.apply(this, [b, c])
+        }, this)
+    },
+    CLASS_NAME: "OpenLayers.Protocol"
+});
+OpenLayers.Protocol.Response = OpenLayers.Class({
+    code: null,
+    requestType: null,
+    last: !0,
+    features: null,
+    data: null,
+    reqFeatures: null,
+    priv: null,
+    error: null,
+    initialize: function(a) {
+        OpenLayers.Util.extend(this, a)
+    },
+    success: function() {
+        return 0 < this.code
+    },
+    CLASS_NAME: "OpenLayers.Protocol.Response"
+});
+OpenLayers.Protocol.Response.SUCCESS = 1;
+OpenLayers.Protocol.Response.FAILURE = 0;
+OpenLayers.Format.JSON = OpenLayers.Class(OpenLayers.Format, {
+    indent: "    ",
+    space: " ",
+    newline: "\n",
+    level: 0,
+    pretty: !1,
+    nativeJSON: function() {
+        return !(!window.JSON || !("function" == typeof JSON.parse && "function" == typeof JSON.stringify))
+    }(),
+    read: function(a, b) {
+        var c;
+        if (this.nativeJSON) c = JSON.parse(a, b);
+        else try {
+            if (/^[\],:{}\s]*$/.test(a.replace(/\\["\\\/bfnrtu]/g, "@").replace(/"[^"\\\n\r]*"|true|false|null|-?\d+(?:\.\d*)?(?:[eE][+\-]?\d+)?/g, "]").replace(/(?:^|:|,)(?:\s*\[)+/g, "")) && (c = eval("(" + a + ")"), "function" ===
+                    typeof b)) {
+                var d = function(a, c) {
+                    if (c && "object" === typeof c)
+                        for (var e in c) c.hasOwnProperty(e) && (c[e] = d(e, c[e]));
+                    return b(a, c)
+                };
+                c = d("", c)
+            }
+        } catch (e) {}
+        this.keepData && (this.data = c);
+        return c
+    },
+    write: function(a, b) {
+        this.pretty = !!b;
+        var c = null,
+            d = typeof a;
+        if (this.serialize[d]) try {
+            c = !this.pretty && this.nativeJSON ? JSON.stringify(a) : this.serialize[d].apply(this, [a])
+        } catch (e) {
+            OpenLayers.Console.error("Trouble serializing: " + e)
+        }
+        return c
+    },
+    writeIndent: function() {
+        var a = [];
+        if (this.pretty)
+            for (var b = 0; b < this.level; ++b) a.push(this.indent);
+        return a.join("")
+    },
+    writeNewline: function() {
+        return this.pretty ? this.newline : ""
+    },
+    writeSpace: function() {
+        return this.pretty ? this.space : ""
+    },
+    serialize: {
+        object: function(a) {
+            if (null == a) return "null";
+            if (a.constructor == Date) return this.serialize.date.apply(this, [a]);
+            if (a.constructor == Array) return this.serialize.array.apply(this, [a]);
+            var b = ["{"];
+            this.level += 1;
+            var c, d, e, f = !1;
+            for (c in a) a.hasOwnProperty(c) && (d = OpenLayers.Format.JSON.prototype.write.apply(this, [c, this.pretty]), e = OpenLayers.Format.JSON.prototype.write.apply(this, [a[c], this.pretty]), null != d && null != e && (f && b.push(","), b.push(this.writeNewline(), this.writeIndent(), d, ":", this.writeSpace(), e), f = !0));
+            this.level -= 1;
+            b.push(this.writeNewline(), this.writeIndent(), "}");
+            return b.join("")
+        },
+        array: function(a) {
+            var b, c = ["["];
+            this.level += 1;
+            for (var d = 0, e = a.length; d < e; ++d) b = OpenLayers.Format.JSON.prototype.write.apply(this, [a[d], this.pretty]), null != b && (0 < d && c.push(","), c.push(this.writeNewline(), this.writeIndent(), b));
+            this.level -= 1;
+            c.push(this.writeNewline(), this.writeIndent(),
+                "]");
+            return c.join("")
+        },
+        string: function(a) {
+            var b = {
+                "\u0008": "\\b",
+                "\t": "\\t",
+                "\n": "\\n",
+                "\u000c": "\\f",
+                "\r": "\\r",
+                '"': '\\"',
+                "\\": "\\\\"
+            };
+            return /["\\\x00-\x1f]/.test(a) ? '"' + a.replace(/([\x00-\x1f\\"])/g, function(a, d) {
+                var e = b[d];
+                if (e) return e;
+                e = d.charCodeAt();
+                return "\\u00" + Math.floor(e / 16).toString(16) + (e % 16).toString(16)
+            }) + '"' : '"' + a + '"'
+        },
+        number: function(a) {
+            return isFinite(a) ? "" + a : "null"
+        },
+        "boolean": function(a) {
+            return "" + a
+        },
+        date: function(a) {
+            function b(a) {
+                return 10 > a ? "0" + a : a
+            }
+            return '"' + a.getFullYear() + "-" +
+                b(a.getMonth() + 1) + "-" + b(a.getDate()) + "T" + b(a.getHours()) + ":" + b(a.getMinutes()) + ":" + b(a.getSeconds()) + '"'
+        }
+    },
+    CLASS_NAME: "OpenLayers.Format.JSON"
+});
+OpenLayers.Format.GeoJSON = OpenLayers.Class(OpenLayers.Format.JSON, {
+    ignoreExtraDims: !1,
+    read: function(a, b, c) {
+        var b = b ? b : "FeatureCollection",
+            d = null,
+            e = null;
+        if (e = "string" == typeof a ? OpenLayers.Format.JSON.prototype.read.apply(this, [a, c]) : a)
+            if ("string" != typeof e.type) OpenLayers.Console.error("Bad GeoJSON - no type: " + a);
+            else {
+                if (this.isValidType(e, b)) switch (b) {
+                    case "Geometry":
+                        try {
+                            d = this.parseGeometry(e)
+                        } catch (f) {
+                            OpenLayers.Console.error(f)
+                        }
+                        break;
+                    case "Feature":
+                        try {
+                            d = this.parseFeature(e), d.type = "Feature"
+                        } catch (g) {
+                            OpenLayers.Console.error(g)
+                        }
+                        break;
+                    case "FeatureCollection":
+                        switch (d = [], e.type) {
+                            case "Feature":
+                                try {
+                                    d.push(this.parseFeature(e))
+                                } catch (h) {
+                                    d = null, OpenLayers.Console.error(h)
+                                }
+                                break;
+                            case "FeatureCollection":
+                                a = 0;
+                                for (b = e.features.length; a < b; ++a) try {
+                                    d.push(this.parseFeature(e.features[a]))
+                                } catch (i) {
+                                    d = null, OpenLayers.Console.error(i)
+                                }
+                                break;
+                            default:
+                                try {
+                                    var j = this.parseGeometry(e);
+                                    d.push(new OpenLayers.Feature.Vector(j))
+                                } catch (k) {
+                                    d = null, OpenLayers.Console.error(k)
+                                }
+                        }
+                }
+            } else OpenLayers.Console.error("Bad JSON: " + a);
+        return d
+    },
+    isValidType: function(a,
+        b) {
+        var c = !1;
+        switch (b) {
+            case "Geometry":
+                -1 == OpenLayers.Util.indexOf("Point MultiPoint LineString MultiLineString Polygon MultiPolygon Box GeometryCollection".split(" "), a.type) ? OpenLayers.Console.error("Unsupported geometry type: " + a.type) : c = !0;
+                break;
+            case "FeatureCollection":
+                c = !0;
+                break;
+            default:
+                a.type == b ? c = !0 : OpenLayers.Console.error("Cannot convert types from " + a.type + " to " + b)
+        }
+        return c
+    },
+    parseFeature: function(a) {
+        var b, c, d;
+        c = a.properties ? a.properties : {};
+        d = a.geometry && a.geometry.bbox || a.bbox;
+        try {
+            b = this.parseGeometry(a.geometry)
+        } catch (e) {
+            throw e;
+        }
+        b = new OpenLayers.Feature.Vector(b, c);
+        d && (b.bounds = OpenLayers.Bounds.fromArray(d));
+        a.id && (b.fid = a.id);
+        return b
+    },
+    parseGeometry: function(a) {
+        if (null == a) return null;
+        var b, c = !1;
+        if ("GeometryCollection" == a.type) {
+            if (!OpenLayers.Util.isArray(a.geometries)) throw "GeometryCollection must have geometries array: " + a;
+            b = a.geometries.length;
+            for (var c = Array(b), d = 0; d < b; ++d) c[d] = this.parseGeometry.apply(this, [a.geometries[d]]);
+            b = new OpenLayers.Geometry.Collection(c);
+            c = !0
+        } else {
+            if (!OpenLayers.Util.isArray(a.coordinates)) throw "Geometry must have coordinates array: " +
+                a;
+            if (!this.parseCoords[a.type.toLowerCase()]) throw "Unsupported geometry type: " + a.type;
+            try {
+                b = this.parseCoords[a.type.toLowerCase()].apply(this, [a.coordinates])
+            } catch (e) {
+                throw e;
+            }
+        }
+        this.internalProjection && (this.externalProjection && !c) && b.transform(this.externalProjection, this.internalProjection);
+        return b
+    },
+    parseCoords: {
+        point: function(a) {
+            if (!1 == this.ignoreExtraDims && 2 != a.length) throw "Only 2D points are supported: " + a;
+            return new OpenLayers.Geometry.Point(a[0], a[1])
+        },
+        multipoint: function(a) {
+            for (var b = [],
+                    c = null, d = 0, e = a.length; d < e; ++d) {
+                try {
+                    c = this.parseCoords.point.apply(this, [a[d]])
+                } catch (f) {
+                    throw f;
+                }
+                b.push(c)
+            }
+            return new OpenLayers.Geometry.MultiPoint(b)
+        },
+        linestring: function(a) {
+            for (var b = [], c = null, d = 0, e = a.length; d < e; ++d) {
+                try {
+                    c = this.parseCoords.point.apply(this, [a[d]])
+                } catch (f) {
+                    throw f;
+                }
+                b.push(c)
+            }
+            return new OpenLayers.Geometry.LineString(b)
+        },
+        multilinestring: function(a) {
+            for (var b = [], c = null, d = 0, e = a.length; d < e; ++d) {
+                try {
+                    c = this.parseCoords.linestring.apply(this, [a[d]])
+                } catch (f) {
+                    throw f;
+                }
+                b.push(c)
+            }
+            return new OpenLayers.Geometry.MultiLineString(b)
+        },
+        polygon: function(a) {
+            for (var b = [], c, d, e = 0, f = a.length; e < f; ++e) {
+                try {
+                    d = this.parseCoords.linestring.apply(this, [a[e]])
+                } catch (g) {
+                    throw g;
+                }
+                c = new OpenLayers.Geometry.LinearRing(d.components);
+                b.push(c)
+            }
+            return new OpenLayers.Geometry.Polygon(b)
+        },
+        multipolygon: function(a) {
+            for (var b = [], c = null, d = 0, e = a.length; d < e; ++d) {
+                try {
+                    c = this.parseCoords.polygon.apply(this, [a[d]])
+                } catch (f) {
+                    throw f;
+                }
+                b.push(c)
+            }
+            return new OpenLayers.Geometry.MultiPolygon(b)
+        },
+        box: function(a) {
+            if (2 != a.length) throw "GeoJSON box coordinates must have 2 elements";
+            return new OpenLayers.Geometry.Polygon([new OpenLayers.Geometry.LinearRing([new OpenLayers.Geometry.Point(a[0][0], a[0][1]), new OpenLayers.Geometry.Point(a[1][0], a[0][1]), new OpenLayers.Geometry.Point(a[1][0], a[1][1]), new OpenLayers.Geometry.Point(a[0][0], a[1][1]), new OpenLayers.Geometry.Point(a[0][0], a[0][1])])])
+        }
+    },
+    write: function(a, b) {
+        var c = {
+            type: null
+        };
+        if (OpenLayers.Util.isArray(a)) {
+            c.type = "FeatureCollection";
+            var d = a.length;
+            c.features = Array(d);
+            for (var e = 0; e < d; ++e) {
+                var f = a[e];
+                if (!f instanceof OpenLayers.Feature.Vector) throw "FeatureCollection only supports collections of features: " +
+                    f;
+                c.features[e] = this.extract.feature.apply(this, [f])
+            }
+        } else 0 == a.CLASS_NAME.indexOf("OpenLayers.Geometry") ? c = this.extract.geometry.apply(this, [a]) : a instanceof OpenLayers.Feature.Vector && (c = this.extract.feature.apply(this, [a]), a.layer && a.layer.projection && (c.crs = this.createCRSObject(a)));
+        return OpenLayers.Format.JSON.prototype.write.apply(this, [c, b])
+    },
+    createCRSObject: function(a) {
+        var a = a.layer.projection.toString(),
+            b = {};
+        a.match(/epsg:/i) && (a = parseInt(a.substring(a.indexOf(":") + 1)), b = 4326 == a ? {
+            type: "name",
+            properties: {
+                name: "urn:ogc:def:crs:OGC:1.3:CRS84"
+            }
+        } : {
+            type: "name",
+            properties: {
+                name: "EPSG:" + a
+            }
+        });
+        return b
+    },
+    extract: {
+        feature: function(a) {
+            var b = this.extract.geometry.apply(this, [a.geometry]),
+                b = {
+                    type: "Feature",
+                    properties: a.attributes,
+                    geometry: b
+                };
+            null != a.fid && (b.id = a.fid);
+            return b
+        },
+        geometry: function(a) {
+            if (null == a) return null;
+            this.internalProjection && this.externalProjection && (a = a.clone(), a.transform(this.internalProjection, this.externalProjection));
+            var b = a.CLASS_NAME.split(".")[2],
+                a = this.extract[b.toLowerCase()].apply(this, [a]);
+            return "Collection" == b ? {
+                type: "GeometryCollection",
+                geometries: a
+            } : {
+                type: b,
+                coordinates: a
+            }
+        },
+        point: function(a) {
+            return [a.x, a.y]
+        },
+        multipoint: function(a) {
+            for (var b = [], c = 0, d = a.components.length; c < d; ++c) b.push(this.extract.point.apply(this, [a.components[c]]));
+            return b
+        },
+        linestring: function(a) {
+            for (var b = [], c = 0, d = a.components.length; c < d; ++c) b.push(this.extract.point.apply(this, [a.components[c]]));
+            return b
+        },
+        multilinestring: function(a) {
+            for (var b = [], c = 0, d = a.components.length; c < d; ++c) b.push(this.extract.linestring.apply(this, [a.components[c]]));
+            return b
+        },
+        polygon: function(a) {
+            for (var b = [], c = 0, d = a.components.length; c < d; ++c) b.push(this.extract.linestring.apply(this, [a.components[c]]));
+            return b
+        },
+        multipolygon: function(a) {
+            for (var b = [], c = 0, d = a.components.length; c < d; ++c) b.push(this.extract.polygon.apply(this, [a.components[c]]));
+            return b
+        },
+        collection: function(a) {
+            for (var b = a.components.length, c = Array(b), d = 0; d < b; ++d) c[d] = this.extract.geometry.apply(this, [a.components[d]]);
+            return c
+        }
+    },
+    CLASS_NAME: "OpenLayers.Format.GeoJSON"
+});
+OpenLayers.Protocol.Script = OpenLayers.Class(OpenLayers.Protocol, {
+    url: null,
+    params: null,
+    callback: null,
+    callbackTemplate: "OpenLayers.Protocol.Script.registry.${id}",
+    callbackKey: "callback",
+    callbackPrefix: "",
+    scope: null,
+    format: null,
+    pendingRequests: null,
+    srsInBBOX: !1,
+    initialize: function(a) {
+        a = a || {};
+        this.params = {};
+        this.pendingRequests = {};
+        OpenLayers.Protocol.prototype.initialize.apply(this, arguments);
+        this.format || (this.format = new OpenLayers.Format.GeoJSON);
+        if (!this.filterToParams && OpenLayers.Format.QueryStringFilter) {
+            var b =
+                new OpenLayers.Format.QueryStringFilter({
+                    srsInBBOX: this.srsInBBOX
+                });
+            this.filterToParams = function(a, d) {
+                return b.write(a, d)
+            }
+        }
+    },
+    read: function(a) {
+        OpenLayers.Protocol.prototype.read.apply(this, arguments);
+        a = OpenLayers.Util.applyDefaults(a, this.options);
+        a.params = OpenLayers.Util.applyDefaults(a.params, this.options.params);
+        a.filter && this.filterToParams && (a.params = this.filterToParams(a.filter, a.params));
+        var b = new OpenLayers.Protocol.Response({
+                requestType: "read"
+            }),
+            c = this.createRequest(a.url, a.params, OpenLayers.Function.bind(function(c) {
+                b.data =
+                    c;
+                this.handleRead(b, a)
+            }, this));
+        b.priv = c;
+        return b
+    },
+    createRequest: function(a, b, c) {
+        var c = OpenLayers.Protocol.Script.register(c),
+            d = OpenLayers.String.format(this.callbackTemplate, {
+                id: c
+            }),
+            b = OpenLayers.Util.extend({}, b);
+        b[this.callbackKey] = this.callbackPrefix + d;
+        a = OpenLayers.Util.urlAppend(a, OpenLayers.Util.getParameterString(b));
+        b = document.createElement("script");
+        b.type = "text/javascript";
+        b.src = a;
+        b.id = "OpenLayers_Protocol_Script_" + c;
+        this.pendingRequests[b.id] = b;
+        document.getElementsByTagName("head")[0].appendChild(b);
+        return b
+    },
+    destroyRequest: function(a) {
+        OpenLayers.Protocol.Script.unregister(a.id.split("_").pop());
+        delete this.pendingRequests[a.id];
+        a.parentNode && a.parentNode.removeChild(a)
+    },
+    handleRead: function(a, b) {
+        this.handleResponse(a, b)
+    },
+    handleResponse: function(a, b) {
+        b.callback && (a.data ? (a.features = this.parseFeatures(a.data), a.code = OpenLayers.Protocol.Response.SUCCESS) : a.code = OpenLayers.Protocol.Response.FAILURE, this.destroyRequest(a.priv), b.callback.call(b.scope, a))
+    },
+    parseFeatures: function(a) {
+        return this.format.read(a)
+    },
+    abort: function(a) {
+        if (a) this.destroyRequest(a.priv);
+        else
+            for (var b in this.pendingRequests) this.destroyRequest(this.pendingRequests[b])
+    },
+    destroy: function() {
+        this.abort();
+        delete this.params;
+        delete this.format;
+        OpenLayers.Protocol.prototype.destroy.apply(this)
+    },
+    CLASS_NAME: "OpenLayers.Protocol.Script"
+});
+(function() {
+    var a = OpenLayers.Protocol.Script,
+        b = 0;
+    a.registry = {};
+    a.register = function(c) {
+        var d = "c" + ++b;
+        a.registry[d] = function() {
+            c.apply(this, arguments)
+        };
+        return d
+    };
+    a.unregister = function(b) {
+        delete a.registry[b]
+    }
+})();
+OpenLayers.Control.Panel = OpenLayers.Class(OpenLayers.Control, {
+    controls: null,
+    autoActivate: !0,
+    defaultControl: null,
+    saveState: !1,
+    allowDepress: !1,
+    activeState: null,
+    initialize: function(a) {
+        OpenLayers.Control.prototype.initialize.apply(this, [a]);
+        this.controls = [];
+        this.activeState = {}
+    },
+    destroy: function() {
+        this.map && this.map.events.unregister("buttonclick", this, this.onButtonClick);
+        OpenLayers.Control.prototype.destroy.apply(this, arguments);
+        for (var a, b = this.controls.length - 1; 0 <= b; b--) a = this.controls[b], a.events &&
+            a.events.un({
+                activate: this.iconOn,
+                deactivate: this.iconOff
+            }), a.panel_div = null;
+        this.activeState = null
+    },
+    activate: function() {
+        if (OpenLayers.Control.prototype.activate.apply(this, arguments)) {
+            for (var a, b = 0, c = this.controls.length; b < c; b++) a = this.controls[b], (a === this.defaultControl || this.saveState && this.activeState[a.id]) && a.activate();
+            !0 === this.saveState && (this.defaultControl = null);
+            this.redraw();
+            return !0
+        }
+        return !1
+    },
+    deactivate: function() {
+        if (OpenLayers.Control.prototype.deactivate.apply(this, arguments)) {
+            for (var a,
+                    b = 0, c = this.controls.length; b < c; b++) a = this.controls[b], this.activeState[a.id] = a.deactivate();
+            this.redraw();
+            return !0
+        }
+        return !1
+    },
+    draw: function() {
+        OpenLayers.Control.prototype.draw.apply(this, arguments);
+        this.outsideViewport ? (this.events.attachToElement(this.div), this.events.register("buttonclick", this, this.onButtonClick)) : this.map.events.register("buttonclick", this, this.onButtonClick);
+        this.addControlsToMap(this.controls);
+        return this.div
+    },
+    redraw: function() {
+        for (var a = this.div.childNodes.length - 1; 0 <= a; a--) this.div.removeChild(this.div.childNodes[a]);
+        this.div.innerHTML = "";
+        if (this.active)
+            for (var a = 0, b = this.controls.length; a < b; a++) this.div.appendChild(this.controls[a].panel_div)
+    },
+    activateControl: function(a) {
+        if (!this.active) return !1;
+        if (a.type == OpenLayers.Control.TYPE_BUTTON) a.trigger();
+        else if (a.type == OpenLayers.Control.TYPE_TOGGLE) a.active ? a.deactivate() : a.activate();
+        else if (this.allowDepress && a.active) a.deactivate();
+        else {
+            for (var b, c = 0, d = this.controls.length; c < d; c++) b = this.controls[c], b != a && (b.type === OpenLayers.Control.TYPE_TOOL || null == b.type) &&
+                b.deactivate();
+            a.activate()
+        }
+    },
+    addControls: function(a) {
+        OpenLayers.Util.isArray(a) || (a = [a]);
+        this.controls = this.controls.concat(a);
+        for (var b = 0, c = a.length; b < c; b++) {
+            var d = a[b],
+                e = this.createControlMarkup(d);
+            OpenLayers.Element.addClass(e, d.displayClass + "ItemInactive");
+            OpenLayers.Element.addClass(e, "olButton");
+            "" != d.title && !e.title && (e.title = d.title);
+            d.panel_div = e
+        }
+        this.map && (this.addControlsToMap(a), this.redraw())
+    },
+    createControlMarkup: function() {
+        return document.createElement("div")
+    },
+    addControlsToMap: function(a) {
+        for (var b,
+                c = 0, d = a.length; c < d; c++) b = a[c], !0 === b.autoActivate ? (b.autoActivate = !1, this.map.addControl(b), b.autoActivate = !0) : (this.map.addControl(b), b.deactivate()), b.events.on({
+            activate: this.iconOn,
+            deactivate: this.iconOff
+        })
+    },
+    iconOn: function() {
+        var a = this.panel_div;
+        a.className = a.className.replace(RegExp("\\b(" + this.displayClass + "Item)Inactive\\b"), "$1Active")
+    },
+    iconOff: function() {
+        var a = this.panel_div;
+        a.className = a.className.replace(RegExp("\\b(" + this.displayClass + "Item)Active\\b"), "$1Inactive")
+    },
+    onButtonClick: function(a) {
+        for (var b =
+                this.controls, a = a.buttonElement, c = b.length - 1; 0 <= c; --c)
+            if (b[c].panel_div === a) {
+                this.activateControl(b[c]);
+                break
+            }
+    },
+    getControlsBy: function(a, b) {
+        var c = "function" == typeof b.test;
+        return OpenLayers.Array.filter(this.controls, function(d) {
+            return d[a] == b || c && b.test(d[a])
+        })
+    },
+    getControlsByName: function(a) {
+        return this.getControlsBy("name", a)
+    },
+    getControlsByClass: function(a) {
+        return this.getControlsBy("CLASS_NAME", a)
+    },
+    CLASS_NAME: "OpenLayers.Control.Panel"
+});
+OpenLayers.Control.ZoomIn = OpenLayers.Class(OpenLayers.Control, {
+    type: OpenLayers.Control.TYPE_BUTTON,
+    trigger: function() {
+        this.map.zoomIn()
+    },
+    CLASS_NAME: "OpenLayers.Control.ZoomIn"
+});
+OpenLayers.Control.ZoomOut = OpenLayers.Class(OpenLayers.Control, {
+    type: OpenLayers.Control.TYPE_BUTTON,
+    trigger: function() {
+        this.map.zoomOut()
+    },
+    CLASS_NAME: "OpenLayers.Control.ZoomOut"
+});
+OpenLayers.Control.ZoomToMaxExtent = OpenLayers.Class(OpenLayers.Control, {
+    type: OpenLayers.Control.TYPE_BUTTON,
+    trigger: function() {
+        this.map && this.map.zoomToMaxExtent()
+    },
+    CLASS_NAME: "OpenLayers.Control.ZoomToMaxExtent"
+});
+OpenLayers.Control.ZoomPanel = OpenLayers.Class(OpenLayers.Control.Panel, {
+    initialize: function(a) {
+        OpenLayers.Control.Panel.prototype.initialize.apply(this, [a]);
+        this.addControls([new OpenLayers.Control.ZoomIn, new OpenLayers.Control.ZoomToMaxExtent, new OpenLayers.Control.ZoomOut])
+    },
+    CLASS_NAME: "OpenLayers.Control.ZoomPanel"
+});
+OpenLayers.Layer.HTTPRequest = OpenLayers.Class(OpenLayers.Layer, {
+    URL_HASH_FACTOR: (Math.sqrt(5) - 1) / 2,
+    url: null,
+    params: null,
+    reproject: !1,
+    initialize: function(a, b, c, d) {
+        OpenLayers.Layer.prototype.initialize.apply(this, [a, d]);
+        this.url = b;
+        this.params || (this.params = OpenLayers.Util.extend({}, c))
+    },
+    destroy: function() {
+        this.params = this.url = null;
+        OpenLayers.Layer.prototype.destroy.apply(this, arguments)
+    },
+    clone: function(a) {
+        null == a && (a = new OpenLayers.Layer.HTTPRequest(this.name, this.url, this.params, this.getOptions()));
+        return a = OpenLayers.Layer.prototype.clone.apply(this, [a])
+    },
+    setUrl: function(a) {
+        this.url = a
+    },
+    mergeNewParams: function(a) {
+        this.params = OpenLayers.Util.extend(this.params, a);
+        a = this.redraw();
+        null != this.map && this.map.events.triggerEvent("changelayer", {
+            layer: this,
+            property: "params"
+        });
+        return a
+    },
+    redraw: function(a) {
+        return a ? this.mergeNewParams({
+            _olSalt: Math.random()
+        }) : OpenLayers.Layer.prototype.redraw.apply(this, [])
+    },
+    selectUrl: function(a, b) {
+        for (var c = 1, d = 0, e = a.length; d < e; d++) c *= a.charCodeAt(d) * this.URL_HASH_FACTOR,
+            c -= Math.floor(c);
+        return b[Math.floor(c * b.length)]
+    },
+    getFullRequestString: function(a, b) {
+        var c = b || this.url,
+            d = OpenLayers.Util.extend({}, this.params),
+            d = OpenLayers.Util.extend(d, a),
+            e = OpenLayers.Util.getParameterString(d);
+        OpenLayers.Util.isArray(c) && (c = this.selectUrl(e, c));
+        var e = OpenLayers.Util.upperCaseObject(OpenLayers.Util.getParameters(c)),
+            f;
+        for (f in d) f.toUpperCase() in e && delete d[f];
+        e = OpenLayers.Util.getParameterString(d);
+        return OpenLayers.Util.urlAppend(c, e)
+    },
+    CLASS_NAME: "OpenLayers.Layer.HTTPRequest"
+});
+OpenLayers.Tile = OpenLayers.Class({
+    events: null,
+    eventListeners: null,
+    id: null,
+    layer: null,
+    url: null,
+    bounds: null,
+    size: null,
+    position: null,
+    isLoading: !1,
+    initialize: function(a, b, c, d, e, f) {
+        this.layer = a;
+        this.position = b.clone();
+        this.setBounds(c);
+        this.url = d;
+        e && (this.size = e.clone());
+        this.id = OpenLayers.Util.createUniqueID("Tile_");
+        OpenLayers.Util.extend(this, f);
+        this.events = new OpenLayers.Events(this);
+        if (this.eventListeners instanceof Object) this.events.on(this.eventListeners)
+    },
+    unload: function() {
+        this.isLoading && (this.isLoading = !1, this.events.triggerEvent("unload"))
+    },
+    destroy: function() {
+        this.position = this.size = this.bounds = this.layer = null;
+        this.eventListeners && this.events.un(this.eventListeners);
+        this.events.destroy();
+        this.events = this.eventListeners = null
+    },
+    draw: function(a) {
+        a || this.clear();
+        var b = this.shouldDraw();
+        b && !a && (b = !1 !== this.events.triggerEvent("beforedraw"));
+        return b
+    },
+    shouldDraw: function() {
+        var a = !1,
+            b = this.layer.maxExtent;
+        if (b) {
+            var c = this.layer.map,
+                c = c.baseLayer.wrapDateLine && c.getMaxExtent();
+            this.bounds.intersectsBounds(b, {
+                inclusive: !1,
+                worldBounds: c
+            }) && (a = !0)
+        }
+        return a || this.layer.displayOutsideMaxExtent
+    },
+    setBounds: function(a) {
+        a = a.clone();
+        if (this.layer.map.baseLayer.wrapDateLine) var b = this.layer.map.getMaxExtent(),
+            c = this.layer.map.getResolution(),
+            a = a.wrapDateLine(b, {
+                leftTolerance: c,
+                rightTolerance: c
+            });
+        this.bounds = a
+    },
+    moveTo: function(a, b, c) {
+        null == c && (c = !0);
+        this.setBounds(a);
+        this.position = b.clone();
+        c && this.draw()
+    },
+    clear: function() {},
+    CLASS_NAME: "OpenLayers.Tile"
+});
+OpenLayers.Tile.Image = OpenLayers.Class(OpenLayers.Tile, {
+    url: null,
+    imgDiv: null,
+    frame: null,
+    imageReloadAttempts: null,
+    layerAlphaHack: null,
+    asyncRequestId: null,
+    blankImageUrl: "data:image/gif;base64,R0lGODlhAQABAIAAAAAAAP///yH5BAEAAAAALAAAAAABAAEAQAIBRAA7",
+    maxGetUrlLength: null,
+    canvasContext: null,
+    crossOriginKeyword: null,
+    initialize: function(a, b, c, d, e, f) {
+        OpenLayers.Tile.prototype.initialize.apply(this, arguments);
+        this.url = d;
+        this.layerAlphaHack = this.layer.alpha && OpenLayers.Util.alphaHack();
+        if (null != this.maxGetUrlLength ||
+            this.layer.gutter || this.layerAlphaHack) this.frame = document.createElement("div"), this.frame.style.position = "absolute", this.frame.style.overflow = "hidden";
+        null != this.maxGetUrlLength && OpenLayers.Util.extend(this, OpenLayers.Tile.Image.IFrame)
+    },
+    destroy: function() {
+        this.imgDiv && (this.clear(), this.frame = this.imgDiv = null);
+        this.asyncRequestId = null;
+        OpenLayers.Tile.prototype.destroy.apply(this, arguments)
+    },
+    draw: function() {
+        var a = OpenLayers.Tile.prototype.draw.apply(this, arguments);
+        a ? (this.layer != this.layer.map.baseLayer &&
+            this.layer.reproject && (this.bounds = this.getBoundsFromBaseLayer(this.position)), this.isLoading ? this._loadEvent = "reload" : (this.isLoading = !0, this._loadEvent = "loadstart"), this.positionTile(), this.renderTile()) : this.unload();
+        return a
+    },
+    renderTile: function() {
+        this.layer.div.appendChild(this.getTile());
+        if (this.layer.async) {
+            var a = this.asyncRequestId = (this.asyncRequestId || 0) + 1;
+            this.layer.getURLasync(this.bounds, function(b) {
+                a == this.asyncRequestId && (this.url = b, this.initImage())
+            }, this)
+        } else this.url = this.layer.getURL(this.bounds),
+            this.initImage()
+    },
+    positionTile: function() {
+        var a = this.getTile().style,
+            b = this.frame ? this.size : this.layer.getImageSize(this.bounds);
+        a.left = this.position.x + "%";
+        a.top = this.position.y + "%";
+        a.width = b.w + "%";
+        a.height = b.h + "%"
+    },
+    clear: function() {
+        OpenLayers.Tile.prototype.clear.apply(this, arguments);
+        var a = this.imgDiv;
+        if (a) {
+            OpenLayers.Event.stopObservingElement(a);
+            var b = this.getTile();
+            b.parentNode === this.layer.div && this.layer.div.removeChild(b);
+            this.setImgSrc();
+            !0 === this.layerAlphaHack && (a.style.filter = "");
+            OpenLayers.Element.removeClass(a,
+                "olImageLoadError")
+        }
+        this.canvasContext = null
+    },
+    getImage: function() {
+        if (!this.imgDiv) {
+            this.imgDiv = document.createElement("img");
+            this.imgDiv.className = "olTileImage";
+            this.imgDiv.galleryImg = "no";
+            var a = this.imgDiv.style;
+            if (this.frame) {
+                var b = 0,
+                    c = 0;
+                this.layer.gutter && (b = 100 * (this.layer.gutter / this.layer.tileSize.w), c = 100 * (this.layer.gutter / this.layer.tileSize.h));
+                a.left = -b + "%";
+                a.top = -c + "%";
+                a.width = 2 * b + 100 + "%";
+                a.height = 2 * c + 100 + "%"
+            }
+            a.visibility = "hidden";
+            a.opacity = 0;
+            1 > this.layer.opacity && (a.filter = "alpha(opacity=" +
+                100 * this.layer.opacity + ")");
+            a.position = "absolute";
+            this.layerAlphaHack && (a.paddingTop = a.height, a.height = "0", a.width = "100%");
+            this.frame && this.frame.appendChild(this.imgDiv)
+        }
+        return this.imgDiv
+    },
+    initImage: function() {
+        this.events.triggerEvent(this._loadEvent);
+        var a = this.getImage();
+        if (this.url && a.getAttribute("src") == this.url) this.onImageLoad();
+        else {
+            var b = OpenLayers.Function.bind(function() {
+                OpenLayers.Event.stopObservingElement(a);
+                OpenLayers.Event.observe(a, "load", OpenLayers.Function.bind(this.onImageLoad,
+                    this));
+                OpenLayers.Event.observe(a, "error", OpenLayers.Function.bind(this.onImageError, this));
+                this.imageReloadAttempts = 0;
+                this.setImgSrc(this.url)
+            }, this);
+            a.getAttribute("src") == this.blankImageUrl ? b() : (OpenLayers.Event.observe(a, "load", b), OpenLayers.Event.observe(a, "error", b), this.crossOriginKeyword && a.removeAttribute("crossorigin"), a.src = this.blankImageUrl)
+        }
+    },
+    setImgSrc: function(a) {
+        var b = this.imgDiv;
+        b.style.visibility = "hidden";
+        b.style.opacity = 0;
+        a && (this.crossOriginKeyword && ("data:" !== a.substr(0, 5) ? b.setAttribute("crossorigin",
+            this.crossOriginKeyword) : b.removeAttribute("crossorigin")), b.src = a)
+    },
+    getTile: function() {
+        return this.frame ? this.frame : this.getImage()
+    },
+    createBackBuffer: function() {
+        if (this.imgDiv && !this.isLoading) {
+            var a;
+            this.frame ? (a = this.frame.cloneNode(!1), a.appendChild(this.imgDiv)) : a = this.imgDiv;
+            this.imgDiv = null;
+            return a
+        }
+    },
+    onImageLoad: function() {
+        var a = this.imgDiv;
+        OpenLayers.Event.stopObservingElement(a);
+        a.style.visibility = "inherit";
+        a.style.opacity = this.layer.opacity;
+        this.isLoading = !1;
+        this.canvasContext = null;
+        this.events.triggerEvent("loadend");
+        if (7 > parseFloat(navigator.appVersion.split("MSIE")[1]) && this.layer && this.layer.div) {
+            var b = document.createElement("span");
+            b.style.display = "none";
+            var c = this.layer.div;
+            c.appendChild(b);
+            window.setTimeout(function() {
+                b.parentNode === c && b.parentNode.removeChild(b)
+            }, 0)
+        }!0 === this.layerAlphaHack && (a.style.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(src='" + a.src + "', sizingMethod='scale')")
+    },
+    onImageError: function() {
+        var a = this.imgDiv;
+        null != a.src && (this.imageReloadAttempts++, this.imageReloadAttempts <=
+            OpenLayers.IMAGE_RELOAD_ATTEMPTS ? this.setImgSrc(this.layer.getURL(this.bounds)) : (OpenLayers.Element.addClass(a, "olImageLoadError"), this.events.triggerEvent("loaderror"), this.onImageLoad()))
+    },
+    getCanvasContext: function() {
+        if (OpenLayers.CANVAS_SUPPORTED && this.imgDiv && !this.isLoading) {
+            if (!this.canvasContext) {
+                var a = document.createElement("canvas");
+                a.width = this.size.w;
+                a.height = this.size.h;
+                this.canvasContext = a.getContext("2d");
+                this.canvasContext.drawImage(this.imgDiv, 0, 0)
+            }
+            return this.canvasContext
+        }
+    },
+    CLASS_NAME: "OpenLayers.Tile.Image"
+});
+OpenLayers.Layer.Grid = OpenLayers.Class(OpenLayers.Layer.HTTPRequest, {
+    tileSize: null,
+    tileOriginCorner: "bl",
+    tileOrigin: null,
+    tileOptions: null,
+    tileClass: OpenLayers.Tile.Image,
+    grid: null,
+    singleTile: !1,
+    ratio: 1.5,
+    buffer: 0,
+    transitionEffect: null,
+    numLoadingTiles: 0,
+    tileLoadingDelay: 85,
+    serverResolutions: null,
+    moveTimerId: null,
+    deferMoveGriddedTiles: null,
+    tileQueueId: null,
+    tileQueue: null,
+    loading: !1,
+    backBuffer: null,
+    gridResolution: null,
+    backBufferResolution: null,
+    backBufferLonLat: null,
+    backBufferTimerId: null,
+    removeBackBufferDelay: null,
+    className: null,
+    initialize: function(a, b, c, d) {
+        OpenLayers.Layer.HTTPRequest.prototype.initialize.apply(this, arguments);
+        this.grid = [];
+        this.tileQueue = [];
+        null === this.removeBackBufferDelay && (this.removeBackBufferDelay = this.singleTile ? 0 : 2500);
+        null === this.className && (this.className = this.singleTile ? "olLayerGridSingleTile" : "olLayerGrid");
+        OpenLayers.Animation.isNative || (this.deferMoveGriddedTiles = OpenLayers.Function.bind(function() {
+            this.moveGriddedTiles(true);
+            this.moveTimerId = null
+        }, this))
+    },
+    setMap: function(a) {
+        OpenLayers.Layer.HTTPRequest.prototype.setMap.call(this,
+            a);
+        OpenLayers.Element.addClass(this.div, this.className)
+    },
+    removeMap: function() {
+        null !== this.moveTimerId && (window.clearTimeout(this.moveTimerId), this.moveTimerId = null);
+        this.clearTileQueue();
+        null !== this.backBufferTimerId && (window.clearTimeout(this.backBufferTimerId), this.backBufferTimerId = null)
+    },
+    destroy: function() {
+        this.removeBackBuffer();
+        this.clearGrid();
+        this.tileSize = this.grid = null;
+        OpenLayers.Layer.HTTPRequest.prototype.destroy.apply(this, arguments)
+    },
+    clearGrid: function() {
+        this.clearTileQueue();
+        if (this.grid) {
+            for (var a =
+                    0, b = this.grid.length; a < b; a++)
+                for (var c = this.grid[a], d = 0, e = c.length; d < e; d++) this.destroyTile(c[d]);
+            this.grid = [];
+            this.gridResolution = null
+        }
+    },
+    clone: function(a) {
+        null == a && (a = new OpenLayers.Layer.Grid(this.name, this.url, this.params, this.getOptions()));
+        a = OpenLayers.Layer.HTTPRequest.prototype.clone.apply(this, [a]);
+        null != this.tileSize && (a.tileSize = this.tileSize.clone());
+        a.grid = [];
+        a.gridResolution = null;
+        a.backBuffer = null;
+        a.backBufferTimerId = null;
+        a.tileQueue = [];
+        a.tileQueueId = null;
+        a.loading = !1;
+        a.moveTimerId = null;
+        return a
+    },
+    moveTo: function(a, b, c) {
+        OpenLayers.Layer.HTTPRequest.prototype.moveTo.apply(this, arguments);
+        a = a || this.map.getExtent();
+        if (null != a) {
+            var d = !this.grid.length || b,
+                e = this.getTilesBounds(),
+                f = this.map.getResolution(),
+                g = this.getServerResolution(f);
+            if (this.singleTile) {
+                if (d || !c && !e.containsBounds(a)) b && "resize" !== this.transitionEffect && this.removeBackBuffer(), (!b || "resize" === this.transitionEffect) && this.applyBackBuffer(g), this.initSingleTile(a)
+            } else(d = d || !e.intersectsBounds(a, {
+                worldBounds: this.map.baseLayer.wrapDateLine &&
+                    this.map.getMaxExtent()
+            }), f !== g ? (a = this.map.calculateBounds(null, g), d && this.transformDiv(g / f)) : (this.div.style.width = "100%", this.div.style.height = "100%", this.div.style.left = "0%", this.div.style.top = "0%"), d) ? (b && "resize" === this.transitionEffect && this.applyBackBuffer(g), this.initGriddedTiles(a)) : this.moveGriddedTiles()
+        }
+    },
+    getTileData: function(a) {
+        var b = null,
+            c = a.lon,
+            d = a.lat,
+            e = this.grid.length;
+        if (this.map && e) {
+            var f = this.map.getResolution(),
+                a = this.tileSize.w,
+                g = this.tileSize.h,
+                h = this.grid[0][0].bounds,
+                i = h.left,
+                h = h.top;
+            if (c < i && this.map.baseLayer.wrapDateLine) var j = this.map.getMaxExtent().getWidth(),
+                k = Math.ceil((i - c) / j),
+                c = c + j * k;
+            c = (c - i) / (f * a);
+            d = (h - d) / (f * g);
+            f = Math.floor(c);
+            i = Math.floor(d);
+            0 <= i && i < e && (e = this.grid[i][f]) && (b = {
+                tile: e,
+                i: Math.floor((c - f) * a),
+                j: Math.floor((d - i) * g)
+            })
+        }
+        return b
+    },
+    queueTileDraw: function(a) {
+        a = a.object;
+        ~OpenLayers.Util.indexOf(this.tileQueue, a) || this.tileQueue.push(a);
+        this.tileQueueId || (this.tileQueueId = OpenLayers.Animation.start(OpenLayers.Function.bind(this.drawTileFromQueue, this), null,
+            this.div));
+        return !1
+    },
+    drawTileFromQueue: function() {
+        0 === this.tileQueue.length ? this.clearTileQueue() : this.tileQueue.shift().draw(!0)
+    },
+    clearTileQueue: function() {
+        OpenLayers.Animation.stop(this.tileQueueId);
+        this.tileQueueId = null;
+        this.tileQueue = []
+    },
+    destroyTile: function(a) {
+        this.removeTileMonitoringHooks(a);
+        a.destroy()
+    },
+    getServerResolution: function(a) {
+        a = a || this.map.getResolution();
+        if (this.serverResolutions && -1 === OpenLayers.Util.indexOf(this.serverResolutions, a)) {
+            var b, c;
+            for (b = this.serverResolutions.length -
+                1; 0 <= b; b--)
+                if (c = this.serverResolutions[b], c > a) {
+                    a = c;
+                    break
+                }
+            if (-1 === b) throw "no appropriate resolution in serverResolutions";
+        }
+        return a
+    },
+    getServerZoom: function() {
+        var a = this.getServerResolution();
+        return this.serverResolutions ? OpenLayers.Util.indexOf(this.serverResolutions, a) : this.map.getZoomForResolution(a) + (this.zoomOffset || 0)
+    },
+    transformDiv: function(a) {
+        this.div.style.width = 100 * a + "%";
+        this.div.style.height = 100 * a + "%";
+        var b = this.map.getSize(),
+            c = parseInt(this.map.layerContainerDiv.style.left, 10),
+            d = (parseInt(this.map.layerContainerDiv.style.top,
+                10) - b.h / 2) * (a - 1);
+        this.div.style.left = (c - b.w / 2) * (a - 1) + "%";
+        this.div.style.top = d + "%"
+    },
+    getResolutionScale: function() {
+        return parseInt(this.div.style.width, 10) / 100
+    },
+    applyBackBuffer: function(a) {
+        null !== this.backBufferTimerId && this.removeBackBuffer();
+        var b = this.backBuffer;
+        if (!b) {
+            b = this.createBackBuffer();
+            if (!b) return;
+            this.div.insertBefore(b, this.div.firstChild);
+            this.backBuffer = b;
+            var c = this.grid[0][0].bounds;
+            this.backBufferLonLat = {
+                lon: c.left,
+                lat: c.top
+            };
+            this.backBufferResolution = this.gridResolution
+        }
+        var c = b.style,
+            d = this.backBufferResolution / a;
+        c.width = 100 * d + "%";
+        c.height = 100 * d + "%";
+        a = this.getViewPortPxFromLonLat(this.backBufferLonLat, a);
+        c = parseInt(this.map.layerContainerDiv.style.left, 10);
+        d = parseInt(this.map.layerContainerDiv.style.top, 10);
+        b.style.left = Math.round(a.x - c) + "%";
+        b.style.top = Math.round(a.y - d) + "%"
+    },
+    createBackBuffer: function() {
+        var a;
+        if (0 < this.grid.length) {
+            a = document.createElement("div");
+            a.id = this.div.id + "_bb";
+            a.className = "olBackBuffer";
+            a.style.position = "absolute";
+            a.style.width = "100%";
+            a.style.height =
+                "100%";
+            for (var b = 0, c = this.grid.length; b < c; b++)
+                for (var d = 0, e = this.grid[b].length; d < e; d++) {
+                    var f = this.grid[b][d].createBackBuffer();
+                    f && (f.style.top = b * this.tileSize.h + "%", f.style.left = d * this.tileSize.w + "%", a.appendChild(f))
+                }
+        }
+        return a
+    },
+    removeBackBuffer: function() {
+        this.backBuffer && (this.div.removeChild(this.backBuffer), this.backBufferResolution = this.backBuffer = null, null !== this.backBufferTimerId && (window.clearTimeout(this.backBufferTimerId), this.backBufferTimerId = null))
+    },
+    moveByPx: function() {
+        this.singleTile ||
+            this.moveGriddedTiles()
+    },
+    setTileSize: function(a) {
+        this.singleTile && (a = this.map.getSize(), a.h = parseInt(a.h * this.ratio), a.w = parseInt(a.w * this.ratio));
+        OpenLayers.Layer.HTTPRequest.prototype.setTileSize.apply(this, [a])
+    },
+    getTilesBounds: function() {
+        var a = null,
+            b = this.grid.length;
+        if (b) var a = this.grid[b - 1][0].bounds,
+            b = this.grid[0].length * a.getWidth(),
+            c = this.grid.length * a.getHeight(),
+            a = new OpenLayers.Bounds(a.left, a.bottom, a.left + b, a.bottom + c);
+        return a
+    },
+    initSingleTile: function(a) {
+        this.clearTileQueue();
+        var b =
+            a.getCenterLonLat(),
+            c = a.getWidth() * this.ratio,
+            a = a.getHeight() * this.ratio,
+            b = new OpenLayers.Bounds(b.lon - c / 2, b.lat - a / 2, b.lon + c / 2, b.lat + a / 2),
+            c = this.map.getLayerPxFromLonLat({
+                lon: b.left,
+                lat: b.top
+            });
+        this.grid.length || (this.grid[0] = []);
+        (a = this.grid[0][0]) ? a.moveTo(b, c): (a = this.addTile(b, c), this.addTileMonitoringHooks(a), a.draw(), this.grid[0][0] = a);
+        this.removeExcessTiles(1, 1);
+        this.gridResolution = this.getServerResolution()
+    },
+    calculateGridLayout: function(a, b, c) {
+        var d = c * this.tileSize.w,
+            c = c * this.tileSize.h,
+            e =
+            a.left - b.lon,
+            f = Math.floor(e / d) - this.buffer,
+            e = -(e / d - f) * this.tileSize.w,
+            f = b.lon + f * d,
+            a = a.top - (b.lat + c),
+            g = Math.ceil(a / c) + this.buffer;
+        return {
+            tilelon: d,
+            tilelat: c,
+            tileoffsetlon: f,
+            tileoffsetlat: b.lat + g * c,
+            tileoffsetx: e,
+            tileoffsety: -(g - a / c) * this.tileSize.h
+        }
+    },
+    getTileOrigin: function() {
+        var a = this.tileOrigin;
+        if (!a) var a = this.getMaxExtent(),
+            b = {
+                tl: ["left", "top"],
+                tr: ["right", "top"],
+                bl: ["left", "bottom"],
+                br: ["right", "bottom"]
+            }[this.tileOriginCorner],
+            a = new OpenLayers.LonLat(a[b[0]], a[b[1]]);
+        return a
+    },
+    initGriddedTiles: function(a) {
+        this.clearTileQueue();
+        var b = this.map.getSize(),
+            c = Math.ceil(b.h / this.tileSize.h) + Math.max(1, 2 * this.buffer),
+            b = Math.ceil(b.w / this.tileSize.w) + Math.max(1, 2 * this.buffer),
+            d = this.getTileOrigin(),
+            e = this.getServerResolution(),
+            d = this.calculateGridLayout(a, d, e),
+            e = Math.round(d.tileoffsetx),
+            f = Math.round(d.tileoffsety),
+            g = d.tileoffsetlon,
+            h = d.tileoffsetlat,
+            i = d.tilelon,
+            j = d.tilelat,
+            k = e,
+            l = g,
+            m = 0,
+            n = parseInt(this.map.layerContainerDiv.style.left),
+            o = parseInt(this.map.layerContainerDiv.style.top),
+            d = [],
+            p = this.map.getCenter();
+        do {
+            var q = this.grid[m++];
+            q || (q = [], this.grid.push(q));
+            var g = l,
+                e = k,
+                r = 0;
+            do {
+                var s = new OpenLayers.Bounds(g, h, g + i, h + j),
+                    t = e,
+                    t = t - n,
+                    u = f,
+                    u = u - o,
+                    u = new OpenLayers.Pixel(t, u);
+                (t = q[r++]) ? t.moveTo(s, u, !1): (t = this.addTile(s, u), this.addTileMonitoringHooks(t), q.push(t));
+                s = s.getCenterLonLat();
+                d.push({
+                    tile: t,
+                    distance: Math.pow(s.lon - p.lon, 2) + Math.pow(s.lat - p.lat, 2)
+                });
+                g += i;
+                e += this.tileSize.w
+            } while (g <= a.right + i * this.buffer || r < b);
+            h -= j;
+            f += this.tileSize.h
+        } while (h >= a.bottom - j * this.buffer || m < c);
+        this.removeExcessTiles(m, r);
+        this.gridResolution = this.getServerResolution();
+        d.sort(function(a, b) {
+            return a.distance - b.distance
+        });
+        a = 0;
+        for (c = d.length; a < c; ++a) d[a].tile.draw()
+    },
+    getMaxExtent: function() {
+        return this.maxExtent
+    },
+    addTile: function(a, b) {
+        var c = new this.tileClass(this, b, a, null, this.tileSize, this.tileOptions);
+        c.events.register("beforedraw", this, this.queueTileDraw);
+        return c
+    },
+    addTileMonitoringHooks: function(a) {
+        a.onLoadStart = function() {
+            !1 === this.loading && (this.loading = !0, this.events.triggerEvent("loadstart"));
+            this.events.triggerEvent("tileloadstart", {
+                tile: a
+            });
+            this.numLoadingTiles++
+        };
+        a.onLoadEnd = function() {
+            this.numLoadingTiles--;
+            this.events.triggerEvent("tileloaded", {
+                tile: a
+            });
+            0 === this.tileQueue.length && 0 === this.numLoadingTiles && (this.loading = !1, this.events.triggerEvent("loadend"), this.backBuffer && (this.backBufferTimerId = window.setTimeout(OpenLayers.Function.bind(this.removeBackBuffer, this), this.removeBackBufferDelay)))
+        };
+        a.onLoadError = function() {
+            this.events.triggerEvent("tileerror", {
+                tile: a
+            })
+        };
+        a.events.on({
+            loadstart: a.onLoadStart,
+            loadend: a.onLoadEnd,
+            unload: a.onLoadEnd,
+            loaderror: a.onLoadError,
+            scope: this
+        })
+    },
+    removeTileMonitoringHooks: function(a) {
+        a.unload();
+        a.events.un({
+            loadstart: a.onLoadStart,
+            loadend: a.onLoadEnd,
+            unload: a.onLoadEnd,
+            loaderror: a.onLoadError,
+            scope: this
+        })
+    },
+    moveGriddedTiles: function(a) {
+        if (!a && !OpenLayers.Animation.isNative) null != this.moveTimerId && window.clearTimeout(this.moveTimerId), this.moveTimerId = window.setTimeout(this.deferMoveGriddedTiles, this.tileLoadingDelay);
+        else
+            for (var a = this.buffer || 1, b = this.getResolutionScale();;) {
+                var c = this.grid[0][0].position.x * b + parseInt(this.div.style.left,
+                        10) + parseInt(this.map.layerContainerDiv.style.left),
+                    d = this.grid[0][0].position.y * b + parseInt(this.div.style.top, 10) + parseInt(this.map.layerContainerDiv.style.top),
+                    e = this.tileSize.w * b,
+                    f = this.tileSize.h * b;
+                if (c > -e * (a - 1)) this.shiftColumn(!0);
+                else if (c < -e * a) this.shiftColumn(!1);
+                else if (d > -f * (a - 1)) this.shiftRow(!0);
+                else if (d < -f * a) this.shiftRow(!1);
+                else break
+            }
+    },
+    shiftRow: function(a) {
+        for (var b = this.grid, c = b[a ? 0 : this.grid.length - 1], d = this.getServerResolution(), e = a ? -this.tileSize.h : this.tileSize.h, d = d * -e, f = a ?
+                b.pop() : b.shift(), g = 0, h = c.length; g < h; g++) {
+            var i = c[g],
+                j = i.bounds.clone(),
+                i = i.position.clone();
+            j.bottom += d;
+            j.top += d;
+            i.y += e;
+            f[g].moveTo(j, i)
+        }
+        a ? b.unshift(f) : b.push(f)
+    },
+    shiftColumn: function(a) {
+        for (var b = a ? -this.tileSize.w : this.tileSize.w, c = this.getServerResolution() * b, d = 0, e = this.grid.length; d < e; d++) {
+            var f = this.grid[d],
+                g = f[a ? 0 : f.length - 1],
+                h = g.bounds.clone(),
+                g = g.position.clone();
+            h.left += c;
+            h.right += c;
+            g.x += b;
+            var i = a ? this.grid[d].pop() : this.grid[d].shift();
+            i.moveTo(h, g);
+            a ? f.unshift(i) : f.push(i)
+        }
+    },
+    removeExcessTiles: function(a,
+        b) {
+        for (var c, d; this.grid.length > a;) {
+            var e = this.grid.pop();
+            c = 0;
+            for (d = e.length; c < d; c++) {
+                var f = e[c];
+                this.destroyTile(f)
+            }
+        }
+        c = 0;
+        for (d = this.grid.length; c < d; c++)
+            for (; this.grid[c].length > b;) e = this.grid[c], f = e.pop(), this.destroyTile(f)
+    },
+    onMapResize: function() {
+        this.singleTile && (this.clearGrid(), this.setTileSize())
+    },
+    getTileBounds: function(a) {
+        var b = this.maxExtent,
+            c = this.getResolution(),
+            d = c * this.tileSize.w,
+            c = c * this.tileSize.h,
+            e = this.getLonLatFromViewPortPx(a),
+            a = b.left + d * Math.floor((e.lon - b.left) / d),
+            b = b.bottom +
+            c * Math.floor((e.lat - b.bottom) / c);
+        return new OpenLayers.Bounds(a, b, a + d, b + c)
+    },
+    CLASS_NAME: "OpenLayers.Layer.Grid"
+});
+OpenLayers.Format.ArcXML = OpenLayers.Class(OpenLayers.Format.XML, {
+    fontStyleKeys: "antialiasing blockout font fontcolor fontsize fontstyle glowing interval outline printmode shadow transparency".split(" "),
+    request: null,
+    response: null,
+    initialize: function(a) {
+        this.request = new OpenLayers.Format.ArcXML.Request;
+        this.response = new OpenLayers.Format.ArcXML.Response;
+        if (a)
+            if ("feature" == a.requesttype) {
+                this.request.get_image = null;
+                var b = this.request.get_feature.query;
+                this.addCoordSys(b.featurecoordsys, a.featureCoordSys);
+                this.addCoordSys(b.filtercoordsys, a.filterCoordSys);
+                a.polygon ? (b.isspatial = !0, b.spatialfilter.polygon = a.polygon) : a.envelope && (b.isspatial = !0, b.spatialfilter.envelope = {
+                    minx: 0,
+                    miny: 0,
+                    maxx: 0,
+                    maxy: 0
+                }, this.parseEnvelope(b.spatialfilter.envelope, a.envelope))
+            } else "image" == a.requesttype ? (this.request.get_feature = null, b = this.request.get_image.properties, this.parseEnvelope(b.envelope, a.envelope), this.addLayers(b.layerlist, a.layers), this.addImageSize(b.imagesize, a.tileSize), this.addCoordSys(b.featurecoordsys,
+                a.featureCoordSys), this.addCoordSys(b.filtercoordsys, a.filterCoordSys)) : this.request = null;
+        OpenLayers.Format.XML.prototype.initialize.apply(this, [a])
+    },
+    parseEnvelope: function(a, b) {
+        b && 4 == b.length && (a.minx = b[0], a.miny = b[1], a.maxx = b[2], a.maxy = b[3])
+    },
+    addLayers: function(a, b) {
+        for (var c = 0, d = b.length; c < d; c++) a.push(b[c])
+    },
+    addImageSize: function(a, b) {
+        null !== b && (a.width = b.w, a.height = b.h, a.printwidth = b.w, a.printheight = b.h)
+    },
+    addCoordSys: function(a, b) {
+        "string" == typeof b ? (a.id = parseInt(b), a.string = b) : "object" == typeof b &&
+            null !== b.proj && (a.id = b.proj.srsProjNumber, a.string = b.proj.srsCode)
+    },
+    iserror: function(a) {
+        var b = null;
+        a ? (a = OpenLayers.Format.XML.prototype.read.apply(this, [a]), a = a.documentElement.getElementsByTagName("ERROR"), b = null !== a && 0 < a.length) : b = "" !== this.response.error;
+        return b
+    },
+    read: function(a) {
+        "string" == typeof a && (a = OpenLayers.Format.XML.prototype.read.apply(this, [a]));
+        var b = null;
+        a && a.documentElement && (b = "ARCXML" == a.documentElement.nodeName ? a.documentElement : a.documentElement.getElementsByTagName("ARCXML")[0]);
+        if (!b || "parsererror" === b.firstChild.nodeName) {
+            var c, d;
+            try {
+                c = a.firstChild.nodeValue, d = a.firstChild.childNodes[1].firstChild.nodeValue
+            } catch (e) {}
+            throw {
+                message: "Error parsing the ArcXML request",
+                error: c,
+                source: d
+            };
+        }
+        return this.parseResponse(b)
+    },
+    write: function(a) {
+        a || (a = this.request);
+        var b = this.createElementNS("", "ARCXML");
+        b.setAttribute("version", "1.1");
+        var c = this.createElementNS("", "REQUEST");
+        if (null != a.get_image) {
+            var d = this.createElementNS("", "GET_IMAGE");
+            c.appendChild(d);
+            var e = this.createElementNS("",
+                "PROPERTIES");
+            d.appendChild(e);
+            a = a.get_image.properties;
+            null != a.featurecoordsys && (d = this.createElementNS("", "FEATURECOORDSYS"), e.appendChild(d), 0 === a.featurecoordsys.id ? d.setAttribute("string", a.featurecoordsys.string) : d.setAttribute("id", a.featurecoordsys.id));
+            null != a.filtercoordsys && (d = this.createElementNS("", "FILTERCOORDSYS"), e.appendChild(d), 0 === a.filtercoordsys.id ? d.setAttribute("string", a.filtercoordsys.string) : d.setAttribute("id", a.filtercoordsys.id));
+            null != a.envelope && (d = this.createElementNS("",
+                "ENVELOPE"), e.appendChild(d), d.setAttribute("minx", a.envelope.minx), d.setAttribute("miny", a.envelope.miny), d.setAttribute("maxx", a.envelope.maxx), d.setAttribute("maxy", a.envelope.maxy));
+            d = this.createElementNS("", "IMAGESIZE");
+            e.appendChild(d);
+            d.setAttribute("height", a.imagesize.height);
+            d.setAttribute("width", a.imagesize.width);
+            if (a.imagesize.height != a.imagesize.printheight || a.imagesize.width != a.imagesize.printwidth) d.setAttribute("printheight", a.imagesize.printheight), d.setArrtibute("printwidth", a.imagesize.printwidth);
+            null != a.background && (d = this.createElementNS("", "BACKGROUND"), e.appendChild(d), d.setAttribute("color", a.background.color.r + "," + a.background.color.g + "," + a.background.color.b), null !== a.background.transcolor && d.setAttribute("transcolor", a.background.transcolor.r + "," + a.background.transcolor.g + "," + a.background.transcolor.b));
+            if (null != a.layerlist && 0 < a.layerlist.length) {
+                d = this.createElementNS("", "LAYERLIST");
+                e.appendChild(d);
+                for (e = 0; e < a.layerlist.length; e++) {
+                    var f = this.createElementNS("", "LAYERDEF");
+                    d.appendChild(f);
+                    f.setAttribute("id", a.layerlist[e].id);
+                    f.setAttribute("visible", a.layerlist[e].visible);
+                    if ("object" == typeof a.layerlist[e].query) {
+                        var g = a.layerlist[e].query;
+                        if (0 > g.where.length) continue;
+                        var h = null,
+                            h = "boolean" == typeof g.spatialfilter && g.spatialfilter ? this.createElementNS("", "SPATIALQUERY") : this.createElementNS("", "QUERY");
+                        h.setAttribute("where", g.where);
+                        "number" == typeof g.accuracy && 0 < g.accuracy && h.setAttribute("accuracy", g.accuracy);
+                        "number" == typeof g.featurelimit && 2E3 > g.featurelimit && h.setAttribute("featurelimit",
+                            g.featurelimit);
+                        "string" == typeof g.subfields && "#ALL#" != g.subfields && h.setAttribute("subfields", g.subfields);
+                        "string" == typeof g.joinexpression && 0 < g.joinexpression.length && h.setAttribute("joinexpression", g.joinexpression);
+                        "string" == typeof g.jointables && 0 < g.jointables.length && h.setAttribute("jointables", g.jointables);
+                        f.appendChild(h)
+                    }
+                    "object" == typeof a.layerlist[e].renderer && this.addRenderer(f, a.layerlist[e].renderer)
+                }
+            }
+        } else if (null != a.get_feature && (d = this.createElementNS("", "GET_FEATURES"), d.setAttribute("outputmode",
+                "newxml"), d.setAttribute("checkesc", "true"), a.get_feature.geometry ? d.setAttribute("geometry", a.get_feature.geometry) : d.setAttribute("geometry", "false"), a.get_feature.compact && d.setAttribute("compact", a.get_feature.compact), "number" == a.get_feature.featurelimit && d.setAttribute("featurelimit", a.get_feature.featurelimit), d.setAttribute("globalenvelope", "true"), c.appendChild(d), null != a.get_feature.layer && 0 < a.get_feature.layer.length && (e = this.createElementNS("", "LAYER"), e.setAttribute("id", a.get_feature.layer),
+                d.appendChild(e)), a = a.get_feature.query, null != a)) e = null, e = a.isspatial ? this.createElementNS("", "SPATIALQUERY") : this.createElementNS("", "QUERY"), d.appendChild(e), "number" == typeof a.accuracy && e.setAttribute("accuracy", a.accuracy), null != a.featurecoordsys && (d = this.createElementNS("", "FEATURECOORDSYS"), 0 == a.featurecoordsys.id ? d.setAttribute("string", a.featurecoordsys.string) : d.setAttribute("id", a.featurecoordsys.id), e.appendChild(d)), null != a.filtercoordsys && (d = this.createElementNS("", "FILTERCOORDSYS"),
+            0 === a.filtercoordsys.id ? d.setAttribute("string", a.filtercoordsys.string) : d.setAttribute("id", a.filtercoordsys.id), e.appendChild(d)), 0 < a.buffer && (d = this.createElementNS("", "BUFFER"), d.setAttribute("distance", a.buffer), e.appendChild(d)), a.isspatial && (d = this.createElementNS("", "SPATIALFILTER"), d.setAttribute("relation", a.spatialfilter.relation), e.appendChild(d), a.spatialfilter.envelope ? (f = this.createElementNS("", "ENVELOPE"), f.setAttribute("minx", a.spatialfilter.envelope.minx), f.setAttribute("miny", a.spatialfilter.envelope.miny),
+            f.setAttribute("maxx", a.spatialfilter.envelope.maxx), f.setAttribute("maxy", a.spatialfilter.envelope.maxy), d.appendChild(f)) : "object" == typeof a.spatialfilter.polygon && d.appendChild(this.writePolygonGeometry(a.spatialfilter.polygon))), null != a.where && 0 < a.where.length && e.setAttribute("where", a.where);
+        b.appendChild(c);
+        return OpenLayers.Format.XML.prototype.write.apply(this, [b])
+    },
+    addGroupRenderer: function(a, b) {
+        var c = this.createElementNS("", "GROUPRENDERER");
+        a.appendChild(c);
+        for (var d = 0; d < b.length; d++) this.addRenderer(c,
+            b[d])
+    },
+    addRenderer: function(a, b) {
+        if (OpenLayers.Util.isArray(b)) this.addGroupRenderer(a, b);
+        else {
+            var c = this.createElementNS("", b.type.toUpperCase() + "RENDERER");
+            a.appendChild(c);
+            "VALUEMAPRENDERER" == c.tagName ? this.addValueMapRenderer(c, b) : "VALUEMAPLABELRENDERER" == c.tagName ? this.addValueMapLabelRenderer(c, b) : "SIMPLELABELRENDERER" == c.tagName ? this.addSimpleLabelRenderer(c, b) : "SCALEDEPENDENTRENDERER" == c.tagName && this.addScaleDependentRenderer(c, b)
+        }
+    },
+    addScaleDependentRenderer: function(a, b) {
+        ("string" == typeof b.lower ||
+            "number" == typeof b.lower) && a.setAttribute("lower", b.lower);
+        ("string" == typeof b.upper || "number" == typeof b.upper) && a.setAttribute("upper", b.upper);
+        this.addRenderer(a, b.renderer)
+    },
+    addValueMapLabelRenderer: function(a, b) {
+        a.setAttribute("lookupfield", b.lookupfield);
+        a.setAttribute("labelfield", b.labelfield);
+        if ("object" == typeof b.exacts)
+            for (var c = 0, d = b.exacts.length; c < d; c++) {
+                var e = b.exacts[c],
+                    f = this.createElementNS("", "EXACT");
+                "string" == typeof e.value && f.setAttribute("value", e.value);
+                "string" == typeof e.label &&
+                    f.setAttribute("label", e.label);
+                "string" == typeof e.method && f.setAttribute("method", e.method);
+                a.appendChild(f);
+                if ("object" == typeof e.symbol) {
+                    var g = null;
+                    "text" == e.symbol.type && (g = this.createElementNS("", "TEXTSYMBOL"));
+                    if (null != g) {
+                        for (var h = this.fontStyleKeys, i = 0, j = h.length; i < j; i++) {
+                            var k = h[i];
+                            e.symbol[k] && g.setAttribute(k, e.symbol[k])
+                        }
+                        f.appendChild(g)
+                    }
+                }
+            }
+    },
+    addValueMapRenderer: function(a, b) {
+        a.setAttribute("lookupfield", b.lookupfield);
+        if ("object" == typeof b.ranges)
+            for (var c = 0, d = b.ranges.length; c < d; c++) {
+                var e =
+                    b.ranges[c],
+                    f = this.createElementNS("", "RANGE");
+                f.setAttribute("lower", e.lower);
+                f.setAttribute("upper", e.upper);
+                a.appendChild(f);
+                if ("object" == typeof e.symbol) {
+                    var g = null;
+                    "simplepolygon" == e.symbol.type && (g = this.createElementNS("", "SIMPLEPOLYGONSYMBOL"));
+                    null != g && ("string" == typeof e.symbol.boundarycolor && g.setAttribute("boundarycolor", e.symbol.boundarycolor), "string" == typeof e.symbol.fillcolor && g.setAttribute("fillcolor", e.symbol.fillcolor), "number" == typeof e.symbol.filltransparency && g.setAttribute("filltransparency",
+                        e.symbol.filltransparency), f.appendChild(g))
+                }
+            } else if ("object" == typeof b.exacts) {
+                c = 0;
+                for (d = b.exacts.length; c < d; c++) e = b.exacts[c], f = this.createElementNS("", "EXACT"), "string" == typeof e.value && f.setAttribute("value", e.value), "string" == typeof e.label && f.setAttribute("label", e.label), "string" == typeof e.method && f.setAttribute("method", e.method), a.appendChild(f), "object" == typeof e.symbol && (g = null, "simplemarker" == e.symbol.type && (g = this.createElementNS("", "SIMPLEMARKERSYMBOL")), null != g && ("string" == typeof e.symbol.antialiasing &&
+                    g.setAttribute("antialiasing", e.symbol.antialiasing), "string" == typeof e.symbol.color && g.setAttribute("color", e.symbol.color), "string" == typeof e.symbol.outline && g.setAttribute("outline", e.symbol.outline), "string" == typeof e.symbol.overlap && g.setAttribute("overlap", e.symbol.overlap), "string" == typeof e.symbol.shadow && g.setAttribute("shadow", e.symbol.shadow), "number" == typeof e.symbol.transparency && g.setAttribute("transparency", e.symbol.transparency), "string" == typeof e.symbol.usecentroid && g.setAttribute("usecentroid",
+                        e.symbol.usecentroid), "number" == typeof e.symbol.width && g.setAttribute("width", e.symbol.width), f.appendChild(g)))
+            }
+    },
+    addSimpleLabelRenderer: function(a, b) {
+        a.setAttribute("field", b.field);
+        for (var c = "featureweight howmanylabels labelbufferratio labelpriorities labelweight linelabelposition rotationalangles".split(" "), d = 0, e = c.length; d < e; d++) {
+            var f = c[d];
+            b[f] && a.setAttribute(f, b[f])
+        }
+        if ("text" == b.symbol.type) {
+            var g = b.symbol,
+                h = this.createElementNS("", "TEXTSYMBOL");
+            a.appendChild(h);
+            c = this.fontStyleKeys;
+            d = 0;
+            for (e = c.length; d < e; d++) f = c[d], g[f] && h.setAttribute(f, b[f])
+        }
+    },
+    writePolygonGeometry: function(a) {
+        if (!(a instanceof OpenLayers.Geometry.Polygon)) throw {
+            message: "Cannot write polygon geometry to ArcXML with an " + a.CLASS_NAME + " object.",
+            geometry: a
+        };
+        for (var b = this.createElementNS("", "POLYGON"), c = 0, d = a.components.length; c < d; c++) {
+            for (var e = a.components[c], f = this.createElementNS("", "RING"), g = 0, h = e.components.length; g < h; g++) {
+                var i = e.components[g],
+                    j = this.createElementNS("", "POINT");
+                j.setAttribute("x", i.x);
+                j.setAttribute("y",
+                    i.y);
+                f.appendChild(j)
+            }
+            b.appendChild(f)
+        }
+        return b
+    },
+    parseResponse: function(a) {
+        "string" == typeof a && (a = (new OpenLayers.Format.XML).read(a));
+        var b = new OpenLayers.Format.ArcXML.Response,
+            c = a.getElementsByTagName("ERROR");
+        if (null != c && 0 < c.length) b.error = this.getChildValue(c, "Unknown error.");
+        else {
+            c = a.getElementsByTagName("RESPONSE");
+            if (null == c || 0 == c.length) return b.error = "No RESPONSE tag found in ArcXML response.", b;
+            var d = c[0].firstChild.nodeName;
+            "#text" == d && (d = c[0].firstChild.nextSibling.nodeName);
+            if ("IMAGE" ==
+                d) c = a.getElementsByTagName("ENVELOPE"), a = a.getElementsByTagName("OUTPUT"), null == c || 0 == c.length ? b.error = "No ENVELOPE tag found in ArcXML response." : null == a || 0 == a.length ? b.error = "No OUTPUT tag found in ArcXML response." : (c = this.parseAttributes(c[0]), d = this.parseAttributes(a[0]), b.image = "string" == typeof d.type ? {
+                envelope: c,
+                output: {
+                    type: d.type,
+                    data: this.getChildValue(a[0])
+                }
+            } : {
+                envelope: c,
+                output: d
+            });
+            else if ("FEATURES" == d) {
+                if (a = c[0].getElementsByTagName("FEATURES"), c = a[0].getElementsByTagName("FEATURECOUNT"),
+                    b.features.featurecount = c[0].getAttribute("count"), 0 < b.features.featurecount) {
+                    c = a[0].getElementsByTagName("ENVELOPE");
+                    b.features.envelope = this.parseAttributes(c[0], "number");
+                    a = a[0].getElementsByTagName("FEATURE");
+                    for (c = 0; c < a.length; c++) {
+                        for (var d = new OpenLayers.Feature.Vector, e = a[c].getElementsByTagName("FIELD"), f = 0; f < e.length; f++) {
+                            var g = e[f].getAttribute("name"),
+                                h = e[f].getAttribute("value");
+                            d.attributes[g] = h
+                        }
+                        e = a[c].getElementsByTagName("POLYGON");
+                        if (0 < e.length) {
+                            e = e[0].getElementsByTagName("RING");
+                            f = [];
+                            for (g = 0; g < e.length; g++) {
+                                h = [];
+                                h.push(this.parsePointGeometry(e[g]));
+                                for (var i = e[g].getElementsByTagName("HOLE"), j = 0; j < i.length; j++) h.push(this.parsePointGeometry(i[j]));
+                                f.push(new OpenLayers.Geometry.Polygon(h))
+                            }
+                            d.geometry = 1 == f.length ? f[0] : new OpenLayers.Geometry.MultiPolygon(f)
+                        }
+                        b.features.feature.push(d)
+                    }
+                }
+            } else b.error = "Unidentified response type."
+        }
+        return b
+    },
+    parseAttributes: function(a, b) {
+        for (var c = {}, d = 0; d < a.attributes.length; d++) c[a.attributes[d].nodeName] = "number" == b ? parseFloat(a.attributes[d].nodeValue) :
+            a.attributes[d].nodeValue;
+        return c
+    },
+    parsePointGeometry: function(a) {
+        var b = [],
+            c = a.getElementsByTagName("COORDS");
+        if (0 < c.length) {
+            a = this.getChildValue(c[0]);
+            a = a.split(/;/);
+            for (c = 0; c < a.length; c++) {
+                var d = a[c].split(/ /);
+                b.push(new OpenLayers.Geometry.Point(d[0], d[1]))
+            }
+        } else if (a = a.getElementsByTagName("POINT"), 0 < a.length)
+            for (c = 0; c < a.length; c++) b.push(new OpenLayers.Geometry.Point(parseFloat(a[c].getAttribute("x")), parseFloat(a[c].getAttribute("y"))));
+        return new OpenLayers.Geometry.LinearRing(b)
+    },
+    CLASS_NAME: "OpenLayers.Format.ArcXML"
+});
+OpenLayers.Format.ArcXML.Request = OpenLayers.Class({
+    initialize: function() {
+        return OpenLayers.Util.extend(this, {
+            get_image: {
+                properties: {
+                    background: null,
+                    draw: !0,
+                    envelope: {
+                        minx: 0,
+                        miny: 0,
+                        maxx: 0,
+                        maxy: 0
+                    },
+                    featurecoordsys: {
+                        id: 0,
+                        string: "",
+                        datumtransformid: 0,
+                        datumtransformstring: ""
+                    },
+                    filtercoordsys: {
+                        id: 0,
+                        string: "",
+                        datumtransformid: 0,
+                        datumtransformstring: ""
+                    },
+                    imagesize: {
+                        height: 0,
+                        width: 0,
+                        dpi: 96,
+                        printheight: 0,
+                        printwidth: 0,
+                        scalesymbols: !1
+                    },
+                    layerlist: [],
+                    output: {
+                        baseurl: "",
+                        legendbaseurl: "",
+                        legendname: "",
+                        legendpath: "",
+                        legendurl: "",
+                        name: "",
+                        path: "",
+                        type: "jpg",
+                        url: ""
+                    }
+                }
+            },
+            get_feature: {
+                layer: "",
+                query: {
+                    isspatial: !1,
+                    featurecoordsys: {
+                        id: 0,
+                        string: "",
+                        datumtransformid: 0,
+                        datumtransformstring: ""
+                    },
+                    filtercoordsys: {
+                        id: 0,
+                        string: "",
+                        datumtransformid: 0,
+                        datumtransformstring: ""
+                    },
+                    buffer: 0,
+                    where: "",
+                    spatialfilter: {
+                        relation: "envelope_intersection",
+                        envelope: null
+                    }
+                }
+            },
+            environment: {
+                separators: {
+                    cs: " ",
+                    ts: ";"
+                }
+            },
+            layer: [],
+            workspaces: []
+        })
+    },
+    CLASS_NAME: "OpenLayers.Format.ArcXML.Request"
+});
+OpenLayers.Format.ArcXML.Response = OpenLayers.Class({
+    initialize: function() {
+        return OpenLayers.Util.extend(this, {
+            image: {
+                envelope: null,
+                output: ""
+            },
+            features: {
+                featurecount: 0,
+                envelope: null,
+                feature: []
+            },
+            error: ""
+        })
+    },
+    CLASS_NAME: "OpenLayers.Format.ArcXML.Response"
+});
+OpenLayers.ProxyHost = "";
+OpenLayers.Request = {
+    DEFAULT_CONFIG: {
+        method: "GET",
+        url: window.location.href,
+        async: !0,
+        user: void 0,
+        password: void 0,
+        params: null,
+        proxy: OpenLayers.ProxyHost,
+        headers: {},
+        data: null,
+        callback: function() {},
+        success: null,
+        failure: null,
+        scope: null
+    },
+    URL_SPLIT_REGEX: /([^:]*:)\/\/([^:]*:?[^@]*@)?([^:\/\?]*):?([^\/\?]*)/,
+    events: new OpenLayers.Events(this),
+    makeSameOrigin: function(a, b) {
+        var c = 0 !== a.indexOf("http"),
+            d = !c && a.match(this.URL_SPLIT_REGEX);
+        if (d) {
+            var e = window.location,
+                c = d[1] == e.protocol && d[3] == e.hostname,
+                d = d[4],
+                e = e.port;
+            if (80 != d && "" != d || "80" != e && "" != e) c = c && d == e
+        }
+        c || (b ? a = "function" == typeof b ? b(a) : b + encodeURIComponent(a) : OpenLayers.Console.warn(OpenLayers.i18n("proxyNeeded"), {
+            url: a
+        }));
+        return a
+    },
+    issue: function(a) {
+        var b = OpenLayers.Util.extend(this.DEFAULT_CONFIG, {
+                proxy: OpenLayers.ProxyHost
+            }),
+            a = OpenLayers.Util.applyDefaults(a, b),
+            b = !1,
+            c;
+        for (c in a.headers) a.headers.hasOwnProperty(c) && "x-requested-with" === c.toLowerCase() && (b = !0);
+        !1 === b && (a.headers["X-Requested-With"] = "XMLHttpRequest");
+        var d = new OpenLayers.Request.XMLHttpRequest,
+            e = OpenLayers.Util.urlAppend(a.url, OpenLayers.Util.getParameterString(a.params || {})),
+            e = OpenLayers.Request.makeSameOrigin(e, a.proxy);
+        d.open(a.method, e, a.async, a.user, a.password);
+        for (var f in a.headers) d.setRequestHeader(f, a.headers[f]);
+        var g = this.events,
+            h = this;
+        d.onreadystatechange = function() {
+            d.readyState == OpenLayers.Request.XMLHttpRequest.DONE && !1 !== g.triggerEvent("complete", {
+                request: d,
+                config: a,
+                requestUrl: e
+            }) && h.runCallbacks({
+                request: d,
+                config: a,
+                requestUrl: e
+            })
+        };
+        !1 === a.async ? d.send(a.data) : window.setTimeout(function() {
+            0 !==
+                d.readyState && d.send(a.data)
+        }, 0);
+        return d
+    },
+    runCallbacks: function(a) {
+        var b = a.request,
+            c = a.config,
+            d = c.scope ? OpenLayers.Function.bind(c.callback, c.scope) : c.callback,
+            e;
+        c.success && (e = c.scope ? OpenLayers.Function.bind(c.success, c.scope) : c.success);
+        var f;
+        c.failure && (f = c.scope ? OpenLayers.Function.bind(c.failure, c.scope) : c.failure);
+        "file:" == OpenLayers.Util.createUrlObject(c.url).protocol && b.responseText && (b.status = 200);
+        d(b);
+        if (!b.status || 200 <= b.status && 300 > b.status) this.events.triggerEvent("success", a), e && e(b);
+        if (b.status && (200 > b.status || 300 <= b.status)) this.events.triggerEvent("failure", a), f && f(b)
+    },
+    GET: function(a) {
+        a = OpenLayers.Util.extend(a, {
+            method: "GET"
+        });
+        return OpenLayers.Request.issue(a)
+    },
+    POST: function(a) {
+        a = OpenLayers.Util.extend(a, {
+            method: "POST"
+        });
+        a.headers = a.headers ? a.headers : {};
+        "CONTENT-TYPE" in OpenLayers.Util.upperCaseObject(a.headers) || (a.headers["Content-Type"] = "application/xml");
+        return OpenLayers.Request.issue(a)
+    },
+    PUT: function(a) {
+        a = OpenLayers.Util.extend(a, {
+            method: "PUT"
+        });
+        a.headers = a.headers ?
+            a.headers : {};
+        "CONTENT-TYPE" in OpenLayers.Util.upperCaseObject(a.headers) || (a.headers["Content-Type"] = "application/xml");
+        return OpenLayers.Request.issue(a)
+    },
+    DELETE: function(a) {
+        a = OpenLayers.Util.extend(a, {
+            method: "DELETE"
+        });
+        return OpenLayers.Request.issue(a)
+    },
+    HEAD: function(a) {
+        a = OpenLayers.Util.extend(a, {
+            method: "HEAD"
+        });
+        return OpenLayers.Request.issue(a)
+    },
+    OPTIONS: function(a) {
+        a = OpenLayers.Util.extend(a, {
+            method: "OPTIONS"
+        });
+        return OpenLayers.Request.issue(a)
+    }
+};
+OpenLayers.Layer.ArcIMS = OpenLayers.Class(OpenLayers.Layer.Grid, {
+    DEFAULT_PARAMS: {
+        ClientVersion: "9.2",
+        ServiceName: ""
+    },
+    featureCoordSys: "4326",
+    filterCoordSys: "4326",
+    layers: null,
+    async: !0,
+    name: "ArcIMS",
+    isBaseLayer: !0,
+    DEFAULT_OPTIONS: {
+        tileSize: new OpenLayers.Size(512, 512),
+        featureCoordSys: "4326",
+        filterCoordSys: "4326",
+        layers: null,
+        isBaseLayer: !0,
+        async: !0,
+        name: "ArcIMS"
+    },
+    initialize: function(a, b, c) {
+        this.tileSize = new OpenLayers.Size(512, 512);
+        this.params = OpenLayers.Util.applyDefaults({
+                ServiceName: c.serviceName
+            },
+            this.DEFAULT_PARAMS);
+        this.options = OpenLayers.Util.applyDefaults(c, this.DEFAULT_OPTIONS);
+        OpenLayers.Layer.Grid.prototype.initialize.apply(this, [a, b, this.params, c]);
+        if (this.transparent && (this.isBaseLayer || (this.isBaseLayer = !1), "image/jpeg" == this.format)) this.format = OpenLayers.Util.alphaHack() ? "image/gif" : "image/png";
+        null === this.options.layers && (this.options.layers = [])
+    },
+    getURL: function(a) {
+        var b = "",
+            a = this.adjustBounds(a),
+            a = new OpenLayers.Format.ArcXML(OpenLayers.Util.extend(this.options, {
+                requesttype: "image",
+                envelope: a.toArray(),
+                tileSize: this.tileSize
+            })),
+            a = new OpenLayers.Request.POST({
+                url: this.getFullRequestString(),
+                data: a.write(),
+                async: !1
+            });
+        if (null != a) {
+            b = a.responseXML;
+            if (!b || !b.documentElement) b = a.responseText;
+            b = this.getUrlOrImage((new OpenLayers.Format.ArcXML).read(b).image.output)
+        }
+        return b
+    },
+    getURLasync: function(a, b, c) {
+        a = this.adjustBounds(a);
+        a = new OpenLayers.Format.ArcXML(OpenLayers.Util.extend(this.options, {
+            requesttype: "image",
+            envelope: a.toArray(),
+            tileSize: this.tileSize
+        }));
+        OpenLayers.Request.POST({
+            url: this.getFullRequestString(),
+            async: !0,
+            data: a.write(),
+            callback: function(a) {
+                var e = a.responseXML;
+                if (!e || !e.documentElement) e = a.responseText;
+                a = (new OpenLayers.Format.ArcXML).read(e);
+                b.call(c, this.getUrlOrImage(a.image.output))
+            },
+            scope: this
+        })
+    },
+    getUrlOrImage: function(a) {
+        var b = "";
+        a.url ? b = a.url : a.data && (b = "data:image/" + a.type + ";base64," + a.data);
+        return b
+    },
+    setLayerQuery: function(a, b) {
+        for (var c = 0; c < this.options.layers.length; c++)
+            if (a == this.options.layers[c].id) {
+                this.options.layers[c].query = b;
+                return
+            }
+        this.options.layers.push({
+            id: a,
+            visible: !0,
+            query: b
+        })
+    },
+    getFeatureInfo: function(a, b, c) {
+        var d = c.buffer || 1,
+            e = c.callback || function() {},
+            f = c.scope || window,
+            g = {};
+        OpenLayers.Util.extend(g, this.options);
+        g.requesttype = "feature";
+        a instanceof OpenLayers.LonLat ? (g.polygon = null, g.envelope = [a.lon - d, a.lat - d, a.lon + d, a.lat + d]) : a instanceof OpenLayers.Geometry.Polygon && (g.envelope = null, g.polygon = a);
+        var h = new OpenLayers.Format.ArcXML(g);
+        OpenLayers.Util.extend(h.request.get_feature, c);
+        h.request.get_feature.layer = b.id;
+        "number" == typeof b.query.accuracy ? h.request.get_feature.query.accuracy =
+            b.query.accuracy : (a = this.map.getCenter(), c = this.map.getViewPortPxFromLonLat(a), c.x++, c = this.map.getLonLatFromPixel(c), h.request.get_feature.query.accuracy = c.lon - a.lon);
+        h.request.get_feature.query.where = b.query.where;
+        h.request.get_feature.query.spatialfilter.relation = "area_intersection";
+        OpenLayers.Request.POST({
+            url: this.getFullRequestString({
+                CustomService: "Query"
+            }),
+            data: h.write(),
+            callback: function(a) {
+                a = h.parseResponse(a.responseText);
+                h.iserror() ? e.call(f, null) : e.call(f, a.features)
+            }
+        })
+    },
+    clone: function(a) {
+        null ==
+            a && (a = new OpenLayers.Layer.ArcIMS(this.name, this.url, this.getOptions()));
+        return a = OpenLayers.Layer.Grid.prototype.clone.apply(this, [a])
+    },
+    CLASS_NAME: "OpenLayers.Layer.ArcIMS"
+});
+OpenLayers.Format.OWSCommon.v1_1_0 = OpenLayers.Class(OpenLayers.Format.OWSCommon.v1, {
+    namespaces: {
+        ows: "http://www.opengis.net/ows/1.1",
+        xlink: "http://www.w3.org/1999/xlink"
+    },
+    readers: {
+        ows: OpenLayers.Util.applyDefaults({
+            ExceptionReport: function(a, b) {
+                b.exceptionReport = {
+                    version: a.getAttribute("version"),
+                    language: a.getAttribute("xml:lang"),
+                    exceptions: []
+                };
+                this.readChildNodes(a, b.exceptionReport)
+            },
+            AllowedValues: function(a, b) {
+                b.allowedValues = {};
+                this.readChildNodes(a, b.allowedValues)
+            },
+            AnyValue: function(a, b) {
+                b.anyValue = !0
+            },
+            DataType: function(a, b) {
+                b.dataType = this.getChildValue(a)
+            },
+            Range: function(a, b) {
+                b.range = {};
+                this.readChildNodes(a, b.range)
+            },
+            MinimumValue: function(a, b) {
+                b.minValue = this.getChildValue(a)
+            },
+            MaximumValue: function(a, b) {
+                b.maxValue = this.getChildValue(a)
+            },
+            Identifier: function(a, b) {
+                b.identifier = this.getChildValue(a)
+            },
+            SupportedCRS: function(a, b) {
+                b.supportedCRS = this.getChildValue(a)
+            }
+        }, OpenLayers.Format.OWSCommon.v1.prototype.readers.ows)
+    },
+    writers: {
+        ows: OpenLayers.Util.applyDefaults({
+            Range: function(a) {
+                var b = this.createElementNSPlus("ows:Range", {
+                    attributes: {
+                        "ows:rangeClosure": a.closure
+                    }
+                });
+                this.writeNode("ows:MinimumValue", a.minValue, b);
+                this.writeNode("ows:MaximumValue", a.maxValue, b);
+                return b
+            },
+            MinimumValue: function(a) {
+                return this.createElementNSPlus("ows:MinimumValue", {
+                    value: a
+                })
+            },
+            MaximumValue: function(a) {
+                return this.createElementNSPlus("ows:MaximumValue", {
+                    value: a
+                })
+            },
+            Value: function(a) {
+                return this.createElementNSPlus("ows:Value", {
+                    value: a
+                })
+            }
+        }, OpenLayers.Format.OWSCommon.v1.prototype.writers.ows)
+    },
+    CLASS_NAME: "OpenLayers.Format.OWSCommon.v1_1_0"
+});
+OpenLayers.Format.WCSGetCoverage = OpenLayers.Class(OpenLayers.Format.XML, {
+    namespaces: {
+        ows: "http://www.opengis.net/ows/1.1",
+        wcs: "http://www.opengis.net/wcs/1.1",
+        xlink: "http://www.w3.org/1999/xlink",
+        xsi: "http://www.w3.org/2001/XMLSchema-instance"
+    },
+    regExes: {
+        trimSpace: /^\s*|\s*$/g,
+        removeSpace: /\s*/g,
+        splitSpace: /\s+/,
+        trimComma: /\s*,\s*/g
+    },
+    VERSION: "1.1.2",
+    schemaLocation: "http://www.opengis.net/wcs/1.1 http://schemas.opengis.net/wcs/1.1/wcsGetCoverage.xsd",
+    write: function(a) {
+        a = this.writeNode("wcs:GetCoverage",
+            a);
+        this.setAttributeNS(a, this.namespaces.xsi, "xsi:schemaLocation", this.schemaLocation);
+        return OpenLayers.Format.XML.prototype.write.apply(this, [a])
+    },
+    writers: {
+        wcs: {
+            GetCoverage: function(a) {
+                var b = this.createElementNSPlus("wcs:GetCoverage", {
+                    attributes: {
+                        version: a.version || this.VERSION,
+                        service: "WCS"
+                    }
+                });
+                this.writeNode("ows:Identifier", a.identifier, b);
+                this.writeNode("wcs:DomainSubset", a.domainSubset, b);
+                this.writeNode("wcs:Output", a.output, b);
+                return b
+            },
+            DomainSubset: function(a) {
+                var b = this.createElementNSPlus("wcs:DomainSubset", {});
+                this.writeNode("ows:BoundingBox", a.boundingBox, b);
+                a.temporalSubset && this.writeNode("wcs:TemporalSubset", a.temporalSubset, b);
+                return b
+            },
+            TemporalSubset: function(a) {
+                for (var b = this.createElementNSPlus("wcs:TemporalSubset", {}), c = 0, d = a.timePeriods.length; c < d; ++c) this.writeNode("wcs:TimePeriod", a.timePeriods[c], b);
+                return b
+            },
+            TimePeriod: function(a) {
+                var b = this.createElementNSPlus("wcs:TimePeriod", {});
+                this.writeNode("wcs:BeginPosition", a.begin, b);
+                this.writeNode("wcs:EndPosition", a.end, b);
+                a.resolution && this.writeNode("wcs:TimeResolution",
+                    a.resolution, b);
+                return b
+            },
+            BeginPosition: function(a) {
+                return this.createElementNSPlus("wcs:BeginPosition", {
+                    value: a
+                })
+            },
+            EndPosition: function(a) {
+                return this.createElementNSPlus("wcs:EndPosition", {
+                    value: a
+                })
+            },
+            TimeResolution: function(a) {
+                return this.createElementNSPlus("wcs:TimeResolution", {
+                    value: a
+                })
+            },
+            Output: function(a) {
+                var b = this.createElementNSPlus("wcs:Output", {
+                    attributes: {
+                        format: a.format,
+                        store: a.store
+                    }
+                });
+                a.gridCRS && this.writeNode("wcs:GridCRS", a.gridCRS, b);
+                return b
+            },
+            GridCRS: function(a) {
+                var b = this.createElementNSPlus("wcs:GridCRS", {});
+                this.writeNode("wcs:GridBaseCRS", a.baseCRS, b);
+                a.type && this.writeNode("wcs:GridType", a.type, b);
+                a.origin && this.writeNode("wcs:GridOrigin", a.origin, b);
+                this.writeNode("wcs:GridOffsets", a.offsets, b);
+                a.CS && this.writeNode("wcs:GridCS", a.CS, b);
+                return b
+            },
+            GridBaseCRS: function(a) {
+                return this.createElementNSPlus("wcs:GridBaseCRS", {
+                    value: a
+                })
+            },
+            GridOrigin: function(a) {
+                return this.createElementNSPlus("wcs:GridOrigin", {
+                    value: a
+                })
+            },
+            GridType: function(a) {
+                return this.createElementNSPlus("wcs:GridType", {
+                    value: a
+                })
+            },
+            GridOffsets: function(a) {
+                return this.createElementNSPlus("wcs:GridOffsets", {
+                    value: a
+                })
+            },
+            GridCS: function(a) {
+                return this.createElementNSPlus("wcs:GridCS", {
+                    value: a
+                })
+            }
+        },
+        ows: OpenLayers.Format.OWSCommon.v1_1_0.prototype.writers.ows
+    },
+    CLASS_NAME: "OpenLayers.Format.WCSGetCoverage"
+});
+OpenLayers.Format.WPSExecute = OpenLayers.Class(OpenLayers.Format.XML, {
+    namespaces: {
+        ows: "http://www.opengis.net/ows/1.1",
+        gml: "http://www.opengis.net/gml",
+        wps: "http://www.opengis.net/wps/1.0.0",
+        wfs: "http://www.opengis.net/wfs",
+        ogc: "http://www.opengis.net/ogc",
+        wcs: "http://www.opengis.net/wcs",
+        xlink: "http://www.w3.org/1999/xlink",
+        xsi: "http://www.w3.org/2001/XMLSchema-instance"
+    },
+    regExes: {
+        trimSpace: /^\s*|\s*$/g,
+        removeSpace: /\s*/g,
+        splitSpace: /\s+/,
+        trimComma: /\s*,\s*/g
+    },
+    VERSION: "1.0.0",
+    schemaLocation: "http://www.opengis.net/wps/1.0.0 http://schemas.opengis.net/wps/1.0.0/wpsAll.xsd",
+    schemaLocationAttr: function() {},
+    write: function(a) {
+        var b;
+        window.ActiveXObject ? this.xmldom = b = new ActiveXObject("Microsoft.XMLDOM") : b = document.implementation.createDocument("", "", null);
+        a = this.writeNode("wps:Execute", a, b);
+        this.setAttributeNS(a, this.namespaces.xsi, "xsi:schemaLocation", this.schemaLocation);
+        return OpenLayers.Format.XML.prototype.write.apply(this, [a])
+    },
+    writers: {
+        wps: {
+            Execute: function(a) {
+                var b = this.createElementNSPlus("wps:Execute", {
+                    attributes: {
+                        version: this.VERSION,
+                        service: "WPS"
+                    }
+                });
+                this.writeNode("ows:Identifier",
+                    a.identifier, b);
+                this.writeNode("wps:DataInputs", a.dataInputs, b);
+                this.writeNode("wps:ResponseForm", a.responseForm, b);
+                return b
+            },
+            ResponseForm: function(a) {
+                var b = this.createElementNSPlus("wps:ResponseForm", {});
+                a.rawDataOutput && this.writeNode("wps:RawDataOutput", a.rawDataOutput, b);
+                a.responseDocument && this.writeNode("wps:ResponseDocument", a.responseDocument, b);
+                return b
+            },
+            ResponseDocument: function(a) {
+                var b = this.createElementNSPlus("wps:ResponseDocument", {
+                    attributes: {
+                        storeExecuteResponse: a.storeExecuteResponse,
+                        lineage: a.lineage,
+                        status: a.status
+                    }
+                });
+                a.output && this.writeNode("wps:Output", a.output, b);
+                return b
+            },
+            Output: function(a) {
+                var b = this.createElementNSPlus("wps:Output", {
+                    attributes: {
+                        asReference: a.asReference
+                    }
+                });
+                this.writeNode("ows:Identifier", a.identifier, b);
+                this.writeNode("ows:Title", a.title, b);
+                this.writeNode("ows:Abstract", a["abstract"], b);
+                return b
+            },
+            RawDataOutput: function(a) {
+                var b = this.createElementNSPlus("wps:RawDataOutput", {
+                    attributes: {
+                        mimeType: a.mimeType
+                    }
+                });
+                this.writeNode("ows:Identifier", a.identifier,
+                    b);
+                return b
+            },
+            DataInputs: function(a) {
+                for (var b = this.createElementNSPlus("wps:DataInputs", {}), c = 0, d = a.length; c < d; ++c) this.writeNode("wps:Input", a[c], b);
+                return b
+            },
+            Input: function(a) {
+                var b = this.createElementNSPlus("wps:Input", {});
+                this.writeNode("ows:Identifier", a.identifier, b);
+                a.title && this.writeNode("ows:Title", a.title, b);
+                a.data && this.writeNode("wps:Data", a.data, b);
+                a.reference && this.writeNode("wps:Reference", a.reference, b);
+                return b
+            },
+            Data: function(a) {
+                var b = this.createElementNSPlus("wps:Data", {});
+                a.literalData ?
+                    this.writeNode("wps:LiteralData", a.literalData, b) : a.complexData && this.writeNode("wps:ComplexData", a.complexData, b);
+                return b
+            },
+            LiteralData: function(a) {
+                return this.createElementNSPlus("wps:LiteralData", {
+                    attributes: {
+                        uom: a.uom
+                    },
+                    value: a.value
+                })
+            },
+            ComplexData: function(a) {
+                var b = this.createElementNSPlus("wps:ComplexData", {
+                        attributes: {
+                            mimeType: a.mimeType,
+                            encoding: a.encoding,
+                            schema: a.schema
+                        }
+                    }),
+                    c = a.value;
+                "string" === typeof c ? b.appendChild(this.getXMLDoc().createCDATASection(a.value)) : b.appendChild(c);
+                return b
+            },
+            Reference: function(a) {
+                var b = this.createElementNSPlus("wps:Reference", {
+                    attributes: {
+                        mimeType: a.mimeType,
+                        "xlink:href": a.href,
+                        method: a.method,
+                        encoding: a.encoding,
+                        schema: a.schema
+                    }
+                });
+                a.body && this.writeNode("wps:Body", a.body, b);
+                return b
+            },
+            Body: function(a) {
+                var b = this.createElementNSPlus("wps:Body", {});
+                a.wcs ? this.writeNode("wcs:GetCoverage", a.wcs, b) : a.wfs ? (this.featureType = a.wfs.featureType, this.version = a.wfs.version, this.writeNode("wfs:GetFeature", a.wfs, b)) : this.writeNode("wps:Execute", a, b);
+                return b
+            }
+        },
+        wcs: OpenLayers.Format.WCSGetCoverage.prototype.writers.wcs,
+        wfs: OpenLayers.Format.WFST.v1_1_0.prototype.writers.wfs,
+        ogc: OpenLayers.Format.Filter.v1_1_0.prototype.writers.ogc,
+        ows: OpenLayers.Format.OWSCommon.v1_1_0.prototype.writers.ows
+    },
+    CLASS_NAME: "OpenLayers.Format.WPSExecute"
+});
+OpenLayers.Control.PanZoom = OpenLayers.Class(OpenLayers.Control, {
+    slideFactor: 50,
+    slideRatio: null,
+    buttons: null,
+    position: null,
+    initialize: function(a) {
+        this.position = new OpenLayers.Pixel(OpenLayers.Control.PanZoom.X, OpenLayers.Control.PanZoom.Y);
+        OpenLayers.Control.prototype.initialize.apply(this, arguments)
+    },
+    destroy: function() {
+        this.map && this.map.events.unregister("buttonclick", this, this.onButtonClick);
+        this.removeButtons();
+        this.position = this.buttons = null;
+        OpenLayers.Control.prototype.destroy.apply(this, arguments)
+    },
+    setMap: function(a) {
+        OpenLayers.Control.prototype.setMap.apply(this, arguments);
+        this.map.events.register("buttonclick", this, this.onButtonClick)
+    },
+    draw: function(a) {
+        OpenLayers.Control.prototype.draw.apply(this, arguments);
+        a = this.position;
+        this.buttons = [];
+        var b = {
+                w: 18,
+                h: 18
+            },
+            c = new OpenLayers.Pixel(a.x + b.w / 2, a.y);
+        this._addButton("panup", "north-mini.png", c, b);
+        a.y = c.y + b.h;
+        this._addButton("panleft", "west-mini.png", a, b);
+        this._addButton("panright", "east-mini.png", a.add(b.w, 0), b);
+        this._addButton("pandown", "south-mini.png",
+            c.add(0, 2 * b.h), b);
+        this._addButton("zoomin", "zoom-plus-mini.png", c.add(0, 3 * b.h + 5), b);
+        this._addButton("zoomworld", "zoom-world-mini.png", c.add(0, 4 * b.h + 5), b);
+        this._addButton("zoomout", "zoom-minus-mini.png", c.add(0, 5 * b.h + 5), b);
+        return this.div
+    },
+    _addButton: function(a, b, c, d) {
+        b = OpenLayers.Util.getImageLocation(b);
+        c = OpenLayers.Util.createAlphaImageDiv(this.id + "_" + a, c, d, b, "absolute");
+        c.style.cursor = "pointer";
+        this.div.appendChild(c);
+        c.action = a;
+        c.className = "olButton";
+        this.buttons.push(c);
+        return c
+    },
+    _removeButton: function(a) {
+        this.div.removeChild(a);
+        OpenLayers.Util.removeItem(this.buttons, a)
+    },
+    removeButtons: function() {
+        for (var a = this.buttons.length - 1; 0 <= a; --a) this._removeButton(this.buttons[a])
+    },
+    onButtonClick: function(a) {
+        switch (a.buttonElement.action) {
+            case "panup":
+                this.map.pan(0, -this.getSlideFactor("h"));
+                break;
+            case "pandown":
+                this.map.pan(0, this.getSlideFactor("h"));
+                break;
+            case "panleft":
+                this.map.pan(-this.getSlideFactor("w"), 0);
+                break;
+            case "panright":
+                this.map.pan(this.getSlideFactor("w"), 0);
+                break;
+            case "zoomin":
+                this.map.zoomIn();
+                break;
+            case "zoomout":
+                this.map.zoomOut();
+                break;
+            case "zoomworld":
+                this.map.zoomToMaxExtent()
+        }
+    },
+    getSlideFactor: function(a) {
+        return this.slideRatio ? this.map.getSize()[a] * this.slideRatio : this.slideFactor
+    },
+    CLASS_NAME: "OpenLayers.Control.PanZoom"
+});
+OpenLayers.Control.PanZoom.X = 4;
+OpenLayers.Control.PanZoom.Y = 4;
+OpenLayers.Control.PanZoomBar = OpenLayers.Class(OpenLayers.Control.PanZoom, {
+    zoomStopWidth: 18,
+    zoomStopHeight: 11,
+    slider: null,
+    sliderEvents: null,
+    zoombarDiv: null,
+    zoomWorldIcon: !1,
+    panIcons: !0,
+    forceFixedZoomLevel: !1,
+    mouseDragStart: null,
+    deltaY: null,
+    zoomStart: null,
+    destroy: function() {
+        this._removeZoomBar();
+        this.map.events.un({
+            changebaselayer: this.redraw,
+            scope: this
+        });
+        OpenLayers.Control.PanZoom.prototype.destroy.apply(this, arguments);
+        delete this.mouseDragStart;
+        delete this.zoomStart
+    },
+    setMap: function(a) {
+        OpenLayers.Control.PanZoom.prototype.setMap.apply(this,
+            arguments);
+        this.map.events.register("changebaselayer", this, this.redraw)
+    },
+    redraw: function() {
+        null != this.div && (this.removeButtons(), this._removeZoomBar());
+        this.draw()
+    },
+    draw: function(a) {
+        OpenLayers.Control.prototype.draw.apply(this, arguments);
+        a = this.position.clone();
+        this.buttons = [];
+        var b = {
+            w: 18,
+            h: 18
+        };
+        if (this.panIcons) {
+            var c = new OpenLayers.Pixel(a.x + b.w / 2, a.y),
+                d = b.w;
+            this.zoomWorldIcon && (c = new OpenLayers.Pixel(a.x + b.w, a.y));
+            this._addButton("panup", "north-mini.png", c, b);
+            a.y = c.y + b.h;
+            this._addButton("panleft",
+                "west-mini.png", a, b);
+            this.zoomWorldIcon && (this._addButton("zoomworld", "zoom-world-mini.png", a.add(b.w, 0), b), d *= 2);
+            this._addButton("panright", "east-mini.png", a.add(d, 0), b);
+            this._addButton("pandown", "south-mini.png", c.add(0, 2 * b.h), b);
+            this._addButton("zoomin", "zoom-plus-mini.png", c.add(0, 3 * b.h + 5), b);
+            c = this._addZoomBar(c.add(0, 4 * b.h + 5));
+            this._addButton("zoomout", "zoom-minus-mini.png", c, b)
+        } else this._addButton("zoomin", "zoom-plus-mini.png", a, b), c = this._addZoomBar(a.add(0, b.h)), this._addButton("zoomout",
+            "zoom-minus-mini.png", c, b), this.zoomWorldIcon && (c = c.add(0, b.h + 3), this._addButton("zoomworld", "zoom-world-mini.png", c, b));
+        return this.div
+    },
+    _addZoomBar: function(a) {
+        var b = OpenLayers.Util.getImageLocation("slider.png"),
+            c = this.id + "_" + this.map.id,
+            d = this.map.getNumZoomLevels() - 1 - this.map.getZoom(),
+            d = OpenLayers.Util.createAlphaImageDiv(c, a.add(-1, d * this.zoomStopHeight), {
+                w: 20,
+                h: 9
+            }, b, "absolute");
+        d.style.cursor = "move";
+        this.slider = d;
+        this.sliderEvents = new OpenLayers.Events(this, d, null, !0, {
+            includeXY: !0
+        });
+        this.sliderEvents.on({
+            touchstart: this.zoomBarDown,
+            touchmove: this.zoomBarDrag,
+            touchend: this.zoomBarUp,
+            mousedown: this.zoomBarDown,
+            mousemove: this.zoomBarDrag,
+            mouseup: this.zoomBarUp
+        });
+        var e = {
+                w: this.zoomStopWidth,
+                h: this.zoomStopHeight * this.map.getNumZoomLevels()
+            },
+            b = OpenLayers.Util.getImageLocation("zoombar.png"),
+            c = null;
+        OpenLayers.Util.alphaHack() ? (c = this.id + "_" + this.map.id, c = OpenLayers.Util.createAlphaImageDiv(c, a, {
+            w: e.w,
+            h: this.zoomStopHeight
+        }, b, "absolute", null, "crop"), c.style.height = e.h + "px") : c = OpenLayers.Util.createDiv("OpenLayers_Control_PanZoomBar_Zoombar" +
+            this.map.id, a, e, b);
+        c.style.cursor = "pointer";
+        c.className = "olButton";
+        this.zoombarDiv = c;
+        this.div.appendChild(c);
+        this.startTop = parseInt(c.style.top);
+        this.div.appendChild(d);
+        this.map.events.register("zoomend", this, this.moveZoomBar);
+        return a = a.add(0, this.zoomStopHeight * this.map.getNumZoomLevels())
+    },
+    _removeZoomBar: function() {
+        this.sliderEvents.un({
+            touchstart: this.zoomBarDown,
+            touchmove: this.zoomBarDrag,
+            touchend: this.zoomBarUp,
+            mousedown: this.zoomBarDown,
+            mousemove: this.zoomBarDrag,
+            mouseup: this.zoomBarUp
+        });
+        this.sliderEvents.destroy();
+        this.div.removeChild(this.zoombarDiv);
+        this.zoombarDiv = null;
+        this.div.removeChild(this.slider);
+        this.slider = null;
+        this.map.events.unregister("zoomend", this, this.moveZoomBar)
+    },
+    onButtonClick: function(a) {
+        OpenLayers.Control.PanZoom.prototype.onButtonClick.apply(this, arguments);
+        if (a.buttonElement === this.zoombarDiv) {
+            var b = a.buttonXY.y / this.zoomStopHeight;
+            if (this.forceFixedZoomLevel || !this.map.fractionalZoom) b = Math.floor(b);
+            b = this.map.getNumZoomLevels() - 1 - b;
+            b = Math.min(Math.max(b, 0), this.map.getNumZoomLevels() -
+                1);
+            this.map.zoomTo(b)
+        }
+    },
+    passEventToSlider: function(a) {
+        this.sliderEvents.handleBrowserEvent(a)
+    },
+    zoomBarDown: function(a) {
+        if (OpenLayers.Event.isLeftClick(a) || OpenLayers.Event.isSingleTouch(a)) this.map.events.on({
+            touchmove: this.passEventToSlider,
+            mousemove: this.passEventToSlider,
+            mouseup: this.passEventToSlider,
+            scope: this
+        }), this.mouseDragStart = a.xy.clone(), this.zoomStart = a.xy.clone(), this.div.style.cursor = "move", this.zoombarDiv.offsets = null, OpenLayers.Event.stop(a)
+    },
+    zoomBarDrag: function(a) {
+        if (null != this.mouseDragStart) {
+            var b =
+                this.mouseDragStart.y - a.xy.y,
+                c = OpenLayers.Util.pagePosition(this.zoombarDiv);
+            0 < a.clientY - c[1] && a.clientY - c[1] < parseInt(this.zoombarDiv.style.height) - 2 && (this.slider.style.top = parseInt(this.slider.style.top) - b + "px", this.mouseDragStart = a.xy.clone());
+            this.deltaY = this.zoomStart.y - a.xy.y;
+            OpenLayers.Event.stop(a)
+        }
+    },
+    zoomBarUp: function(a) {
+        if ((OpenLayers.Event.isLeftClick(a) || "touchend" === a.type) && this.mouseDragStart) {
+            this.div.style.cursor = "";
+            this.map.events.un({
+                touchmove: this.passEventToSlider,
+                mouseup: this.passEventToSlider,
+                mousemove: this.passEventToSlider,
+                scope: this
+            });
+            var b = this.map.zoom;
+            !this.forceFixedZoomLevel && this.map.fractionalZoom ? (b += this.deltaY / this.zoomStopHeight, b = Math.min(Math.max(b, 0), this.map.getNumZoomLevels() - 1)) : (b += this.deltaY / this.zoomStopHeight, b = Math.max(Math.round(b), 0));
+            this.map.zoomTo(b);
+            this.zoomStart = this.mouseDragStart = null;
+            this.deltaY = 0;
+            OpenLayers.Event.stop(a)
+        }
+    },
+    moveZoomBar: function() {
+        this.slider.style.top = (this.map.getNumZoomLevels() - 1 - this.map.getZoom()) * this.zoomStopHeight + this.startTop +
+            1 + "px"
+    },
+    CLASS_NAME: "OpenLayers.Control.PanZoomBar"
+});
+OpenLayers.Format.WFSCapabilities = OpenLayers.Class(OpenLayers.Format.XML.VersionedOGC, {
+    defaultVersion: "1.1.0",
+    errorProperty: "service",
+    CLASS_NAME: "OpenLayers.Format.WFSCapabilities"
+});
+OpenLayers.Format.WFSCapabilities.v1 = OpenLayers.Class(OpenLayers.Format.XML, {
+    namespaces: {
+        wfs: "http://www.opengis.net/wfs",
+        xlink: "http://www.w3.org/1999/xlink",
+        xsi: "http://www.w3.org/2001/XMLSchema-instance",
+        ows: "http://www.opengis.net/ows"
+    },
+    defaultPrefix: "wfs",
+    read: function(a) {
+        "string" == typeof a && (a = OpenLayers.Format.XML.prototype.read.apply(this, [a]));
+        a && 9 == a.nodeType && (a = a.documentElement);
+        var b = {};
+        this.readNode(a, b);
+        return b
+    },
+    readers: {
+        wfs: {
+            WFS_Capabilities: function(a, b) {
+                this.readChildNodes(a, b)
+            },
+            FeatureTypeList: function(a, b) {
+                b.featureTypeList = {
+                    featureTypes: []
+                };
+                this.readChildNodes(a, b.featureTypeList)
+            },
+            FeatureType: function(a, b) {
+                var c = {};
+                this.readChildNodes(a, c);
+                b.featureTypes.push(c)
+            },
+            Name: function(a, b) {
+                var c = this.getChildValue(a);
+                c && (c = c.split(":"), b.name = c.pop(), 0 < c.length && (b.featureNS = this.lookupNamespaceURI(a, c[0])))
+            },
+            Title: function(a, b) {
+                var c = this.getChildValue(a);
+                c && (b.title = c)
+            },
+            Abstract: function(a, b) {
+                var c = this.getChildValue(a);
+                c && (b["abstract"] = c)
+            }
+        }
+    },
+    CLASS_NAME: "OpenLayers.Format.WFSCapabilities.v1"
+});
+OpenLayers.Format.WFSCapabilities.v1_1_0 = OpenLayers.Class(OpenLayers.Format.WFSCapabilities.v1, {
+    regExes: {
+        trimSpace: /^\s*|\s*$/g,
+        removeSpace: /\s*/g,
+        splitSpace: /\s+/,
+        trimComma: /\s*,\s*/g
+    },
+    readers: {
+        wfs: OpenLayers.Util.applyDefaults({
+            DefaultSRS: function(a, b) {
+                var c = this.getChildValue(a);
+                c && (b.srs = c)
+            }
+        }, OpenLayers.Format.WFSCapabilities.v1.prototype.readers.wfs),
+        ows: OpenLayers.Format.OWSCommon.v1.prototype.readers.ows
+    },
+    CLASS_NAME: "OpenLayers.Format.WFSCapabilities.v1_1_0"
+});
+OpenLayers.Layer.Image = OpenLayers.Class(OpenLayers.Layer, {
+    isBaseLayer: !0,
+    url: null,
+    extent: null,
+    size: null,
+    tile: null,
+    aspectRatio: null,
+    initialize: function(a, b, c, d, e) {
+        this.url = b;
+        this.maxExtent = this.extent = c;
+        this.size = d;
+        OpenLayers.Layer.prototype.initialize.apply(this, [a, e]);
+        this.aspectRatio = this.extent.getHeight() / this.size.h / (this.extent.getWidth() / this.size.w)
+    },
+    destroy: function() {
+        this.tile && (this.removeTileMonitoringHooks(this.tile), this.tile.destroy(), this.tile = null);
+        OpenLayers.Layer.prototype.destroy.apply(this,
+            arguments)
+    },
+    clone: function(a) {
+        null == a && (a = new OpenLayers.Layer.Image(this.name, this.url, this.extent, this.size, this.getOptions()));
+        return a = OpenLayers.Layer.prototype.clone.apply(this, [a])
+    },
+    setMap: function(a) {
+        null == this.options.maxResolution && (this.options.maxResolution = this.aspectRatio * this.extent.getWidth() / this.size.w);
+        OpenLayers.Layer.prototype.setMap.apply(this, arguments)
+    },
+    moveTo: function(a, b, c) {
+        OpenLayers.Layer.prototype.moveTo.apply(this, arguments);
+        var d = null == this.tile;
+        if (b || d) {
+            this.setTileSize();
+            var e = this.map.getLayerPxFromLonLat({
+                lon: this.extent.left,
+                lat: this.extent.top
+            });
+            d ? (this.tile = new OpenLayers.Tile.Image(this, e, this.extent, null, this.tileSize), this.addTileMonitoringHooks(this.tile)) : (this.tile.size = this.tileSize.clone(), this.tile.position = e.clone());
+            this.tile.draw()
+        }
+    },
+    setTileSize: function() {
+        var a = this.extent.getWidth() / this.map.getResolution(),
+            b = this.extent.getHeight() / this.map.getResolution();
+        this.tileSize = new OpenLayers.Size(a, b)
+    },
+    addTileMonitoringHooks: function(a) {
+        a.onLoadStart =
+            function() {
+                this.events.triggerEvent("loadstart")
+            };
+        a.events.register("loadstart", this, a.onLoadStart);
+        a.onLoadEnd = function() {
+            this.events.triggerEvent("loadend")
+        };
+        a.events.register("loadend", this, a.onLoadEnd);
+        a.events.register("unload", this, a.onLoadEnd)
+    },
+    removeTileMonitoringHooks: function(a) {
+        a.unload();
+        a.events.un({
+            loadstart: a.onLoadStart,
+            loadend: a.onLoadEnd,
+            unload: a.onLoadEnd,
+            scope: this
+        })
+    },
+    setUrl: function(a) {
+        this.url = a;
+        this.tile.draw()
+    },
+    getURL: function() {
+        return this.url
+    },
+    CLASS_NAME: "OpenLayers.Layer.Image"
+});
+OpenLayers.Strategy = OpenLayers.Class({
+    layer: null,
+    options: null,
+    active: null,
+    autoActivate: !0,
+    autoDestroy: !0,
+    initialize: function(a) {
+        OpenLayers.Util.extend(this, a);
+        this.options = a;
+        this.active = !1
+    },
+    destroy: function() {
+        this.deactivate();
+        this.options = this.layer = null
+    },
+    setLayer: function(a) {
+        this.layer = a
+    },
+    activate: function() {
+        return !this.active ? this.active = !0 : !1
+    },
+    deactivate: function() {
+        return this.active ? (this.active = !1, !0) : !1
+    },
+    CLASS_NAME: "OpenLayers.Strategy"
+});
+OpenLayers.Strategy.Save = OpenLayers.Class(OpenLayers.Strategy, {
+    events: null,
+    auto: !1,
+    timer: null,
+    initialize: function(a) {
+        OpenLayers.Strategy.prototype.initialize.apply(this, [a]);
+        this.events = new OpenLayers.Events(this)
+    },
+    activate: function() {
+        var a = OpenLayers.Strategy.prototype.activate.call(this);
+        if (a && this.auto)
+            if ("number" === typeof this.auto) this.timer = window.setInterval(OpenLayers.Function.bind(this.save, this), 1E3 * this.auto);
+            else this.layer.events.on({
+                featureadded: this.triggerSave,
+                afterfeaturemodified: this.triggerSave,
+                scope: this
+            });
+        return a
+    },
+    deactivate: function() {
+        var a = OpenLayers.Strategy.prototype.deactivate.call(this);
+        a && this.auto && ("number" === typeof this.auto ? window.clearInterval(this.timer) : this.layer.events.un({
+            featureadded: this.triggerSave,
+            afterfeaturemodified: this.triggerSave,
+            scope: this
+        }));
+        return a
+    },
+    triggerSave: function(a) {
+        var b = a.feature;
+        (b.state === OpenLayers.State.INSERT || b.state === OpenLayers.State.UPDATE || b.state === OpenLayers.State.DELETE) && this.save([a.feature])
+    },
+    save: function(a) {
+        a || (a = this.layer.features);
+        this.events.triggerEvent("start", {
+            features: a
+        });
+        var b = this.layer.projection,
+            c = this.layer.map.getProjectionObject();
+        if (!c.equals(b)) {
+            for (var d = a.length, e = Array(d), f, g, h = 0; h < d; ++h) f = a[h], g = f.clone(), g.fid = f.fid, g.state = f.state, f.url && (g.url = f.url), g._original = f, g.geometry.transform(c, b), e[h] = g;
+            a = e
+        }
+        this.layer.protocol.commit(a, {
+            callback: this.onCommit,
+            scope: this
+        })
+    },
+    onCommit: function(a) {
+        var b = {
+            response: a
+        };
+        if (a.success()) {
+            for (var c = a.reqFeatures, d, e = [], f = a.insertIds || [], g = 0, h = 0, i = c.length; h < i; ++h)
+                if (d = c[h],
+                    d = d._original || d, a = d.state) a == OpenLayers.State.DELETE ? e.push(d) : a == OpenLayers.State.INSERT && (d.fid = f[g], ++g), d.state = null;
+            0 < e.length && this.layer.destroyFeatures(e);
+            this.events.triggerEvent("success", b)
+        } else this.events.triggerEvent("fail", b)
+    },
+    CLASS_NAME: "OpenLayers.Strategy.Save"
+});
+OpenLayers.Format.GPX = OpenLayers.Class(OpenLayers.Format.XML, {
+    defaultDesc: "No description available",
+    extractWaypoints: !0,
+    extractTracks: !0,
+    extractRoutes: !0,
+    extractAttributes: !0,
+    namespaces: {
+        gpx: "http://www.topografix.com/GPX/1/1",
+        xsi: "http://www.w3.org/2001/XMLSchema-instance"
+    },
+    schemaLocation: "http://www.topografix.com/GPX/1/1 http://www.topografix.com/GPX/1/1/gpx.xsd",
+    creator: "OpenLayers",
+    initialize: function(a) {
+        this.externalProjection = new OpenLayers.Projection("EPSG:4326");
+        OpenLayers.Format.XML.prototype.initialize.apply(this, [a])
+    },
+    read: function(a) {
+        "string" == typeof a && (a = OpenLayers.Format.XML.prototype.read.apply(this, [a]));
+        var b = [];
+        if (this.extractTracks)
+            for (var c = a.getElementsByTagName("trk"), d = 0, e = c.length; d < e; d++) {
+                var f = {};
+                this.extractAttributes && (f = this.parseAttributes(c[d]));
+                for (var g = this.getElementsByTagNameNS(c[d], c[d].namespaceURI, "trkseg"), h = 0, i = g.length; h < i; h++) {
+                    var j = this.extractSegment(g[h], "trkpt");
+                    b.push(new OpenLayers.Feature.Vector(j, f))
+                }
+            }
+        if (this.extractRoutes) {
+            e = a.getElementsByTagName("rte");
+            c = 0;
+            for (d =
+                e.length; c < d; c++) f = {}, this.extractAttributes && (f = this.parseAttributes(e[c])), g = this.extractSegment(e[c], "rtept"), b.push(new OpenLayers.Feature.Vector(g, f))
+        }
+        if (this.extractWaypoints) {
+            a = a.getElementsByTagName("wpt");
+            c = 0;
+            for (e = a.length; c < e; c++) f = {}, this.extractAttributes && (f = this.parseAttributes(a[c])), d = new OpenLayers.Geometry.Point(a[c].getAttribute("lon"), a[c].getAttribute("lat")), b.push(new OpenLayers.Feature.Vector(d, f))
+        }
+        if (this.internalProjection && this.externalProjection) {
+            f = 0;
+            for (a = b.length; f <
+                a; f++) b[f].geometry.transform(this.externalProjection, this.internalProjection)
+        }
+        return b
+    },
+    extractSegment: function(a, b) {
+        for (var c = this.getElementsByTagNameNS(a, a.namespaceURI, b), d = [], e = 0, f = c.length; e < f; e++) d.push(new OpenLayers.Geometry.Point(c[e].getAttribute("lon"), c[e].getAttribute("lat")));
+        return new OpenLayers.Geometry.LineString(d)
+    },
+    parseAttributes: function(a) {
+        for (var b = {}, a = a.firstChild, c, d; a;) {
+            if (1 == a.nodeType && a.firstChild && (c = a.firstChild, 3 == c.nodeType || 4 == c.nodeType)) d = a.prefix ? a.nodeName.split(":")[1] :
+                a.nodeName, "trkseg" != d && "rtept" != d && (b[d] = c.nodeValue);
+            a = a.nextSibling
+        }
+        return b
+    },
+    write: function(a, b) {
+        var a = OpenLayers.Util.isArray(a) ? a : [a],
+            c = this.createElementNS(this.namespaces.gpx, "gpx");
+        c.setAttribute("version", "1.1");
+        c.setAttribute("creator", this.creator);
+        this.setAttributes(c, {
+            "xsi:schemaLocation": this.schemaLocation
+        });
+        b && "object" == typeof b && c.appendChild(this.buildMetadataNode(b));
+        for (var d = 0, e = a.length; d < e; d++) c.appendChild(this.buildFeatureNode(a[d]));
+        return OpenLayers.Format.XML.prototype.write.apply(this, [c])
+    },
+    buildMetadataNode: function(a) {
+        for (var b = ["name", "desc", "author"], c = this.createElementNSPlus("gpx:metadata"), d = 0; d < b.length; d++) {
+            var e = b[d];
+            if (a[e]) {
+                var f = this.createElementNSPlus("gpx:" + e);
+                f.appendChild(this.createTextNode(a[e]));
+                c.appendChild(f)
+            }
+        }
+        return c
+    },
+    buildFeatureNode: function(a) {
+        var b = a.geometry,
+            b = b.clone();
+        this.internalProjection && this.externalProjection && b.transform(this.internalProjection, this.externalProjection);
+        if ("OpenLayers.Geometry.Point" == b.CLASS_NAME) {
+            var c = this.buildWptNode(b);
+            this.appendAttributesNode(c, a);
+            return c
+        }
+        c = this.createElementNSPlus("gpx:trk");
+        this.appendAttributesNode(c, a);
+        for (var a = this.buildTrkSegNode(b), a = OpenLayers.Util.isArray(a) ? a : [a], b = 0, d = a.length; b < d; b++) c.appendChild(a[b]);
+        return c
+    },
+    buildTrkSegNode: function(a) {
+        var b, c, d, e;
+        if ("OpenLayers.Geometry.LineString" == a.CLASS_NAME || "OpenLayers.Geometry.LinearRing" == a.CLASS_NAME) {
+            b = this.createElementNSPlus("gpx:trkseg");
+            c = 0;
+            for (d = a.components.length; c < d; c++) e = a.components[c], b.appendChild(this.buildTrkPtNode(e));
+            return b
+        }
+        b = [];
+        c = 0;
+        for (d = a.components.length; c < d; c++) b.push(this.buildTrkSegNode(a.components[c]));
+        return b
+    },
+    buildTrkPtNode: function(a) {
+        var b = this.createElementNSPlus("gpx:trkpt");
+        b.setAttribute("lon", a.x);
+        b.setAttribute("lat", a.y);
+        return b
+    },
+    buildWptNode: function(a) {
+        var b = this.createElementNSPlus("gpx:wpt");
+        b.setAttribute("lon", a.x);
+        b.setAttribute("lat", a.y);
+        return b
+    },
+    appendAttributesNode: function(a, b) {
+        var c = this.createElementNSPlus("gpx:name");
+        c.appendChild(this.createTextNode(b.attributes.name ||
+            b.id));
+        a.appendChild(c);
+        c = this.createElementNSPlus("gpx:desc");
+        c.appendChild(this.createTextNode(b.attributes.description || this.defaultDesc));
+        a.appendChild(c)
+    },
+    CLASS_NAME: "OpenLayers.Format.GPX"
+});
+OpenLayers.Format.WMSDescribeLayer = OpenLayers.Class(OpenLayers.Format.XML.VersionedOGC, {
+    defaultVersion: "1.1.1",
+    getVersion: function(a, b) {
+        var c = OpenLayers.Format.XML.VersionedOGC.prototype.getVersion.apply(this, arguments);
+        if ("1.1.1" == c || "1.1.0" == c) c = "1.1";
+        return c
+    },
+    CLASS_NAME: "OpenLayers.Format.WMSDescribeLayer"
+});
+OpenLayers.Format.WMSDescribeLayer.v1_1 = OpenLayers.Class(OpenLayers.Format.WMSDescribeLayer, {
+    initialize: function(a) {
+        OpenLayers.Format.WMSDescribeLayer.prototype.initialize.apply(this, [a])
+    },
+    read: function(a) {
+        "string" == typeof a && (a = OpenLayers.Format.XML.prototype.read.apply(this, [a]));
+        for (var a = a.documentElement.childNodes, b = [], c, d, e = 0; e < a.length; ++e)
+            if (c = a[e], d = c.nodeName, "LayerDescription" == d) {
+                d = c.getAttribute("name");
+                var f = "",
+                    g = "",
+                    h = "";
+                c.getAttribute("owsType") ? (f = c.getAttribute("owsType"), g = c.getAttribute("owsURL")) :
+                    "" != c.getAttribute("wfs") ? (f = "WFS", g = c.getAttribute("wfs")) : "" != c.getAttribute("wcs") && (f = "WCS", g = c.getAttribute("wcs"));
+                c = c.getElementsByTagName("Query");
+                0 < c.length && ((h = c[0].getAttribute("typeName")) || (h = c[0].getAttribute("typename")));
+                b.push({
+                    layerName: d,
+                    owsType: f,
+                    owsURL: g,
+                    typeName: h
+                })
+            }
+        return b
+    },
+    CLASS_NAME: "OpenLayers.Format.WMSDescribeLayer.v1_1"
+});
+OpenLayers.Layer.XYZ = OpenLayers.Class(OpenLayers.Layer.Grid, {
+    isBaseLayer: !0,
+    sphericalMercator: !1,
+    zoomOffset: 0,
+    serverResolutions: null,
+    initialize: function(a, b, c) {
+        if (c && c.sphericalMercator || this.sphericalMercator) c = OpenLayers.Util.extend({
+            projection: "EPSG:900913",
+            numZoomLevels: 19
+        }, c);
+        OpenLayers.Layer.Grid.prototype.initialize.apply(this, [a || this.name, b || this.url, {}, c])
+    },
+    clone: function(a) {
+        null == a && (a = new OpenLayers.Layer.XYZ(this.name, this.url, this.getOptions()));
+        return a = OpenLayers.Layer.Grid.prototype.clone.apply(this, [a])
+    },
+    getURL: function(a) {
+        var a = this.getXYZ(a),
+            b = this.url;
+        OpenLayers.Util.isArray(b) && (b = this.selectUrl("" + a.x + a.y + a.z, b));
+        return OpenLayers.String.format(b, a)
+    },
+    getXYZ: function(a) {
+        var b = this.getServerResolution(),
+            c = Math.round((a.left - this.maxExtent.left) / (b * this.tileSize.w)),
+            a = Math.round((this.maxExtent.top - a.top) / (b * this.tileSize.h)),
+            b = this.getServerZoom();
+        if (this.wrapDateLine) var d = Math.pow(2, b),
+            c = (c % d + d) % d;
+        return {
+            x: c,
+            y: a,
+            z: b
+        }
+    },
+    setMap: function(a) {
+        OpenLayers.Layer.Grid.prototype.setMap.apply(this,
+            arguments);
+        this.tileOrigin || (this.tileOrigin = new OpenLayers.LonLat(this.maxExtent.left, this.maxExtent.bottom))
+    },
+    CLASS_NAME: "OpenLayers.Layer.XYZ"
+});
+OpenLayers.Layer.OSM = OpenLayers.Class(OpenLayers.Layer.XYZ, {
+    name: "OpenStreetMap",
+    url: ["http://a.tile.openstreetmap.org/${z}/${x}/${y}.png", "http://b.tile.openstreetmap.org/${z}/${x}/${y}.png", "http://c.tile.openstreetmap.org/${z}/${x}/${y}.png"],
+    attribution: "Data CC-By-SA by <a href='http://openstreetmap.org/'>OpenStreetMap</a>",
+    sphericalMercator: !0,
+    wrapDateLine: !0,
+    tileOptions: null,
+    initialize: function(a, b, c) {
+        OpenLayers.Layer.XYZ.prototype.initialize.apply(this, arguments);
+        this.tileOptions = OpenLayers.Util.extend({
+                crossOriginKeyword: "anonymous"
+            },
+            this.options && this.options.tileOptions)
+    },
+    clone: function(a) {
+        null == a && (a = new OpenLayers.Layer.OSM(this.name, this.url, this.getOptions()));
+        return a = OpenLayers.Layer.XYZ.prototype.clone.apply(this, [a])
+    },
+    CLASS_NAME: "OpenLayers.Layer.OSM"
+});
+OpenLayers.Renderer = OpenLayers.Class({
+    container: null,
+    root: null,
+    extent: null,
+    locked: !1,
+    size: null,
+    resolution: null,
+    map: null,
+    featureDx: 0,
+    initialize: function(a, b) {
+        this.container = OpenLayers.Util.getElement(a);
+        OpenLayers.Util.extend(this, b)
+    },
+    destroy: function() {
+        this.map = this.resolution = this.size = this.extent = this.container = null
+    },
+    supported: function() {
+        return !1
+    },
+    setExtent: function(a, b) {
+        this.extent = a.clone();
+        if (this.map.baseLayer && this.map.baseLayer.wrapDateLine) {
+            var c = a.getWidth() / this.map.getExtent().getWidth(),
+                a = a.scale(1 / c);
+            this.extent = a.wrapDateLine(this.map.getMaxExtent()).scale(c)
+        }
+        b && (this.resolution = null);
+        return !0
+    },
+    setSize: function(a) {
+        this.size = a.clone();
+        this.resolution = null
+    },
+    getResolution: function() {
+        return this.resolution = this.resolution || this.map.getResolution()
+    },
+    drawFeature: function(a, b) {
+        null == b && (b = a.style);
+        if (a.geometry) {
+            var c = a.geometry.getBounds();
+            if (c) {
+                var d;
+                this.map.baseLayer && this.map.baseLayer.wrapDateLine && (d = this.map.getMaxExtent());
+                c.intersectsBounds(this.extent, {
+                    worldBounds: d
+                }) ? this.calculateFeatureDx(c,
+                    d) : b = {
+                    display: "none"
+                };
+                c = this.drawGeometry(a.geometry, b, a.id);
+                if ("none" != b.display && b.label && !1 !== c) {
+                    d = a.geometry.getCentroid();
+                    if (b.labelXOffset || b.labelYOffset) {
+                        var e = isNaN(b.labelXOffset) ? 0 : b.labelXOffset,
+                            f = isNaN(b.labelYOffset) ? 0 : b.labelYOffset,
+                            g = this.getResolution();
+                        d.move(e * g, f * g)
+                    }
+                    this.drawText(a.id, b, d)
+                } else this.removeText(a.id);
+                return c
+            }
+        }
+    },
+    calculateFeatureDx: function(a, b) {
+        this.featureDx = 0;
+        if (b) {
+            var c = b.getWidth();
+            this.featureDx = Math.round(((a.left + a.right) / 2 - (this.extent.left + this.extent.right) /
+                2) / c) * c
+        }
+    },
+    drawGeometry: function() {},
+    drawText: function() {},
+    removeText: function() {},
+    clear: function() {},
+    getFeatureIdFromEvent: function() {},
+    eraseFeatures: function(a) {
+        OpenLayers.Util.isArray(a) || (a = [a]);
+        for (var b = 0, c = a.length; b < c; ++b) {
+            var d = a[b];
+            this.eraseGeometry(d.geometry, d.id);
+            this.removeText(d.id)
+        }
+    },
+    eraseGeometry: function() {},
+    moveRoot: function() {},
+    getRenderLayerId: function() {
+        return this.container.id
+    },
+    applyDefaultSymbolizer: function(a) {
+        var b = OpenLayers.Util.extend({}, OpenLayers.Renderer.defaultSymbolizer);
+        !1 === a.stroke && (delete b.strokeWidth, delete b.strokeColor);
+        !1 === a.fill && delete b.fillColor;
+        OpenLayers.Util.extend(b, a);
+        return b
+    },
+    CLASS_NAME: "OpenLayers.Renderer"
+});
+OpenLayers.Renderer.defaultSymbolizer = {
+    fillColor: "#000000",
+    strokeColor: "#000000",
+    strokeWidth: 2,
+    fillOpacity: 1,
+    strokeOpacity: 1,
+    pointRadius: 0,
+    labelAlign: "cm"
+};
+OpenLayers.Renderer.symbol = {
+    star: [350, 75, 379, 161, 469, 161, 397, 215, 423, 301, 350, 250, 277, 301, 303, 215, 231, 161, 321, 161, 350, 75],
+    cross: [4, 0, 6, 0, 6, 4, 10, 4, 10, 6, 6, 6, 6, 10, 4, 10, 4, 6, 0, 6, 0, 4, 4, 4, 4, 0],
+    x: [0, 0, 25, 0, 50, 35, 75, 0, 100, 0, 65, 50, 100, 100, 75, 100, 50, 65, 25, 100, 0, 100, 35, 50, 0, 0],
+    square: [0, 0, 0, 1, 1, 1, 1, 0, 0, 0],
+    triangle: [0, 10, 10, 10, 5, 0, 0, 10]
+};
+OpenLayers.Renderer.Canvas = OpenLayers.Class(OpenLayers.Renderer, {
+    hitDetection: !0,
+    hitOverflow: 0,
+    canvas: null,
+    features: null,
+    pendingRedraw: !1,
+    cachedSymbolBounds: {},
+    initialize: function(a, b) {
+        OpenLayers.Renderer.prototype.initialize.apply(this, arguments);
+        this.root = document.createElement("canvas");
+        this.container.appendChild(this.root);
+        this.canvas = this.root.getContext("2d");
+        this.features = {};
+        this.hitDetection && (this.hitCanvas = document.createElement("canvas"), this.hitContext = this.hitCanvas.getContext("2d"))
+    },
+    setExtent: function() {
+        OpenLayers.Renderer.prototype.setExtent.apply(this, arguments);
+        return !1
+    },
+    eraseGeometry: function(a, b) {
+        this.eraseFeatures(this.features[b][0])
+    },
+    supported: function() {
+        return OpenLayers.CANVAS_SUPPORTED
+    },
+    setSize: function(a) {
+        this.size = a.clone();
+        var b = this.root;
+        b.style.width = a.w + "px";
+        b.style.height = a.h + "px";
+        b.width = a.w;
+        b.height = a.h;
+        this.resolution = null;
+        this.hitDetection && (b = this.hitCanvas, b.style.width = a.w + "px", b.style.height = a.h + "px", b.width = a.w, b.height = a.h)
+    },
+    drawFeature: function(a,
+        b) {
+        var c;
+        if (a.geometry) {
+            b = this.applyDefaultSymbolizer(b || a.style);
+            c = a.geometry.getBounds();
+            var d;
+            this.map.baseLayer && this.map.baseLayer.wrapDateLine && (d = this.map.getMaxExtent());
+            d = c && c.intersectsBounds(this.extent, {
+                worldBounds: d
+            });
+            (c = "none" !== b.display && !!c && d) ? this.features[a.id] = [a, b]: delete this.features[a.id];
+            this.pendingRedraw = !0
+        }
+        this.pendingRedraw && !this.locked && (this.redraw(), this.pendingRedraw = !1);
+        return c
+    },
+    drawGeometry: function(a, b, c) {
+        var d = a.CLASS_NAME;
+        if ("OpenLayers.Geometry.Collection" ==
+            d || "OpenLayers.Geometry.MultiPoint" == d || "OpenLayers.Geometry.MultiLineString" == d || "OpenLayers.Geometry.MultiPolygon" == d)
+            for (d = 0; d < a.components.length; d++) this.drawGeometry(a.components[d], b, c);
+        else switch (a.CLASS_NAME) {
+            case "OpenLayers.Geometry.Point":
+                this.drawPoint(a, b, c);
+                break;
+            case "OpenLayers.Geometry.LineString":
+                this.drawLineString(a, b, c);
+                break;
+            case "OpenLayers.Geometry.LinearRing":
+                this.drawLinearRing(a, b, c);
+                break;
+            case "OpenLayers.Geometry.Polygon":
+                this.drawPolygon(a, b, c)
+        }
+    },
+    drawExternalGraphic: function(a,
+        b, c) {
+        var d = new Image;
+        b.graphicTitle && (d.title = b.graphicTitle);
+        var e = b.graphicWidth || b.graphicHeight,
+            f = b.graphicHeight || b.graphicWidth,
+            e = e ? e : 2 * b.pointRadius,
+            f = f ? f : 2 * b.pointRadius,
+            g = void 0 != b.graphicXOffset ? b.graphicXOffset : -(0.5 * e),
+            h = void 0 != b.graphicYOffset ? b.graphicYOffset : -(0.5 * f),
+            i = b.graphicOpacity || b.fillOpacity;
+        d.onload = OpenLayers.Function.bind(function() {
+            if (this.features[c]) {
+                var b = this.getLocalXY(a),
+                    k = b[0],
+                    b = b[1];
+                if (!isNaN(k) && !isNaN(b)) {
+                    var k = k + g | 0,
+                        b = b + h | 0,
+                        l = this.canvas;
+                    l.globalAlpha = i;
+                    var m =
+                        OpenLayers.Renderer.Canvas.drawImageScaleFactor || (OpenLayers.Renderer.Canvas.drawImageScaleFactor = /android 2.1/.test(navigator.userAgent.toLowerCase()) ? 320 / window.screen.width : 1);
+                    l.drawImage(d, k * m, b * m, e * m, f * m);
+                    if (this.hitDetection) {
+                        this.setHitContextStyle("fill", c);
+                        this.hitContext.fillRect(k, b, e, f)
+                    }
+                }
+            }
+        }, this);
+        d.src = b.externalGraphic
+    },
+    drawNamedSymbol: function(a, b, c) {
+        var d, e, f, g;
+        f = Math.PI / 180;
+        var h = OpenLayers.Renderer.symbol[b.graphicName];
+        if (!h) throw Error(b.graphicName + " is not a valid symbol name");
+        if (h.length && !(2 > h.length) && (a = this.getLocalXY(a), e = a[0], g = a[1], !isNaN(e) && !isNaN(g))) {
+            this.canvas.lineCap = "round";
+            this.canvas.lineJoin = "round";
+            this.hitDetection && (this.hitContext.lineCap = "round", this.hitContext.lineJoin = "round");
+            if (b.graphicName in this.cachedSymbolBounds) d = this.cachedSymbolBounds[b.graphicName];
+            else {
+                d = new OpenLayers.Bounds;
+                for (a = 0; a < h.length; a += 2) d.extend(new OpenLayers.LonLat(h[a], h[a + 1]));
+                this.cachedSymbolBounds[b.graphicName] = d
+            }
+            this.canvas.save();
+            this.hitDetection && this.hitContext.save();
+            this.canvas.translate(e, g);
+            this.hitDetection && this.hitContext.translate(e, g);
+            a = f * b.rotation;
+            isNaN(a) || (this.canvas.rotate(a), this.hitDetection && this.hitContext.rotate(a));
+            f = 2 * b.pointRadius / Math.max(d.getWidth(), d.getHeight());
+            this.canvas.scale(f, f);
+            this.hitDetection && this.hitContext.scale(f, f);
+            a = d.getCenterLonLat().lon;
+            d = d.getCenterLonLat().lat;
+            this.canvas.translate(-a, -d);
+            this.hitDetection && this.hitContext.translate(-a, -d);
+            g = b.strokeWidth;
+            b.strokeWidth = g / f;
+            if (!1 !== b.fill) {
+                this.setCanvasStyle("fill",
+                    b);
+                this.canvas.beginPath();
+                for (a = 0; a < h.length; a += 2) d = h[a], e = h[a + 1], 0 == a && this.canvas.moveTo(d, e), this.canvas.lineTo(d, e);
+                this.canvas.closePath();
+                this.canvas.fill();
+                if (this.hitDetection) {
+                    this.setHitContextStyle("fill", c, b);
+                    this.hitContext.beginPath();
+                    for (a = 0; a < h.length; a += 2) d = h[a], e = h[a + 1], 0 == a && this.canvas.moveTo(d, e), this.hitContext.lineTo(d, e);
+                    this.hitContext.closePath();
+                    this.hitContext.fill()
+                }
+            }
+            if (!1 !== b.stroke) {
+                this.setCanvasStyle("stroke", b);
+                this.canvas.beginPath();
+                for (a = 0; a < h.length; a += 2) d = h[a],
+                    e = h[a + 1], 0 == a && this.canvas.moveTo(d, e), this.canvas.lineTo(d, e);
+                this.canvas.closePath();
+                this.canvas.stroke();
+                if (this.hitDetection) {
+                    this.setHitContextStyle("stroke", c, b, f);
+                    this.hitContext.beginPath();
+                    for (a = 0; a < h.length; a += 2) d = h[a], e = h[a + 1], 0 == a && this.hitContext.moveTo(d, e), this.hitContext.lineTo(d, e);
+                    this.hitContext.closePath();
+                    this.hitContext.stroke()
+                }
+            }
+            b.strokeWidth = g;
+            this.canvas.restore();
+            this.hitDetection && this.hitContext.restore();
+            this.setCanvasStyle("reset")
+        }
+    },
+    setCanvasStyle: function(a, b) {
+        "fill" ===
+        a ? (this.canvas.globalAlpha = b.fillOpacity, this.canvas.fillStyle = b.fillColor) : "stroke" === a ? (this.canvas.globalAlpha = b.strokeOpacity, this.canvas.strokeStyle = b.strokeColor, this.canvas.lineWidth = b.strokeWidth) : (this.canvas.globalAlpha = 0, this.canvas.lineWidth = 1)
+    },
+    featureIdToHex: function(a) {
+        a = Number(a.split("_").pop()) + 1;
+        16777216 <= a && (this.hitOverflow = a - 16777215, a = a % 16777216 + 1);
+        var a = "000000" + a.toString(16),
+            b = a.length;
+        return a = "#" + a.substring(b - 6, b)
+    },
+    setHitContextStyle: function(a, b, c, d) {
+        b = this.featureIdToHex(b);
+        "fill" == a ? (this.hitContext.globalAlpha = 1, this.hitContext.fillStyle = b) : "stroke" == a ? (this.hitContext.globalAlpha = 1, this.hitContext.strokeStyle = b, "undefined" === typeof d ? this.hitContext.lineWidth = c.strokeWidth + 2 : isNaN(d) || (this.hitContext.lineWidth = c.strokeWidth + 2 / d)) : (this.hitContext.globalAlpha = 0, this.hitContext.lineWidth = 1)
+    },
+    drawPoint: function(a, b, c) {
+        if (!1 !== b.graphic)
+            if (b.externalGraphic) this.drawExternalGraphic(a, b, c);
+            else if (b.graphicName && "circle" != b.graphicName) this.drawNamedSymbol(a, b, c);
+        else {
+            var d =
+                this.getLocalXY(a),
+                a = d[0],
+                d = d[1];
+            if (!isNaN(a) && !isNaN(d)) {
+                var e = 2 * Math.PI,
+                    f = b.pointRadius;
+                !1 !== b.fill && (this.setCanvasStyle("fill", b), this.canvas.beginPath(), this.canvas.arc(a, d, f, 0, e, !0), this.canvas.fill(), this.hitDetection && (this.setHitContextStyle("fill", c, b), this.hitContext.beginPath(), this.hitContext.arc(a, d, f, 0, e, !0), this.hitContext.fill()));
+                !1 !== b.stroke && (this.setCanvasStyle("stroke", b), this.canvas.beginPath(), this.canvas.arc(a, d, f, 0, e, !0), this.canvas.stroke(), this.hitDetection && (this.setHitContextStyle("stroke",
+                    c, b), this.hitContext.beginPath(), this.hitContext.arc(a, d, f, 0, e, !0), this.hitContext.stroke()), this.setCanvasStyle("reset"))
+            }
+        }
+    },
+    drawLineString: function(a, b, c) {
+        b = OpenLayers.Util.applyDefaults({
+            fill: !1
+        }, b);
+        this.drawLinearRing(a, b, c)
+    },
+    drawLinearRing: function(a, b, c) {
+        !1 !== b.fill && (this.setCanvasStyle("fill", b), this.renderPath(this.canvas, a, b, c, "fill"), this.hitDetection && (this.setHitContextStyle("fill", c, b), this.renderPath(this.hitContext, a, b, c, "fill")));
+        !1 !== b.stroke && (this.setCanvasStyle("stroke", b), this.renderPath(this.canvas,
+            a, b, c, "stroke"), this.hitDetection && (this.setHitContextStyle("stroke", c, b), this.renderPath(this.hitContext, a, b, c, "stroke")));
+        this.setCanvasStyle("reset")
+    },
+    renderPath: function(a, b, c, d, e) {
+        b = b.components;
+        c = b.length;
+        a.beginPath();
+        var d = this.getLocalXY(b[0]),
+            f = d[1];
+        if (!isNaN(d[0]) && !isNaN(f)) {
+            a.moveTo(d[0], d[1]);
+            for (d = 1; d < c; ++d) f = this.getLocalXY(b[d]), a.lineTo(f[0], f[1]);
+            "fill" === e ? a.fill() : a.stroke()
+        }
+    },
+    drawPolygon: function(a, b, c) {
+        var a = a.components,
+            d = a.length;
+        this.drawLinearRing(a[0], b, c);
+        for (var e = 1; e <
+            d; ++e) this.canvas.globalCompositeOperation = "destination-out", this.hitDetection && (this.hitContext.globalCompositeOperation = "destination-out"), this.drawLinearRing(a[e], OpenLayers.Util.applyDefaults({
+            stroke: !1,
+            fillOpacity: 1
+        }, b), c), this.canvas.globalCompositeOperation = "source-over", this.hitDetection && (this.hitContext.globalCompositeOperation = "source-over"), this.drawLinearRing(a[e], OpenLayers.Util.applyDefaults({
+            fill: !1
+        }, b), c)
+    },
+    drawText: function(a, b) {
+        var c = this.getLocalXY(a);
+        this.setCanvasStyle("reset");
+        this.canvas.fillStyle = b.fontColor;
+        this.canvas.globalAlpha = b.fontOpacity || 1;
+        var d = [b.fontStyle ? b.fontStyle : "normal", "normal", b.fontWeight ? b.fontWeight : "normal", b.fontSize ? b.fontSize : "1em", b.fontFamily ? b.fontFamily : "sans-serif"].join(" "),
+            e = b.label.split("\n"),
+            f = e.length;
+        if (this.canvas.fillText) {
+            this.canvas.font = d;
+            this.canvas.textAlign = OpenLayers.Renderer.Canvas.LABEL_ALIGN[b.labelAlign[0]] || "center";
+            this.canvas.textBaseline = OpenLayers.Renderer.Canvas.LABEL_ALIGN[b.labelAlign[1]] || "middle";
+            var g = OpenLayers.Renderer.Canvas.LABEL_FACTOR[b.labelAlign[1]];
+            null == g && (g = -0.5);
+            d = this.canvas.measureText("Mg").height || this.canvas.measureText("xx").width;
+            c[1] += d * g * (f - 1);
+            for (g = 0; g < f; g++) b.labelOutlineWidth && (this.canvas.save(), this.canvas.strokeStyle = b.labelOutlineColor, this.canvas.lineWidth = b.labelOutlineWidth, this.canvas.strokeText(e[g], c[0], c[1] + d * g + 1), this.canvas.restore()), this.canvas.fillText(e[g], c[0], c[1] + d * g)
+        } else if (this.canvas.mozDrawText) {
+            this.canvas.mozTextStyle = d;
+            var h = OpenLayers.Renderer.Canvas.LABEL_FACTOR[b.labelAlign[0]];
+            null == h && (h = -0.5);
+            g = OpenLayers.Renderer.Canvas.LABEL_FACTOR[b.labelAlign[1]];
+            null == g && (g = -0.5);
+            d = this.canvas.mozMeasureText("xx");
+            c[1] += d * (1 + g * f);
+            for (g = 0; g < f; g++) {
+                var i = c[0] + h * this.canvas.mozMeasureText(e[g]),
+                    j = c[1] + g * d;
+                this.canvas.translate(i, j);
+                this.canvas.mozDrawText(e[g]);
+                this.canvas.translate(-i, -j)
+            }
+        }
+        this.setCanvasStyle("reset")
+    },
+    getLocalXY: function(a) {
+        var b = this.getResolution(),
+            c = this.extent;
+        return [(a.x - this.featureDx) / b + -c.left / b, c.top / b - a.y / b]
+    },
+    clear: function() {
+        var a = this.root.height,
+            b = this.root.width;
+        this.canvas.clearRect(0,
+            0, b, a);
+        this.features = {};
+        this.hitDetection && this.hitContext.clearRect(0, 0, b, a)
+    },
+    getFeatureIdFromEvent: function(a) {
+        var b;
+        if (this.hitDetection && "none" !== this.root.style.display && !this.map.dragging && (a = a.xy, a = this.hitContext.getImageData(a.x | 0, a.y | 0, 1, 1).data, 255 === a[3] && (a = a[2] + 256 * (a[1] + 256 * a[0])))) {
+            a = "OpenLayers.Feature.Vector_" + (a - 1 + this.hitOverflow);
+            try {
+                b = this.features[a][0]
+            } catch (c) {}
+        }
+        return b
+    },
+    eraseFeatures: function(a) {
+        OpenLayers.Util.isArray(a) || (a = [a]);
+        for (var b = 0; b < a.length; ++b) delete this.features[a[b].id];
+        this.redraw()
+    },
+    redraw: function() {
+        if (!this.locked) {
+            var a = this.root.height,
+                b = this.root.width;
+            this.canvas.clearRect(0, 0, b, a);
+            this.hitDetection && this.hitContext.clearRect(0, 0, b, a);
+            var a = [],
+                c, d, e = this.map.baseLayer && this.map.baseLayer.wrapDateLine && this.map.getMaxExtent(),
+                f;
+            for (f in this.features) this.features.hasOwnProperty(f) && (b = this.features[f][0], c = b.geometry, this.calculateFeatureDx(c.getBounds(), e), d = this.features[f][1], this.drawGeometry(c, d, b.id), d.label && a.push([b, d]));
+            b = 0;
+            for (c = a.length; b < c; ++b) f =
+                a[b], this.drawText(f[0].geometry.getCentroid(), f[1])
+        }
+    },
+    CLASS_NAME: "OpenLayers.Renderer.Canvas"
+});
+OpenLayers.Renderer.Canvas.LABEL_ALIGN = {
+    l: "left",
+    r: "right",
+    t: "top",
+    b: "bottom"
+};
+OpenLayers.Renderer.Canvas.LABEL_FACTOR = {
+    l: 0,
+    r: -1,
+    t: 0,
+    b: -1
+};
+OpenLayers.Renderer.Canvas.drawImageScaleFactor = null;
+OpenLayers.Format.OSM = OpenLayers.Class(OpenLayers.Format.XML, {
+    checkTags: !1,
+    interestingTagsExclude: null,
+    areaTags: null,
+    initialize: function(a) {
+        for (var b = {
+                interestingTagsExclude: "source source_ref source:ref history attribution created_by".split(" "),
+                areaTags: "area building leisure tourism ruins historic landuse military natural sport".split(" ")
+            }, b = OpenLayers.Util.extend(b, a), c = {}, a = 0; a < b.interestingTagsExclude.length; a++) c[b.interestingTagsExclude[a]] = !0;
+        b.interestingTagsExclude = c;
+        c = {};
+        for (a = 0; a < b.areaTags.length; a++) c[b.areaTags[a]] = !0;
+        b.areaTags = c;
+        this.externalProjection = new OpenLayers.Projection("EPSG:4326");
+        OpenLayers.Format.XML.prototype.initialize.apply(this, [b])
+    },
+    read: function(a) {
+        "string" == typeof a && (a = OpenLayers.Format.XML.prototype.read.apply(this, [a]));
+        for (var b = this.getNodes(a), c = this.getWays(a), a = Array(c.length), d = 0; d < c.length; d++) {
+            for (var e = Array(c[d].nodes.length), f = this.isWayArea(c[d]) ? 1 : 0, g = 0; g < c[d].nodes.length; g++) {
+                var h = b[c[d].nodes[g]],
+                    i = new OpenLayers.Geometry.Point(h.lon, h.lat);
+                i.osm_id = parseInt(c[d].nodes[g]);
+                e[g] = i;
+                h.used = !0
+            }
+            h = null;
+            h = f ? new OpenLayers.Geometry.Polygon(new OpenLayers.Geometry.LinearRing(e)) : new OpenLayers.Geometry.LineString(e);
+            this.internalProjection && this.externalProjection && h.transform(this.externalProjection, this.internalProjection);
+            e = new OpenLayers.Feature.Vector(h, c[d].tags);
+            e.osm_id = parseInt(c[d].id);
+            e.fid = "way." + e.osm_id;
+            a[d] = e
+        }
+        for (var j in b) {
+            h = b[j];
+            if (!h.used || this.checkTags) {
+                c = null;
+                if (this.checkTags) {
+                    c = this.getTags(h.node, !0);
+                    if (h.used && !c[1]) continue;
+                    c = c[0]
+                } else c = this.getTags(h.node);
+                e = new OpenLayers.Feature.Vector(new OpenLayers.Geometry.Point(h.lon, h.lat), c);
+                this.internalProjection && this.externalProjection && e.geometry.transform(this.externalProjection, this.internalProjection);
+                e.osm_id = parseInt(j);
+                e.fid = "node." + e.osm_id;
+                a.push(e)
+            }
+            h.node = null
+        }
+        return a
+    },
+    getNodes: function(a) {
+        for (var a = a.getElementsByTagName("node"), b = {}, c = 0; c < a.length; c++) {
+            var d = a[c],
+                e = d.getAttribute("id");
+            b[e] = {
+                lat: d.getAttribute("lat"),
+                lon: d.getAttribute("lon"),
+                node: d
+            }
+        }
+        return b
+    },
+    getWays: function(a) {
+        for (var a =
+                a.getElementsByTagName("way"), b = [], c = 0; c < a.length; c++) {
+            var d = a[c],
+                e = {
+                    id: d.getAttribute("id")
+                };
+            e.tags = this.getTags(d);
+            d = d.getElementsByTagName("nd");
+            e.nodes = Array(d.length);
+            for (var f = 0; f < d.length; f++) e.nodes[f] = d[f].getAttribute("ref");
+            b.push(e)
+        }
+        return b
+    },
+    getTags: function(a, b) {
+        for (var c = a.getElementsByTagName("tag"), d = {}, e = !1, f = 0; f < c.length; f++) {
+            var g = c[f].getAttribute("k");
+            d[g] = c[f].getAttribute("v");
+            b && (this.interestingTagsExclude[g] || (e = !0))
+        }
+        return b ? [d, e] : d
+    },
+    isWayArea: function(a) {
+        var b = !1,
+            c = !1;
+        a.nodes[0] == a.nodes[a.nodes.length - 1] && (b = !0);
+        if (this.checkTags)
+            for (var d in a.tags)
+                if (this.areaTags[d]) {
+                    c = !0;
+                    break
+                }
+        return b && (this.checkTags ? c : !0)
+    },
+    write: function(a) {
+        OpenLayers.Util.isArray(a) || (a = [a]);
+        this.osm_id = 1;
+        this.created_nodes = {};
+        var b = this.createElementNS(null, "osm");
+        b.setAttribute("version", "0.5");
+        b.setAttribute("generator", "OpenLayers " + OpenLayers.VERSION_NUMBER);
+        for (var c = a.length - 1; 0 <= c; c--)
+            for (var d = this.createFeatureNodes(a[c]), e = 0; e < d.length; e++) b.appendChild(d[e]);
+        return OpenLayers.Format.XML.prototype.write.apply(this, [b])
+    },
+    createFeatureNodes: function(a) {
+        var b = [],
+            c = a.geometry.CLASS_NAME,
+            c = c.substring(c.lastIndexOf(".") + 1),
+            c = c.toLowerCase();
+        (c = this.createXML[c]) && (b = c.apply(this, [a]));
+        return b
+    },
+    createXML: {
+        point: function(a) {
+            var b = null,
+                c = a.geometry ? a.geometry : a;
+            this.internalProjection && this.externalProjection && (c = c.clone(), c.transform(this.internalProjection, this.externalProjection));
+            var d = !1;
+            a.osm_id ? (b = a.osm_id, this.created_nodes[b] && (d = !0)) : (b = -this.osm_id, this.osm_id++);
+            var e = d ? this.created_nodes[b] : this.createElementNS(null,
+                "node");
+            this.created_nodes[b] = e;
+            e.setAttribute("id", b);
+            e.setAttribute("lon", c.x);
+            e.setAttribute("lat", c.y);
+            a.attributes && this.serializeTags(a, e);
+            this.setState(a, e);
+            return d ? [] : [e]
+        },
+        linestring: function(a) {
+            var b, c = [],
+                d = a.geometry;
+            a.osm_id ? b = a.osm_id : (b = -this.osm_id, this.osm_id++);
+            var e = this.createElementNS(null, "way");
+            e.setAttribute("id", b);
+            for (b = 0; b < d.components.length; b++) {
+                var f = this.createXML.point.apply(this, [d.components[b]]);
+                if (f.length) {
+                    var f = f[0],
+                        g = f.getAttribute("id");
+                    c.push(f)
+                } else g = d.components[b].osm_id,
+                    f = this.created_nodes[g];
+                this.setState(a, f);
+                f = this.createElementNS(null, "nd");
+                f.setAttribute("ref", g);
+                e.appendChild(f)
+            }
+            this.serializeTags(a, e);
+            c.push(e);
+            return c
+        },
+        polygon: function(a) {
+            var b = OpenLayers.Util.extend({
+                    area: "yes"
+                }, a.attributes),
+                b = new OpenLayers.Feature.Vector(a.geometry.components[0], b);
+            b.osm_id = a.osm_id;
+            return this.createXML.linestring.apply(this, [b])
+        }
+    },
+    serializeTags: function(a, b) {
+        for (var c in a.attributes) {
+            var d = this.createElementNS(null, "tag");
+            d.setAttribute("k", c);
+            d.setAttribute("v",
+                a.attributes[c]);
+            b.appendChild(d)
+        }
+    },
+    setState: function(a, b) {
+        if (a.state) {
+            var c = null;
+            switch (a.state) {
+                case OpenLayers.State.UPDATE:
+                case OpenLayers.State.DELETE:
+                    c = "delete"
+            }
+            c && b.setAttribute("action", c)
+        }
+    },
+    CLASS_NAME: "OpenLayers.Format.OSM"
+});
+OpenLayers.Handler = OpenLayers.Class({
+    id: null,
+    control: null,
+    map: null,
+    keyMask: null,
+    active: !1,
+    evt: null,
+    initialize: function(a, b, c) {
+        OpenLayers.Util.extend(this, c);
+        this.control = a;
+        this.callbacks = b;
+        (a = this.map || a.map) && this.setMap(a);
+        this.id = OpenLayers.Util.createUniqueID(this.CLASS_NAME + "_")
+    },
+    setMap: function(a) {
+        this.map = a
+    },
+    checkModifiers: function(a) {
+        return null == this.keyMask ? !0 : ((a.shiftKey ? OpenLayers.Handler.MOD_SHIFT : 0) | (a.ctrlKey ? OpenLayers.Handler.MOD_CTRL : 0) | (a.altKey ? OpenLayers.Handler.MOD_ALT : 0)) ==
+            this.keyMask
+    },
+    activate: function() {
+        if (this.active) return !1;
+        for (var a = OpenLayers.Events.prototype.BROWSER_EVENTS, b = 0, c = a.length; b < c; b++) this[a[b]] && this.register(a[b], this[a[b]]);
+        return this.active = !0
+    },
+    deactivate: function() {
+        if (!this.active) return !1;
+        for (var a = OpenLayers.Events.prototype.BROWSER_EVENTS, b = 0, c = a.length; b < c; b++) this[a[b]] && this.unregister(a[b], this[a[b]]);
+        this.active = !1;
+        return !0
+    },
+    callback: function(a, b) {
+        a && this.callbacks[a] && this.callbacks[a].apply(this.control, b)
+    },
+    register: function(a, b) {
+        this.map.events.registerPriority(a,
+            this, b);
+        this.map.events.registerPriority(a, this, this.setEvent)
+    },
+    unregister: function(a, b) {
+        this.map.events.unregister(a, this, b);
+        this.map.events.unregister(a, this, this.setEvent)
+    },
+    setEvent: function(a) {
+        this.evt = a;
+        return !0
+    },
+    destroy: function() {
+        this.deactivate();
+        this.control = this.map = null
+    },
+    CLASS_NAME: "OpenLayers.Handler"
+});
+OpenLayers.Handler.MOD_NONE = 0;
+OpenLayers.Handler.MOD_SHIFT = 1;
+OpenLayers.Handler.MOD_CTRL = 2;
+OpenLayers.Handler.MOD_ALT = 4;
+OpenLayers.Handler.Drag = OpenLayers.Class(OpenLayers.Handler, {
+    started: !1,
+    stopDown: !0,
+    dragging: !1,
+    touch: !1,
+    last: null,
+    start: null,
+    lastMoveEvt: null,
+    oldOnselectstart: null,
+    interval: 0,
+    timeoutId: null,
+    documentDrag: !1,
+    documentEvents: null,
+    initialize: function(a, b, c) {
+        OpenLayers.Handler.prototype.initialize.apply(this, arguments);
+        if (!0 === this.documentDrag) {
+            var d = this;
+            this._docMove = function(a) {
+                d.mousemove({
+                    xy: {
+                        x: a.clientX,
+                        y: a.clientY
+                    },
+                    element: document
+                })
+            };
+            this._docUp = function(a) {
+                d.mouseup({
+                    xy: {
+                        x: a.clientX,
+                        y: a.clientY
+                    }
+                })
+            }
+        }
+    },
+    dragstart: function(a) {
+        var b = !0;
+        this.dragging = !1;
+        this.checkModifiers(a) && (OpenLayers.Event.isLeftClick(a) || OpenLayers.Event.isSingleTouch(a)) ? (this.started = !0, this.last = this.start = a.xy, OpenLayers.Element.addClass(this.map.viewPortDiv, "olDragDown"), this.down(a), this.callback("down", [a.xy]), OpenLayers.Event.stop(a), this.oldOnselectstart || (this.oldOnselectstart = document.onselectstart ? document.onselectstart : OpenLayers.Function.True), document.onselectstart = OpenLayers.Function.False, b = !this.stopDown) : (this.started = !1, this.last = this.start = null);
+        return b
+    },
+    dragmove: function(a) {
+        this.lastMoveEvt = a;
+        if (this.started && !this.timeoutId && (a.xy.x != this.last.x || a.xy.y != this.last.y)) !0 === this.documentDrag && this.documentEvents && (a.element === document ? (this.adjustXY(a), this.setEvent(a)) : this.removeDocumentEvents()), 0 < this.interval && (this.timeoutId = setTimeout(OpenLayers.Function.bind(this.removeTimeout, this), this.interval)), this.dragging = !0, this.move(a), this.callback("move", [a.xy]), this.oldOnselectstart || (this.oldOnselectstart =
+            document.onselectstart, document.onselectstart = OpenLayers.Function.False), this.last = a.xy;
+        return !0
+    },
+    dragend: function(a) {
+        if (this.started) {
+            !0 === this.documentDrag && this.documentEvents && (this.adjustXY(a), this.removeDocumentEvents());
+            var b = this.start != this.last;
+            this.dragging = this.started = !1;
+            OpenLayers.Element.removeClass(this.map.viewPortDiv, "olDragDown");
+            this.up(a);
+            this.callback("up", [a.xy]);
+            b && this.callback("done", [a.xy]);
+            document.onselectstart = this.oldOnselectstart
+        }
+        return !0
+    },
+    down: function() {},
+    move: function() {},
+    up: function() {},
+    out: function() {},
+    mousedown: function(a) {
+        return this.dragstart(a)
+    },
+    touchstart: function(a) {
+        this.touch || (this.touch = !0, this.map.events.un({
+            mousedown: this.mousedown,
+            mouseup: this.mouseup,
+            mousemove: this.mousemove,
+            click: this.click,
+            scope: this
+        }));
+        return this.dragstart(a)
+    },
+    mousemove: function(a) {
+        return this.dragmove(a)
+    },
+    touchmove: function(a) {
+        return this.dragmove(a)
+    },
+    removeTimeout: function() {
+        this.timeoutId = null;
+        this.dragging && this.mousemove(this.lastMoveEvt)
+    },
+    mouseup: function(a) {
+        return this.dragend(a)
+    },
+    touchend: function(a) {
+        a.xy = this.last;
+        return this.dragend(a)
+    },
+    mouseout: function(a) {
+        if (this.started && OpenLayers.Util.mouseLeft(a, this.map.viewPortDiv))
+            if (!0 === this.documentDrag) this.addDocumentEvents();
+            else {
+                var b = this.start != this.last;
+                this.dragging = this.started = !1;
+                OpenLayers.Element.removeClass(this.map.viewPortDiv, "olDragDown");
+                this.out(a);
+                this.callback("out", []);
+                b && this.callback("done", [a.xy]);
+                document.onselectstart && (document.onselectstart = this.oldOnselectstart)
+            }
+        return !0
+    },
+    click: function() {
+        return this.start ==
+            this.last
+    },
+    activate: function() {
+        var a = !1;
+        OpenLayers.Handler.prototype.activate.apply(this, arguments) && (this.dragging = !1, a = !0);
+        return a
+    },
+    deactivate: function() {
+        var a = !1;
+        OpenLayers.Handler.prototype.deactivate.apply(this, arguments) && (this.dragging = this.started = this.touch = !1, this.last = this.start = null, a = !0, OpenLayers.Element.removeClass(this.map.viewPortDiv, "olDragDown"));
+        return a
+    },
+    adjustXY: function(a) {
+        var b = OpenLayers.Util.pagePosition(this.map.viewPortDiv);
+        a.xy.x -= b[0];
+        a.xy.y -= b[1]
+    },
+    addDocumentEvents: function() {
+        OpenLayers.Element.addClass(document.body,
+            "olDragDown");
+        this.documentEvents = !0;
+        OpenLayers.Event.observe(document, "mousemove", this._docMove);
+        OpenLayers.Event.observe(document, "mouseup", this._docUp)
+    },
+    removeDocumentEvents: function() {
+        OpenLayers.Element.removeClass(document.body, "olDragDown");
+        this.documentEvents = !1;
+        OpenLayers.Event.stopObserving(document, "mousemove", this._docMove);
+        OpenLayers.Event.stopObserving(document, "mouseup", this._docUp)
+    },
+    CLASS_NAME: "OpenLayers.Handler.Drag"
+});
+OpenLayers.Handler.Feature = OpenLayers.Class(OpenLayers.Handler, {
+    EVENTMAP: {
+        click: {
+            "in": "click",
+            out: "clickout"
+        },
+        mousemove: {
+            "in": "over",
+            out: "out"
+        },
+        dblclick: {
+            "in": "dblclick",
+            out: null
+        },
+        mousedown: {
+            "in": null,
+            out: null
+        },
+        mouseup: {
+            "in": null,
+            out: null
+        },
+        touchstart: {
+            "in": "click",
+            out: "clickout"
+        }
+    },
+    feature: null,
+    lastFeature: null,
+    down: null,
+    up: null,
+    touch: !1,
+    clickTolerance: 4,
+    geometryTypes: null,
+    stopClick: !0,
+    stopDown: !0,
+    stopUp: !1,
+    initialize: function(a, b, c, d) {
+        OpenLayers.Handler.prototype.initialize.apply(this, [a, c, d]);
+        this.layer =
+            b
+    },
+    touchstart: function(a) {
+        this.touch || (this.touch = !0, this.map.events.un({
+            mousedown: this.mousedown,
+            mouseup: this.mouseup,
+            mousemove: this.mousemove,
+            click: this.click,
+            dblclick: this.dblclick,
+            scope: this
+        }));
+        return OpenLayers.Event.isMultiTouch(a) ? !0 : this.mousedown(a)
+    },
+    touchmove: function(a) {
+        OpenLayers.Event.stop(a)
+    },
+    mousedown: function(a) {
+        if (OpenLayers.Event.isLeftClick(a) || OpenLayers.Event.isSingleTouch(a)) this.down = a.xy;
+        return this.handle(a) ? !this.stopDown : !0
+    },
+    mouseup: function(a) {
+        this.up = a.xy;
+        return this.handle(a) ?
+            !this.stopUp : !0
+    },
+    click: function(a) {
+        return this.handle(a) ? !this.stopClick : !0
+    },
+    mousemove: function(a) {
+        if (!this.callbacks.over && !this.callbacks.out) return !0;
+        this.handle(a);
+        return !0
+    },
+    dblclick: function(a) {
+        return !this.handle(a)
+    },
+    geometryTypeMatches: function(a) {
+        return null == this.geometryTypes || -1 < OpenLayers.Util.indexOf(this.geometryTypes, a.geometry.CLASS_NAME)
+    },
+    handle: function(a) {
+        this.feature && !this.feature.layer && (this.feature = null);
+        var b = a.type,
+            c = !1,
+            d = !!this.feature,
+            e = "click" == b || "dblclick" == b || "touchstart" ==
+            b;
+        if ((this.feature = this.layer.getFeatureFromEvent(a)) && !this.feature.layer) this.feature = null;
+        this.lastFeature && !this.lastFeature.layer && (this.lastFeature = null);
+        this.feature ? ("touchstart" === b && OpenLayers.Event.stop(a), a = this.feature != this.lastFeature, this.geometryTypeMatches(this.feature) ? (d && a ? (this.lastFeature && this.triggerCallback(b, "out", [this.lastFeature]), this.triggerCallback(b, "in", [this.feature])) : (!d || e) && this.triggerCallback(b, "in", [this.feature]), this.lastFeature = this.feature, c = !0) : (this.lastFeature &&
+            (d && a || e) && this.triggerCallback(b, "out", [this.lastFeature]), this.feature = null)) : this.lastFeature && (d || e) && this.triggerCallback(b, "out", [this.lastFeature]);
+        return c
+    },
+    triggerCallback: function(a, b, c) {
+        (b = this.EVENTMAP[a][b]) && ("click" == a && this.up && this.down ? Math.sqrt(Math.pow(this.up.x - this.down.x, 2) + Math.pow(this.up.y - this.down.y, 2)) <= this.clickTolerance && this.callback(b, c) : this.callback(b, c))
+    },
+    activate: function() {
+        var a = !1;
+        OpenLayers.Handler.prototype.activate.apply(this, arguments) && (this.moveLayerToTop(),
+            this.map.events.on({
+                removelayer: this.handleMapEvents,
+                changelayer: this.handleMapEvents,
+                scope: this
+            }), a = !0);
+        return a
+    },
+    deactivate: function() {
+        var a = !1;
+        OpenLayers.Handler.prototype.deactivate.apply(this, arguments) && (this.moveLayerBack(), this.up = this.down = this.lastFeature = this.feature = null, this.touch = !1, this.map.events.un({
+            removelayer: this.handleMapEvents,
+            changelayer: this.handleMapEvents,
+            scope: this
+        }), a = !0);
+        return a
+    },
+    handleMapEvents: function(a) {
+        ("removelayer" == a.type || "order" == a.property) && this.moveLayerToTop()
+    },
+    moveLayerToTop: function() {
+        this.layer.setZIndex(Math.max(this.map.Z_INDEX_BASE.Feature - 1, this.layer.getZIndex()) + 1)
+    },
+    moveLayerBack: function() {
+        var a = this.layer.getZIndex() - 1;
+        a >= this.map.Z_INDEX_BASE.Feature ? this.layer.setZIndex(a) : this.map.setLayerZIndex(this.layer, this.map.getLayerIndex(this.layer))
+    },
+    CLASS_NAME: "OpenLayers.Handler.Feature"
+});
+OpenLayers.Control.DragFeature = OpenLayers.Class(OpenLayers.Control, {
+    geometryTypes: null,
+    onStart: function() {},
+    onDrag: function() {},
+    onComplete: function() {},
+    onEnter: function() {},
+    onLeave: function() {},
+    documentDrag: !1,
+    layer: null,
+    feature: null,
+    dragCallbacks: {},
+    featureCallbacks: {},
+    lastPixel: null,
+    initialize: function(a, b) {
+        OpenLayers.Control.prototype.initialize.apply(this, [b]);
+        this.layer = a;
+        this.handlers = {
+            drag: new OpenLayers.Handler.Drag(this, OpenLayers.Util.extend({
+                down: this.downFeature,
+                move: this.moveFeature,
+                up: this.upFeature,
+                out: this.cancel,
+                done: this.doneDragging
+            }, this.dragCallbacks), {
+                documentDrag: this.documentDrag
+            }),
+            feature: new OpenLayers.Handler.Feature(this, this.layer, OpenLayers.Util.extend({
+                click: this.clickFeature,
+                clickout: this.clickoutFeature,
+                over: this.overFeature,
+                out: this.outFeature
+            }, this.featureCallbacks), {
+                geometryTypes: this.geometryTypes
+            })
+        }
+    },
+    clickFeature: function(a) {
+        this.handlers.feature.touch && (!this.over && this.overFeature(a)) && (this.handlers.drag.dragstart(this.handlers.feature.evt), this.handlers.drag.stopDown = !1)
+    },
+    clickoutFeature: function(a) {
+        this.handlers.feature.touch && this.over && (this.outFeature(a), this.handlers.drag.stopDown = !0)
+    },
+    destroy: function() {
+        this.layer = null;
+        OpenLayers.Control.prototype.destroy.apply(this, [])
+    },
+    activate: function() {
+        return this.handlers.feature.activate() && OpenLayers.Control.prototype.activate.apply(this, arguments)
+    },
+    deactivate: function() {
+        this.handlers.drag.deactivate();
+        this.handlers.feature.deactivate();
+        this.feature = null;
+        this.dragging = !1;
+        this.lastPixel = null;
+        OpenLayers.Element.removeClass(this.map.viewPortDiv,
+            this.displayClass + "Over");
+        return OpenLayers.Control.prototype.deactivate.apply(this, arguments)
+    },
+    overFeature: function(a) {
+        var b = !1;
+        this.handlers.drag.dragging ? this.over = this.feature.id == a.id ? !0 : !1 : (this.feature = a, this.handlers.drag.activate(), this.over = b = !0, OpenLayers.Element.addClass(this.map.viewPortDiv, this.displayClass + "Over"), this.onEnter(a));
+        return b
+    },
+    downFeature: function(a) {
+        this.lastPixel = a;
+        this.onStart(this.feature, a)
+    },
+    moveFeature: function(a) {
+        var b = this.map.getResolution();
+        this.feature.geometry.move(b *
+            (a.x - this.lastPixel.x), b * (this.lastPixel.y - a.y));
+        this.layer.drawFeature(this.feature);
+        this.lastPixel = a;
+        this.onDrag(this.feature, a)
+    },
+    upFeature: function() {
+        this.over || this.handlers.drag.deactivate()
+    },
+    doneDragging: function(a) {
+        this.onComplete(this.feature, a)
+    },
+    outFeature: function(a) {
+        this.handlers.drag.dragging ? this.feature.id == a.id && (this.over = !1) : (this.over = !1, this.handlers.drag.deactivate(), OpenLayers.Element.removeClass(this.map.viewPortDiv, this.displayClass + "Over"), this.onLeave(a), this.feature = null)
+    },
+    cancel: function() {
+        this.handlers.drag.deactivate();
+        this.over = !1
+    },
+    setMap: function(a) {
+        this.handlers.drag.setMap(a);
+        this.handlers.feature.setMap(a);
+        OpenLayers.Control.prototype.setMap.apply(this, arguments)
+    },
+    CLASS_NAME: "OpenLayers.Control.DragFeature"
+});
+OpenLayers.StyleMap = OpenLayers.Class({
+    styles: null,
+    extendDefault: !0,
+    initialize: function(a, b) {
+        this.styles = {
+            "default": new OpenLayers.Style(OpenLayers.Feature.Vector.style["default"]),
+            select: new OpenLayers.Style(OpenLayers.Feature.Vector.style.select),
+            temporary: new OpenLayers.Style(OpenLayers.Feature.Vector.style.temporary),
+            "delete": new OpenLayers.Style(OpenLayers.Feature.Vector.style["delete"])
+        };
+        if (a instanceof OpenLayers.Style) this.styles["default"] = a, this.styles.select = a, this.styles.temporary = a, this.styles["delete"] =
+            a;
+        else if ("object" == typeof a)
+            for (var c in a)
+                if (a[c] instanceof OpenLayers.Style) this.styles[c] = a[c];
+                else if ("object" == typeof a[c]) this.styles[c] = new OpenLayers.Style(a[c]);
+        else {
+            this.styles["default"] = new OpenLayers.Style(a);
+            this.styles.select = new OpenLayers.Style(a);
+            this.styles.temporary = new OpenLayers.Style(a);
+            this.styles["delete"] = new OpenLayers.Style(a);
+            break
+        }
+        OpenLayers.Util.extend(this, b)
+    },
+    destroy: function() {
+        for (var a in this.styles) this.styles[a].destroy();
+        this.styles = null
+    },
+    createSymbolizer: function(a,
+        b) {
+        a || (a = new OpenLayers.Feature.Vector);
+        this.styles[b] || (b = "default");
+        a.renderIntent = b;
+        var c = {};
+        this.extendDefault && "default" != b && (c = this.styles["default"].createSymbolizer(a));
+        return OpenLayers.Util.extend(c, this.styles[b].createSymbolizer(a))
+    },
+    addUniqueValueRules: function(a, b, c, d) {
+        var e = [],
+            f;
+        for (f in c) e.push(new OpenLayers.Rule({
+            symbolizer: c[f],
+            context: d,
+            filter: new OpenLayers.Filter.Comparison({
+                type: OpenLayers.Filter.Comparison.EQUAL_TO,
+                property: b,
+                value: f
+            })
+        }));
+        this.styles[a].addRules(e)
+    },
+    CLASS_NAME: "OpenLayers.StyleMap"
+});
+OpenLayers.Layer.Vector = OpenLayers.Class(OpenLayers.Layer, {
+    isBaseLayer: !1,
+    isFixed: !1,
+    features: null,
+    filter: null,
+    selectedFeatures: null,
+    unrenderedFeatures: null,
+    reportError: !0,
+    style: null,
+    styleMap: null,
+    strategies: null,
+    protocol: null,
+    renderers: ["SVG", "VML", "Canvas"],
+    renderer: null,
+    rendererOptions: null,
+    geometryType: null,
+    drawn: !1,
+    ratio: 1,
+    initialize: function(a, b) {
+        OpenLayers.Layer.prototype.initialize.apply(this, arguments);
+        (!this.renderer || !this.renderer.supported()) && this.assignRenderer();
+        if (!this.renderer ||
+            !this.renderer.supported()) this.renderer = null, this.displayError();
+        this.styleMap || (this.styleMap = new OpenLayers.StyleMap);
+        this.features = [];
+        this.selectedFeatures = [];
+        this.unrenderedFeatures = {};
+        if (this.strategies)
+            for (var c = 0, d = this.strategies.length; c < d; c++) this.strategies[c].setLayer(this)
+    },
+    destroy: function() {
+        if (this.strategies) {
+            var a, b, c;
+            b = 0;
+            for (c = this.strategies.length; b < c; b++) a = this.strategies[b], a.autoDestroy && a.destroy();
+            this.strategies = null
+        }
+        this.protocol && (this.protocol.autoDestroy && this.protocol.destroy(),
+            this.protocol = null);
+        this.destroyFeatures();
+        this.unrenderedFeatures = this.selectedFeatures = this.features = null;
+        this.renderer && this.renderer.destroy();
+        this.drawn = this.geometryType = this.renderer = null;
+        OpenLayers.Layer.prototype.destroy.apply(this, arguments)
+    },
+    clone: function(a) {
+        null == a && (a = new OpenLayers.Layer.Vector(this.name, this.getOptions()));
+        for (var a = OpenLayers.Layer.prototype.clone.apply(this, [a]), b = this.features, c = b.length, d = Array(c), e = 0; e < c; ++e) d[e] = b[e].clone();
+        a.features = d;
+        return a
+    },
+    refresh: function(a) {
+        this.calculateInRange() &&
+            this.visibility && this.events.triggerEvent("refresh", a)
+    },
+    assignRenderer: function() {
+        for (var a = 0, b = this.renderers.length; a < b; a++) {
+            var c = this.renderers[a];
+            if ((c = "function" == typeof c ? c : OpenLayers.Renderer[c]) && c.prototype.supported()) {
+                this.renderer = new c(this.div, this.rendererOptions);
+                break
+            }
+        }
+    },
+    displayError: function() {
+        this.reportError && OpenLayers.Console.userError(OpenLayers.i18n("browserNotSupported", {
+            renderers: this.renderers.join("\n")
+        }))
+    },
+    setMap: function(a) {
+        OpenLayers.Layer.prototype.setMap.apply(this,
+            arguments);
+        if (this.renderer) {
+            this.renderer.map = this.map;
+            var b = this.map.getSize();
+            b.w *= this.ratio;
+            b.h *= this.ratio;
+            this.renderer.setSize(b)
+        } else this.map.removeLayer(this)
+    },
+    afterAdd: function() {
+        if (this.strategies) {
+            var a, b, c;
+            b = 0;
+            for (c = this.strategies.length; b < c; b++) a = this.strategies[b], a.autoActivate && a.activate()
+        }
+    },
+    removeMap: function() {
+        this.drawn = !1;
+        if (this.strategies) {
+            var a, b, c;
+            b = 0;
+            for (c = this.strategies.length; b < c; b++) a = this.strategies[b], a.autoActivate && a.deactivate()
+        }
+    },
+    onMapResize: function() {
+        OpenLayers.Layer.prototype.onMapResize.apply(this,
+            arguments);
+        var a = this.map.getSize();
+        a.w *= this.ratio;
+        a.h *= this.ratio;
+        this.renderer.setSize(a)
+    },
+    moveTo: function(a, b, c) {
+        OpenLayers.Layer.prototype.moveTo.apply(this, arguments);
+        var d = !0;
+        if (!c) {
+            this.renderer.root.style.visibility = "hidden";
+            var d = this.map.getSize(),
+                e = d.w,
+                d = d.h,
+                e = e / 2 * this.ratio - e / 2,
+                d = d / 2 * this.ratio - d / 2,
+                e = e + parseInt(this.map.layerContainerDiv.style.left, 10),
+                e = -Math.round(e),
+                d = d + parseInt(this.map.layerContainerDiv.style.top, 10),
+                d = -Math.round(d);
+            this.div.style.left = e + "px";
+            this.div.style.top =
+                d + "px";
+            d = this.renderer.setExtent(this.map.getExtent().scale(this.ratio), b);
+            this.renderer.root.style.visibility = "visible";
+            !0 === OpenLayers.IS_GECKO && (this.div.scrollLeft = this.div.scrollLeft);
+            if (!b && d)
+                for (var f in this.unrenderedFeatures) e = this.unrenderedFeatures[f], this.drawFeature(e)
+        }
+        if (!this.drawn || b || !d) {
+            this.drawn = !0;
+            f = 0;
+            for (d = this.features.length; f < d; f++) this.renderer.locked = f !== d - 1, e = this.features[f], this.drawFeature(e)
+        }
+    },
+    display: function(a) {
+        OpenLayers.Layer.prototype.display.apply(this, arguments);
+        var b = this.div.style.display;
+        b != this.renderer.root.style.display && (this.renderer.root.style.display = b)
+    },
+    addFeatures: function(a, b) {
+        OpenLayers.Util.isArray(a) || (a = [a]);
+        var c = !b || !b.silent;
+        if (c) {
+            var d = {
+                features: a
+            };
+            if (!1 === this.events.triggerEvent("beforefeaturesadded", d)) return;
+            a = d.features
+        }
+        for (var d = [], e = 0, f = a.length; e < f; e++) {
+            this.renderer.locked = e != a.length - 1 ? !0 : !1;
+            var g = a[e];
+            if (this.geometryType && !(g.geometry instanceof this.geometryType)) throw new TypeError("addFeatures: component should be an " +
+                this.geometryType.prototype.CLASS_NAME);
+            g.layer = this;
+            !g.style && this.style && (g.style = OpenLayers.Util.extend({}, this.style));
+            if (c) {
+                if (!1 === this.events.triggerEvent("beforefeatureadded", {
+                        feature: g
+                    })) continue;
+                this.preFeatureInsert(g)
+            }
+            d.push(g);
+            this.features.push(g);
+            this.drawFeature(g);
+            c && (this.events.triggerEvent("featureadded", {
+                feature: g
+            }), this.onFeatureInsert(g))
+        }
+        c && this.events.triggerEvent("featuresadded", {
+            features: d
+        })
+    },
+    removeFeatures: function(a, b) {
+        if (a && 0 !== a.length) {
+            if (a === this.features) return this.removeAllFeatures(b);
+            OpenLayers.Util.isArray(a) || (a = [a]);
+            a === this.selectedFeatures && (a = a.slice());
+            var c = !b || !b.silent;
+            c && this.events.triggerEvent("beforefeaturesremoved", {
+                features: a
+            });
+            for (var d = a.length - 1; 0 <= d; d--) {
+                this.renderer.locked = 0 != d && a[d - 1].geometry ? !0 : !1;
+                var e = a[d];
+                delete this.unrenderedFeatures[e.id];
+                c && this.events.triggerEvent("beforefeatureremoved", {
+                    feature: e
+                });
+                this.features = OpenLayers.Util.removeItem(this.features, e);
+                e.layer = null;
+                e.geometry && this.renderer.eraseFeatures(e); - 1 != OpenLayers.Util.indexOf(this.selectedFeatures,
+                    e) && OpenLayers.Util.removeItem(this.selectedFeatures, e);
+                c && this.events.triggerEvent("featureremoved", {
+                    feature: e
+                })
+            }
+            c && this.events.triggerEvent("featuresremoved", {
+                features: a
+            })
+        }
+    },
+    removeAllFeatures: function(a) {
+        var a = !a || !a.silent,
+            b = this.features;
+        a && this.events.triggerEvent("beforefeaturesremoved", {
+            features: b
+        });
+        for (var c, d = b.length - 1; 0 <= d; d--) c = b[d], a && this.events.triggerEvent("beforefeatureremoved", {
+            feature: c
+        }), c.layer = null, a && this.events.triggerEvent("featureremoved", {
+            feature: c
+        });
+        this.renderer.clear();
+        this.features = [];
+        this.unrenderedFeatures = {};
+        this.selectedFeatures = [];
+        a && this.events.triggerEvent("featuresremoved", {
+            features: b
+        })
+    },
+    destroyFeatures: function(a, b) {
+        void 0 == a && (a = this.features);
+        if (a) {
+            this.removeFeatures(a, b);
+            for (var c = a.length - 1; 0 <= c; c--) a[c].destroy()
+        }
+    },
+    drawFeature: function(a, b) {
+        if (this.drawn) {
+            if ("object" != typeof b) {
+                !b && a.state === OpenLayers.State.DELETE && (b = "delete");
+                var c = b || a.renderIntent;
+                (b = a.style || this.style) || (b = this.styleMap.createSymbolizer(a, c))
+            }
+            c = this.renderer.drawFeature(a,
+                b);
+            !1 === c || null === c ? this.unrenderedFeatures[a.id] = a : delete this.unrenderedFeatures[a.id]
+        }
+    },
+    eraseFeatures: function(a) {
+        this.renderer.eraseFeatures(a)
+    },
+    getFeatureFromEvent: function(a) {
+        if (!this.renderer) throw Error("getFeatureFromEvent called on layer with no renderer. This usually means you destroyed a layer, but not some handler which is associated with it.");
+        var b = null;
+        (a = this.renderer.getFeatureIdFromEvent(a)) && (b = "string" === typeof a ? this.getFeatureById(a) : a);
+        return b
+    },
+    getFeatureBy: function(a, b) {
+        for (var c =
+                null, d = 0, e = this.features.length; d < e; ++d)
+            if (this.features[d][a] == b) {
+                c = this.features[d];
+                break
+            }
+        return c
+    },
+    getFeatureById: function(a) {
+        return this.getFeatureBy("id", a)
+    },
+    getFeatureByFid: function(a) {
+        return this.getFeatureBy("fid", a)
+    },
+    getFeaturesByAttribute: function(a, b) {
+        var c, d, e = this.features.length,
+            f = [];
+        for (c = 0; c < e; c++)(d = this.features[c]) && d.attributes && d.attributes[a] === b && f.push(d);
+        return f
+    },
+    onFeatureInsert: function() {},
+    preFeatureInsert: function() {},
+    getDataExtent: function() {
+        var a = null,
+            b = this.features;
+        if (b && 0 < b.length)
+            for (var c = null, d = 0, e = b.length; d < e; d++)
+                if (c = b[d].geometry) null === a && (a = new OpenLayers.Bounds), a.extend(c.getBounds());
+        return a
+    },
+    CLASS_NAME: "OpenLayers.Layer.Vector"
+});
+OpenLayers.Layer.Vector.RootContainer = OpenLayers.Class(OpenLayers.Layer.Vector, {
+    displayInLayerSwitcher: !1,
+    layers: null,
+    display: function() {},
+    getFeatureFromEvent: function(a) {
+        for (var b = this.layers, c, d = 0; d < b.length; d++)
+            if (c = b[d].getFeatureFromEvent(a)) return c
+    },
+    setMap: function(a) {
+        OpenLayers.Layer.Vector.prototype.setMap.apply(this, arguments);
+        this.collectRoots();
+        a.events.register("changelayer", this, this.handleChangeLayer)
+    },
+    removeMap: function(a) {
+        a.events.unregister("changelayer", this, this.handleChangeLayer);
+        this.resetRoots();
+        OpenLayers.Layer.Vector.prototype.removeMap.apply(this, arguments)
+    },
+    collectRoots: function() {
+        for (var a, b = 0; b < this.map.layers.length; ++b) a = this.map.layers[b], -1 != OpenLayers.Util.indexOf(this.layers, a) && a.renderer.moveRoot(this.renderer)
+    },
+    resetRoots: function() {
+        for (var a, b = 0; b < this.layers.length; ++b) a = this.layers[b], this.renderer && a.renderer.getRenderLayerId() == this.id && this.renderer.moveRoot(a.renderer)
+    },
+    handleChangeLayer: function(a) {
+        var b = a.layer;
+        "order" == a.property && -1 != OpenLayers.Util.indexOf(this.layers,
+            b) && (this.resetRoots(), this.collectRoots())
+    },
+    CLASS_NAME: "OpenLayers.Layer.Vector.RootContainer"
+});
+OpenLayers.Control.SelectFeature = OpenLayers.Class(OpenLayers.Control, {
+    multipleKey: null,
+    toggleKey: null,
+    multiple: !1,
+    clickout: !0,
+    toggle: !1,
+    hover: !1,
+    highlightOnly: !1,
+    box: !1,
+    onBeforeSelect: function() {},
+    onSelect: function() {},
+    onUnselect: function() {},
+    scope: null,
+    geometryTypes: null,
+    layer: null,
+    layers: null,
+    callbacks: null,
+    selectStyle: null,
+    renderIntent: "select",
+    handlers: null,
+    initialize: function(a, b) {
+        OpenLayers.Control.prototype.initialize.apply(this, [b]);
+        null === this.scope && (this.scope = this);
+        this.initLayer(a);
+        var c = {
+            click: this.clickFeature,
+            clickout: this.clickoutFeature
+        };
+        this.hover && (c.over = this.overFeature, c.out = this.outFeature);
+        this.callbacks = OpenLayers.Util.extend(c, this.callbacks);
+        this.handlers = {
+            feature: new OpenLayers.Handler.Feature(this, this.layer, this.callbacks, {
+                geometryTypes: this.geometryTypes
+            })
+        };
+        this.box && (this.handlers.box = new OpenLayers.Handler.Box(this, {
+            done: this.selectBox
+        }, {
+            boxDivClassName: "olHandlerBoxSelectFeature"
+        }))
+    },
+    initLayer: function(a) {
+        OpenLayers.Util.isArray(a) ? (this.layers = a, this.layer =
+            new OpenLayers.Layer.Vector.RootContainer(this.id + "_container", {
+                layers: a
+            })) : this.layer = a
+    },
+    destroy: function() {
+        this.active && this.layers && this.map.removeLayer(this.layer);
+        OpenLayers.Control.prototype.destroy.apply(this, arguments);
+        this.layers && this.layer.destroy()
+    },
+    activate: function() {
+        this.active || (this.layers && this.map.addLayer(this.layer), this.handlers.feature.activate(), this.box && this.handlers.box && this.handlers.box.activate());
+        return OpenLayers.Control.prototype.activate.apply(this, arguments)
+    },
+    deactivate: function() {
+        this.active &&
+            (this.handlers.feature.deactivate(), this.handlers.box && this.handlers.box.deactivate(), this.layers && this.map.removeLayer(this.layer));
+        return OpenLayers.Control.prototype.deactivate.apply(this, arguments)
+    },
+    unselectAll: function(a) {
+        for (var b = this.layers || [this.layer], c, d, e = 0; e < b.length; ++e) {
+            c = b[e];
+            for (var f = c.selectedFeatures.length - 1; 0 <= f; --f) d = c.selectedFeatures[f], (!a || a.except != d) && this.unselect(d)
+        }
+    },
+    clickFeature: function(a) {
+        this.hover || (-1 < OpenLayers.Util.indexOf(a.layer.selectedFeatures, a) ? this.toggleSelect() ?
+            this.unselect(a) : this.multipleSelect() || this.unselectAll({
+                except: a
+            }) : (this.multipleSelect() || this.unselectAll({
+                except: a
+            }), this.select(a)))
+    },
+    multipleSelect: function() {
+        return this.multiple || this.handlers.feature.evt && this.handlers.feature.evt[this.multipleKey]
+    },
+    toggleSelect: function() {
+        return this.toggle || this.handlers.feature.evt && this.handlers.feature.evt[this.toggleKey]
+    },
+    clickoutFeature: function() {
+        !this.hover && this.clickout && this.unselectAll()
+    },
+    overFeature: function(a) {
+        var b = a.layer;
+        this.hover && (this.highlightOnly ?
+            this.highlight(a) : -1 == OpenLayers.Util.indexOf(b.selectedFeatures, a) && this.select(a))
+    },
+    outFeature: function(a) {
+        if (this.hover)
+            if (this.highlightOnly) {
+                if (a._lastHighlighter == this.id)
+                    if (a._prevHighlighter && a._prevHighlighter != this.id) {
+                        delete a._lastHighlighter;
+                        var b = this.map.getControl(a._prevHighlighter);
+                        b && b.highlight(a)
+                    } else this.unhighlight(a)
+            } else this.unselect(a)
+    },
+    highlight: function(a) {
+        var b = a.layer;
+        !1 !== this.events.triggerEvent("beforefeaturehighlighted", {
+            feature: a
+        }) && (a._prevHighlighter = a._lastHighlighter,
+            a._lastHighlighter = this.id, b.drawFeature(a, this.selectStyle || this.renderIntent), this.events.triggerEvent("featurehighlighted", {
+                feature: a
+            }))
+    },
+    unhighlight: function(a) {
+        var b = a.layer;
+        void 0 == a._prevHighlighter ? delete a._lastHighlighter : (a._prevHighlighter != this.id && (a._lastHighlighter = a._prevHighlighter), delete a._prevHighlighter);
+        b.drawFeature(a, a.style || a.layer.style || "default");
+        this.events.triggerEvent("featureunhighlighted", {
+            feature: a
+        })
+    },
+    select: function(a) {
+        var b = this.onBeforeSelect.call(this.scope,
+                a),
+            c = a.layer;
+        !1 !== b && (b = c.events.triggerEvent("beforefeatureselected", {
+            feature: a
+        }), !1 !== b && (c.selectedFeatures.push(a), this.highlight(a), this.handlers.feature.lastFeature || (this.handlers.feature.lastFeature = c.selectedFeatures[0]), c.events.triggerEvent("featureselected", {
+            feature: a
+        }), this.onSelect.call(this.scope, a)))
+    },
+    unselect: function(a) {
+        var b = a.layer;
+        this.unhighlight(a);
+        OpenLayers.Util.removeItem(b.selectedFeatures, a);
+        b.events.triggerEvent("featureunselected", {
+            feature: a
+        });
+        this.onUnselect.call(this.scope,
+            a)
+    },
+    selectBox: function(a) {
+        if (a instanceof OpenLayers.Bounds) {
+            var b = this.map.getLonLatFromPixel({
+                    x: a.left,
+                    y: a.bottom
+                }),
+                a = this.map.getLonLatFromPixel({
+                    x: a.right,
+                    y: a.top
+                }),
+                b = new OpenLayers.Bounds(b.lon, b.lat, a.lon, a.lat);
+            this.multipleSelect() || this.unselectAll();
+            a = this.multiple;
+            this.multiple = !0;
+            var c = this.layers || [this.layer];
+            this.events.triggerEvent("boxselectionstart", {
+                layers: c
+            });
+            for (var d, e = 0; e < c.length; ++e) {
+                d = c[e];
+                for (var f = 0, g = d.features.length; f < g; ++f) {
+                    var h = d.features[f];
+                    h.getVisibility() && (null ==
+                        this.geometryTypes || -1 < OpenLayers.Util.indexOf(this.geometryTypes, h.geometry.CLASS_NAME)) && b.toGeometry().intersects(h.geometry) && -1 == OpenLayers.Util.indexOf(d.selectedFeatures, h) && this.select(h)
+                }
+            }
+            this.multiple = a;
+            this.events.triggerEvent("boxselectionend", {
+                layers: c
+            })
+        }
+    },
+    setMap: function(a) {
+        this.handlers.feature.setMap(a);
+        this.box && this.handlers.box.setMap(a);
+        OpenLayers.Control.prototype.setMap.apply(this, arguments)
+    },
+    setLayer: function(a) {
+        var b = this.active;
+        this.unselectAll();
+        this.deactivate();
+        this.layers &&
+            (this.layer.destroy(), this.layers = null);
+        this.initLayer(a);
+        this.handlers.feature.layer = this.layer;
+        b && this.activate()
+    },
+    CLASS_NAME: "OpenLayers.Control.SelectFeature"
+});
+OpenLayers.Handler.Keyboard = OpenLayers.Class(OpenLayers.Handler, {
+    KEY_EVENTS: ["keydown", "keyup"],
+    eventListener: null,
+    observeElement: null,
+    initialize: function(a, b, c) {
+        OpenLayers.Handler.prototype.initialize.apply(this, arguments);
+        this.eventListener = OpenLayers.Function.bindAsEventListener(this.handleKeyEvent, this)
+    },
+    destroy: function() {
+        this.deactivate();
+        this.eventListener = null;
+        OpenLayers.Handler.prototype.destroy.apply(this, arguments)
+    },
+    activate: function() {
+        if (OpenLayers.Handler.prototype.activate.apply(this,
+                arguments)) {
+            this.observeElement = this.observeElement || document;
+            for (var a = 0, b = this.KEY_EVENTS.length; a < b; a++) OpenLayers.Event.observe(this.observeElement, this.KEY_EVENTS[a], this.eventListener);
+            return !0
+        }
+        return !1
+    },
+    deactivate: function() {
+        var a = !1;
+        if (OpenLayers.Handler.prototype.deactivate.apply(this, arguments)) {
+            for (var a = 0, b = this.KEY_EVENTS.length; a < b; a++) OpenLayers.Event.stopObserving(this.observeElement, this.KEY_EVENTS[a], this.eventListener);
+            a = !0
+        }
+        return a
+    },
+    handleKeyEvent: function(a) {
+        this.checkModifiers(a) &&
+            this.callback(a.type, [a])
+    },
+    CLASS_NAME: "OpenLayers.Handler.Keyboard"
+});
+OpenLayers.Control.ModifyFeature = OpenLayers.Class(OpenLayers.Control, {
+    geometryTypes: null,
+    clickout: !0,
+    toggle: !0,
+    standalone: !1,
+    layer: null,
+    feature: null,
+    vertices: null,
+    virtualVertices: null,
+    selectControl: null,
+    dragControl: null,
+    handlers: null,
+    deleteCodes: null,
+    virtualStyle: null,
+    vertexRenderIntent: null,
+    mode: null,
+    createVertices: !0,
+    modified: !1,
+    radiusHandle: null,
+    dragHandle: null,
+    onModificationStart: function() {},
+    onModification: function() {},
+    onModificationEnd: function() {},
+    initialize: function(a, b) {
+        b = b || {};
+        this.layer =
+            a;
+        this.vertices = [];
+        this.virtualVertices = [];
+        this.virtualStyle = OpenLayers.Util.extend({}, this.layer.style || this.layer.styleMap.createSymbolizer(null, b.vertexRenderIntent));
+        this.virtualStyle.fillOpacity = 0.3;
+        this.virtualStyle.strokeOpacity = 0.3;
+        this.deleteCodes = [46, 68];
+        this.mode = OpenLayers.Control.ModifyFeature.RESHAPE;
+        OpenLayers.Control.prototype.initialize.apply(this, [b]);
+        OpenLayers.Util.isArray(this.deleteCodes) || (this.deleteCodes = [this.deleteCodes]);
+        var c = this,
+            d = {
+                geometryTypes: this.geometryTypes,
+                clickout: this.clickout,
+                toggle: this.toggle,
+                onBeforeSelect: this.beforeSelectFeature,
+                onSelect: this.selectFeature,
+                onUnselect: this.unselectFeature,
+                scope: this
+            };
+        !1 === this.standalone && (this.selectControl = new OpenLayers.Control.SelectFeature(a, d));
+        this.dragControl = new OpenLayers.Control.DragFeature(a, {
+            geometryTypes: ["OpenLayers.Geometry.Point"],
+            onStart: function(a, b) {
+                c.dragStart.apply(c, [a, b])
+            },
+            onDrag: function(a, b) {
+                c.dragVertex.apply(c, [a, b])
+            },
+            onComplete: function(a) {
+                c.dragComplete.apply(c, [a])
+            },
+            featureCallbacks: {
+                over: function(a) {
+                    (c.standalone !==
+                        true || a._sketch || c.feature === a) && c.dragControl.overFeature.apply(c.dragControl, [a])
+                }
+            }
+        });
+        this.handlers = {
+            keyboard: new OpenLayers.Handler.Keyboard(this, {
+                keydown: this.handleKeypress
+            })
+        }
+    },
+    destroy: function() {
+        this.layer = null;
+        this.standalone || this.selectControl.destroy();
+        this.dragControl.destroy();
+        OpenLayers.Control.prototype.destroy.apply(this, [])
+    },
+    activate: function() {
+        return (this.standalone || this.selectControl.activate()) && this.handlers.keyboard.activate() && OpenLayers.Control.prototype.activate.apply(this,
+            arguments)
+    },
+    deactivate: function() {
+        var a = !1;
+        if (OpenLayers.Control.prototype.deactivate.apply(this, arguments)) {
+            this.layer.removeFeatures(this.vertices, {
+                silent: !0
+            });
+            this.layer.removeFeatures(this.virtualVertices, {
+                silent: !0
+            });
+            this.vertices = [];
+            this.dragControl.deactivate();
+            var b = (a = this.feature) && a.geometry && a.layer;
+            !1 === this.standalone ? (b && this.selectControl.unselect.apply(this.selectControl, [a]), this.selectControl.deactivate()) : b && this.unselectFeature(a);
+            this.handlers.keyboard.deactivate();
+            a = !0
+        }
+        return a
+    },
+    beforeSelectFeature: function(a) {
+        return this.layer.events.triggerEvent("beforefeaturemodified", {
+            feature: a
+        })
+    },
+    selectFeature: function(a) {
+        if (!this.standalone || !1 !== this.beforeSelectFeature(a)) this.feature = a, this.modified = !1, this.resetVertices(), this.dragControl.activate(), this.onModificationStart(this.feature);
+        var b = a.modified;
+        if (a.geometry && (!b || !b.geometry)) this._originalGeometry = a.geometry.clone()
+    },
+    unselectFeature: function(a) {
+        this.layer.removeFeatures(this.vertices, {
+            silent: !0
+        });
+        this.vertices = [];
+        this.layer.destroyFeatures(this.virtualVertices, {
+            silent: !0
+        });
+        this.virtualVertices = [];
+        this.dragHandle && (this.layer.destroyFeatures([this.dragHandle], {
+            silent: !0
+        }), delete this.dragHandle);
+        this.radiusHandle && (this.layer.destroyFeatures([this.radiusHandle], {
+            silent: !0
+        }), delete this.radiusHandle);
+        this.feature = null;
+        this.dragControl.deactivate();
+        this.onModificationEnd(a);
+        this.layer.events.triggerEvent("afterfeaturemodified", {
+            feature: a,
+            modified: this.modified
+        });
+        this.modified = !1
+    },
+    dragStart: function(a, b) {
+        if (a != this.feature && (!a.geometry.parent && a != this.dragHandle &&
+                a != this.radiusHandle) && (!1 === this.standalone && this.feature && this.selectControl.clickFeature.apply(this.selectControl, [this.feature]), null == this.geometryTypes || -1 != OpenLayers.Util.indexOf(this.geometryTypes, a.geometry.CLASS_NAME))) this.standalone || this.selectControl.clickFeature.apply(this.selectControl, [a]), this.dragControl.overFeature.apply(this.dragControl, [a]), this.dragControl.lastPixel = b, this.dragControl.handlers.drag.started = !0, this.dragControl.handlers.drag.start = b, this.dragControl.handlers.drag.last =
+            b
+    },
+    dragVertex: function(a, b) {
+        this.modified = !0;
+        "OpenLayers.Geometry.Point" == this.feature.geometry.CLASS_NAME ? (this.feature != a && (this.feature = a), this.layer.events.triggerEvent("vertexmodified", {
+            vertex: a.geometry,
+            feature: this.feature,
+            pixel: b
+        })) : (a._index ? (a.geometry.parent.addComponent(a.geometry, a._index), delete a._index, OpenLayers.Util.removeItem(this.virtualVertices, a), this.vertices.push(a)) : a == this.dragHandle ? (this.layer.removeFeatures(this.vertices, {
+                silent: !0
+            }), this.vertices = [], this.radiusHandle &&
+            (this.layer.destroyFeatures([this.radiusHandle], {
+                silent: !0
+            }), this.radiusHandle = null)) : a !== this.radiusHandle && this.layer.events.triggerEvent("vertexmodified", {
+            vertex: a.geometry,
+            feature: this.feature,
+            pixel: b
+        }), 0 < this.virtualVertices.length && (this.layer.destroyFeatures(this.virtualVertices, {
+            silent: !0
+        }), this.virtualVertices = []), this.layer.drawFeature(this.feature, this.standalone ? void 0 : this.selectControl.renderIntent));
+        this.layer.drawFeature(a)
+    },
+    dragComplete: function() {
+        this.resetVertices();
+        this.setFeatureState();
+        this.onModification(this.feature);
+        this.layer.events.triggerEvent("featuremodified", {
+            feature: this.feature
+        })
+    },
+    setFeatureState: function() {
+        if (this.feature.state != OpenLayers.State.INSERT && this.feature.state != OpenLayers.State.DELETE && (this.feature.state = OpenLayers.State.UPDATE, this.modified && this._originalGeometry)) {
+            var a = this.feature;
+            a.modified = OpenLayers.Util.extend(a.modified, {
+                geometry: this._originalGeometry
+            });
+            delete this._originalGeometry
+        }
+    },
+    resetVertices: function() {
+        this.dragControl.feature && this.dragControl.outFeature(this.dragControl.feature);
+        0 < this.vertices.length && (this.layer.removeFeatures(this.vertices, {
+            silent: !0
+        }), this.vertices = []);
+        0 < this.virtualVertices.length && (this.layer.removeFeatures(this.virtualVertices, {
+            silent: !0
+        }), this.virtualVertices = []);
+        this.dragHandle && (this.layer.destroyFeatures([this.dragHandle], {
+            silent: !0
+        }), this.dragHandle = null);
+        this.radiusHandle && (this.layer.destroyFeatures([this.radiusHandle], {
+            silent: !0
+        }), this.radiusHandle = null);
+        this.feature && "OpenLayers.Geometry.Point" != this.feature.geometry.CLASS_NAME && (this.mode &
+            OpenLayers.Control.ModifyFeature.DRAG && this.collectDragHandle(), this.mode & (OpenLayers.Control.ModifyFeature.ROTATE | OpenLayers.Control.ModifyFeature.RESIZE) && this.collectRadiusHandle(), this.mode & OpenLayers.Control.ModifyFeature.RESHAPE && (this.mode & OpenLayers.Control.ModifyFeature.RESIZE || this.collectVertices()))
+    },
+    handleKeypress: function(a) {
+        var b = a.keyCode;
+        if (this.feature && -1 != OpenLayers.Util.indexOf(this.deleteCodes, b) && (b = this.dragControl.feature) && -1 != OpenLayers.Util.indexOf(this.vertices, b) && !this.dragControl.handlers.drag.dragging &&
+            b.geometry.parent) b.geometry.parent.removeComponent(b.geometry), this.layer.events.triggerEvent("vertexremoved", {
+            vertex: b.geometry,
+            feature: this.feature,
+            pixel: a.xy
+        }), this.layer.drawFeature(this.feature, this.standalone ? void 0 : this.selectControl.renderIntent), this.modified = !0, this.resetVertices(), this.setFeatureState(), this.onModification(this.feature), this.layer.events.triggerEvent("featuremodified", {
+            feature: this.feature
+        })
+    },
+    collectVertices: function() {
+        function a(c) {
+            var d, e, f;
+            if ("OpenLayers.Geometry.Point" ==
+                c.CLASS_NAME) e = new OpenLayers.Feature.Vector(c), e._sketch = !0, e.renderIntent = b.vertexRenderIntent, b.vertices.push(e);
+            else {
+                f = c.components.length;
+                "OpenLayers.Geometry.LinearRing" == c.CLASS_NAME && (f -= 1);
+                for (d = 0; d < f; ++d) e = c.components[d], "OpenLayers.Geometry.Point" == e.CLASS_NAME ? (e = new OpenLayers.Feature.Vector(e), e._sketch = !0, e.renderIntent = b.vertexRenderIntent, b.vertices.push(e)) : a(e);
+                if (b.createVertices && "OpenLayers.Geometry.MultiPoint" != c.CLASS_NAME) {
+                    d = 0;
+                    for (f = c.components.length; d < f - 1; ++d) {
+                        e = c.components[d];
+                        var g = c.components[d + 1];
+                        "OpenLayers.Geometry.Point" == e.CLASS_NAME && "OpenLayers.Geometry.Point" == g.CLASS_NAME && (e = new OpenLayers.Feature.Vector(new OpenLayers.Geometry.Point((e.x + g.x) / 2, (e.y + g.y) / 2), null, b.virtualStyle), e.geometry.parent = c, e._index = d + 1, e._sketch = !0, b.virtualVertices.push(e))
+                    }
+                }
+            }
+        }
+        this.vertices = [];
+        this.virtualVertices = [];
+        var b = this;
+        a.call(this, this.feature.geometry);
+        this.layer.addFeatures(this.virtualVertices, {
+            silent: !0
+        });
+        this.layer.addFeatures(this.vertices, {
+            silent: !0
+        })
+    },
+    collectDragHandle: function() {
+        var a =
+            this.feature.geometry,
+            b = a.getBounds().getCenterLonLat(),
+            b = new OpenLayers.Geometry.Point(b.lon, b.lat),
+            c = new OpenLayers.Feature.Vector(b);
+        b.move = function(b, c) {
+            OpenLayers.Geometry.Point.prototype.move.call(this, b, c);
+            a.move(b, c)
+        };
+        c._sketch = !0;
+        this.dragHandle = c;
+        this.dragHandle.renderIntent = this.vertexRenderIntent;
+        this.layer.addFeatures([this.dragHandle], {
+            silent: !0
+        })
+    },
+    collectRadiusHandle: function() {
+        var a = this.feature.geometry,
+            b = a.getBounds(),
+            c = b.getCenterLonLat(),
+            d = new OpenLayers.Geometry.Point(c.lon, c.lat),
+            b = new OpenLayers.Geometry.Point(b.right, b.bottom),
+            c = new OpenLayers.Feature.Vector(b),
+            e = this.mode & OpenLayers.Control.ModifyFeature.RESIZE,
+            f = this.mode & OpenLayers.Control.ModifyFeature.RESHAPE,
+            g = this.mode & OpenLayers.Control.ModifyFeature.ROTATE;
+        b.move = function(b, c) {
+            OpenLayers.Geometry.Point.prototype.move.call(this, b, c);
+            var j = this.x - d.x,
+                k = this.y - d.y,
+                l = j - b,
+                m = k - c;
+            if (g) {
+                var n = Math.atan2(m, l),
+                    n = Math.atan2(k, j) - n,
+                    n = n * (180 / Math.PI);
+                a.rotate(n, d)
+            }
+            if (e) {
+                var o;
+                f ? (k /= m, o = j / l / k) : (l = Math.sqrt(l * l + m * m), k = Math.sqrt(j *
+                    j + k * k) / l);
+                a.resize(k, d, o)
+            }
+        };
+        c._sketch = !0;
+        this.radiusHandle = c;
+        this.radiusHandle.renderIntent = this.vertexRenderIntent;
+        this.layer.addFeatures([this.radiusHandle], {
+            silent: !0
+        })
+    },
+    setMap: function(a) {
+        this.standalone || this.selectControl.setMap(a);
+        this.dragControl.setMap(a);
+        OpenLayers.Control.prototype.setMap.apply(this, arguments)
+    },
+    CLASS_NAME: "OpenLayers.Control.ModifyFeature"
+});
+OpenLayers.Control.ModifyFeature.RESHAPE = 1;
+OpenLayers.Control.ModifyFeature.RESIZE = 2;
+OpenLayers.Control.ModifyFeature.ROTATE = 4;
+OpenLayers.Control.ModifyFeature.DRAG = 8;
+OpenLayers.Layer.Bing = OpenLayers.Class(OpenLayers.Layer.XYZ, {
+    key: null,
+    serverResolutions: [156543.03390625, 78271.516953125, 39135.7584765625, 19567.87923828125, 9783.939619140625, 4891.9698095703125, 2445.9849047851562, 1222.9924523925781, 611.4962261962891, 305.74811309814453, 152.87405654907226, 76.43702827453613, 38.218514137268066, 19.109257068634033, 9.554628534317017, 4.777314267158508, 2.388657133579254, 1.194328566789627, 0.5971642833948135, 0.29858214169740677, 0.14929107084870338, 0.07464553542435169],
+    attributionTemplate: '<span class="olBingAttribution ${type}"><div><a target="_blank" href="http://www.bing.com/maps/"><img src="${logo}" /></a></div>${copyrights}<a style="white-space: nowrap" target="_blank" href="http://www.microsoft.com/maps/product/terms.html">Terms of Use</a></span>',
+    metadata: null,
+    type: "Road",
+    culture: "en-US",
+    metadataParams: null,
+    tileOptions: null,
+    initialize: function(a) {
+        a = OpenLayers.Util.applyDefaults({
+            sphericalMercator: !0
+        }, a);
+        OpenLayers.Layer.XYZ.prototype.initialize.apply(this, [a.name || "Bing " + (a.type || this.type), null, a]);
+        this.tileOptions = OpenLayers.Util.extend({
+            crossOriginKeyword: "anonymous"
+        }, this.options.tileOptions);
+        this.loadMetadata()
+    },
+    loadMetadata: function() {
+        this._callbackId = "_callback_" + this.id.replace(/\./g, "_");
+        window[this._callbackId] = OpenLayers.Function.bind(OpenLayers.Layer.Bing.processMetadata,
+            this);
+        var a = OpenLayers.Util.applyDefaults({
+                key: this.key,
+                jsonp: this._callbackId,
+                include: "ImageryProviders"
+            }, this.metadataParams),
+            a = "http://dev.virtualearth.net/REST/v1/Imagery/Metadata/" + this.type + "?" + OpenLayers.Util.getParameterString(a),
+            b = document.createElement("script");
+        b.type = "text/javascript";
+        b.src = a;
+        b.id = this._callbackId;
+        document.getElementsByTagName("head")[0].appendChild(b)
+    },
+    initLayer: function() {
+        var a = this.metadata.resourceSets[0].resources[0],
+            b = a.imageUrl.replace("{quadkey}", "${quadkey}"),
+            b = b.replace("{culture}", this.culture);
+        this.url = [];
+        for (var c = 0; c < a.imageUrlSubdomains.length; ++c) this.url.push(b.replace("{subdomain}", a.imageUrlSubdomains[c]));
+        this.addOptions({
+            maxResolution: Math.min(this.serverResolutions[a.zoomMin], this.maxResolution || Number.POSITIVE_INFINITY),
+            numZoomLevels: Math.min(a.zoomMax + 1 - a.zoomMin, this.numZoomLevels)
+        }, !0)
+    },
+    getURL: function(a) {
+        if (this.url) {
+            for (var b = this.getXYZ(a), a = b.x, c = b.y, b = b.z, d = [], e = b; 0 < e; --e) {
+                var f = "0",
+                    g = 1 << e - 1;
+                0 != (a & g) && f++;
+                0 != (c & g) && (f++, f++);
+                d.push(f)
+            }
+            d =
+                d.join("");
+            a = this.selectUrl("" + a + c + b, this.url);
+            return OpenLayers.String.format(a, {
+                quadkey: d
+            })
+        }
+    },
+    updateAttribution: function() {
+        var a = this.metadata;
+        if (a.resourceSets && this.map && this.map.center) {
+            var b = a.resourceSets[0].resources[0],
+                c = this.map.getExtent().transform(this.map.getProjectionObject(), new OpenLayers.Projection("EPSG:4326")),
+                b = b.imageryProviders,
+                d = OpenLayers.Util.indexOf(this.serverResolutions, this.getServerResolution()),
+                e = "",
+                f, g, h, i, j, k, l;
+            g = 0;
+            for (h = b.length; g < h; ++g) {
+                f = b[g];
+                i = 0;
+                for (j = f.coverageAreas.length; i <
+                    j; ++i) l = f.coverageAreas[i], k = OpenLayers.Bounds.fromArray(l.bbox, !0), c.intersectsBounds(k) && (d <= l.zoomMax && d >= l.zoomMin) && (e += f.attribution + " ")
+            }
+            this.attribution = OpenLayers.String.format(this.attributionTemplate, {
+                type: this.type.toLowerCase(),
+                logo: a.brandLogoUri,
+                copyrights: e
+            });
+            this.map && this.map.events.triggerEvent("changelayer", {
+                layer: this,
+                property: "attribution"
+            })
+        }
+    },
+    setMap: function() {
+        OpenLayers.Layer.XYZ.prototype.setMap.apply(this, arguments);
+        this.updateAttribution();
+        this.map.events.register("moveend",
+            this, this.updateAttribution)
+    },
+    clone: function(a) {
+        null == a && (a = new OpenLayers.Layer.Bing(this.options));
+        return a = OpenLayers.Layer.XYZ.prototype.clone.apply(this, [a])
+    },
+    destroy: function() {
+        this.map && this.map.events.unregister("moveend", this, this.updateAttribution);
+        OpenLayers.Layer.XYZ.prototype.destroy.apply(this, arguments)
+    },
+    CLASS_NAME: "OpenLayers.Layer.Bing"
+});
+OpenLayers.Layer.Bing.processMetadata = function(a) {
+    this.metadata = a;
+    this.initLayer();
+    a = document.getElementById(this._callbackId);
+    a.parentNode.removeChild(a);
+    window[this._callbackId] = void 0;
+    delete this._callbackId
+};
+OpenLayers.Layer.PointGrid = OpenLayers.Class(OpenLayers.Layer.Vector, {
+    dx: null,
+    dy: null,
+    ratio: 1.5,
+    maxFeatures: 250,
+    rotation: 0,
+    origin: null,
+    gridBounds: null,
+    initialize: function(a) {
+        a = a || {};
+        OpenLayers.Layer.Vector.prototype.initialize.apply(this, [a.name, a])
+    },
+    setMap: function(a) {
+        OpenLayers.Layer.Vector.prototype.setMap.apply(this, arguments);
+        a.events.register("moveend", this, this.onMoveEnd)
+    },
+    removeMap: function(a) {
+        a.events.unregister("moveend", this, this.onMoveEnd);
+        OpenLayers.Layer.Vector.prototype.removeMap.apply(this,
+            arguments)
+    },
+    setRatio: function(a) {
+        this.ratio = a;
+        this.updateGrid(!0)
+    },
+    setMaxFeatures: function(a) {
+        this.maxFeatures = a;
+        this.updateGrid(!0)
+    },
+    setSpacing: function(a, b) {
+        this.dx = a;
+        this.dy = b || a;
+        this.updateGrid(!0)
+    },
+    setOrigin: function(a) {
+        this.origin = a;
+        this.updateGrid(!0)
+    },
+    getOrigin: function() {
+        this.origin || (this.origin = this.map.getExtent().getCenterLonLat());
+        return this.origin
+    },
+    setRotation: function(a) {
+        this.rotation = a;
+        this.updateGrid(!0)
+    },
+    onMoveEnd: function() {
+        this.updateGrid()
+    },
+    getViewBounds: function() {
+        var a = this.map.getExtent();
+        if (this.rotation) {
+            var b = this.getOrigin(),
+                b = new OpenLayers.Geometry.Point(b.lon, b.lat),
+                a = a.toGeometry();
+            a.rotate(-this.rotation, b);
+            a = a.getBounds()
+        }
+        return a
+    },
+    updateGrid: function(a) {
+        if (a || this.invalidBounds()) {
+            var b = this.getViewBounds(),
+                c = this.getOrigin(),
+                a = new OpenLayers.Geometry.Point(c.lon, c.lat),
+                d = b.getWidth(),
+                e = b.getHeight(),
+                f = d / e,
+                g = Math.sqrt(this.dx * this.dy * this.maxFeatures / f),
+                d = Math.min(d * this.ratio, g * f),
+                e = Math.min(e * this.ratio, g),
+                b = b.getCenterLonLat();
+            this.gridBounds = new OpenLayers.Bounds(b.lon -
+                d / 2, b.lat - e / 2, b.lon + d / 2, b.lat + e / 2);
+            for (var b = Math.floor(e / this.dy), d = Math.floor(d / this.dx), e = c.lon + this.dx * Math.ceil((this.gridBounds.left - c.lon) / this.dx), c = c.lat + this.dy * Math.ceil((this.gridBounds.bottom - c.lat) / this.dy), g = Array(b * d), h, i = 0; i < d; ++i)
+                for (var f = e + i * this.dx, j = 0; j < b; ++j) h = c + j * this.dy, h = new OpenLayers.Geometry.Point(f, h), this.rotation && h.rotate(this.rotation, a), g[i * b + j] = new OpenLayers.Feature.Vector(h);
+            this.destroyFeatures(this.features, {
+                silent: !0
+            });
+            this.addFeatures(g, {
+                silent: !0
+            })
+        }
+    },
+    invalidBounds: function() {
+        return !this.gridBounds ||
+            !this.gridBounds.containsBounds(this.getViewBounds())
+    },
+    CLASS_NAME: "OpenLayers.Layer.PointGrid"
+});
+OpenLayers.Handler.MouseWheel = OpenLayers.Class(OpenLayers.Handler, {
+    wheelListener: null,
+    mousePosition: null,
+    interval: 0,
+    delta: 0,
+    cumulative: !0,
+    initialize: function(a, b, c) {
+        OpenLayers.Handler.prototype.initialize.apply(this, arguments);
+        this.wheelListener = OpenLayers.Function.bindAsEventListener(this.onWheelEvent, this)
+    },
+    destroy: function() {
+        OpenLayers.Handler.prototype.destroy.apply(this, arguments);
+        this.wheelListener = null
+    },
+    onWheelEvent: function(a) {
+        if (this.map && this.checkModifiers(a)) {
+            for (var b = !1, c = !1, d = !1, e =
+                    OpenLayers.Event.element(a); null != e && !d && !b;) {
+                if (!b) try {
+                    var f = e.currentStyle ? e.currentStyle.overflow : document.defaultView.getComputedStyle(e, null).getPropertyValue("overflow"),
+                        b = f && "auto" == f || "scroll" == f
+                } catch (g) {}
+                if (!c)
+                    for (var d = 0, h = this.map.layers.length; d < h; d++)
+                        if (e == this.map.layers[d].div || e == this.map.layers[d].pane) {
+                            c = !0;
+                            break
+                        }
+                d = e == this.map.div;
+                e = e.parentNode
+            }!b && d && (c && ((b = 0, a || (a = window.event), a.wheelDelta ? (b = a.wheelDelta / 120, window.opera && 9.2 > window.opera.version() && (b = -b)) : a.detail && (b = -a.detail /
+                3), this.delta += b, this.interval) ? (window.clearTimeout(this._timeoutId), this._timeoutId = window.setTimeout(OpenLayers.Function.bind(function() {
+                this.wheelZoom(a)
+            }, this), this.interval)) : this.wheelZoom(a)), OpenLayers.Event.stop(a))
+        }
+    },
+    wheelZoom: function(a) {
+        var b = this.delta;
+        this.delta = 0;
+        b && (this.mousePosition && (a.xy = this.mousePosition), a.xy || (a.xy = this.map.getPixelFromLonLat(this.map.getCenter())), 0 > b ? this.callback("down", [a, this.cumulative ? b : -1]) : this.callback("up", [a, this.cumulative ? b : 1]))
+    },
+    mousemove: function(a) {
+    //alert(a.xy);
+        this.mousePosition =
+            a.xy
+    },
+    activate: function(a) {
+        if (OpenLayers.Handler.prototype.activate.apply(this, arguments)) {
+            var b = this.wheelListener;
+            OpenLayers.Event.observe(window, "DOMMouseScroll", b);
+            OpenLayers.Event.observe(window, "mousewheel", b);
+            OpenLayers.Event.observe(document, "mousewheel", b);
+            return !0
+        }
+        return !1
+    },
+    deactivate: function(a) {
+        if (OpenLayers.Handler.prototype.deactivate.apply(this, arguments)) {
+            var b = this.wheelListener;
+            OpenLayers.Event.stopObserving(window, "DOMMouseScroll", b);
+            OpenLayers.Event.stopObserving(window, "mousewheel",
+                b);
+            OpenLayers.Event.stopObserving(document, "mousewheel", b);
+            return !0
+        }
+        return !1
+    },
+    CLASS_NAME: "OpenLayers.Handler.MouseWheel"
+});
+OpenLayers.Symbolizer = OpenLayers.Class({
+    zIndex: 0,
+    initialize: function(a) {
+        OpenLayers.Util.extend(this, a)
+    },
+    clone: function() {
+        return new(eval(this.CLASS_NAME))(OpenLayers.Util.extend({}, this))
+    },
+    CLASS_NAME: "OpenLayers.Symbolizer"
+});
+OpenLayers.Symbolizer.Raster = OpenLayers.Class(OpenLayers.Symbolizer, {
+    initialize: function(a) {
+        OpenLayers.Symbolizer.prototype.initialize.apply(this, arguments)
+    },
+    CLASS_NAME: "OpenLayers.Symbolizer.Raster"
+});
+OpenLayers.Rule = OpenLayers.Class({
+    id: null,
+    name: null,
+    title: null,
+    description: null,
+    context: null,
+    filter: null,
+    elseFilter: !1,
+    symbolizer: null,
+    symbolizers: null,
+    minScaleDenominator: null,
+    maxScaleDenominator: null,
+    initialize: function(a) {
+        this.symbolizer = {};
+        OpenLayers.Util.extend(this, a);
+        this.symbolizers && delete this.symbolizer;
+        this.id = OpenLayers.Util.createUniqueID(this.CLASS_NAME + "_")
+    },
+    destroy: function() {
+        for (var a in this.symbolizer) this.symbolizer[a] = null;
+        this.symbolizer = null;
+        delete this.symbolizers
+    },
+    evaluate: function(a) {
+        var b =
+            this.getContext(a),
+            c = !0;
+        if (this.minScaleDenominator || this.maxScaleDenominator) var d = a.layer.map.getScale();
+        this.minScaleDenominator && (c = d >= OpenLayers.Style.createLiteral(this.minScaleDenominator, b));
+        c && this.maxScaleDenominator && (c = d < OpenLayers.Style.createLiteral(this.maxScaleDenominator, b));
+        c && this.filter && (c = "OpenLayers.Filter.FeatureId" == this.filter.CLASS_NAME ? this.filter.evaluate(a) : this.filter.evaluate(b));
+        return c
+    },
+    getContext: function(a) {
+        var b = this.context;
+        b || (b = a.attributes || a.data);
+        "function" ==
+        typeof this.context && (b = this.context(a));
+        return b
+    },
+    clone: function() {
+        var a = OpenLayers.Util.extend({}, this);
+        if (this.symbolizers) {
+            var b = this.symbolizers.length;
+            a.symbolizers = Array(b);
+            for (var c = 0; c < b; ++c) a.symbolizers[c] = this.symbolizers[c].clone()
+        } else {
+            a.symbolizer = {};
+            for (var d in this.symbolizer) b = this.symbolizer[d], c = typeof b, "object" === c ? a.symbolizer[d] = OpenLayers.Util.extend({}, b) : "string" === c && (a.symbolizer[d] = b)
+        }
+        a.filter = this.filter && this.filter.clone();
+        a.context = this.context && OpenLayers.Util.extend({},
+            this.context);
+        return new OpenLayers.Rule(a)
+    },
+    CLASS_NAME: "OpenLayers.Rule"
+});
+OpenLayers.Filter.Spatial = OpenLayers.Class(OpenLayers.Filter, {
+    type: null,
+    property: null,
+    value: null,
+    distance: null,
+    distanceUnits: null,
+    evaluate: function(a) {
+        var b = !1;
+        switch (this.type) {
+            case OpenLayers.Filter.Spatial.BBOX:
+            case OpenLayers.Filter.Spatial.INTERSECTS:
+                if (a.geometry) {
+                    var c = this.value;
+                    "OpenLayers.Bounds" == this.value.CLASS_NAME && (c = this.value.toGeometry());
+                    a.geometry.intersects(c) && (b = !0)
+                }
+                break;
+            default:
+                throw Error("evaluate is not implemented for this filter type.");
+        }
+        return b
+    },
+    clone: function() {
+        var a =
+            OpenLayers.Util.applyDefaults({
+                value: this.value && this.value.clone && this.value.clone()
+            }, this);
+        return new OpenLayers.Filter.Spatial(a)
+    },
+    CLASS_NAME: "OpenLayers.Filter.Spatial"
+});
+OpenLayers.Filter.Spatial.BBOX = "BBOX";
+OpenLayers.Filter.Spatial.INTERSECTS = "INTERSECTS";
+OpenLayers.Filter.Spatial.DWITHIN = "DWITHIN";
+OpenLayers.Filter.Spatial.WITHIN = "WITHIN";
+OpenLayers.Filter.Spatial.CONTAINS = "CONTAINS";
+OpenLayers.Format.SLD = OpenLayers.Class(OpenLayers.Format.XML.VersionedOGC, {
+    profile: null,
+    defaultVersion: "1.0.0",
+    stringifyOutput: !0,
+    namedLayersAsArray: !1,
+    CLASS_NAME: "OpenLayers.Format.SLD"
+});
+OpenLayers.Symbolizer.Polygon = OpenLayers.Class(OpenLayers.Symbolizer, {
+    initialize: function(a) {
+        OpenLayers.Symbolizer.prototype.initialize.apply(this, arguments)
+    },
+    CLASS_NAME: "OpenLayers.Symbolizer.Polygon"
+});
+OpenLayers.Format.GML.v2 = OpenLayers.Class(OpenLayers.Format.GML.Base, {
+    schemaLocation: "http://www.opengis.net/gml http://schemas.opengis.net/gml/2.1.2/feature.xsd",
+    initialize: function(a) {
+        OpenLayers.Format.GML.Base.prototype.initialize.apply(this, [a])
+    },
+    readers: {
+        gml: OpenLayers.Util.applyDefaults({
+            outerBoundaryIs: function(a, b) {
+                var c = {};
+                this.readChildNodes(a, c);
+                b.outer = c.components[0]
+            },
+            innerBoundaryIs: function(a, b) {
+                var c = {};
+                this.readChildNodes(a, c);
+                b.inner.push(c.components[0])
+            },
+            Box: function(a, b) {
+                var c = {};
+                this.readChildNodes(a, c);
+                b.components || (b.components = []);
+                var d = c.points[0],
+                    c = c.points[1];
+                b.components.push(new OpenLayers.Bounds(d.x, d.y, c.x, c.y))
+            }
+        }, OpenLayers.Format.GML.Base.prototype.readers.gml),
+        feature: OpenLayers.Format.GML.Base.prototype.readers.feature,
+        wfs: OpenLayers.Format.GML.Base.prototype.readers.wfs
+    },
+    write: function(a) {
+        a = this.writeNode(OpenLayers.Util.isArray(a) ? "wfs:FeatureCollection" : "gml:featureMember", a);
+        this.setAttributeNS(a, this.namespaces.xsi, "xsi:schemaLocation", this.schemaLocation);
+        return OpenLayers.Format.XML.prototype.write.apply(this, [a])
+    },
+    writers: {
+        gml: OpenLayers.Util.applyDefaults({
+            Point: function(a) {
+                var b = this.createElementNSPlus("gml:Point");
+                this.writeNode("coordinates", [a], b);
+                return b
+            },
+            coordinates: function(a) {
+                for (var b = a.length, c = Array(b), d, e = 0; e < b; ++e) d = a[e], c[e] = this.xy ? d.x + "," + d.y : d.y + "," + d.x, void 0 != d.z && (c[e] += "," + d.z);
+                return this.createElementNSPlus("gml:coordinates", {
+                    attributes: {
+                        decimal: ".",
+                        cs: ",",
+                        ts: " "
+                    },
+                    value: 1 == b ? c[0] : c.join(" ")
+                })
+            },
+            LineString: function(a) {
+                var b =
+                    this.createElementNSPlus("gml:LineString");
+                this.writeNode("coordinates", a.components, b);
+                return b
+            },
+            Polygon: function(a) {
+                var b = this.createElementNSPlus("gml:Polygon");
+                this.writeNode("outerBoundaryIs", a.components[0], b);
+                for (var c = 1; c < a.components.length; ++c) this.writeNode("innerBoundaryIs", a.components[c], b);
+                return b
+            },
+            outerBoundaryIs: function(a) {
+                var b = this.createElementNSPlus("gml:outerBoundaryIs");
+                this.writeNode("LinearRing", a, b);
+                return b
+            },
+            innerBoundaryIs: function(a) {
+                var b = this.createElementNSPlus("gml:innerBoundaryIs");
+                this.writeNode("LinearRing", a, b);
+                return b
+            },
+            LinearRing: function(a) {
+                var b = this.createElementNSPlus("gml:LinearRing");
+                this.writeNode("coordinates", a.components, b);
+                return b
+            },
+            Box: function(a) {
+                var b = this.createElementNSPlus("gml:Box");
+                this.writeNode("coordinates", [{
+                    x: a.left,
+                    y: a.bottom
+                }, {
+                    x: a.right,
+                    y: a.top
+                }], b);
+                this.srsName && b.setAttribute("srsName", this.srsName);
+                return b
+            }
+        }, OpenLayers.Format.GML.Base.prototype.writers.gml),
+        feature: OpenLayers.Format.GML.Base.prototype.writers.feature,
+        wfs: OpenLayers.Format.GML.Base.prototype.writers.wfs
+    },
+    CLASS_NAME: "OpenLayers.Format.GML.v2"
+});
+OpenLayers.Format.Filter.v1_0_0 = OpenLayers.Class(OpenLayers.Format.GML.v2, OpenLayers.Format.Filter.v1, {
+    VERSION: "1.0.0",
+    schemaLocation: "http://www.opengis.net/ogc/filter/1.0.0/filter.xsd",
+    initialize: function(a) {
+        OpenLayers.Format.GML.v2.prototype.initialize.apply(this, [a])
+    },
+    readers: {
+        ogc: OpenLayers.Util.applyDefaults({
+            PropertyIsEqualTo: function(a, b) {
+                var c = new OpenLayers.Filter.Comparison({
+                    type: OpenLayers.Filter.Comparison.EQUAL_TO
+                });
+                this.readChildNodes(a, c);
+                b.filters.push(c)
+            },
+            PropertyIsNotEqualTo: function(a,
+                b) {
+                var c = new OpenLayers.Filter.Comparison({
+                    type: OpenLayers.Filter.Comparison.NOT_EQUAL_TO
+                });
+                this.readChildNodes(a, c);
+                b.filters.push(c)
+            },
+            PropertyIsLike: function(a, b) {
+                var c = new OpenLayers.Filter.Comparison({
+                    type: OpenLayers.Filter.Comparison.LIKE
+                });
+                this.readChildNodes(a, c);
+                var d = a.getAttribute("wildCard"),
+                    e = a.getAttribute("singleChar"),
+                    f = a.getAttribute("escape");
+                c.value2regex(d, e, f);
+                b.filters.push(c)
+            }
+        }, OpenLayers.Format.Filter.v1.prototype.readers.ogc),
+        gml: OpenLayers.Format.GML.v2.prototype.readers.gml,
+        feature: OpenLayers.Format.GML.v2.prototype.readers.feature
+    },
+    writers: {
+        ogc: OpenLayers.Util.applyDefaults({
+            PropertyIsEqualTo: function(a) {
+                var b = this.createElementNSPlus("ogc:PropertyIsEqualTo");
+                this.writeNode("PropertyName", a, b);
+                this.writeOgcExpression(a.value, b);
+                return b
+            },
+            PropertyIsNotEqualTo: function(a) {
+                var b = this.createElementNSPlus("ogc:PropertyIsNotEqualTo");
+                this.writeNode("PropertyName", a, b);
+                this.writeOgcExpression(a.value, b);
+                return b
+            },
+            PropertyIsLike: function(a) {
+                var b = this.createElementNSPlus("ogc:PropertyIsLike", {
+                    attributes: {
+                        wildCard: "*",
+                        singleChar: ".",
+                        escape: "!"
+                    }
+                });
+                this.writeNode("PropertyName", a, b);
+                this.writeNode("Literal", a.regex2value(), b);
+                return b
+            },
+            BBOX: function(a) {
+                var b = this.createElementNSPlus("ogc:BBOX");
+                a.property && this.writeNode("PropertyName", a, b);
+                var c = this.writeNode("gml:Box", a.value, b);
+                a.projection && c.setAttribute("srsName", a.projection);
+                return b
+            }
+        }, OpenLayers.Format.Filter.v1.prototype.writers.ogc),
+        gml: OpenLayers.Format.GML.v2.prototype.writers.gml,
+        feature: OpenLayers.Format.GML.v2.prototype.writers.feature
+    },
+    writeSpatial: function(a, b) {
+        var c = this.createElementNSPlus("ogc:" + b);
+        this.writeNode("PropertyName", a, c);
+        if (a.value instanceof OpenLayers.Filter.Function) this.writeNode("Function", a.value, c);
+        else {
+            var d;
+            d = a.value instanceof OpenLayers.Geometry ? this.writeNode("feature:_geometry", a.value).firstChild : this.writeNode("gml:Box", a.value);
+            a.projection && d.setAttribute("srsName", a.projection);
+            c.appendChild(d)
+        }
+        return c
+    },
+    CLASS_NAME: "OpenLayers.Format.Filter.v1_0_0"
+});
+OpenLayers.Format.WFST.v1_0_0 = OpenLayers.Class(OpenLayers.Format.Filter.v1_0_0, OpenLayers.Format.WFST.v1, {
+    version: "1.0.0",
+    srsNameInQuery: !1,
+    schemaLocations: {
+        wfs: "http://schemas.opengis.net/wfs/1.0.0/WFS-transaction.xsd"
+    },
+    initialize: function(a) {
+        OpenLayers.Format.Filter.v1_0_0.prototype.initialize.apply(this, [a]);
+        OpenLayers.Format.WFST.v1.prototype.initialize.apply(this, [a])
+    },
+    readNode: function(a, b) {
+        return OpenLayers.Format.GML.v2.prototype.readNode.apply(this, [a, b])
+    },
+    readers: {
+        wfs: OpenLayers.Util.applyDefaults({
+            WFS_TransactionResponse: function(a,
+                b) {
+                b.insertIds = [];
+                b.success = !1;
+                this.readChildNodes(a, b)
+            },
+            InsertResult: function(a, b) {
+                var c = {
+                    fids: []
+                };
+                this.readChildNodes(a, c);
+                b.insertIds.push(c.fids[0])
+            },
+            TransactionResult: function(a, b) {
+                this.readChildNodes(a, b)
+            },
+            Status: function(a, b) {
+                this.readChildNodes(a, b)
+            },
+            SUCCESS: function(a, b) {
+                b.success = !0
+            }
+        }, OpenLayers.Format.WFST.v1.prototype.readers.wfs),
+        gml: OpenLayers.Format.GML.v2.prototype.readers.gml,
+        feature: OpenLayers.Format.GML.v2.prototype.readers.feature,
+        ogc: OpenLayers.Format.Filter.v1_0_0.prototype.readers.ogc
+    },
+    writers: {
+        wfs: OpenLayers.Util.applyDefaults({
+            Query: function(a) {
+                var a = OpenLayers.Util.extend({
+                        featureNS: this.featureNS,
+                        featurePrefix: this.featurePrefix,
+                        featureType: this.featureType,
+                        srsName: this.srsName,
+                        srsNameInQuery: this.srsNameInQuery
+                    }, a),
+                    b = a.featurePrefix,
+                    c = this.createElementNSPlus("wfs:Query", {
+                        attributes: {
+                            typeName: (b ? b + ":" : "") + a.featureType
+                        }
+                    });
+                a.srsNameInQuery && a.srsName && c.setAttribute("srsName", a.srsName);
+                a.featureNS && c.setAttribute("xmlns:" + b, a.featureNS);
+                if (a.propertyNames)
+                    for (var b = 0, d = a.propertyNames.length; b <
+                        d; b++) this.writeNode("ogc:PropertyName", {
+                        property: a.propertyNames[b]
+                    }, c);
+                a.filter && (this.setFilterProperty(a.filter), this.writeNode("ogc:Filter", a.filter, c));
+                return c
+            }
+        }, OpenLayers.Format.WFST.v1.prototype.writers.wfs),
+        gml: OpenLayers.Format.GML.v2.prototype.writers.gml,
+        feature: OpenLayers.Format.GML.v2.prototype.writers.feature,
+        ogc: OpenLayers.Format.Filter.v1_0_0.prototype.writers.ogc
+    },
+    CLASS_NAME: "OpenLayers.Format.WFST.v1_0_0"
+});
+OpenLayers.ElementsIndexer = OpenLayers.Class({
+    maxZIndex: null,
+    order: null,
+    indices: null,
+    compare: null,
+    initialize: function(a) {
+        this.compare = a ? OpenLayers.ElementsIndexer.IndexingMethods.Z_ORDER_Y_ORDER : OpenLayers.ElementsIndexer.IndexingMethods.Z_ORDER_DRAWING_ORDER;
+        this.clear()
+    },
+    insert: function(a) {
+        this.exists(a) && this.remove(a);
+        var b = a.id;
+        this.determineZIndex(a);
+        for (var c = -1, d = this.order.length, e; 1 < d - c;) e = parseInt((c + d) / 2), 0 < this.compare(this, a, OpenLayers.Util.getElement(this.order[e])) ? c = e : d = e;
+        this.order.splice(d,
+            0, b);
+        this.indices[b] = this.getZIndex(a);
+        return this.getNextElement(d)
+    },
+    remove: function(a) {
+        var a = a.id,
+            b = OpenLayers.Util.indexOf(this.order, a);
+        0 <= b && (this.order.splice(b, 1), delete this.indices[a], this.maxZIndex = 0 < this.order.length ? this.indices[this.order[this.order.length - 1]] : 0)
+    },
+    clear: function() {
+        this.order = [];
+        this.indices = {};
+        this.maxZIndex = 0
+    },
+    exists: function(a) {
+        return null != this.indices[a.id]
+    },
+    getZIndex: function(a) {
+        return a._style.graphicZIndex
+    },
+    determineZIndex: function(a) {
+        var b = a._style.graphicZIndex;
+        null == b ? (b = this.maxZIndex, a._style.graphicZIndex = b) : b > this.maxZIndex && (this.maxZIndex = b)
+    },
+    getNextElement: function(a) {
+        a += 1;
+        if (a < this.order.length) {
+            var b = OpenLayers.Util.getElement(this.order[a]);
+            void 0 == b && (b = this.getNextElement(a));
+            return b
+        }
+        return null
+    },
+    CLASS_NAME: "OpenLayers.ElementsIndexer"
+});
+OpenLayers.ElementsIndexer.IndexingMethods = {
+    Z_ORDER: function(a, b, c) {
+        var b = a.getZIndex(b),
+            d = 0;
+        c && (a = a.getZIndex(c), d = b - a);
+        return d
+    },
+    Z_ORDER_DRAWING_ORDER: function(a, b, c) {
+        a = OpenLayers.ElementsIndexer.IndexingMethods.Z_ORDER(a, b, c);
+        c && 0 == a && (a = 1);
+        return a
+    },
+    Z_ORDER_Y_ORDER: function(a, b, c) {
+        a = OpenLayers.ElementsIndexer.IndexingMethods.Z_ORDER(a, b, c);
+        c && 0 === a && (b = c._boundsBottom - b._boundsBottom, a = 0 === b ? 1 : b);
+        return a
+    }
+};
+OpenLayers.Renderer.Elements = OpenLayers.Class(OpenLayers.Renderer, {
+    rendererRoot: null,
+    root: null,
+    vectorRoot: null,
+    textRoot: null,
+    xmlns: null,
+    xOffset: 0,
+    indexer: null,
+    BACKGROUND_ID_SUFFIX: "_background",
+    LABEL_ID_SUFFIX: "_label",
+    LABEL_OUTLINE_SUFFIX: "_outline",
+    initialize: function(a, b) {
+        OpenLayers.Renderer.prototype.initialize.apply(this, arguments);
+        this.rendererRoot = this.createRenderRoot();
+        this.root = this.createRoot("_root");
+        this.vectorRoot = this.createRoot("_vroot");
+        this.textRoot = this.createRoot("_troot");
+        this.root.appendChild(this.vectorRoot);
+        this.root.appendChild(this.textRoot);
+        this.rendererRoot.appendChild(this.root);
+        this.container.appendChild(this.rendererRoot);
+        if (b && (b.zIndexing || b.yOrdering)) this.indexer = new OpenLayers.ElementsIndexer(b.yOrdering)
+    },
+    destroy: function() {
+        this.clear();
+        this.xmlns = this.root = this.rendererRoot = null;
+        OpenLayers.Renderer.prototype.destroy.apply(this, arguments)
+    },
+    clear: function() {
+        var a, b = this.vectorRoot;
+        if (b)
+            for (; a = b.firstChild;) b.removeChild(a);
+        if (b = this.textRoot)
+            for (; a = b.firstChild;) b.removeChild(a);
+        this.indexer &&
+            this.indexer.clear()
+    },
+    setExtent: function(a, b) {
+        var c = OpenLayers.Renderer.prototype.setExtent.apply(this, arguments),
+            d = this.getResolution();
+        if (this.map.baseLayer && this.map.baseLayer.wrapDateLine) {
+            var e, f = a.getWidth() / this.map.getExtent().getWidth(),
+                a = a.scale(1 / f),
+                f = this.map.getMaxExtent();
+            f.right > a.left && f.right < a.right ? e = !0 : f.left > a.left && f.left < a.right && (e = !1);
+            if (e !== this.rightOfDateLine || b) c = !1, this.xOffset = !0 === e ? f.getWidth() / d : 0;
+            this.rightOfDateLine = e
+        }
+        return c
+    },
+    getNodeType: function() {},
+    drawGeometry: function(a,
+        b, c) {
+        var d = a.CLASS_NAME,
+            e = !0;
+        if ("OpenLayers.Geometry.Collection" == d || "OpenLayers.Geometry.MultiPoint" == d || "OpenLayers.Geometry.MultiLineString" == d || "OpenLayers.Geometry.MultiPolygon" == d) {
+            for (var d = 0, f = a.components.length; d < f; d++) e = this.drawGeometry(a.components[d], b, c) && e;
+            return e
+        }
+        d = e = !1;
+        "none" != b.display && (b.backgroundGraphic ? this.redrawBackgroundNode(a.id, a, b, c) : d = !0, e = this.redrawNode(a.id, a, b, c));
+        if (!1 == e && (b = document.getElementById(a.id))) b._style.backgroundGraphic && (d = !0), b.parentNode.removeChild(b);
+        d && (b = document.getElementById(a.id + this.BACKGROUND_ID_SUFFIX)) && b.parentNode.removeChild(b);
+        return e
+    },
+    redrawNode: function(a, b, c, d) {
+        c = this.applyDefaultSymbolizer(c);
+        a = this.nodeFactory(a, this.getNodeType(b, c));
+        a._featureId = d;
+        a._boundsBottom = b.getBounds().bottom;
+        a._geometryClass = b.CLASS_NAME;
+        a._style = c;
+        b = this.drawGeometryNode(a, b, c);
+        if (!1 === b) return !1;
+        a = b.node;
+        this.indexer ? (c = this.indexer.insert(a)) ? this.vectorRoot.insertBefore(a, c) : this.vectorRoot.appendChild(a) : a.parentNode !== this.vectorRoot && this.vectorRoot.appendChild(a);
+        this.postDraw(a);
+        return b.complete
+    },
+    redrawBackgroundNode: function(a, b, c) {
+        c = OpenLayers.Util.extend({}, c);
+        c.externalGraphic = c.backgroundGraphic;
+        c.graphicXOffset = c.backgroundXOffset;
+        c.graphicYOffset = c.backgroundYOffset;
+        c.graphicZIndex = c.backgroundGraphicZIndex;
+        c.graphicWidth = c.backgroundWidth || c.graphicWidth;
+        c.graphicHeight = c.backgroundHeight || c.graphicHeight;
+        c.backgroundGraphic = null;
+        c.backgroundXOffset = null;
+        c.backgroundYOffset = null;
+        c.backgroundGraphicZIndex = null;
+        return this.redrawNode(a + this.BACKGROUND_ID_SUFFIX,
+            b, c, null)
+    },
+    drawGeometryNode: function(a, b, c) {
+        var c = c || a._style,
+            d = {
+                isFilled: void 0 === c.fill ? !0 : c.fill,
+                isStroked: void 0 === c.stroke ? !!c.strokeWidth : c.stroke
+            },
+            e;
+        switch (b.CLASS_NAME) {
+            case "OpenLayers.Geometry.Point":
+                !1 === c.graphic && (d.isFilled = !1, d.isStroked = !1);
+                e = this.drawPoint(a, b);
+                break;
+            case "OpenLayers.Geometry.LineString":
+                d.isFilled = !1;
+                e = this.drawLineString(a, b);
+                break;
+            case "OpenLayers.Geometry.LinearRing":
+                e = this.drawLinearRing(a, b);
+                break;
+            case "OpenLayers.Geometry.Polygon":
+                e = this.drawPolygon(a, b);
+                break;
+            case "OpenLayers.Geometry.Rectangle":
+                e = this.drawRectangle(a, b)
+        }
+        a._options = d;
+        return !1 != e ? {
+            node: this.setStyle(a, c, d, b),
+            complete: e
+        } : !1
+    },
+    postDraw: function() {},
+    drawPoint: function() {},
+    drawLineString: function() {},
+    drawLinearRing: function() {},
+    drawPolygon: function() {},
+    drawRectangle: function() {},
+    drawCircle: function() {},
+    removeText: function(a) {
+        var b = document.getElementById(a + this.LABEL_ID_SUFFIX);
+        b && this.textRoot.removeChild(b);
+        (a = document.getElementById(a + this.LABEL_OUTLINE_SUFFIX)) && this.textRoot.removeChild(a)
+    },
+    getFeatureIdFromEvent: function(a) {
+        var b = a.target,
+            c = b && b.correspondingUseElement;
+        return (c ? c : b || a.srcElement)._featureId
+    },
+    eraseGeometry: function(a, b) {
+        if ("OpenLayers.Geometry.MultiPoint" == a.CLASS_NAME || "OpenLayers.Geometry.MultiLineString" == a.CLASS_NAME || "OpenLayers.Geometry.MultiPolygon" == a.CLASS_NAME || "OpenLayers.Geometry.Collection" == a.CLASS_NAME)
+            for (var c = 0, d = a.components.length; c < d; c++) this.eraseGeometry(a.components[c], b);
+        else if ((c = OpenLayers.Util.getElement(a.id)) && c.parentNode)
+            if (c.geometry &&
+                (c.geometry.destroy(), c.geometry = null), c.parentNode.removeChild(c), this.indexer && this.indexer.remove(c), c._style.backgroundGraphic)(c = OpenLayers.Util.getElement(a.id + this.BACKGROUND_ID_SUFFIX)) && c.parentNode && c.parentNode.removeChild(c)
+    },
+    nodeFactory: function(a, b) {
+        var c = OpenLayers.Util.getElement(a);
+        c ? this.nodeTypeCompare(c, b) || (c.parentNode.removeChild(c), c = this.nodeFactory(a, b)) : c = this.createNode(b, a);
+        return c
+    },
+    nodeTypeCompare: function() {},
+    createNode: function() {},
+    moveRoot: function(a) {
+        var b = this.root;
+        a.root.parentNode == this.rendererRoot && (b = a.root);
+        b.parentNode.removeChild(b);
+        a.rendererRoot.appendChild(b)
+    },
+    getRenderLayerId: function() {
+        return this.root.parentNode.parentNode.id
+    },
+    isComplexSymbol: function(a) {
+        return "circle" != a && !!a
+    },
+    CLASS_NAME: "OpenLayers.Renderer.Elements"
+});
+OpenLayers.Control.ArgParser = OpenLayers.Class(OpenLayers.Control, {
+    center: null,
+    zoom: null,
+    layers: null,
+    displayProjection: null,
+    getParameters: function(a) {
+        var a = a || window.location.href,
+            b = OpenLayers.Util.getParameters(a),
+            c = a.indexOf("#");
+        0 < c && (a = "?" + a.substring(c + 1, a.length), OpenLayers.Util.extend(b, OpenLayers.Util.getParameters(a)));
+        return b
+    },
+    setMap: function(a) {
+        OpenLayers.Control.prototype.setMap.apply(this, arguments);
+        for (var b = 0, c = this.map.controls.length; b < c; b++) {
+            var d = this.map.controls[b];
+            if (d != this &&
+                "OpenLayers.Control.ArgParser" == d.CLASS_NAME) {
+                d.displayProjection != this.displayProjection && (this.displayProjection = d.displayProjection);
+                break
+            }
+        }
+        if (b == this.map.controls.length && (b = this.getParameters(), b.layers && (this.layers = b.layers, this.map.events.register("addlayer", this, this.configureLayers), this.configureLayers()), b.lat && b.lon)) this.center = new OpenLayers.LonLat(parseFloat(b.lon), parseFloat(b.lat)), b.zoom && (this.zoom = parseFloat(b.zoom)), this.map.events.register("changebaselayer", this, this.setCenter),
+            this.setCenter()
+    },
+    setCenter: function() {
+        this.map.baseLayer && (this.map.events.unregister("changebaselayer", this, this.setCenter), this.displayProjection && this.center.transform(this.displayProjection, this.map.getProjectionObject()), this.map.setCenter(this.center, this.zoom))
+    },
+    configureLayers: function() {
+        if (this.layers.length == this.map.layers.length) {
+            this.map.events.unregister("addlayer", this, this.configureLayers);
+            for (var a = 0, b = this.layers.length; a < b; a++) {
+                var c = this.map.layers[a],
+                    d = this.layers.charAt(a);
+                "B" == d ? this.map.setBaseLayer(c) : ("T" == d || "F" == d) && c.setVisibility("T" == d)
+            }
+        }
+    },
+    CLASS_NAME: "OpenLayers.Control.ArgParser"
+});
+OpenLayers.Control.Permalink = OpenLayers.Class(OpenLayers.Control, {
+    argParserClass: OpenLayers.Control.ArgParser,
+    element: null,
+    anchor: !1,
+    base: "",
+    displayProjection: null,
+    initialize: function(a, b, c) {
+        null !== a && "object" == typeof a && !OpenLayers.Util.isElement(a) ? (this.base = document.location.href, OpenLayers.Control.prototype.initialize.apply(this, [a]), null != this.element && (this.element = OpenLayers.Util.getElement(this.element))) : (OpenLayers.Control.prototype.initialize.apply(this, [c]), this.element = OpenLayers.Util.getElement(a),
+            this.base = b || document.location.href)
+    },
+    destroy: function() {
+        this.element && this.element.parentNode == this.div && (this.div.removeChild(this.element), this.element = null);
+        this.map && this.map.events.unregister("moveend", this, this.updateLink);
+        OpenLayers.Control.prototype.destroy.apply(this, arguments)
+    },
+    setMap: function(a) {
+        OpenLayers.Control.prototype.setMap.apply(this, arguments);
+        for (var b = 0, c = this.map.controls.length; b < c; b++) {
+            var d = this.map.controls[b];
+            if (d.CLASS_NAME == this.argParserClass.CLASS_NAME) {
+                d.displayProjection !=
+                    this.displayProjection && (this.displayProjection = d.displayProjection);
+                break
+            }
+        }
+        b == this.map.controls.length && this.map.addControl(new this.argParserClass({
+            displayProjection: this.displayProjection
+        }))
+    },
+    draw: function() {
+        OpenLayers.Control.prototype.draw.apply(this, arguments);
+        !this.element && !this.anchor && (this.element = document.createElement("a"), this.element.innerHTML = OpenLayers.i18n("Permalink"), this.element.href = "", this.div.appendChild(this.element));
+        this.map.events.on({
+            moveend: this.updateLink,
+            changelayer: this.updateLink,
+            changebaselayer: this.updateLink,
+            scope: this
+        });
+        this.updateLink();
+        return this.div
+    },
+    updateLink: function() {
+        var a = this.anchor ? "#" : "?",
+            b = this.base; - 1 != b.indexOf(a) && (b = b.substring(0, b.indexOf(a)));
+        b += a + OpenLayers.Util.getParameterString(this.createParams());
+        this.anchor && !this.element ? window.location.href = b : this.element.href = b
+    },
+    createParams: function(a, b, c) {
+        var a = a || this.map.getCenter(),
+            d = OpenLayers.Util.getParameters(this.base);
+        if (a) {
+            d.zoom = b || this.map.getZoom();
+            b = a.lat;
+            a = a.lon;
+            this.displayProjection && (b =
+                OpenLayers.Projection.transform({
+                    x: a,
+                    y: b
+                }, this.map.getProjectionObject(), this.displayProjection), a = b.x, b = b.y);
+            d.lat = Math.round(1E5 * b) / 1E5;
+            d.lon = Math.round(1E5 * a) / 1E5;
+            c = c || this.map.layers;
+            d.layers = "";
+            a = 0;
+            for (b = c.length; a < b; a++) {
+                var e = c[a];
+                d.layers = e.isBaseLayer ? d.layers + (e == this.map.baseLayer ? "B" : "0") : d.layers + (e.getVisibility() ? "T" : "F")
+            }
+        }
+        return d
+    },
+    CLASS_NAME: "OpenLayers.Control.Permalink"
+});
+OpenLayers.Layer.TMS = OpenLayers.Class(OpenLayers.Layer.Grid, {
+    serviceVersion: "1.0.0",
+    layername: null,
+    type: null,
+    isBaseLayer: !0,
+    tileOrigin: null,
+    serverResolutions: null,
+    zoomOffset: 0,
+    initialize: function(a, b, c) {
+        var d = [];
+        d.push(a, b, {}, c);
+        OpenLayers.Layer.Grid.prototype.initialize.apply(this, d)
+    },
+    clone: function(a) {
+        null == a && (a = new OpenLayers.Layer.TMS(this.name, this.url, this.getOptions()));
+        return a = OpenLayers.Layer.Grid.prototype.clone.apply(this, [a])
+    },
+    getURL: function(a) {
+        var a = this.adjustBounds(a),
+            b = this.getServerResolution(),
+            c = Math.round((a.left - this.tileOrigin.lon) / (b * this.tileSize.w)),
+            a = Math.round((a.bottom - this.tileOrigin.lat) / (b * this.tileSize.h)),
+            c = this.serviceVersion + "/" + this.layername + "/" + this.getServerZoom() + "/" + c + "/" + a + "." + this.type,
+            a = this.url;
+        OpenLayers.Util.isArray(a) && (a = this.selectUrl(c, a));
+        return a + c
+    },
+    setMap: function(a) {
+        OpenLayers.Layer.Grid.prototype.setMap.apply(this, arguments);
+        this.tileOrigin || (this.tileOrigin = new OpenLayers.LonLat(this.map.maxExtent.left, this.map.maxExtent.bottom))
+    },
+    CLASS_NAME: "OpenLayers.Layer.TMS"
+});
+OpenLayers.Strategy.Fixed = OpenLayers.Class(OpenLayers.Strategy, {
+    preload: !1,
+    activate: function() {
+        if (OpenLayers.Strategy.prototype.activate.apply(this, arguments)) {
+            this.layer.events.on({
+                refresh: this.load,
+                scope: this
+            });
+            if (!0 == this.layer.visibility || this.preload) this.load();
+            else this.layer.events.on({
+                visibilitychanged: this.load,
+                scope: this
+            });
+            return !0
+        }
+        return !1
+    },
+    deactivate: function() {
+        var a = OpenLayers.Strategy.prototype.deactivate.call(this);
+        a && this.layer.events.un({
+            refresh: this.load,
+            visibilitychanged: this.load,
+            scope: this
+        });
+        return a
+    },
+    load: function(a) {
+        var b = this.layer;
+        b.events.triggerEvent("loadstart");
+        b.protocol.read(OpenLayers.Util.applyDefaults({
+            callback: OpenLayers.Function.bind(this.merge, this, b.map.getProjectionObject()),
+            filter: b.filter
+        }, a));
+        b.events.un({
+            visibilitychanged: this.load,
+            scope: this
+        })
+    },
+    merge: function(a, b) {
+        var c = this.layer;
+        c.destroyFeatures();
+        var d = b.features;
+        if (d && 0 < d.length) {
+            if (!a.equals(c.projection))
+                for (var e, f = 0, g = d.length; f < g; ++f)(e = d[f].geometry) && e.transform(c.projection, a);
+            c.addFeatures(d)
+        }
+        c.events.triggerEvent("loadend")
+    },
+    CLASS_NAME: "OpenLayers.Strategy.Fixed"
+});
+OpenLayers.Control.Zoom = OpenLayers.Class(OpenLayers.Control, {
+    zoomInText: "+",
+    zoomInId: "olZoomInLink",
+    zoomOutText: "-",
+    zoomOutId: "olZoomOutLink",
+    draw: function() {
+        var a = OpenLayers.Control.prototype.draw.apply(this),
+            b = this.getOrCreateLinks(a),
+            c = b.zoomIn,
+            b = b.zoomOut,
+            d = this.map.events;
+        b.parentNode !== a && (d = this.events, d.attachToElement(b.parentNode));
+        d.register("buttonclick", this, this.onZoomClick);
+        this.zoomInLink = c;
+        this.zoomOutLink = b;
+        return a
+    },
+    getOrCreateLinks: function(a) {
+        var b = document.getElementById(this.zoomInId),
+            c = document.getElementById(this.zoomOutId);
+        b || (b = document.createElement("a"), b.href = "#zoomIn", b.appendChild(document.createTextNode(this.zoomInText)), b.className = "olControlZoomIn", a.appendChild(b));
+        OpenLayers.Element.addClass(b, "olButton");
+        c || (c = document.createElement("a"), c.href = "#zoomOut", c.appendChild(document.createTextNode(this.zoomOutText)), c.className = "olControlZoomOut", a.appendChild(c));
+        OpenLayers.Element.addClass(c, "olButton");
+        return {
+            zoomIn: b,
+            zoomOut: c
+        }
+    },
+    onZoomClick: function(a) {
+        a = a.buttonElement;
+        a === this.zoomInLink ? this.map.zoomIn() : a === this.zoomOutLink && this.map.zoomOut()
+    },
+    destroy: function() {
+        this.map && this.map.events.unregister("buttonclick", this, this.onZoomClick);
+        delete this.zoomInLink;
+        delete this.zoomOutLink;
+        OpenLayers.Control.prototype.destroy.apply(this)
+    },
+    CLASS_NAME: "OpenLayers.Control.Zoom"
+});
+OpenLayers.Layer.PointTrack = OpenLayers.Class(OpenLayers.Layer.Vector, {
+    dataFrom: null,
+    styleFrom: null,
+    addNodes: function(a, b) {
+        if (2 > a.length) throw Error("At least two point features have to be added to create a line from");
+        for (var c = Array(a.length - 1), d, e, f, g = 0, h = a.length; g < h; g++) {
+            d = a[g];
+            if (f = d.geometry) {
+                if ("OpenLayers.Geometry.Point" != f.CLASS_NAME) throw new TypeError("Only features with point geometries are supported.");
+            } else f = d.lonlat, f = new OpenLayers.Geometry.Point(f.lon, f.lat);
+            if (0 < g) {
+                d = null != this.dataFrom ?
+                    a[g + this.dataFrom].data || a[g + this.dataFrom].attributes : null;
+                var i = null != this.styleFrom ? a[g + this.styleFrom].style : null;
+                e = new OpenLayers.Geometry.LineString([e, f]);
+                c[g - 1] = new OpenLayers.Feature.Vector(e, d, i)
+            }
+            e = f
+        }
+        this.addFeatures(c, b)
+    },
+    CLASS_NAME: "OpenLayers.Layer.PointTrack"
+});
+OpenLayers.Layer.PointTrack.SOURCE_NODE = -1;
+OpenLayers.Layer.PointTrack.TARGET_NODE = 0;
+OpenLayers.Layer.PointTrack.dataFrom = {
+    SOURCE_NODE: -1,
+    TARGET_NODE: 0
+};
+OpenLayers.Protocol.WFS = function(a) {
+    var a = OpenLayers.Util.applyDefaults(a, OpenLayers.Protocol.WFS.DEFAULTS),
+        b = OpenLayers.Protocol.WFS["v" + a.version.replace(/\./g, "_")];
+    if (!b) throw "Unsupported WFS version: " + a.version;
+    return new b(a)
+};
+OpenLayers.Protocol.WFS.fromWMSLayer = function(a, b) {
+    var c, d;
+    c = a.params.LAYERS;
+    c = (OpenLayers.Util.isArray(c) ? c[0] : c).split(":");
+    1 < c.length && (d = c[0]);
+    c = c.pop();
+    d = {
+        url: a.url,
+        featureType: c,
+        featurePrefix: d,
+        srsName: a.projection && a.projection.getCode() || a.map && a.map.getProjectionObject().getCode(),
+        version: "1.1.0"
+    };
+    return new OpenLayers.Protocol.WFS(OpenLayers.Util.applyDefaults(b, d))
+};
+OpenLayers.Protocol.WFS.DEFAULTS = {
+    version: "1.0.0"
+};
+OpenLayers.Layer.Markers = OpenLayers.Class(OpenLayers.Layer, {
+    isBaseLayer: !1,
+    markers: null,
+    drawn: !1,
+    initialize: function(a, b) {
+        OpenLayers.Layer.prototype.initialize.apply(this, arguments);
+        this.markers = []
+    },
+    destroy: function() {
+        this.clearMarkers();
+        this.markers = null;
+        OpenLayers.Layer.prototype.destroy.apply(this, arguments)
+    },
+    setOpacity: function(a) {
+        if (a != this.opacity) {
+            this.opacity = a;
+            for (var a = 0, b = this.markers.length; a < b; a++) this.markers[a].setOpacity(this.opacity)
+        }
+    },
+    moveTo: function(a, b, c) {
+        OpenLayers.Layer.prototype.moveTo.apply(this,
+            arguments);
+        if (b || !this.drawn) {
+            for (var d = 0, e = this.markers.length; d < e; d++) this.drawMarker(this.markers[d]);
+            this.drawn = !0
+        }
+    },
+    addMarker: function(a) {
+        this.markers.push(a);
+        1 > this.opacity && a.setOpacity(this.opacity);
+        this.map && this.map.getExtent() && (a.map = this.map, this.drawMarker(a))
+    },
+    removeMarker: function(a) {
+        this.markers && this.markers.length && (OpenLayers.Util.removeItem(this.markers, a), a.erase())
+    },
+    clearMarkers: function() {
+        if (null != this.markers)
+            for (; 0 < this.markers.length;) this.removeMarker(this.markers[0])
+    },
+    drawMarker: function(a) {
+        var b = this.map.getLayerPxFromLonLat(a.lonlat);
+        null == b ? a.display(!1) : a.isDrawn() ? a.icon && a.icon.moveTo(b) : this.div.appendChild(a.draw(b))
+    },
+    getDataExtent: function() {
+        var a = null;
+        if (this.markers && 0 < this.markers.length)
+            for (var a = new OpenLayers.Bounds, b = 0, c = this.markers.length; b < c; b++) a.extend(this.markers[b].lonlat);
+        return a
+    },
+    CLASS_NAME: "OpenLayers.Layer.Markers"
+});
+OpenLayers.Control.Pan = OpenLayers.Class(OpenLayers.Control, {
+    slideFactor: 50,
+    slideRatio: null,
+    direction: null,
+    type: OpenLayers.Control.TYPE_BUTTON,
+    initialize: function(a, b) {
+        this.direction = a;
+        this.CLASS_NAME += this.direction;
+        OpenLayers.Control.prototype.initialize.apply(this, [b])
+    },
+    trigger: function() {
+        var a = OpenLayers.Function.bind(function(a) {
+            return this.slideRatio ? this.map.getSize()[a] * this.slideRatio : this.slideFactor
+        }, this);
+        switch (this.direction) {
+            case OpenLayers.Control.Pan.NORTH:
+                this.map.pan(0, -a("h"));
+                break;
+            case OpenLayers.Control.Pan.SOUTH:
+                this.map.pan(0, a("h"));
+                break;
+            case OpenLayers.Control.Pan.WEST:
+                this.map.pan(-a("w"), 0);
+                break;
+            case OpenLayers.Control.Pan.EAST:
+                this.map.pan(a("w"), 0)
+        }
+    },
+    CLASS_NAME: "OpenLayers.Control.Pan"
+});
+OpenLayers.Control.Pan.NORTH = "North";
+OpenLayers.Control.Pan.SOUTH = "South";
+OpenLayers.Control.Pan.EAST = "East";
+OpenLayers.Control.Pan.WEST = "West";
+OpenLayers.Format.CSWGetDomain = function(a) {
+    var a = OpenLayers.Util.applyDefaults(a, OpenLayers.Format.CSWGetDomain.DEFAULTS),
+        b = OpenLayers.Format.CSWGetDomain["v" + a.version.replace(/\./g, "_")];
+    if (!b) throw "Unsupported CSWGetDomain version: " + a.version;
+    return new b(a)
+};
+OpenLayers.Format.CSWGetDomain.DEFAULTS = {
+    version: "2.0.2"
+};
+OpenLayers.Format.CSWGetDomain.v2_0_2 = OpenLayers.Class(OpenLayers.Format.XML, {
+    namespaces: {
+        xlink: "http://www.w3.org/1999/xlink",
+        xsi: "http://www.w3.org/2001/XMLSchema-instance",
+        csw: "http://www.opengis.net/cat/csw/2.0.2"
+    },
+    defaultPrefix: "csw",
+    version: "2.0.2",
+    schemaLocation: "http://www.opengis.net/cat/csw/2.0.2 http://schemas.opengis.net/csw/2.0.2/CSW-discovery.xsd",
+    PropertyName: null,
+    ParameterName: null,
+    read: function(a) {
+        "string" == typeof a && (a = OpenLayers.Format.XML.prototype.read.apply(this, [a]));
+        a && 9 ==
+            a.nodeType && (a = a.documentElement);
+        var b = {};
+        this.readNode(a, b);
+        return b
+    },
+    readers: {
+        csw: {
+            GetDomainResponse: function(a, b) {
+                this.readChildNodes(a, b)
+            },
+            DomainValues: function(a, b) {
+                OpenLayers.Util.isArray(b.DomainValues) || (b.DomainValues = []);
+                for (var c = a.attributes, d = {}, e = 0, f = c.length; e < f; ++e) d[c[e].name] = c[e].nodeValue;
+                this.readChildNodes(a, d);
+                b.DomainValues.push(d)
+            },
+            PropertyName: function(a, b) {
+                b.PropertyName = this.getChildValue(a)
+            },
+            ParameterName: function(a, b) {
+                b.ParameterName = this.getChildValue(a)
+            },
+            ListOfValues: function(a,
+                b) {
+                OpenLayers.Util.isArray(b.ListOfValues) || (b.ListOfValues = []);
+                this.readChildNodes(a, b.ListOfValues)
+            },
+            Value: function(a, b) {
+                for (var c = a.attributes, d = {}, e = 0, f = c.length; e < f; ++e) d[c[e].name] = c[e].nodeValue;
+                d.value = this.getChildValue(a);
+                b.push({
+                    Value: d
+                })
+            },
+            ConceptualScheme: function(a, b) {
+                b.ConceptualScheme = {};
+                this.readChildNodes(a, b.ConceptualScheme)
+            },
+            Name: function(a, b) {
+                b.Name = this.getChildValue(a)
+            },
+            Document: function(a, b) {
+                b.Document = this.getChildValue(a)
+            },
+            Authority: function(a, b) {
+                b.Authority = this.getChildValue(a)
+            },
+            RangeOfValues: function(a, b) {
+                b.RangeOfValues = {};
+                this.readChildNodes(a, b.RangeOfValues)
+            },
+            MinValue: function(a, b) {
+                for (var c = a.attributes, d = {}, e = 0, f = c.length; e < f; ++e) d[c[e].name] = c[e].nodeValue;
+                d.value = this.getChildValue(a);
+                b.MinValue = d
+            },
+            MaxValue: function(a, b) {
+                for (var c = a.attributes, d = {}, e = 0, f = c.length; e < f; ++e) d[c[e].name] = c[e].nodeValue;
+                d.value = this.getChildValue(a);
+                b.MaxValue = d
+            }
+        }
+    },
+    write: function(a) {
+        a = this.writeNode("csw:GetDomain", a);
+        return OpenLayers.Format.XML.prototype.write.apply(this, [a])
+    },
+    writers: {
+        csw: {
+            GetDomain: function(a) {
+                var b =
+                    this.createElementNSPlus("csw:GetDomain", {
+                        attributes: {
+                            service: "CSW",
+                            version: this.version
+                        }
+                    });
+                if (a.PropertyName || this.PropertyName) this.writeNode("csw:PropertyName", a.PropertyName || this.PropertyName, b);
+                else if (a.ParameterName || this.ParameterName) this.writeNode("csw:ParameterName", a.ParameterName || this.ParameterName, b);
+                this.readChildNodes(b, a);
+                return b
+            },
+            PropertyName: function(a) {
+                return this.createElementNSPlus("csw:PropertyName", {
+                    value: a
+                })
+            },
+            ParameterName: function(a) {
+                return this.createElementNSPlus("csw:ParameterName", {
+                    value: a
+                })
+            }
+        }
+    },
+    CLASS_NAME: "OpenLayers.Format.CSWGetDomain.v2_0_2"
+});
+OpenLayers.Format.ArcXML.Features = OpenLayers.Class(OpenLayers.Format.XML, {
+    read: function(a) {
+        return (new OpenLayers.Format.ArcXML).read(a).features.feature
+    }
+});
+OpenLayers.Control.Snapping = OpenLayers.Class(OpenLayers.Control, {
+    DEFAULTS: {
+        tolerance: 10,
+        node: !0,
+        edge: !0,
+        vertex: !0
+    },
+    greedy: !0,
+    precedence: ["node", "vertex", "edge"],
+    resolution: null,
+    geoToleranceCache: null,
+    layer: null,
+    feature: null,
+    point: null,
+    initialize: function(a) {
+        OpenLayers.Control.prototype.initialize.apply(this, [a]);
+        this.options = a || {};
+        this.options.layer && this.setLayer(this.options.layer);
+        a = OpenLayers.Util.extend({}, this.options.defaults);
+        this.defaults = OpenLayers.Util.applyDefaults(a, this.DEFAULTS);
+        this.setTargets(this.options.targets);
+        0 === this.targets.length && this.layer && this.addTargetLayer(this.layer);
+        this.geoToleranceCache = {}
+    },
+    setLayer: function(a) {
+        this.active ? (this.deactivate(), this.layer = a, this.activate()) : this.layer = a
+    },
+    setTargets: function(a) {
+        this.targets = [];
+        if (a && a.length)
+            for (var b, c = 0, d = a.length; c < d; ++c) b = a[c], b instanceof OpenLayers.Layer.Vector ? this.addTargetLayer(b) : this.addTarget(b)
+    },
+    addTargetLayer: function(a) {
+        this.addTarget({
+            layer: a
+        })
+    },
+    addTarget: function(a) {
+        a = OpenLayers.Util.applyDefaults(a, this.defaults);
+        a.nodeTolerance =
+            a.nodeTolerance || a.tolerance;
+        a.vertexTolerance = a.vertexTolerance || a.tolerance;
+        a.edgeTolerance = a.edgeTolerance || a.tolerance;
+        this.targets.push(a)
+    },
+    removeTargetLayer: function(a) {
+        for (var b, c = this.targets.length - 1; 0 <= c; --c) b = this.targets[c], b.layer === a && this.removeTarget(b)
+    },
+    removeTarget: function(a) {
+        return OpenLayers.Util.removeItem(this.targets, a)
+    },
+    activate: function() {
+        var a = OpenLayers.Control.prototype.activate.call(this);
+        if (a && this.layer && this.layer.events) this.layer.events.on({
+            sketchstarted: this.onSketchModified,
+            sketchmodified: this.onSketchModified,
+            vertexmodified: this.onVertexModified,
+            scope: this
+        });
+        return a
+    },
+    deactivate: function() {
+        var a = OpenLayers.Control.prototype.deactivate.call(this);
+        a && this.layer && this.layer.events && this.layer.events.un({
+            sketchstarted: this.onSketchModified,
+            sketchmodified: this.onSketchModified,
+            vertexmodified: this.onVertexModified,
+            scope: this
+        });
+        this.point = this.feature = null;
+        return a
+    },
+    onSketchModified: function(a) {
+        this.feature = a.feature;
+        this.considerSnapping(a.vertex, a.vertex)
+    },
+    onVertexModified: function(a) {
+        this.feature =
+            a.feature;
+        var b = this.layer.map.getLonLatFromViewPortPx(a.pixel);
+        this.considerSnapping(a.vertex, new OpenLayers.Geometry.Point(b.lon, b.lat))
+    },
+    considerSnapping: function(a, b) {
+        for (var c = {
+                rank: Number.POSITIVE_INFINITY,
+                dist: Number.POSITIVE_INFINITY,
+                x: null,
+                y: null
+            }, d = !1, e, f, g = 0, h = this.targets.length; g < h; ++g)
+            if (f = this.targets[g], e = this.testTarget(f, b))
+                if (this.greedy) {
+                    c = e;
+                    c.target = f;
+                    d = !0;
+                    break
+                } else if (e.rank < c.rank || e.rank === c.rank && e.dist < c.dist) c = e, c.target = f, d = !0;
+        d && (!1 !== this.events.triggerEvent("beforesnap", {
+            point: a,
+            x: c.x,
+            y: c.y,
+            distance: c.dist,
+            layer: c.target.layer,
+            snapType: this.precedence[c.rank]
+        }) ? (a.x = c.x, a.y = c.y, this.point = a, this.events.triggerEvent("snap", {
+            point: a,
+            snapType: this.precedence[c.rank],
+            layer: c.target.layer,
+            distance: c.dist
+        })) : d = !1);
+        this.point && !d && (a.x = b.x, a.y = b.y, this.point = null, this.events.triggerEvent("unsnap", {
+            point: a
+        }))
+    },
+    testTarget: function(a, b) {
+        var c = this.layer.map.getResolution();
+        if ("minResolution" in a && c < a.minResolution || "maxResolution" in a && c >= a.maxResolution) return null;
+        for (var c = {
+                node: this.getGeoTolerance(a.nodeTolerance, c),
+                vertex: this.getGeoTolerance(a.vertexTolerance, c),
+                edge: this.getGeoTolerance(a.edgeTolerance, c)
+            }, d = Math.max(c.node, c.vertex, c.edge), e = {
+                rank: Number.POSITIVE_INFINITY,
+                dist: Number.POSITIVE_INFINITY
+            }, f = !1, g = a.layer.features, h, i, j, k, l, m, n = this.precedence.length, o = new OpenLayers.LonLat(b.x, b.y), p = 0, q = g.length; p < q; ++p)
+            if (h = g[p], h !== this.feature && (!h._sketch && h.state !== OpenLayers.State.DELETE && (!a.filter || a.filter.evaluate(h))) && h.atPoint(o, d, d))
+                for (var r = 0, s = Math.min(e.rank +
+                        1, n); r < s; ++r)
+                    if (i = this.precedence[r], a[i])
+                        if ("edge" === i) {
+                            if (j = h.geometry.distanceTo(b, {
+                                    details: !0
+                                }), l = j.distance, l <= c[i] && l < e.dist) {
+                                e = {
+                                    rank: r,
+                                    dist: l,
+                                    x: j.x0,
+                                    y: j.y0
+                                };
+                                f = !0;
+                                break
+                            }
+                        } else {
+                            j = h.geometry.getVertices("node" === i);
+                            m = !1;
+                            for (var t = 0, u = j.length; t < u; ++t)
+                                if (k = j[t], l = k.distanceTo(b), l <= c[i] && (r < e.rank || r === e.rank && l < e.dist)) e = {
+                                    rank: r,
+                                    dist: l,
+                                    x: k.x,
+                                    y: k.y
+                                }, m = f = !0;
+                            if (m) break
+                        }
+        return f ? e : null
+    },
+    getGeoTolerance: function(a, b) {
+        b !== this.resolution && (this.resolution = b, this.geoToleranceCache = {});
+        var c = this.geoToleranceCache[a];
+        void 0 === c && (c = a * b, this.geoToleranceCache[a] = c);
+        return c
+    },
+    destroy: function() {
+        this.active && this.deactivate();
+        delete this.layer;
+        delete this.targets;
+        OpenLayers.Control.prototype.destroy.call(this)
+    },
+    CLASS_NAME: "OpenLayers.Control.Snapping"
+});
+OpenLayers.Date = {
+    toISOString: function() {
+        if ("toISOString" in Date.prototype) return function(a) {
+            return a.toISOString()
+        };
+        var a = function(a, c) {
+            for (var d = a + ""; d.length < c;) d = "0" + d;
+            return d
+        };
+        return function(b) {
+            return isNaN(b.getTime()) ? "Invalid Date" : b.getUTCFullYear() + "-" + a(b.getUTCMonth() + 1, 2) + "-" + a(b.getUTCDate(), 2) + "T" + a(b.getUTCHours(), 2) + ":" + a(b.getUTCMinutes(), 2) + ":" + a(b.getUTCSeconds(), 2) + "." + a(b.getUTCMilliseconds(), 3) + "Z"
+        }
+    }(),
+    parse: function(a) {
+        var b;
+        if ((a = a.match(/^(?:(\d{4})(?:-(\d{2})(?:-(\d{2}))?)?)?(?:(?:T(\d{1,2}):(\d{2}):(\d{2}(?:\.\d+)?)(Z|(?:[+-]\d{1,2}(?::(\d{2}))?)))|Z)?$/)) &&
+            (a[1] || a[7])) {
+            b = parseInt(a[1], 10) || 0;
+            var c = parseInt(a[2], 10) - 1 || 0,
+                d = parseInt(a[3], 10) || 1;
+            b = new Date(Date.UTC(b, c, d));
+            if (c = a[7]) {
+                var d = parseInt(a[4], 10),
+                    e = parseInt(a[5], 10),
+                    f = parseFloat(a[6]),
+                    g = f | 0,
+                    f = Math.round(1E3 * (f - g));
+                b.setUTCHours(d, e, g, f);
+                "Z" !== c && (c = parseInt(c, 10), a = parseInt(a[8], 10) || 0, b = new Date(b.getTime() + -1E3 * (60 * 60 * c + 60 * a)))
+            }
+        } else b = new Date("invalid");
+        return b
+    }
+};
+(function() {
+    function a() {
+        this._object = f && !i ? new f : new window.ActiveXObject("Microsoft.XMLHTTP");
+        this._listeners = []
+    }
+
+    function b() {
+        return new a
+    }
+
+    function c(a) {
+        b.onreadystatechange && b.onreadystatechange.apply(a);
+        a.dispatchEvent({
+            type: "readystatechange",
+            bubbles: !1,
+            cancelable: !1,
+            timeStamp: new Date + 0
+        })
+    }
+
+    function d(a) {
+        try {
+            a.responseText = a._object.responseText
+        } catch (b) {}
+        try {
+            var c;
+            var d = a._object,
+                e = d.responseXML,
+                f = d.responseText;
+            h && (f && e && !e.documentElement && d.getResponseHeader("Content-Type").match(/[^\/]+\/[^\+]+\+xml/)) &&
+                (e = new window.ActiveXObject("Microsoft.XMLDOM"), e.async = !1, e.validateOnParse = !1, e.loadXML(f));
+            c = e && (h && 0 != e.parseError || !e.documentElement || e.documentElement && "parsererror" == e.documentElement.tagName) ? null : e;
+            a.responseXML = c
+        } catch (g) {}
+        try {
+            a.status = a._object.status
+        } catch (i) {}
+        try {
+            a.statusText = a._object.statusText
+        } catch (r) {}
+    }
+
+    function e(a) {
+        a._object.onreadystatechange = new window.Function
+    }
+    var f = window.XMLHttpRequest,
+        g = !!window.controllers,
+        h = window.document.all && !window.opera,
+        i = h && window.navigator.userAgent.match(/MSIE 7.0/);
+    b.prototype = a.prototype;
+    g && f.wrapped && (b.wrapped = f.wrapped);
+    b.UNSENT = 0;
+    b.OPENED = 1;
+    b.HEADERS_RECEIVED = 2;
+    b.LOADING = 3;
+    b.DONE = 4;
+    b.prototype.readyState = b.UNSENT;
+    b.prototype.responseText = "";
+    b.prototype.responseXML = null;
+    b.prototype.status = 0;
+    b.prototype.statusText = "";
+    b.prototype.priority = "NORMAL";
+    b.prototype.onreadystatechange = null;
+    b.onreadystatechange = null;
+    b.onopen = null;
+    b.onsend = null;
+    b.onabort = null;
+    b.prototype.open = function(a, f, i, m, n) {
+        delete this._headers;
+        arguments.length < 3 && (i = true);
+        this._async = i;
+        var o =
+            this,
+            p = this.readyState,
+            q;
+        if (h && i) {
+            q = function() {
+                if (p != b.DONE) {
+                    e(o);
+                    o.abort()
+                }
+            };
+            window.attachEvent("onunload", q)
+        }
+        b.onopen && b.onopen.apply(this, arguments);
+        arguments.length > 4 ? this._object.open(a, f, i, m, n) : arguments.length > 3 ? this._object.open(a, f, i, m) : this._object.open(a, f, i);
+        this.readyState = b.OPENED;
+        c(this);
+        this._object.onreadystatechange = function() {
+            if (!g || i) {
+                o.readyState = o._object.readyState;
+                d(o);
+                if (o._aborted) o.readyState = b.UNSENT;
+                else {
+                    if (o.readyState == b.DONE) {
+                        delete o._data;
+                        e(o);
+                        h && i && window.detachEvent("onunload",
+                            q)
+                    }
+                    p != o.readyState && c(o);
+                    p = o.readyState
+                }
+            }
+        }
+    };
+    b.prototype.send = function(a) {
+        b.onsend && b.onsend.apply(this, arguments);
+        arguments.length || (a = null);
+        if (a && a.nodeType) {
+            a = window.XMLSerializer ? (new window.XMLSerializer).serializeToString(a) : a.xml;
+            this._headers["Content-Type"] || this._object.setRequestHeader("Content-Type", "application/xml")
+        }
+        this._data = a;
+        a: {
+            this._object.send(this._data);
+            if (g && !this._async) {
+                this.readyState = b.OPENED;
+                for (d(this); this.readyState < b.DONE;) {
+                    this.readyState++;
+                    c(this);
+                    if (this._aborted) break a
+                }
+            }
+        }
+    };
+    b.prototype.abort = function() {
+        b.onabort && b.onabort.apply(this, arguments);
+        if (this.readyState > b.UNSENT) this._aborted = true;
+        this._object.abort();
+        e(this);
+        this.readyState = b.UNSENT;
+        delete this._data
+    };
+    b.prototype.getAllResponseHeaders = function() {
+        return this._object.getAllResponseHeaders()
+    };
+    b.prototype.getResponseHeader = function(a) {
+        return this._object.getResponseHeader(a)
+    };
+    b.prototype.setRequestHeader = function(a, b) {
+        if (!this._headers) this._headers = {};
+        this._headers[a] = b;
+        return this._object.setRequestHeader(a,
+            b)
+    };
+    b.prototype.addEventListener = function(a, b, c) {
+        for (var d = 0, e; e = this._listeners[d]; d++)
+            if (e[0] == a && e[1] == b && e[2] == c) return;
+        this._listeners.push([a, b, c])
+    };
+    b.prototype.removeEventListener = function(a, b, c) {
+        for (var d = 0, e; e = this._listeners[d]; d++)
+            if (e[0] == a && e[1] == b && e[2] == c) break;
+        e && this._listeners.splice(d, 1)
+    };
+    b.prototype.dispatchEvent = function(a) {
+        a = {
+            type: a.type,
+            target: this,
+            currentTarget: this,
+            eventPhase: 2,
+            bubbles: a.bubbles,
+            cancelable: a.cancelable,
+            timeStamp: a.timeStamp,
+            stopPropagation: function() {},
+            preventDefault: function() {},
+            initEvent: function() {}
+        };
+        a.type == "readystatechange" && this.onreadystatechange && (this.onreadystatechange.handleEvent || this.onreadystatechange).apply(this, [a]);
+        for (var b = 0, c; c = this._listeners[b]; b++) c[0] == a.type && !c[2] && (c[1].handleEvent || c[1]).apply(this, [a])
+    };
+    b.prototype.toString = function() {
+        return "[object XMLHttpRequest]"
+    };
+    b.toString = function() {
+        return "[XMLHttpRequest]"
+    };
+    window.Function.prototype.apply || (window.Function.prototype.apply = function(a, b) {
+        b || (b = []);
+        a.__func = this;
+        a.__func(b[0], b[1], b[2], b[3],
+            b[4]);
+        delete a.__func
+    });
+    OpenLayers.Request.XMLHttpRequest = b
+})();
+OpenLayers.Format.KML = OpenLayers.Class(OpenLayers.Format.XML, {
+    namespaces: {
+        kml: "http://www.opengis.net/kml/2.2",
+        gx: "http://www.google.com/kml/ext/2.2"
+    },
+    kmlns: "http://earth.google.com/kml/2.0",
+    placemarksDesc: "No description available",
+    foldersName: "OpenLayers export",
+    foldersDesc: "Exported on " + new Date,
+    extractAttributes: !0,
+    kvpAttributes: !1,
+    extractStyles: !1,
+    extractTracks: !1,
+    trackAttributes: null,
+    internalns: null,
+    features: null,
+    styles: null,
+    styleBaseUrl: "",
+    fetched: null,
+    maxDepth: 0,
+    initialize: function(a) {
+        this.regExes = {
+            trimSpace: /^\s*|\s*$/g,
+            removeSpace: /\s*/g,
+            splitSpace: /\s+/,
+            trimComma: /\s*,\s*/g,
+            kmlColor: /(\w{2})(\w{2})(\w{2})(\w{2})/,
+            kmlIconPalette: /root:\/\/icons\/palette-(\d+)(\.\w+)/,
+            straightBracket: /\$\[(.*?)\]/g
+        };
+        this.externalProjection = new OpenLayers.Projection("EPSG:4326");
+        OpenLayers.Format.XML.prototype.initialize.apply(this, [a])
+    },
+    read: function(a) {
+        this.features = [];
+        this.styles = {};
+        this.fetched = {};
+        return this.parseData(a, {
+            depth: 0,
+            styleBaseUrl: this.styleBaseUrl
+        })
+    },
+    parseData: function(a, b) {
+        "string" == typeof a &&
+            (a = OpenLayers.Format.XML.prototype.read.apply(this, [a]));
+        for (var c = ["Link", "NetworkLink", "Style", "StyleMap", "Placemark"], d = 0, e = c.length; d < e; ++d) {
+            var f = c[d],
+                g = this.getElementsByTagNameNS(a, "*", f);
+            if (0 != g.length) switch (f.toLowerCase()) {
+                case "link":
+                case "networklink":
+                    this.parseLinks(g, b);
+                    break;
+                case "style":
+                    this.extractStyles && this.parseStyles(g, b);
+                    break;
+                case "stylemap":
+                    this.extractStyles && this.parseStyleMaps(g, b);
+                    break;
+                case "placemark":
+                    this.parseFeatures(g, b)
+            }
+        }
+        return this.features
+    },
+    parseLinks: function(a,
+        b) {
+        if (b.depth >= this.maxDepth) return !1;
+        var c = OpenLayers.Util.extend({}, b);
+        c.depth++;
+        for (var d = 0, e = a.length; d < e; d++) {
+            var f = this.parseProperty(a[d], "*", "href");
+            f && !this.fetched[f] && (this.fetched[f] = !0, (f = this.fetchLink(f)) && this.parseData(f, c))
+        }
+    },
+    fetchLink: function(a) {
+        if (a = OpenLayers.Request.GET({
+                url: a,
+                async: !1
+            })) return a.responseText
+    },
+    parseStyles: function(a, b) {
+        for (var c = 0, d = a.length; c < d; c++) {
+            var e = this.parseStyle(a[c]);
+            e && (this.styles[(b.styleBaseUrl || "") + "#" + e.id] = e)
+        }
+    },
+    parseKmlColor: function(a) {
+        var b =
+            null;
+        a && (a = a.match(this.regExes.kmlColor)) && (b = {
+            color: "#" + a[4] + a[3] + a[2],
+            opacity: parseInt(a[1], 16) / 255
+        });
+        return b
+    },
+    parseStyle: function(a) {
+        for (var b = {}, c = ["LineStyle", "PolyStyle", "IconStyle", "BalloonStyle", "LabelStyle"], d, e, f = 0, g = c.length; f < g; ++f)
+            if (d = c[f], e = this.getElementsByTagNameNS(a, "*", d)[0]) switch (d.toLowerCase()) {
+                case "linestyle":
+                    d = this.parseProperty(e, "*", "color");
+                    if (d = this.parseKmlColor(d)) b.strokeColor = d.color, b.strokeOpacity = d.opacity;
+                    (d = this.parseProperty(e, "*", "width")) && (b.strokeWidth =
+                        d);
+                    break;
+                case "polystyle":
+                    d = this.parseProperty(e, "*", "color");
+                    if (d = this.parseKmlColor(d)) b.fillOpacity = d.opacity, b.fillColor = d.color;
+                    "0" == this.parseProperty(e, "*", "fill") && (b.fillColor = "none");
+                    "0" == this.parseProperty(e, "*", "outline") && (b.strokeWidth = "0");
+                    break;
+                case "iconstyle":
+                    var h = parseFloat(this.parseProperty(e, "*", "scale") || 1);
+                    d = 32 * h;
+                    var i = 32 * h,
+                        j = this.getElementsByTagNameNS(e, "*", "Icon")[0];
+                    if (j) {
+                        var k = this.parseProperty(j, "*", "href");
+                        if (k) {
+                            var l = this.parseProperty(j, "*", "w"),
+                                m = this.parseProperty(j,
+                                    "*", "h");
+                            OpenLayers.String.startsWith(k, "http://maps.google.com/mapfiles/kml") && (!l && !m) && (m = l = 64, h /= 2);
+                            l = l || m;
+                            m = m || l;
+                            l && (d = parseInt(l) * h);
+                            m && (i = parseInt(m) * h);
+                            if (m = k.match(this.regExes.kmlIconPalette)) l = m[1], m = m[2], k = this.parseProperty(j, "*", "x"), j = this.parseProperty(j, "*", "y"), k = "http://maps.google.com/mapfiles/kml/pal" + l + "/icon" + (8 * (j ? 7 - j / 32 : 7) + (k ? k / 32 : 0)) + m;
+                            b.graphicOpacity = 1;
+                            b.externalGraphic = k
+                        }
+                    }
+                    if (e = this.getElementsByTagNameNS(e, "*", "hotSpot")[0]) k = parseFloat(e.getAttribute("x")), j = parseFloat(e.getAttribute("y")),
+                        l = e.getAttribute("xunits"), "pixels" == l ? b.graphicXOffset = -k * h : "insetPixels" == l ? b.graphicXOffset = -d + k * h : "fraction" == l && (b.graphicXOffset = -d * k), e = e.getAttribute("yunits"), "pixels" == e ? b.graphicYOffset = -i + j * h + 1 : "insetPixels" == e ? b.graphicYOffset = -(j * h) + 1 : "fraction" == e && (b.graphicYOffset = -i * (1 - j) + 1);
+                    b.graphicWidth = d;
+                    b.graphicHeight = i;
+                    break;
+                case "balloonstyle":
+                    (e = OpenLayers.Util.getXmlNodeValue(e)) && (b.balloonStyle = e.replace(this.regExes.straightBracket, "${$1}"));
+                    break;
+                case "labelstyle":
+                    if (d = this.parseProperty(e,
+                            "*", "color"), d = this.parseKmlColor(d)) b.fontColor = d.color, b.fontOpacity = d.opacity
+            }!b.strokeColor && b.fillColor && (b.strokeColor = b.fillColor);
+        if ((a = a.getAttribute("id")) && b) b.id = a;
+        return b
+    },
+    parseStyleMaps: function(a, b) {
+        for (var c = 0, d = a.length; c < d; c++)
+            for (var e = a[c], f = this.getElementsByTagNameNS(e, "*", "Pair"), e = e.getAttribute("id"), g = 0, h = f.length; g < h; g++) {
+                var i = f[g],
+                    j = this.parseProperty(i, "*", "key");
+                (i = this.parseProperty(i, "*", "styleUrl")) && "normal" == j && (this.styles[(b.styleBaseUrl || "") + "#" + e] = this.styles[(b.styleBaseUrl ||
+                    "") + i])
+            }
+    },
+    parseFeatures: function(a, b) {
+        for (var c = [], d = 0, e = a.length; d < e; d++) {
+            var f = a[d],
+                g = this.parseFeature.apply(this, [f]);
+            if (g) {
+                this.extractStyles && (g.attributes && g.attributes.styleUrl) && (g.style = this.getStyle(g.attributes.styleUrl, b));
+                if (this.extractStyles) {
+                    var h = this.getElementsByTagNameNS(f, "*", "Style")[0];
+                    if (h && (h = this.parseStyle(h))) g.style = OpenLayers.Util.extend(g.style, h)
+                }
+                if (this.extractTracks) {
+                    if ((f = this.getElementsByTagNameNS(f, this.namespaces.gx, "Track")) && 0 < f.length) g = {
+                            features: [],
+                            feature: g
+                        },
+                        this.readNode(f[0], g), 0 < g.features.length && c.push.apply(c, g.features)
+                } else c.push(g)
+            } else throw "Bad Placemark: " + d;
+        }
+        this.features = this.features.concat(c)
+    },
+    readers: {
+        kml: {
+            when: function(a, b) {
+                b.whens.push(OpenLayers.Date.parse(this.getChildValue(a)))
+            },
+            _trackPointAttribute: function(a, b) {
+                var c = a.nodeName.split(":").pop();
+                b.attributes[c].push(this.getChildValue(a))
+            }
+        },
+        gx: {
+            Track: function(a, b) {
+                var c = {
+                    whens: [],
+                    points: [],
+                    angles: []
+                };
+                if (this.trackAttributes) {
+                    var d;
+                    c.attributes = {};
+                    for (var e = 0, f = this.trackAttributes.length; e <
+                        f; ++e) d = this.trackAttributes[e], c.attributes[d] = [], d in this.readers.kml || (this.readers.kml[d] = this.readers.kml._trackPointAttribute)
+                }
+                this.readChildNodes(a, c);
+                if (c.whens.length !== c.points.length) throw Error("gx:Track with unequal number of when (" + c.whens.length + ") and gx:coord (" + c.points.length + ") elements.");
+                var g = 0 < c.angles.length;
+                if (g && c.whens.length !== c.angles.length) throw Error("gx:Track with unequal number of when (" + c.whens.length + ") and gx:angles (" + c.angles.length + ") elements.");
+                for (var h,
+                        i, e = 0, f = c.whens.length; e < f; ++e) {
+                    h = b.feature.clone();
+                    h.fid = b.feature.fid || b.feature.id;
+                    i = c.points[e];
+                    h.geometry = i;
+                    "z" in i && (h.attributes.altitude = i.z);
+                    this.internalProjection && this.externalProjection && h.geometry.transform(this.externalProjection, this.internalProjection);
+                    if (this.trackAttributes) {
+                        i = 0;
+                        for (var j = this.trackAttributes.length; i < j; ++i) h.attributes[d] = c.attributes[this.trackAttributes[i]][e]
+                    }
+                    h.attributes.when = c.whens[e];
+                    h.attributes.trackId = b.feature.id;
+                    g && (i = c.angles[e], h.attributes.heading =
+                        parseFloat(i[0]), h.attributes.tilt = parseFloat(i[1]), h.attributes.roll = parseFloat(i[2]));
+                    b.features.push(h)
+                }
+            },
+            coord: function(a, b) {
+                var c = this.getChildValue(a).replace(this.regExes.trimSpace, "").split(/\s+/),
+                    d = new OpenLayers.Geometry.Point(c[0], c[1]);
+                2 < c.length && (d.z = parseFloat(c[2]));
+                b.points.push(d)
+            },
+            angles: function(a, b) {
+                var c = this.getChildValue(a).replace(this.regExes.trimSpace, "").split(/\s+/);
+                b.angles.push(c)
+            }
+        }
+    },
+    parseFeature: function(a) {
+        for (var b = ["MultiGeometry", "Polygon", "LineString", "Point"],
+                c, d, e, f = 0, g = b.length; f < g; ++f)
+            if (c = b[f], this.internalns = a.namespaceURI ? a.namespaceURI : this.kmlns, d = this.getElementsByTagNameNS(a, this.internalns, c), 0 < d.length) {
+                if (b = this.parseGeometry[c.toLowerCase()]) e = b.apply(this, [d[0]]), this.internalProjection && this.externalProjection && e.transform(this.externalProjection, this.internalProjection);
+                else throw new TypeError("Unsupported geometry type: " + c);
+                break
+            }
+        var h;
+        this.extractAttributes && (h = this.parseAttributes(a));
+        c = new OpenLayers.Feature.Vector(e, h);
+        a = a.getAttribute("id") ||
+            a.getAttribute("name");
+        null != a && (c.fid = a);
+        return c
+    },
+    getStyle: function(a, b) {
+        var c = OpenLayers.Util.removeTail(a),
+            d = OpenLayers.Util.extend({}, b);
+        d.depth++;
+        d.styleBaseUrl = c;
+        !this.styles[a] && !OpenLayers.String.startsWith(a, "#") && d.depth <= this.maxDepth && !this.fetched[c] && (c = this.fetchLink(c)) && this.parseData(c, d);
+        return OpenLayers.Util.extend({}, this.styles[a])
+    },
+    parseGeometry: {
+        point: function(a) {
+            var b = this.getElementsByTagNameNS(a, this.internalns, "coordinates"),
+                a = [];
+            if (0 < b.length) var c = b[0].firstChild.nodeValue,
+                c = c.replace(this.regExes.removeSpace, ""),
+                a = c.split(",");
+            b = null;
+            if (1 < a.length) 2 == a.length && (a[2] = null), b = new OpenLayers.Geometry.Point(a[0], a[1], a[2]);
+            else throw "Bad coordinate string: " + c;
+            return b
+        },
+        linestring: function(a, b) {
+            var c = this.getElementsByTagNameNS(a, this.internalns, "coordinates"),
+                d = null;
+            if (0 < c.length) {
+                for (var c = this.getChildValue(c[0]), c = c.replace(this.regExes.trimSpace, ""), c = c.replace(this.regExes.trimComma, ","), d = c.split(this.regExes.splitSpace), e = d.length, f = Array(e), g, h, i = 0; i < e; ++i)
+                    if (g =
+                        d[i].split(","), h = g.length, 1 < h) 2 == g.length && (g[2] = null), f[i] = new OpenLayers.Geometry.Point(g[0], g[1], g[2]);
+                    else throw "Bad LineString point coordinates: " + d[i];
+                if (e) d = b ? new OpenLayers.Geometry.LinearRing(f) : new OpenLayers.Geometry.LineString(f);
+                else throw "Bad LineString coordinates: " + c;
+            }
+            return d
+        },
+        polygon: function(a) {
+            var a = this.getElementsByTagNameNS(a, this.internalns, "LinearRing"),
+                b = a.length,
+                c = Array(b);
+            if (0 < b)
+                for (var d = 0, e = a.length; d < e; ++d)
+                    if (b = this.parseGeometry.linestring.apply(this, [a[d], !0])) c[d] =
+                        b;
+                    else throw "Bad LinearRing geometry: " + d;
+            return new OpenLayers.Geometry.Polygon(c)
+        },
+        multigeometry: function(a) {
+            for (var b, c = [], d = a.childNodes, e = 0, f = d.length; e < f; ++e) a = d[e], 1 == a.nodeType && (b = this.parseGeometry[(a.prefix ? a.nodeName.split(":")[1] : a.nodeName).toLowerCase()]) && c.push(b.apply(this, [a]));
+            return new OpenLayers.Geometry.Collection(c)
+        }
+    },
+    parseAttributes: function(a) {
+        var b = {},
+            c = a.getElementsByTagName("ExtendedData");
+        c.length && (b = this.parseExtendedData(c[0]));
+        for (var d, e, f, a = a.childNodes, c = 0, g =
+                a.length; c < g; ++c)
+            if (d = a[c], 1 == d.nodeType && (e = d.childNodes, 1 <= e.length && 3 >= e.length)) {
+                switch (e.length) {
+                    case 1:
+                        f = e[0];
+                        break;
+                    case 2:
+                        f = e[0];
+                        e = e[1];
+                        f = 3 == f.nodeType || 4 == f.nodeType ? f : e;
+                        break;
+                    default:
+                        f = e[1]
+                }
+                if (3 == f.nodeType || 4 == f.nodeType)
+                    if (d = d.prefix ? d.nodeName.split(":")[1] : d.nodeName, f = OpenLayers.Util.getXmlNodeValue(f)) f = f.replace(this.regExes.trimSpace, ""), b[d] = f
+            }
+        return b
+    },
+    parseExtendedData: function(a) {
+        var b = {},
+            c, d, e, f, g = a.getElementsByTagName("Data");
+        c = 0;
+        for (d = g.length; c < d; c++) {
+            e = g[c];
+            f = e.getAttribute("name");
+            var h = {},
+                i = e.getElementsByTagName("value");
+            i.length && (h.value = this.getChildValue(i[0]));
+            this.kvpAttributes ? b[f] = h.value : (e = e.getElementsByTagName("displayName"), e.length && (h.displayName = this.getChildValue(e[0])), b[f] = h)
+        }
+        a = a.getElementsByTagName("SimpleData");
+        c = 0;
+        for (d = a.length; c < d; c++) h = {}, e = a[c], f = e.getAttribute("name"), h.value = this.getChildValue(e), this.kvpAttributes ? b[f] = h.value : (h.displayName = f, b[f] = h);
+        return b
+    },
+    parseProperty: function(a, b, c) {
+        var d, a = this.getElementsByTagNameNS(a, b, c);
+        try {
+            d = OpenLayers.Util.getXmlNodeValue(a[0])
+        } catch (e) {
+            d =
+                null
+        }
+        return d
+    },
+    write: function(a) {
+        OpenLayers.Util.isArray(a) || (a = [a]);
+        for (var b = this.createElementNS(this.kmlns, "kml"), c = this.createFolderXML(), d = 0, e = a.length; d < e; ++d) c.appendChild(this.createPlacemarkXML(a[d]));
+        b.appendChild(c);
+        return OpenLayers.Format.XML.prototype.write.apply(this, [b])
+    },
+    createFolderXML: function() {
+        var a = this.createElementNS(this.kmlns, "Folder");
+        if (this.foldersName) {
+            var b = this.createElementNS(this.kmlns, "name"),
+                c = this.createTextNode(this.foldersName);
+            b.appendChild(c);
+            a.appendChild(b)
+        }
+        this.foldersDesc &&
+            (b = this.createElementNS(this.kmlns, "description"), c = this.createTextNode(this.foldersDesc), b.appendChild(c), a.appendChild(b));
+        return a
+    },
+    createPlacemarkXML: function(a) {
+        var b = this.createElementNS(this.kmlns, "name");
+        b.appendChild(this.createTextNode(a.style && a.style.label ? a.style.label : a.attributes.name || a.id));
+        var c = this.createElementNS(this.kmlns, "description");
+        c.appendChild(this.createTextNode(a.attributes.description || this.placemarksDesc));
+        var d = this.createElementNS(this.kmlns, "Placemark");
+        null !=
+            a.fid && d.setAttribute("id", a.fid);
+        d.appendChild(b);
+        d.appendChild(c);
+        b = this.buildGeometryNode(a.geometry);
+        d.appendChild(b);
+        a.attributes && (a = this.buildExtendedData(a.attributes)) && d.appendChild(a);
+        return d
+    },
+    buildGeometryNode: function(a) {
+        var b = a.CLASS_NAME,
+            b = this.buildGeometry[b.substring(b.lastIndexOf(".") + 1).toLowerCase()],
+            c = null;
+        b && (c = b.apply(this, [a]));
+        return c
+    },
+    buildGeometry: {
+        point: function(a) {
+            var b = this.createElementNS(this.kmlns, "Point");
+            b.appendChild(this.buildCoordinatesNode(a));
+            return b
+        },
+        multipoint: function(a) {
+            return this.buildGeometry.collection.apply(this, [a])
+        },
+        linestring: function(a) {
+            var b = this.createElementNS(this.kmlns, "LineString");
+            b.appendChild(this.buildCoordinatesNode(a));
+            return b
+        },
+        multilinestring: function(a) {
+            return this.buildGeometry.collection.apply(this, [a])
+        },
+        linearring: function(a) {
+            var b = this.createElementNS(this.kmlns, "LinearRing");
+            b.appendChild(this.buildCoordinatesNode(a));
+            return b
+        },
+        polygon: function(a) {
+            for (var b = this.createElementNS(this.kmlns, "Polygon"), a = a.components, c, d, e = 0, f = a.length; e < f; ++e) c = 0 == e ? "outerBoundaryIs" : "innerBoundaryIs",
+                c = this.createElementNS(this.kmlns, c), d = this.buildGeometry.linearring.apply(this, [a[e]]), c.appendChild(d), b.appendChild(c);
+            return b
+        },
+        multipolygon: function(a) {
+            return this.buildGeometry.collection.apply(this, [a])
+        },
+        collection: function(a) {
+            for (var b = this.createElementNS(this.kmlns, "MultiGeometry"), c, d = 0, e = a.components.length; d < e; ++d)(c = this.buildGeometryNode.apply(this, [a.components[d]])) && b.appendChild(c);
+            return b
+        }
+    },
+    buildCoordinatesNode: function(a) {
+        var b = this.createElementNS(this.kmlns, "coordinates"),
+            c;
+        if (c = a.components) {
+            for (var d = c.length, e = Array(d), f = 0; f < d; ++f) a = c[f], e[f] = this.buildCoordinates(a);
+            c = e.join(" ")
+        } else c = this.buildCoordinates(a);
+        c = this.createTextNode(c);
+        b.appendChild(c);
+        return b
+    },
+    buildCoordinates: function(a) {
+        this.internalProjection && this.externalProjection && (a = a.clone(), a.transform(this.internalProjection, this.externalProjection));
+        return a.x + "," + a.y
+    },
+    buildExtendedData: function(a) {
+        var b = this.createElementNS(this.kmlns, "ExtendedData"),
+            c;
+        for (c in a)
+            if (a[c] && "name" != c && "description" !=
+                c && "styleUrl" != c) {
+                var d = this.createElementNS(this.kmlns, "Data");
+                d.setAttribute("name", c);
+                var e = this.createElementNS(this.kmlns, "value");
+                if ("object" == typeof a[c]) {
+                    if (a[c].value && e.appendChild(this.createTextNode(a[c].value)), a[c].displayName) {
+                        var f = this.createElementNS(this.kmlns, "displayName");
+                        f.appendChild(this.getXMLDoc().createCDATASection(a[c].displayName));
+                        d.appendChild(f)
+                    }
+                } else e.appendChild(this.createTextNode(a[c]));
+                d.appendChild(e);
+                b.appendChild(d)
+            }
+        return this.isSimpleContent(b) ? null : b
+    },
+    CLASS_NAME: "OpenLayers.Format.KML"
+});
+OpenLayers.Popup = OpenLayers.Class({
+    events: null,
+    id: "",
+    lonlat: null,
+    div: null,
+    contentSize: null,
+    size: null,
+    contentHTML: null,
+    backgroundColor: "",
+    opacity: "",
+    border: "",
+    contentDiv: null,
+    groupDiv: null,
+    closeDiv: null,
+    autoSize: !1,
+    minSize: null,
+    maxSize: null,
+    displayClass: "olPopup",
+    contentDisplayClass: "olPopupContent",
+    padding: 0,
+    disableFirefoxOverflowHack: !1,
+    fixPadding: function() {
+        "number" == typeof this.padding && (this.padding = new OpenLayers.Bounds(this.padding, this.padding, this.padding, this.padding))
+    },
+    panMapIfOutOfView: !1,
+    keepInMap: !1,
+    closeOnMove: !1,
+    map: null,
+    initialize: function(a, b, c, d, e, f) {
+        null == a && (a = OpenLayers.Util.createUniqueID(this.CLASS_NAME + "_"));
+        this.id = a;
+        this.lonlat = b;
+        this.contentSize = null != c ? c : new OpenLayers.Size(OpenLayers.Popup.WIDTH, OpenLayers.Popup.HEIGHT);
+        null != d && (this.contentHTML = d);
+        this.backgroundColor = OpenLayers.Popup.COLOR;
+        this.opacity = OpenLayers.Popup.OPACITY;
+        this.border = OpenLayers.Popup.BORDER;
+        this.div = OpenLayers.Util.createDiv(this.id, null, null, null, null, null, "hidden");
+        this.div.className = this.displayClass;
+        this.groupDiv = OpenLayers.Util.createDiv(this.id + "_GroupDiv", null, null, null, "relative", null, "hidden");
+        a = this.div.id + "_contentDiv";
+        this.contentDiv = OpenLayers.Util.createDiv(a, null, this.contentSize.clone(), null, "relative");
+        this.contentDiv.className = this.contentDisplayClass;
+        this.groupDiv.appendChild(this.contentDiv);
+        this.div.appendChild(this.groupDiv);
+        e && this.addCloseBox(f);
+        this.registerEvents()
+    },
+    destroy: function() {
+        this.border = this.opacity = this.backgroundColor = this.contentHTML = this.size = this.lonlat = this.id =
+            null;
+        this.closeOnMove && this.map && this.map.events.unregister("movestart", this, this.hide);
+        this.events.destroy();
+        this.events = null;
+        this.closeDiv && (OpenLayers.Event.stopObservingElement(this.closeDiv), this.groupDiv.removeChild(this.closeDiv));
+        this.closeDiv = null;
+        this.div.removeChild(this.groupDiv);
+        this.groupDiv = null;
+        null != this.map && this.map.removePopup(this);
+        this.panMapIfOutOfView = this.padding = this.maxSize = this.minSize = this.autoSize = this.div = this.map = null
+    },
+    draw: function(a) {
+        null == a && null != this.lonlat && null !=
+            this.map && (a = this.map.getLayerPxFromLonLat(this.lonlat));
+        this.closeOnMove && this.map.events.register("movestart", this, this.hide);
+        !this.disableFirefoxOverflowHack && "firefox" == OpenLayers.BROWSER_NAME && (this.map.events.register("movestart", this, function() {
+            var a = document.defaultView.getComputedStyle(this.contentDiv, null).getPropertyValue("overflow");
+            "hidden" != a && (this.contentDiv._oldOverflow = a, this.contentDiv.style.overflow = "hidden")
+        }), this.map.events.register("moveend", this, function() {
+            var a = this.contentDiv._oldOverflow;
+            a && (this.contentDiv.style.overflow = a, this.contentDiv._oldOverflow = null)
+        }));
+        this.moveTo(a);
+        !this.autoSize && !this.size && this.setSize(this.contentSize);
+        this.setBackgroundColor();
+        this.setOpacity();
+        this.setBorder();
+        this.setContentHTML();
+        this.panMapIfOutOfView && this.panIntoView();
+        return this.div
+    },
+    updatePosition: function() {
+        if (this.lonlat && this.map) {
+            var a = this.map.getLayerPxFromLonLat(this.lonlat);
+            a && this.moveTo(a)
+        }
+    },
+    moveTo: function(a) {
+        null != a && null != this.div && (this.div.style.left = a.x + "px", this.div.style.top =
+            a.y + "px")
+    },
+    visible: function() {
+        return OpenLayers.Element.visible(this.div)
+    },
+    toggle: function() {
+        this.visible() ? this.hide() : this.show()
+    },
+    show: function() {
+        this.div.style.display = "";
+        this.panMapIfOutOfView && this.panIntoView()
+    },
+    hide: function() {
+        this.div.style.display = "none"
+    },
+    setSize: function(a) {
+        this.size = a.clone();
+        var b = this.getContentDivPadding(),
+            c = b.left + b.right,
+            d = b.top + b.bottom;
+        this.fixPadding();
+        c += this.padding.left + this.padding.right;
+        d += this.padding.top + this.padding.bottom;
+        if (this.closeDiv) var e = parseInt(this.closeDiv.style.width),
+            c = c + (e + b.right);
+        this.size.w += c;
+        this.size.h += d;
+        "msie" == OpenLayers.BROWSER_NAME && (this.contentSize.w += b.left + b.right, this.contentSize.h += b.bottom + b.top);
+        null != this.div && (this.div.style.width = this.size.w + "px", this.div.style.height = this.size.h + "px");
+        null != this.contentDiv && (this.contentDiv.style.width = a.w + "px", this.contentDiv.style.height = a.h + "px")
+    },
+    updateSize: function() {
+        var a = "<div class='" + this.contentDisplayClass + "'>" + this.contentDiv.innerHTML + "</div>",
+            b = this.map ? this.map.div : document.body,
+            c = OpenLayers.Util.getRenderedDimensions(a,
+                null, {
+                    displayClass: this.displayClass,
+                    containerElement: b
+                }),
+            d = this.getSafeContentSize(c),
+            e = null;
+        d.equals(c) ? e = c : (c = {
+            w: d.w < c.w ? d.w : null,
+            h: d.h < c.h ? d.h : null
+        }, c.w && c.h ? e = d : (a = OpenLayers.Util.getRenderedDimensions(a, c, {
+            displayClass: this.contentDisplayClass,
+            containerElement: b
+        }), "hidden" != OpenLayers.Element.getStyle(this.contentDiv, "overflow") && a.equals(d) && (d = OpenLayers.Util.getScrollbarWidth(), c.w ? a.h += d : a.w += d), e = this.getSafeContentSize(a)));
+        this.setSize(e)
+    },
+    setBackgroundColor: function(a) {
+        void 0 != a && (this.backgroundColor =
+            a);
+        null != this.div && (this.div.style.backgroundColor = this.backgroundColor)
+    },
+    setOpacity: function(a) {
+        void 0 != a && (this.opacity = a);
+        null != this.div && (this.div.style.opacity = this.opacity, this.div.style.filter = "alpha(opacity=" + 100 * this.opacity + ")")
+    },
+    setBorder: function(a) {
+        void 0 != a && (this.border = a);
+        null != this.div && (this.div.style.border = this.border)
+    },
+    setContentHTML: function(a) {
+        null != a && (this.contentHTML = a);
+        null != this.contentDiv && (null != this.contentHTML && this.contentHTML != this.contentDiv.innerHTML) && (this.contentDiv.innerHTML =
+            this.contentHTML, this.autoSize && (this.registerImageListeners(), this.updateSize()))
+    },
+    registerImageListeners: function() {
+        for (var a = function() {
+                null !== this.popup.id && (this.popup.updateSize(), this.popup.visible() && this.popup.panMapIfOutOfView && this.popup.panIntoView(), OpenLayers.Event.stopObserving(this.img, "load", this.img._onImageLoad))
+            }, b = this.contentDiv.getElementsByTagName("img"), c = 0, d = b.length; c < d; c++) {
+            var e = b[c];
+            if (0 == e.width || 0 == e.height) e._onImgLoad = OpenLayers.Function.bind(a, {
+                    popup: this,
+                    img: e
+                }),
+                OpenLayers.Event.observe(e, "load", e._onImgLoad)
+        }
+    },
+    getSafeContentSize: function(a) {
+        var a = a.clone(),
+            b = this.getContentDivPadding(),
+            c = b.left + b.right,
+            d = b.top + b.bottom;
+        this.fixPadding();
+        c += this.padding.left + this.padding.right;
+        d += this.padding.top + this.padding.bottom;
+        if (this.closeDiv) var e = parseInt(this.closeDiv.style.width),
+            c = c + (e + b.right);
+        this.minSize && (a.w = Math.max(a.w, this.minSize.w - c), a.h = Math.max(a.h, this.minSize.h - d));
+        this.maxSize && (a.w = Math.min(a.w, this.maxSize.w - c), a.h = Math.min(a.h, this.maxSize.h -
+            d));
+        if (this.map && this.map.size) {
+            e = b = 0;
+            if (this.keepInMap && !this.panMapIfOutOfView) switch (e = this.map.getPixelFromLonLat(this.lonlat), this.relativePosition) {
+                case "tr":
+                    b = e.x;
+                    e = this.map.size.h - e.y;
+                    break;
+                case "tl":
+                    b = this.map.size.w - e.x;
+                    e = this.map.size.h - e.y;
+                    break;
+                case "bl":
+                    b = this.map.size.w - e.x;
+                    e = e.y;
+                    break;
+                case "br":
+                    b = e.x;
+                    e = e.y;
+                    break;
+                default:
+                    b = e.x, e = this.map.size.h - e.y
+            }
+            d = this.map.size.h - this.map.paddingForPopups.top - this.map.paddingForPopups.bottom - d - e;
+            a.w = Math.min(a.w, this.map.size.w - this.map.paddingForPopups.left -
+                this.map.paddingForPopups.right - c - b);
+            a.h = Math.min(a.h, d)
+        }
+        return a
+    },
+    getContentDivPadding: function() {
+        var a = this._contentDivPadding;
+        if (!a && (null == this.div.parentNode && (this.div.style.display = "none", document.body.appendChild(this.div)), this._contentDivPadding = a = new OpenLayers.Bounds(OpenLayers.Element.getStyle(this.contentDiv, "padding-left"), OpenLayers.Element.getStyle(this.contentDiv, "padding-bottom"), OpenLayers.Element.getStyle(this.contentDiv, "padding-right"), OpenLayers.Element.getStyle(this.contentDiv,
+                "padding-top")), this.div.parentNode == document.body)) document.body.removeChild(this.div), this.div.style.display = "";
+        return a
+    },
+    addCloseBox: function(a) {
+        this.closeDiv = OpenLayers.Util.createDiv(this.id + "_close", null, {
+            w: 17,
+            h: 17
+        });
+        this.closeDiv.className = "olPopupCloseBox";
+        var b = this.getContentDivPadding();
+        this.closeDiv.style.right = b.right + "px";
+        this.closeDiv.style.top = b.top + "px";
+        this.groupDiv.appendChild(this.closeDiv);
+        a = a || function(a) {
+            this.hide();
+            OpenLayers.Event.stop(a)
+        };
+        OpenLayers.Event.observe(this.closeDiv,
+            "touchend", OpenLayers.Function.bindAsEventListener(a, this));
+        OpenLayers.Event.observe(this.closeDiv, "click", OpenLayers.Function.bindAsEventListener(a, this))
+    },
+    panIntoView: function() {
+        var a = this.map.getSize(),
+            b = this.map.getViewPortPxFromLayerPx(new OpenLayers.Pixel(parseInt(this.div.style.left), parseInt(this.div.style.top))),
+            c = b.clone();
+        b.x < this.map.paddingForPopups.left ? c.x = this.map.paddingForPopups.left : b.x + this.size.w > a.w - this.map.paddingForPopups.right && (c.x = a.w - this.map.paddingForPopups.right - this.size.w);
+        b.y < this.map.paddingForPopups.top ? c.y = this.map.paddingForPopups.top : b.y + this.size.h > a.h - this.map.paddingForPopups.bottom && (c.y = a.h - this.map.paddingForPopups.bottom - this.size.h);
+        this.map.pan(b.x - c.x, b.y - c.y)
+    },
+    registerEvents: function() {
+        this.events = new OpenLayers.Events(this, this.div, null, !0);
+        this.events.on({
+            mousedown: this.onmousedown,
+            mousemove: this.onmousemove,
+            mouseup: this.onmouseup,
+            click: this.onclick,
+            mouseout: this.onmouseout,
+            dblclick: this.ondblclick,
+            touchstart: function(a) {
+                OpenLayers.Event.stop(a, !0)
+            },
+            scope: this
+        })
+    },
+    onmousedown: function(a) {
+        this.mousedown = !0;
+        OpenLayers.Event.stop(a, !0)
+    },
+    onmousemove: function(a) {
+        this.mousedown && OpenLayers.Event.stop(a, !0)
+    },
+    onmouseup: function(a) {
+        this.mousedown && (this.mousedown = !1, OpenLayers.Event.stop(a, !0))
+    },
+    onclick: function(a) {
+        OpenLayers.Event.stop(a, !0)
+    },
+    onmouseout: function() {
+        this.mousedown = !1
+    },
+    ondblclick: function(a) {
+        OpenLayers.Event.stop(a, !0)
+    },
+    CLASS_NAME: "OpenLayers.Popup"
+});
+OpenLayers.Popup.WIDTH = 200;
+OpenLayers.Popup.HEIGHT = 200;
+OpenLayers.Popup.COLOR = "white";
+OpenLayers.Popup.OPACITY = 1;
+OpenLayers.Popup.BORDER = "0px";
+OpenLayers.Popup.Anchored = OpenLayers.Class(OpenLayers.Popup, {
+    relativePosition: null,
+    keepInMap: !0,
+    anchor: null,
+    initialize: function(a, b, c, d, e, f, g) {
+        OpenLayers.Popup.prototype.initialize.apply(this, [a, b, c, d, f, g]);
+        this.anchor = null != e ? e : {
+            size: new OpenLayers.Size(0, 0),
+            offset: new OpenLayers.Pixel(0, 0)
+        }
+    },
+    destroy: function() {
+        this.relativePosition = this.anchor = null;
+        OpenLayers.Popup.prototype.destroy.apply(this, arguments)
+    },
+    show: function() {
+        this.updatePosition();
+        OpenLayers.Popup.prototype.show.apply(this, arguments)
+    },
+    moveTo: function(a) {
+        var b = this.relativePosition;
+        this.relativePosition = this.calculateRelativePosition(a);
+        a = this.calculateNewPx(a);
+        OpenLayers.Popup.prototype.moveTo.apply(this, Array(a));
+        this.relativePosition != b && this.updateRelativePosition()
+    },
+    setSize: function(a) {
+        OpenLayers.Popup.prototype.setSize.apply(this, arguments);
+        this.lonlat && this.map && this.moveTo(this.map.getLayerPxFromLonLat(this.lonlat))
+    },
+    calculateRelativePosition: function(a) {
+        a = this.map.getLonLatFromLayerPx(a);
+        a = this.map.getExtent().determineQuadrant(a);
+        return OpenLayers.Bounds.oppositeQuadrant(a)
+    },
+    updateRelativePosition: function() {},
+    calculateNewPx: function(a) {
+        var a = a.offset(this.anchor.offset),
+            b = this.size || this.contentSize,
+            c = "t" == this.relativePosition.charAt(0);
+        a.y += c ? -b.h : this.anchor.size.h;
+        c = "l" == this.relativePosition.charAt(1);
+        a.x += c ? -b.w : this.anchor.size.w;
+        return a
+    },
+    CLASS_NAME: "OpenLayers.Popup.Anchored"
+});
+/*
+ Apache 2 
+
+ Contains portions of Rico <http://openrico.org/>
+
+ Copyright 2005 Sabre Airline Solutions  
+
+ Licensed under the Apache License, Version 2.0 (the "License"); you
+ may not use this file except in compliance with the License. You
+ may obtain a copy of the License at
+
+     http://www.apache.org/licenses/LICENSE-2.0  
+
+ Unless required by applicable law or agreed to in writing, software
+ distributed under the License is distributed on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
+ implied. See the License for the specific language governing
+ permissions and limitations under the License. 
+*/
+OpenLayers.Console.warn("OpenLayers.Rico is deprecated");
+OpenLayers.Rico = OpenLayers.Rico || {};
+OpenLayers.Rico.Color = OpenLayers.Class({
+    initialize: function(a, b, c) {
+        this.rgb = {
+            r: a,
+            g: b,
+            b: c
+        }
+    },
+    setRed: function(a) {
+        this.rgb.r = a
+    },
+    setGreen: function(a) {
+        this.rgb.g = a
+    },
+    setBlue: function(a) {
+        this.rgb.b = a
+    },
+    setHue: function(a) {
+        var b = this.asHSB();
+        b.h = a;
+        this.rgb = OpenLayers.Rico.Color.HSBtoRGB(b.h, b.s, b.b)
+    },
+    setSaturation: function(a) {
+        var b = this.asHSB();
+        b.s = a;
+        this.rgb = OpenLayers.Rico.Color.HSBtoRGB(b.h, b.s, b.b)
+    },
+    setBrightness: function(a) {
+        var b = this.asHSB();
+        b.b = a;
+        this.rgb = OpenLayers.Rico.Color.HSBtoRGB(b.h, b.s, b.b)
+    },
+    darken: function(a) {
+        var b = this.asHSB();
+        this.rgb = OpenLayers.Rico.Color.HSBtoRGB(b.h, b.s, Math.max(b.b - a, 0))
+    },
+    brighten: function(a) {
+        var b = this.asHSB();
+        this.rgb = OpenLayers.Rico.Color.HSBtoRGB(b.h, b.s, Math.min(b.b + a, 1))
+    },
+    blend: function(a) {
+        this.rgb.r = Math.floor((this.rgb.r + a.rgb.r) / 2);
+        this.rgb.g = Math.floor((this.rgb.g + a.rgb.g) / 2);
+        this.rgb.b = Math.floor((this.rgb.b + a.rgb.b) / 2)
+    },
+    isBright: function() {
+        this.asHSB();
+        return 0.5 < this.asHSB().b
+    },
+    isDark: function() {
+        return !this.isBright()
+    },
+    asRGB: function() {
+        return "rgb(" +
+            this.rgb.r + "," + this.rgb.g + "," + this.rgb.b + ")"
+    },
+    asHex: function() {
+        return "#" + this.rgb.r.toColorPart() + this.rgb.g.toColorPart() + this.rgb.b.toColorPart()
+    },
+    asHSB: function() {
+        return OpenLayers.Rico.Color.RGBtoHSB(this.rgb.r, this.rgb.g, this.rgb.b)
+    },
+    toString: function() {
+        return this.asHex()
+    }
+});
+OpenLayers.Rico.Color.createFromHex = function(a) {
+    if (4 == a.length)
+        for (var b = a, a = "#", c = 1; 4 > c; c++) a += b.charAt(c) + b.charAt(c);
+    0 == a.indexOf("#") && (a = a.substring(1));
+    b = a.substring(0, 2);
+    c = a.substring(2, 4);
+    a = a.substring(4, 6);
+    return new OpenLayers.Rico.Color(parseInt(b, 16), parseInt(c, 16), parseInt(a, 16))
+};
+OpenLayers.Rico.Color.createColorFromBackground = function(a) {
+    var b = OpenLayers.Element.getStyle(OpenLayers.Util.getElement(a), "backgroundColor");
+    return "transparent" == b && a.parentNode ? OpenLayers.Rico.Color.createColorFromBackground(a.parentNode) : null == b ? new OpenLayers.Rico.Color(255, 255, 255) : 0 == b.indexOf("rgb(") ? (a = b.substring(4, b.length - 1).split(","), new OpenLayers.Rico.Color(parseInt(a[0]), parseInt(a[1]), parseInt(a[2]))) : 0 == b.indexOf("#") ? OpenLayers.Rico.Color.createFromHex(b) : new OpenLayers.Rico.Color(255,
+        255, 255)
+};
+OpenLayers.Rico.Color.HSBtoRGB = function(a, b, c) {
+    var d = 0,
+        e = 0,
+        f = 0;
+    if (0 == b) f = e = d = parseInt(255 * c + 0.5);
+    else {
+        var a = 6 * (a - Math.floor(a)),
+            g = a - Math.floor(a),
+            h = c * (1 - b),
+            i = c * (1 - b * g),
+            b = c * (1 - b * (1 - g));
+        switch (parseInt(a)) {
+            case 0:
+                d = 255 * c + 0.5;
+                e = 255 * b + 0.5;
+                f = 255 * h + 0.5;
+                break;
+            case 1:
+                d = 255 * i + 0.5;
+                e = 255 * c + 0.5;
+                f = 255 * h + 0.5;
+                break;
+            case 2:
+                d = 255 * h + 0.5;
+                e = 255 * c + 0.5;
+                f = 255 * b + 0.5;
+                break;
+            case 3:
+                d = 255 * h + 0.5;
+                e = 255 * i + 0.5;
+                f = 255 * c + 0.5;
+                break;
+            case 4:
+                d = 255 * b + 0.5;
+                e = 255 * h + 0.5;
+                f = 255 * c + 0.5;
+                break;
+            case 5:
+                d = 255 * c + 0.5, e = 255 * h + 0.5, f = 255 * i + 0.5
+        }
+    }
+    return {
+        r: parseInt(d),
+        g: parseInt(e),
+        b: parseInt(f)
+    }
+};
+OpenLayers.Rico.Color.RGBtoHSB = function(a, b, c) {
+    var d, e = a > b ? a : b;
+    c > e && (e = c);
+    var f = a < b ? a : b;
+    c < f && (f = c);
+    d = 0 != e ? (e - f) / e : 0;
+    if (0 == d) a = 0;
+    else {
+        var g = (e - a) / (e - f),
+            h = (e - b) / (e - f),
+            c = (e - c) / (e - f),
+            a = (a == e ? c - h : b == e ? 2 + g - c : 4 + h - g) / 6;
+        0 > a && (a += 1)
+    }
+    return {
+        h: a,
+        s: d,
+        b: e / 255
+    }
+};
+OpenLayers.Console.warn("OpenLayers.Rico is deprecated");
+OpenLayers.Rico = OpenLayers.Rico || {};
+OpenLayers.Rico.Corner = {
+    round: function(a, b) {
+        a = OpenLayers.Util.getElement(a);
+        this._setOptions(b);
+        var c = this.options.color;
+        "fromElement" == this.options.color && (c = this._background(a));
+        var d = this.options.bgColor;
+        "fromParent" == this.options.bgColor && (d = this._background(a.offsetParent));
+        this._roundCornersImpl(a, c, d)
+    },
+    changeColor: function(a, b) {
+        a.style.backgroundColor = b;
+        for (var c = a.parentNode.getElementsByTagName("span"), d = 0; d < c.length; d++) c[d].style.backgroundColor = b
+    },
+    changeOpacity: function(a, b) {
+        var c = "alpha(opacity=" +
+            100 * b + ")";
+        a.style.opacity = b;
+        a.style.filter = c;
+        for (var d = a.parentNode.getElementsByTagName("span"), e = 0; e < d.length; e++) d[e].style.opacity = b, d[e].style.filter = c
+    },
+    reRound: function(a, b) {
+        var c = a.parentNode.childNodes[2];
+        a.parentNode.removeChild(a.parentNode.childNodes[0]);
+        a.parentNode.removeChild(c);
+        this.round(a.parentNode, b)
+    },
+    _roundCornersImpl: function(a, b, c) {
+        this.options.border && this._renderBorder(a, c);
+        this._isTopRounded() && this._roundTopCorners(a, b, c);
+        this._isBottomRounded() && this._roundBottomCorners(a,
+            b, c)
+    },
+    _renderBorder: function(a, b) {
+        var c = "1px solid " + this._borderColor(b);
+        a.innerHTML = "<div " + ("style='border-left: " + c + ";" + ("border-right: " + c) + "'") + ">" + a.innerHTML + "</div>"
+    },
+    _roundTopCorners: function(a, b, c) {
+        for (var d = this._createCorner(c), e = 0; e < this.options.numSlices; e++) d.appendChild(this._createCornerSlice(b, c, e, "top"));
+        a.style.paddingTop = 0;
+        a.insertBefore(d, a.firstChild)
+    },
+    _roundBottomCorners: function(a, b, c) {
+        for (var d = this._createCorner(c), e = this.options.numSlices - 1; 0 <= e; e--) d.appendChild(this._createCornerSlice(b,
+            c, e, "bottom"));
+        a.style.paddingBottom = 0;
+        a.appendChild(d)
+    },
+    _createCorner: function(a) {
+        var b = document.createElement("div");
+        b.style.backgroundColor = this._isTransparent() ? "transparent" : a;
+        return b
+    },
+    _createCornerSlice: function(a, b, c, d) {
+        var e = document.createElement("span"),
+            f = e.style;
+        f.backgroundColor = a;
+        f.display = "block";
+        f.height = "1px";
+        f.overflow = "hidden";
+        f.fontSize = "1px";
+        a = this._borderColor(a, b);
+        this.options.border && 0 == c ? (f.borderTopStyle = "solid", f.borderTopWidth = "1px", f.borderLeftWidth = "0px", f.borderRightWidth =
+            "0px", f.borderBottomWidth = "0px", f.height = "0px", f.borderColor = a) : a && (f.borderColor = a, f.borderStyle = "solid", f.borderWidth = "0px 1px");
+        !this.options.compact && c == this.options.numSlices - 1 && (f.height = "2px");
+        this._setMargin(e, c, d);
+        this._setBorder(e, c, d);
+        return e
+    },
+    _setOptions: function(a) {
+        this.options = {
+            corners: "all",
+            color: "fromElement",
+            bgColor: "fromParent",
+            blend: !0,
+            border: !1,
+            compact: !1
+        };
+        OpenLayers.Util.extend(this.options, a || {});
+        this.options.numSlices = this.options.compact ? 2 : 4;
+        this._isTransparent() && (this.options.blend = !1)
+    },
+    _whichSideTop: function() {
+        return this._hasString(this.options.corners, "all", "top") || 0 <= this.options.corners.indexOf("tl") && 0 <= this.options.corners.indexOf("tr") ? "" : 0 <= this.options.corners.indexOf("tl") ? "left" : 0 <= this.options.corners.indexOf("tr") ? "right" : ""
+    },
+    _whichSideBottom: function() {
+        return this._hasString(this.options.corners, "all", "bottom") || 0 <= this.options.corners.indexOf("bl") && 0 <= this.options.corners.indexOf("br") ? "" : 0 <= this.options.corners.indexOf("bl") ? "left" : 0 <= this.options.corners.indexOf("br") ?
+            "right" : ""
+    },
+    _borderColor: function(a, b) {
+        return "transparent" == a ? b : this.options.border ? this.options.border : this.options.blend ? this._blend(b, a) : ""
+    },
+    _setMargin: function(a, b, c) {
+        b = this._marginSize(b);
+        c = "top" == c ? this._whichSideTop() : this._whichSideBottom();
+        "left" == c ? (a.style.marginLeft = b + "px", a.style.marginRight = "0px") : "right" == c ? (a.style.marginRight = b + "px", a.style.marginLeft = "0px") : (a.style.marginLeft = b + "px", a.style.marginRight = b + "px")
+    },
+    _setBorder: function(a, b, c) {
+        b = this._borderSize(b);
+        c = "top" == c ? this._whichSideTop() :
+            this._whichSideBottom();
+        "left" == c ? (a.style.borderLeftWidth = b + "px", a.style.borderRightWidth = "0px") : "right" == c ? (a.style.borderRightWidth = b + "px", a.style.borderLeftWidth = "0px") : (a.style.borderLeftWidth = b + "px", a.style.borderRightWidth = b + "px");
+        !1 != this.options.border && (a.style.borderLeftWidth = b + "px", a.style.borderRightWidth = b + "px")
+    },
+    _marginSize: function(a) {
+        if (this._isTransparent()) return 0;
+        var b = [5, 3, 2, 1],
+            c = [3, 2, 1, 0],
+            d = [2, 1],
+            e = [1, 0];
+        return this.options.compact && this.options.blend ? e[a] : this.options.compact ?
+            d[a] : this.options.blend ? c[a] : b[a]
+    },
+    _borderSize: function(a) {
+        var b = [5, 3, 2, 1],
+            c = [2, 1, 1, 1],
+            d = [1, 0],
+            e = [0, 2, 0, 0];
+        return this.options.compact && (this.options.blend || this._isTransparent()) ? 1 : this.options.compact ? d[a] : this.options.blend ? c[a] : this.options.border ? e[a] : this._isTransparent() ? b[a] : 0
+    },
+    _hasString: function(a) {
+        for (var b = 1; b < arguments.length; b++)
+            if (0 <= a.indexOf(arguments[b])) return !0;
+        return !1
+    },
+    _blend: function(a, b) {
+        var c = OpenLayers.Rico.Color.createFromHex(a);
+        c.blend(OpenLayers.Rico.Color.createFromHex(b));
+        return c
+    },
+    _background: function(a) {
+        try {
+            return OpenLayers.Rico.Color.createColorFromBackground(a).asHex()
+        } catch (b) {
+            return "#ffffff"
+        }
+    },
+    _isTransparent: function() {
+        return "transparent" == this.options.color
+    },
+    _isTopRounded: function() {
+        return this._hasString(this.options.corners, "all", "top", "tl", "tr")
+    },
+    _isBottomRounded: function() {
+        return this._hasString(this.options.corners, "all", "bottom", "bl", "br")
+    },
+    _hasSingleTextChild: function(a) {
+        return 1 == a.childNodes.length && 3 == a.childNodes[0].nodeType
+    }
+};
+OpenLayers.Popup.AnchoredBubble = OpenLayers.Class(OpenLayers.Popup.Anchored, {
+    rounded: !1,
+    initialize: function(a, b, c, d, e, f, g) {
+        OpenLayers.Console.warn("AnchoredBubble is deprecated");
+        this.padding = new OpenLayers.Bounds(0, OpenLayers.Popup.AnchoredBubble.CORNER_SIZE, 0, OpenLayers.Popup.AnchoredBubble.CORNER_SIZE);
+        OpenLayers.Popup.Anchored.prototype.initialize.apply(this, arguments)
+    },
+    draw: function(a) {
+        OpenLayers.Popup.Anchored.prototype.draw.apply(this, arguments);
+        this.setContentHTML();
+        this.setBackgroundColor();
+        this.setOpacity();
+        return this.div
+    },
+    updateRelativePosition: function() {
+        this.setRicoCorners()
+    },
+    setSize: function(a) {
+        OpenLayers.Popup.Anchored.prototype.setSize.apply(this, arguments);
+        this.setRicoCorners()
+    },
+    setBackgroundColor: function(a) {
+        void 0 != a && (this.backgroundColor = a);
+        null != this.div && null != this.contentDiv && (this.div.style.background = "transparent", OpenLayers.Rico.Corner.changeColor(this.groupDiv, this.backgroundColor))
+    },
+    setOpacity: function(a) {
+        OpenLayers.Popup.Anchored.prototype.setOpacity.call(this,
+            a);
+        null != this.div && null != this.groupDiv && OpenLayers.Rico.Corner.changeOpacity(this.groupDiv, this.opacity)
+    },
+    setBorder: function() {
+        this.border = 0
+    },
+    setRicoCorners: function() {
+        var a = {
+            corners: this.getCornersToRound(this.relativePosition),
+            color: this.backgroundColor,
+            bgColor: "transparent",
+            blend: !1
+        };
+        this.rounded ? (OpenLayers.Rico.Corner.reRound(this.groupDiv, a), this.setBackgroundColor(), this.setOpacity()) : (OpenLayers.Rico.Corner.round(this.div, a), this.rounded = !0)
+    },
+    getCornersToRound: function() {
+        var a = ["tl", "tr",
+                "bl", "br"
+            ],
+            b = OpenLayers.Bounds.oppositeQuadrant(this.relativePosition);
+        OpenLayers.Util.removeItem(a, b);
+        return a.join(" ")
+    },
+    CLASS_NAME: "OpenLayers.Popup.AnchoredBubble"
+});
+OpenLayers.Popup.AnchoredBubble.CORNER_SIZE = 5;
+OpenLayers.Protocol.WFS.v1 = OpenLayers.Class(OpenLayers.Protocol, {
+    version: null,
+    srsName: "EPSG:4326",
+    featureType: null,
+    featureNS: null,
+    geometryName: "the_geom",
+    schema: null,
+    featurePrefix: "feature",
+    formatOptions: null,
+    readFormat: null,
+    readOptions: null,
+    initialize: function(a) {
+        OpenLayers.Protocol.prototype.initialize.apply(this, [a]);
+        a.format || (this.format = OpenLayers.Format.WFST(OpenLayers.Util.extend({
+            version: this.version,
+            featureType: this.featureType,
+            featureNS: this.featureNS,
+            featurePrefix: this.featurePrefix,
+            geometryName: this.geometryName,
+            srsName: this.srsName,
+            schema: this.schema
+        }, this.formatOptions)));
+        !a.geometryName && 1 < parseFloat(this.format.version) && this.setGeometryName(null)
+    },
+    destroy: function() {
+        this.options && !this.options.format && this.format.destroy();
+        this.format = null;
+        OpenLayers.Protocol.prototype.destroy.apply(this)
+    },
+    read: function(a) {
+        OpenLayers.Protocol.prototype.read.apply(this, arguments);
+        a = OpenLayers.Util.extend({}, a);
+        OpenLayers.Util.applyDefaults(a, this.options || {});
+        var b = new OpenLayers.Protocol.Response({
+                requestType: "read"
+            }),
+            c = OpenLayers.Format.XML.prototype.write.apply(this.format, [this.format.writeNode("wfs:GetFeature", a)]);
+        b.priv = OpenLayers.Request.POST({
+            url: a.url,
+            callback: this.createCallback(this.handleRead, b, a),
+            params: a.params,
+            headers: a.headers,
+            data: c
+        });
+        return b
+    },
+    setFeatureType: function(a) {
+        this.featureType = a;
+        this.format.featureType = a
+    },
+    setGeometryName: function(a) {
+        this.geometryName = a;
+        this.format.geometryName = a
+    },
+    handleRead: function(a, b) {
+        b = OpenLayers.Util.extend({}, b);
+        OpenLayers.Util.applyDefaults(b, this.options);
+        if (b.callback) {
+            var c =
+                a.priv;
+            200 <= c.status && 300 > c.status ? (c = this.parseResponse(c, b.readOptions)) && !1 !== c.success ? (b.readOptions && "object" == b.readOptions.output ? OpenLayers.Util.extend(a, c) : a.features = c, a.code = OpenLayers.Protocol.Response.SUCCESS) : (a.code = OpenLayers.Protocol.Response.FAILURE, a.error = c) : a.code = OpenLayers.Protocol.Response.FAILURE;
+            b.callback.call(b.scope, a)
+        }
+    },
+    parseResponse: function(a, b) {
+        var c = a.responseXML;
+        if (!c || !c.documentElement) c = a.responseText;
+        if (!c || 0 >= c.length) return null;
+        c = null !== this.readFormat ? this.readFormat.read(c) :
+            this.format.read(c, b);
+        if (!this.featureNS) {
+            var d = this.readFormat || this.format;
+            this.featureNS = d.featureNS;
+            d.autoConfig = !1;
+            this.geometryName || this.setGeometryName(d.geometryName)
+        }
+        return c
+    },
+    commit: function(a, b) {
+        b = OpenLayers.Util.extend({}, b);
+        OpenLayers.Util.applyDefaults(b, this.options);
+        var c = new OpenLayers.Protocol.Response({
+            requestType: "commit",
+            reqFeatures: a
+        });
+        c.priv = OpenLayers.Request.POST({
+            url: b.url,
+            headers: b.headers,
+            data: this.format.write(a, b),
+            callback: this.createCallback(this.handleCommit, c, b)
+        });
+        return c
+    },
+    handleCommit: function(a, b) {
+        if (b.callback) {
+            var c = a.priv,
+                d = c.responseXML;
+            if (!d || !d.documentElement) d = c.responseText;
+            c = this.format.read(d) || {};
+            a.insertIds = c.insertIds || [];
+            c.success ? a.code = OpenLayers.Protocol.Response.SUCCESS : (a.code = OpenLayers.Protocol.Response.FAILURE, a.error = c);
+            b.callback.call(b.scope, a)
+        }
+    },
+    filterDelete: function(a, b) {
+        b = OpenLayers.Util.extend({}, b);
+        OpenLayers.Util.applyDefaults(b, this.options);
+        new OpenLayers.Protocol.Response({
+            requestType: "commit"
+        });
+        var c = this.format.createElementNSPlus("wfs:Transaction", {
+                attributes: {
+                    service: "WFS",
+                    version: this.version
+                }
+            }),
+            d = this.format.createElementNSPlus("wfs:Delete", {
+                attributes: {
+                    typeName: (b.featureNS ? this.featurePrefix + ":" : "") + b.featureType
+                }
+            });
+        b.featureNS && d.setAttribute("xmlns:" + this.featurePrefix, b.featureNS);
+        var e = this.format.writeNode("ogc:Filter", a);
+        d.appendChild(e);
+        c.appendChild(d);
+        c = OpenLayers.Format.XML.prototype.write.apply(this.format, [c]);
+        return OpenLayers.Request.POST({
+            url: this.url,
+            callback: b.callback || function() {},
+            data: c
+        })
+    },
+    abort: function(a) {
+        a && a.priv.abort()
+    },
+    CLASS_NAME: "OpenLayers.Protocol.WFS.v1"
+});
+OpenLayers.Handler.Point = OpenLayers.Class(OpenLayers.Handler, {
+    point: null,
+    layer: null,
+    multi: !1,
+    citeCompliant: !1,
+    mouseDown: !1,
+    stoppedDown: null,
+    lastDown: null,
+    lastUp: null,
+    persist: !1,
+    stopDown: !1,
+    stopUp: !1,
+    layerOptions: null,
+    pixelTolerance: 5,
+    touch: !1,
+    lastTouchPx: null,
+    initialize: function(a, b, c) {
+        if (!c || !c.layerOptions || !c.layerOptions.styleMap) this.style = OpenLayers.Util.extend(OpenLayers.Feature.Vector.style["default"], {});
+        OpenLayers.Handler.prototype.initialize.apply(this, arguments)
+    },
+    activate: function() {
+        if (!OpenLayers.Handler.prototype.activate.apply(this,
+                arguments)) return !1;
+        var a = OpenLayers.Util.extend({
+            displayInLayerSwitcher: !1,
+            calculateInRange: OpenLayers.Function.True,
+            wrapDateLine: this.citeCompliant
+        }, this.layerOptions);
+        this.layer = new OpenLayers.Layer.Vector(this.CLASS_NAME, a);
+        this.map.addLayer(this.layer);
+        return !0
+    },
+    createFeature: function(a) {
+        a = this.layer.getLonLatFromViewPortPx(a);
+        a = new OpenLayers.Geometry.Point(a.lon, a.lat);
+        this.point = new OpenLayers.Feature.Vector(a);
+        this.callback("create", [this.point.geometry, this.point]);
+        this.point.geometry.clearBounds();
+        this.layer.addFeatures([this.point], {
+            silent: !0
+        })
+    },
+    deactivate: function() {
+        if (!OpenLayers.Handler.prototype.deactivate.apply(this, arguments)) return !1;
+        this.cancel();
+        null != this.layer.map && (this.destroyFeature(!0), this.layer.destroy(!1));
+        this.layer = null;
+        this.touch = !1;
+        return !0
+    },
+    destroyFeature: function(a) {
+        this.layer && (a || !this.persist) && this.layer.destroyFeatures();
+        this.point = null
+    },
+    destroyPersistedFeature: function() {
+        var a = this.layer;
+        a && 1 < a.features.length && this.layer.features[0].destroy()
+    },
+    finalize: function(a) {
+        this.mouseDown = !1;
+        this.lastTouchPx = this.lastUp = this.lastDown = null;
+        this.callback(a ? "cancel" : "done", [this.geometryClone()]);
+        this.destroyFeature(a)
+    },
+    cancel: function() {
+        this.finalize(!0)
+    },
+    click: function(a) {
+        OpenLayers.Event.stop(a);
+        return !1
+    },
+    dblclick: function(a) {
+        OpenLayers.Event.stop(a);
+        return !1
+    },
+    modifyFeature: function(a) {
+        this.point || this.createFeature(a);
+        a = this.layer.getLonLatFromViewPortPx(a);
+        this.point.geometry.x = a.lon;
+        this.point.geometry.y = a.lat;
+        this.callback("modify", [this.point.geometry, this.point, !1]);
+        this.point.geometry.clearBounds();
+        this.drawFeature()
+    },
+    drawFeature: function() {
+        this.layer.drawFeature(this.point, this.style)
+    },
+    getGeometry: function() {
+        var a = this.point && this.point.geometry;
+        a && this.multi && (a = new OpenLayers.Geometry.MultiPoint([a]));
+        return a
+    },
+    geometryClone: function() {
+        var a = this.getGeometry();
+        return a && a.clone()
+    },
+    mousedown: function(a) {
+        return this.down(a)
+    },
+    touchstart: function(a) {
+        this.touch || (this.touch = !0, this.map.events.un({
+            mousedown: this.mousedown,
+            mouseup: this.mouseup,
+            mousemove: this.mousemove,
+            click: this.click,
+            dblclick: this.dblclick,
+            scope: this
+        }));
+        this.lastTouchPx = a.xy;
+        return this.down(a)
+    },
+    mousemove: function(a) {
+        return this.move(a)
+    },
+    touchmove: function(a) {
+        this.lastTouchPx = a.xy;
+        return this.move(a)
+    },
+    mouseup: function(a) {
+        return this.up(a)
+    },
+    touchend: function(a) {
+        a.xy = this.lastTouchPx;
+        return this.up(a)
+    },
+    down: function(a) {
+        this.mouseDown = !0;
+        this.lastDown = a.xy;
+        this.touch || this.modifyFeature(a.xy);
+        this.stoppedDown = this.stopDown;
+        return !this.stopDown
+    },
+    move: function(a) {
+        !this.touch && (!this.mouseDown || this.stoppedDown) && this.modifyFeature(a.xy);
+        return !0
+    },
+    up: function(a) {
+        this.mouseDown = !1;
+        this.stoppedDown = this.stopDown;
+        return this.checkModifiers(a) && (!this.lastUp || !this.lastUp.equals(a.xy)) && this.lastDown && this.passesTolerance(this.lastDown, a.xy, this.pixelTolerance) ? (this.touch && this.modifyFeature(a.xy), this.persist && this.destroyPersistedFeature(), this.lastUp = a.xy, this.finalize(), !this.stopUp) : !0
+    },
+    mouseout: function(a) {
+        OpenLayers.Util.mouseLeft(a, this.map.viewPortDiv) && (this.stoppedDown = this.stopDown, this.mouseDown = !1)
+    },
+    passesTolerance: function(a,
+        b, c) {
+        var d = !0;
+        null != c && a && b && a.distanceTo(b) > c && (d = !1);
+        return d
+    },
+    CLASS_NAME: "OpenLayers.Handler.Point"
+});
+OpenLayers.Handler.Path = OpenLayers.Class(OpenLayers.Handler.Point, {
+    line: null,
+    maxVertices: null,
+    doubleTouchTolerance: 20,
+    freehand: !1,
+    freehandToggle: "shiftKey",
+    timerId: null,
+    redoStack: null,
+    createFeature: function(a) {
+        a = this.layer.getLonLatFromViewPortPx(a);
+        a = new OpenLayers.Geometry.Point(a.lon, a.lat);
+        this.point = new OpenLayers.Feature.Vector(a);
+        this.line = new OpenLayers.Feature.Vector(new OpenLayers.Geometry.LineString([this.point.geometry]));
+        this.callback("create", [this.point.geometry, this.getSketch()]);
+        this.point.geometry.clearBounds();
+        this.layer.addFeatures([this.line, this.point], {
+            silent: !0
+        })
+    },
+    destroyFeature: function(a) {
+        OpenLayers.Handler.Point.prototype.destroyFeature.call(this, a);
+        this.line = null
+    },
+    destroyPersistedFeature: function() {
+        var a = this.layer;
+        a && 2 < a.features.length && this.layer.features[0].destroy()
+    },
+    removePoint: function() {
+        this.point && this.layer.removeFeatures([this.point])
+    },
+    addPoint: function(a) {
+        this.layer.removeFeatures([this.point]);
+        a = this.layer.getLonLatFromViewPortPx(a);
+        this.point = new OpenLayers.Feature.Vector(new OpenLayers.Geometry.Point(a.lon,
+            a.lat));
+        this.line.geometry.addComponent(this.point.geometry, this.line.geometry.components.length);
+        this.layer.addFeatures([this.point]);
+        this.callback("point", [this.point.geometry, this.getGeometry()]);
+        this.callback("modify", [this.point.geometry, this.getSketch()]);
+        this.drawFeature();
+        delete this.redoStack
+    },
+    insertXY: function(a, b) {
+        this.line.geometry.addComponent(new OpenLayers.Geometry.Point(a, b), this.getCurrentPointIndex());
+        this.drawFeature();
+        delete this.redoStack
+    },
+    insertDeltaXY: function(a, b) {
+        var c = this.line.geometry.components[this.getCurrentPointIndex() -
+            1];
+        c && (!isNaN(c.x) && !isNaN(c.y)) && this.insertXY(c.x + a, c.y + b)
+    },
+    insertDirectionLength: function(a, b) {
+        var a = a * (Math.PI / 180),
+            c = b * Math.cos(a),
+            d = b * Math.sin(a);
+        this.insertDeltaXY(c, d)
+    },
+    insertDeflectionLength: function(a, b) {
+        var c = this.getCurrentPointIndex() - 1;
+        if (0 < c) {
+            var d = this.line.geometry.components[c],
+                c = this.line.geometry.components[c - 1];
+            this.insertDirectionLength(180 * Math.atan2(d.y - c.y, d.x - c.x) / Math.PI + a, b)
+        }
+    },
+    getCurrentPointIndex: function() {
+        return this.line.geometry.components.length - 1
+    },
+    undo: function() {
+        var a =
+            this.line.geometry,
+            b = a.components,
+            c = this.getCurrentPointIndex() - 1,
+            b = b[c];
+        if (a = a.removeComponent(b)) this.redoStack || (this.redoStack = []), this.redoStack.push(b), this.drawFeature();
+        return a
+    },
+    redo: function() {
+        var a = this.redoStack && this.redoStack.pop();
+        a && (this.line.geometry.addComponent(a, this.getCurrentPointIndex()), this.drawFeature());
+        return !!a
+    },
+    freehandMode: function(a) {
+        return this.freehandToggle && a[this.freehandToggle] ? !this.freehand : this.freehand
+    },
+    modifyFeature: function(a, b) {
+        this.line || this.createFeature(a);
+        var c = this.layer.getLonLatFromViewPortPx(a);
+        this.point.geometry.x = c.lon;
+        this.point.geometry.y = c.lat;
+        this.callback("modify", [this.point.geometry, this.getSketch(), b]);
+        this.point.geometry.clearBounds();
+        this.drawFeature()
+    },
+    drawFeature: function() {
+        this.layer.drawFeature(this.line, this.style);
+        this.layer.drawFeature(this.point, this.style)
+    },
+    getSketch: function() {
+        return this.line
+    },
+    getGeometry: function() {
+        var a = this.line && this.line.geometry;
+        a && this.multi && (a = new OpenLayers.Geometry.MultiLineString([a]));
+        return a
+    },
+    touchstart: function(a) {
+        if (this.timerId && this.passesTolerance(this.lastTouchPx, a.xy, this.doubleTouchTolerance)) return this.finishGeometry(), window.clearTimeout(this.timerId), this.timerId = null, !1;
+        this.timerId && (window.clearTimeout(this.timerId), this.timerId = null);
+        this.timerId = window.setTimeout(OpenLayers.Function.bind(function() {
+            this.timerId = null
+        }, this), 300);
+        return OpenLayers.Handler.Point.prototype.touchstart.call(this, a)
+    },
+    down: function(a) {
+        var b = this.stopDown;
+        this.freehandMode(a) && (b = !0, this.touch &&
+            (this.modifyFeature(a.xy, !!this.lastUp), OpenLayers.Event.stop(a)));
+        !this.touch && (!this.lastDown || !this.passesTolerance(this.lastDown, a.xy, this.pixelTolerance)) && this.modifyFeature(a.xy, !!this.lastUp);
+        this.mouseDown = !0;
+        this.lastDown = a.xy;
+        this.stoppedDown = b;
+        return !b
+    },
+    move: function(a) {
+        if (this.stoppedDown && this.freehandMode(a)) return this.persist && this.destroyPersistedFeature(), this.maxVertices && this.line && this.line.geometry.components.length === this.maxVertices ? (this.removePoint(), this.finalize()) : this.addPoint(a.xy), !1;
+        !this.touch && (!this.mouseDown || this.stoppedDown) && this.modifyFeature(a.xy, !!this.lastUp);
+        return !0
+    },
+    up: function(a) {
+        if (this.mouseDown && (!this.lastUp || !this.lastUp.equals(a.xy))) this.stoppedDown && this.freehandMode(a) ? (this.persist && this.destroyPersistedFeature(), this.removePoint(), this.finalize()) : this.passesTolerance(this.lastDown, a.xy, this.pixelTolerance) && (this.touch && this.modifyFeature(a.xy), null == this.lastUp && this.persist && this.destroyPersistedFeature(), this.addPoint(a.xy), this.lastUp = a.xy, this.line.geometry.components.length ===
+            this.maxVertices + 1 && this.finishGeometry());
+        this.stoppedDown = this.stopDown;
+        this.mouseDown = !1;
+        return !this.stopUp
+    },
+    finishGeometry: function() {
+        this.line.geometry.removeComponent(this.line.geometry.components[this.line.geometry.components.length - 1]);
+        this.removePoint();
+        this.finalize()
+    },
+    dblclick: function(a) {
+        this.freehandMode(a) || this.finishGeometry();
+        return !1
+    },
+    CLASS_NAME: "OpenLayers.Handler.Path"
+});
+OpenLayers.Spherical = OpenLayers.Spherical || {};
+OpenLayers.Spherical.DEFAULT_RADIUS = 6378137;
+OpenLayers.Spherical.computeDistanceBetween = function(a, b, c) {
+    var c = c || OpenLayers.Spherical.DEFAULT_RADIUS,
+        d = Math.sin(Math.PI * (b.lon - a.lon) / 360),
+        e = Math.sin(Math.PI * (b.lat - a.lat) / 360),
+        a = e * e + d * d * Math.cos(Math.PI * a.lat / 180) * Math.cos(Math.PI * b.lat / 180);
+    return 2 * c * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a))
+};
+OpenLayers.Spherical.computeHeading = function(a, b) {
+    var c = Math.sin(Math.PI * (a.lon - b.lon) / 180) * Math.cos(Math.PI * b.lat / 180),
+        d = Math.cos(Math.PI * a.lat / 180) * Math.sin(Math.PI * b.lat / 180) - Math.sin(Math.PI * a.lat / 180) * Math.cos(Math.PI * b.lat / 180) * Math.cos(Math.PI * (a.lon - b.lon) / 180);
+    return 180 * Math.atan2(c, d) / Math.PI
+};
+OpenLayers.Control.CacheWrite = OpenLayers.Class(OpenLayers.Control, {
+    layers: null,
+    imageFormat: "image/png",
+    quotaRegEx: /quota/i,
+    setMap: function(a) {
+        OpenLayers.Control.prototype.setMap.apply(this, arguments);
+        var b, c = this.layers || a.layers;
+        for (b = c.length - 1; 0 <= b; --b) this.addLayer({
+            layer: c[b]
+        });
+        if (!this.layers) a.events.on({
+            addlayer: this.addLayer,
+            removeLayer: this.removeLayer,
+            scope: this
+        })
+    },
+    addLayer: function(a) {
+        a.layer.events.on({
+            tileloadstart: this.makeSameOrigin,
+            tileloaded: this.cache,
+            scope: this
+        })
+    },
+    removeLayer: function(a) {
+        a.layer.events.un({
+            tileloadstart: this.makeSameOrigin,
+            tileloaded: this.cache,
+            scope: this
+        })
+    },
+    makeSameOrigin: function(a) {
+        if (this.active && (a = a.tile, a instanceof OpenLayers.Tile.Image && !a.crossOriginKeyword && "data:" !== a.url.substr(0, 5))) {
+            var b = OpenLayers.Request.makeSameOrigin(a.url, OpenLayers.ProxyHost);
+            OpenLayers.Control.CacheWrite.urlMap[b] = a.url;
+            a.url = b
+        }
+    },
+    cache: function(a) {
+        if (this.active && window.localStorage && (a = a.tile, a instanceof OpenLayers.Tile.Image && "data:" !== a.url.substr(0, 5))) try {
+            var b = a.getCanvasContext();
+            if (b) {
+                var c = OpenLayers.Control.CacheWrite.urlMap;
+                window.localStorage.setItem("olCache_" + (c[a.url] || a.url), b.canvas.toDataURL(this.imageFormat));
+                delete c[a.url]
+            }
+        } catch (d) {
+            (b = d.name || d.message) && this.quotaRegEx.test(b) ? this.events.triggerEvent("cachefull", {
+                tile: a
+            }) : OpenLayers.Console.error(d.toString())
+        }
+    },
+    destroy: function() {
+        if (this.layers || this.map) {
+            var a, b = this.layers || this.map.layers;
+            for (a = b.length - 1; 0 <= a; --a) this.removeLayer({
+                layer: b[a]
+            })
+        }
+        this.map && this.map.events.un({
+            addlayer: this.addLayer,
+            removeLayer: this.removeLayer,
+            scope: this
+        });
+        OpenLayers.Control.prototype.destroy.apply(this,
+            arguments)
+    },
+    CLASS_NAME: "OpenLayers.Control.CacheWrite"
+});
+OpenLayers.Control.CacheWrite.clearCache = function() {
+    if (window.localStorage) {
+        var a, b;
+        for (a = window.localStorage.length - 1; 0 <= a; --a) b = window.localStorage.key(a), "olCache_" === b.substr(0, 8) && window.localStorage.removeItem(b)
+    }
+};
+OpenLayers.Control.CacheWrite.urlMap = {};
+OpenLayers.Format.Context = OpenLayers.Class(OpenLayers.Format.XML.VersionedOGC, {
+    layerOptions: null,
+    layerParams: null,
+    read: function(a, b) {
+        var c = OpenLayers.Format.XML.VersionedOGC.prototype.read.apply(this, arguments);
+        if (b && b.map)
+            if (this.context = c, b.map instanceof OpenLayers.Map) c = this.mergeContextToMap(c, b.map);
+            else {
+                var d = b.map;
+                if (OpenLayers.Util.isElement(d) || "string" == typeof d) d = {
+                    div: d
+                };
+                c = this.contextToMap(c, d)
+            }
+        return c
+    },
+    getLayerFromContext: function(a) {
+        var b, c, d = {
+            queryable: a.queryable,
+            visibility: a.visibility,
+            maxExtent: a.maxExtent,
+            metadata: OpenLayers.Util.applyDefaults(a.metadata, {
+                styles: a.styles,
+                formats: a.formats,
+                "abstract": a["abstract"],
+                dataURL: a.dataURL
+            }),
+            numZoomLevels: a.numZoomLevels,
+            units: a.units,
+            isBaseLayer: a.isBaseLayer,
+            opacity: a.opacity,
+            displayInLayerSwitcher: a.displayInLayerSwitcher,
+            singleTile: a.singleTile,
+            tileSize: a.tileSize ? new OpenLayers.Size(a.tileSize.width, a.tileSize.height) : void 0,
+            minScale: a.minScale || a.maxScaleDenominator,
+            maxScale: a.maxScale || a.minScaleDenominator,
+            srs: a.srs,
+            dimensions: a.dimensions,
+            metadataURL: a.metadataURL
+        };
+        this.layerOptions && OpenLayers.Util.applyDefaults(d, this.layerOptions);
+        var e = {
+            layers: a.name,
+            transparent: a.transparent,
+            version: a.version
+        };
+        if (a.formats && 0 < a.formats.length) {
+            e.format = a.formats[0].value;
+            b = 0;
+            for (c = a.formats.length; b < c; b++) {
+                var f = a.formats[b];
+                if (!0 == f.current) {
+                    e.format = f.value;
+                    break
+                }
+            }
+        }
+        if (a.styles && 0 < a.styles.length) {
+            b = 0;
+            for (c = a.styles.length; b < c; b++)
+                if (f = a.styles[b], !0 == f.current) {
+                    f.href ? e.sld = f.href : f.body ? e.sld_body = f.body : e.styles = f.name;
+                    break
+                }
+        }
+        this.layerParams &&
+            OpenLayers.Util.applyDefaults(e, this.layerParams);
+        b = null;
+        c = a.service;
+        c == OpenLayers.Format.Context.serviceTypes.WFS ? (d.strategies = [new OpenLayers.Strategy.BBOX], d.protocol = new OpenLayers.Protocol.WFS({
+            url: a.url,
+            featurePrefix: a.name.split(":")[0],
+            featureType: a.name.split(":").pop()
+        }), b = new OpenLayers.Layer.Vector(a.title || a.name, d)) : c == OpenLayers.Format.Context.serviceTypes.KML ? (d.strategies = [new OpenLayers.Strategy.Fixed], d.protocol = new OpenLayers.Protocol.HTTP({
+                url: a.url,
+                format: new OpenLayers.Format.KML
+            }),
+            b = new OpenLayers.Layer.Vector(a.title || a.name, d)) : c == OpenLayers.Format.Context.serviceTypes.GML ? (d.strategies = [new OpenLayers.Strategy.Fixed], d.protocol = new OpenLayers.Protocol.HTTP({
+            url: a.url,
+            format: new OpenLayers.Format.GML
+        }), b = new OpenLayers.Layer.Vector(a.title || a.name, d)) : a.features ? (b = new OpenLayers.Layer.Vector(a.title || a.name, d), b.addFeatures(a.features)) : !0 !== a.categoryLayer && (b = new OpenLayers.Layer.WMS(a.title || a.name, a.url, e, d));
+        return b
+    },
+    getLayersFromContext: function(a) {
+        for (var b = [], c =
+                0, d = a.length; c < d; c++) {
+            var e = this.getLayerFromContext(a[c]);
+            null !== e && b.push(e)
+        }
+        return b
+    },
+    contextToMap: function(a, b) {
+        b = OpenLayers.Util.applyDefaults({
+            maxExtent: a.maxExtent,
+            projection: a.projection,
+            units: a.units
+        }, b);
+        b.maxExtent && (b.maxResolution = b.maxExtent.getWidth() / OpenLayers.Map.TILE_WIDTH);
+        b.metadata = {
+            contactInformation: a.contactInformation,
+            "abstract": a["abstract"],
+            keywords: a.keywords,
+            logo: a.logo,
+            descriptionURL: a.descriptionURL
+        };
+        var c = new OpenLayers.Map(b);
+        c.addLayers(this.getLayersFromContext(a.layersContext));
+        c.setCenter(a.bounds.getCenterLonLat(), c.getZoomForExtent(a.bounds, !0));
+        return c
+    },
+    mergeContextToMap: function(a, b) {
+        b.addLayers(this.getLayersFromContext(a.layersContext));
+        return b
+    },
+    write: function(a, b) {
+        a = this.toContext(a);
+        return OpenLayers.Format.XML.VersionedOGC.prototype.write.apply(this, arguments)
+    },
+    CLASS_NAME: "OpenLayers.Format.Context"
+});
+OpenLayers.Format.Context.serviceTypes = {
+    WMS: "urn:ogc:serviceType:WMS",
+    WFS: "urn:ogc:serviceType:WFS",
+    WCS: "urn:ogc:serviceType:WCS",
+    GML: "urn:ogc:serviceType:GML",
+    SLD: "urn:ogc:serviceType:SLD",
+    FES: "urn:ogc:serviceType:FES",
+    KML: "urn:ogc:serviceType:KML"
+};
+OpenLayers.Format.WMC = OpenLayers.Class(OpenLayers.Format.Context, {
+    defaultVersion: "1.1.0",
+    layerToContext: function(a) {
+        var b = this.getParser(),
+            c = {
+                queryable: a.queryable,
+                visibility: a.visibility,
+                name: a.params.LAYERS,
+                title: a.name,
+                "abstract": a.metadata["abstract"],
+                dataURL: a.metadata.dataURL,
+                metadataURL: a.metadataURL,
+                server: {
+                    version: a.params.VERSION,
+                    url: a.url
+                },
+                maxExtent: a.maxExtent,
+                transparent: a.params.TRANSPARENT,
+                numZoomLevels: a.numZoomLevels,
+                units: a.units,
+                isBaseLayer: a.isBaseLayer,
+                opacity: 1 == a.opacity ? void 0 : a.opacity,
+                displayInLayerSwitcher: a.displayInLayerSwitcher,
+                singleTile: a.singleTile,
+                tileSize: a.singleTile || !a.tileSize ? void 0 : {
+                    width: a.tileSize.w,
+                    height: a.tileSize.h
+                },
+                minScale: a.options.resolutions || a.options.scales || a.options.maxResolution || a.options.minScale ? a.minScale : void 0,
+                maxScale: a.options.resolutions || a.options.scales || a.options.minResolution || a.options.maxScale ? a.maxScale : void 0,
+                formats: [],
+                styles: [],
+                srs: a.srs,
+                dimensions: a.dimensions
+            };
+        a.metadata.servertitle && (c.server.title = a.metadata.servertitle);
+        if (a.metadata.formats && 0 < a.metadata.formats.length)
+            for (var d = 0, e = a.metadata.formats.length; d < e; d++) {
+                var f = a.metadata.formats[d];
+                c.formats.push({
+                    value: f.value,
+                    current: f.value == a.params.FORMAT
+                })
+            } else c.formats.push({
+                value: a.params.FORMAT,
+                current: !0
+            });
+        if (a.metadata.styles && 0 < a.metadata.styles.length) {
+            d = 0;
+            for (e = a.metadata.styles.length; d < e; d++) b = a.metadata.styles[d], b.current = b.href == a.params.SLD || b.body == a.params.SLD_BODY || b.name == a.params.STYLES ? !0 : !1, c.styles.push(b)
+        } else c.styles.push({
+            href: a.params.SLD,
+            body: a.params.SLD_BODY,
+            name: a.params.STYLES || b.defaultStyleName,
+            title: b.defaultStyleTitle,
+            current: !0
+        });
+        return c
+    },
+    toContext: function(a) {
+        var b = {},
+            c = a.layers;
+        if ("OpenLayers.Map" == a.CLASS_NAME) {
+            var d = a.metadata || {};
+            b.size = a.getSize();
+            b.bounds = a.getExtent();
+            b.projection = a.projection;
+            b.title = a.title;
+            b.keywords = d.keywords;
+            b["abstract"] = d["abstract"];
+            b.logo = d.logo;
+            b.descriptionURL = d.descriptionURL;
+            b.contactInformation = d.contactInformation;
+            b.maxExtent = a.maxExtent
+        } else OpenLayers.Util.applyDefaults(b, a), void 0 !=
+            b.layers && delete b.layers;
+        void 0 == b.layersContext && (b.layersContext = []);
+        if (void 0 != c && OpenLayers.Util.isArray(c)) {
+            a = 0;
+            for (d = c.length; a < d; a++) {
+                var e = c[a];
+                e instanceof OpenLayers.Layer.WMS && b.layersContext.push(this.layerToContext(e))
+            }
+        }
+        return b
+    },
+    CLASS_NAME: "OpenLayers.Format.WMC"
+});
+OpenLayers.Format.WMC.v1 = OpenLayers.Class(OpenLayers.Format.XML, {
+    namespaces: {
+        ol: "http://openlayers.org/context",
+        wmc: "http://www.opengis.net/context",
+        sld: "http://www.opengis.net/sld",
+        xlink: "http://www.w3.org/1999/xlink",
+        xsi: "http://www.w3.org/2001/XMLSchema-instance"
+    },
+    schemaLocation: "",
+    getNamespacePrefix: function(a) {
+        var b = null;
+        if (null == a) b = this.namespaces[this.defaultPrefix];
+        else
+            for (b in this.namespaces)
+                if (this.namespaces[b] == a) break; return b
+    },
+    defaultPrefix: "wmc",
+    rootPrefix: null,
+    defaultStyleName: "",
+    defaultStyleTitle: "Default",
+    initialize: function(a) {
+        OpenLayers.Format.XML.prototype.initialize.apply(this, [a])
+    },
+    read: function(a) {
+        "string" == typeof a && (a = OpenLayers.Format.XML.prototype.read.apply(this, [a]));
+        a = a.documentElement;
+        this.rootPrefix = a.prefix;
+        var b = {
+            version: a.getAttribute("version")
+        };
+        this.runChildNodes(b, a);
+        return b
+    },
+    runChildNodes: function(a, b) {
+        for (var c = b.childNodes, d, e, f, g = 0, h = c.length; g < h; ++g) d = c[g], 1 == d.nodeType && (e = this.getNamespacePrefix(d.namespaceURI), f = d.nodeName.split(":").pop(), (e = this["read_" + e + "_" + f]) && e.apply(this, [a, d]))
+    },
+    read_wmc_General: function(a, b) {
+        this.runChildNodes(a, b)
+    },
+    read_wmc_BoundingBox: function(a, b) {
+        a.projection = b.getAttribute("SRS");
+        a.bounds = new OpenLayers.Bounds(b.getAttribute("minx"), b.getAttribute("miny"), b.getAttribute("maxx"), b.getAttribute("maxy"))
+    },
+    read_wmc_LayerList: function(a, b) {
+        a.layersContext = [];
+        this.runChildNodes(a, b)
+    },
+    read_wmc_Layer: function(a, b) {
+        var c = {
+            visibility: "1" != b.getAttribute("hidden"),
+            queryable: "1" == b.getAttribute("queryable"),
+            formats: [],
+            styles: [],
+            metadata: {}
+        };
+        this.runChildNodes(c, b);
+        a.layersContext.push(c)
+    },
+    read_wmc_Extension: function(a, b) {
+        this.runChildNodes(a, b)
+    },
+    read_ol_units: function(a, b) {
+        a.units = this.getChildValue(b)
+    },
+    read_ol_maxExtent: function(a, b) {
+        var c = new OpenLayers.Bounds(b.getAttribute("minx"), b.getAttribute("miny"), b.getAttribute("maxx"), b.getAttribute("maxy"));
+        a.maxExtent = c
+    },
+    read_ol_transparent: function(a, b) {
+        a.transparent = this.getChildValue(b)
+    },
+    read_ol_numZoomLevels: function(a, b) {
+        a.numZoomLevels = parseInt(this.getChildValue(b))
+    },
+    read_ol_opacity: function(a, b) {
+        a.opacity = parseFloat(this.getChildValue(b))
+    },
+    read_ol_singleTile: function(a, b) {
+        a.singleTile = "true" == this.getChildValue(b)
+    },
+    read_ol_tileSize: function(a, b) {
+        var c = {
+            width: b.getAttribute("width"),
+            height: b.getAttribute("height")
+        };
+        a.tileSize = c
+    },
+    read_ol_isBaseLayer: function(a, b) {
+        a.isBaseLayer = "true" == this.getChildValue(b)
+    },
+    read_ol_displayInLayerSwitcher: function(a, b) {
+        a.displayInLayerSwitcher = "true" == this.getChildValue(b)
+    },
+    read_wmc_Server: function(a, b) {
+        a.version = b.getAttribute("version");
+        a.url = this.getOnlineResource_href(b);
+        a.metadata.servertitle = b.getAttribute("title")
+    },
+    read_wmc_FormatList: function(a, b) {
+        this.runChildNodes(a, b)
+    },
+    read_wmc_Format: function(a, b) {
+        var c = {
+            value: this.getChildValue(b)
+        };
+        "1" == b.getAttribute("current") && (c.current = !0);
+        a.formats.push(c)
+    },
+    read_wmc_StyleList: function(a, b) {
+        this.runChildNodes(a, b)
+    },
+    read_wmc_Style: function(a, b) {
+        var c = {};
+        this.runChildNodes(c, b);
+        "1" == b.getAttribute("current") && (c.current = !0);
+        a.styles.push(c)
+    },
+    read_wmc_SLD: function(a, b) {
+        this.runChildNodes(a,
+            b)
+    },
+    read_sld_StyledLayerDescriptor: function(a, b) {
+        var c = OpenLayers.Format.XML.prototype.write.apply(this, [b]);
+        a.body = c
+    },
+    read_sld_FeatureTypeStyle: function(a, b) {
+        var c = OpenLayers.Format.XML.prototype.write.apply(this, [b]);
+        a.body = c
+    },
+    read_wmc_OnlineResource: function(a, b) {
+        a.href = this.getAttributeNS(b, this.namespaces.xlink, "href")
+    },
+    read_wmc_Name: function(a, b) {
+        var c = this.getChildValue(b);
+        c && (a.name = c)
+    },
+    read_wmc_Title: function(a, b) {
+        var c = this.getChildValue(b);
+        c && (a.title = c)
+    },
+    read_wmc_MetadataURL: function(a,
+        b) {
+        a.metadataURL = this.getOnlineResource_href(b)
+    },
+    read_wmc_KeywordList: function(a, b) {
+        a.keywords = [];
+        this.runChildNodes(a.keywords, b)
+    },
+    read_wmc_Keyword: function(a, b) {
+        a.push(this.getChildValue(b))
+    },
+    read_wmc_Abstract: function(a, b) {
+        var c = this.getChildValue(b);
+        c && (a["abstract"] = c)
+    },
+    read_wmc_LogoURL: function(a, b) {
+        a.logo = {
+            width: b.getAttribute("width"),
+            height: b.getAttribute("height"),
+            format: b.getAttribute("format"),
+            href: this.getOnlineResource_href(b)
+        }
+    },
+    read_wmc_DescriptionURL: function(a, b) {
+        a.descriptionURL =
+            this.getOnlineResource_href(b)
+    },
+    read_wmc_ContactInformation: function(a, b) {
+        var c = {};
+        this.runChildNodes(c, b);
+        a.contactInformation = c
+    },
+    read_wmc_ContactPersonPrimary: function(a, b) {
+        var c = {};
+        this.runChildNodes(c, b);
+        a.personPrimary = c
+    },
+    read_wmc_ContactPerson: function(a, b) {
+        var c = this.getChildValue(b);
+        c && (a.person = c)
+    },
+    read_wmc_ContactOrganization: function(a, b) {
+        var c = this.getChildValue(b);
+        c && (a.organization = c)
+    },
+    read_wmc_ContactPosition: function(a, b) {
+        var c = this.getChildValue(b);
+        c && (a.position = c)
+    },
+    read_wmc_ContactAddress: function(a,
+        b) {
+        var c = {};
+        this.runChildNodes(c, b);
+        a.contactAddress = c
+    },
+    read_wmc_AddressType: function(a, b) {
+        var c = this.getChildValue(b);
+        c && (a.type = c)
+    },
+    read_wmc_Address: function(a, b) {
+        var c = this.getChildValue(b);
+        c && (a.address = c)
+    },
+    read_wmc_City: function(a, b) {
+        var c = this.getChildValue(b);
+        c && (a.city = c)
+    },
+    read_wmc_StateOrProvince: function(a, b) {
+        var c = this.getChildValue(b);
+        c && (a.stateOrProvince = c)
+    },
+    read_wmc_PostCode: function(a, b) {
+        var c = this.getChildValue(b);
+        c && (a.postcode = c)
+    },
+    read_wmc_Country: function(a, b) {
+        var c = this.getChildValue(b);
+        c && (a.country = c)
+    },
+    read_wmc_ContactVoiceTelephone: function(a, b) {
+        var c = this.getChildValue(b);
+        c && (a.phone = c)
+    },
+    read_wmc_ContactFacsimileTelephone: function(a, b) {
+        var c = this.getChildValue(b);
+        c && (a.fax = c)
+    },
+    read_wmc_ContactElectronicMailAddress: function(a, b) {
+        var c = this.getChildValue(b);
+        c && (a.email = c)
+    },
+    read_wmc_DataURL: function(a, b) {
+        a.dataURL = this.getOnlineResource_href(b)
+    },
+    read_wmc_LegendURL: function(a, b) {
+        var c = {
+            width: b.getAttribute("width"),
+            height: b.getAttribute("height"),
+            format: b.getAttribute("format"),
+            href: this.getOnlineResource_href(b)
+        };
+        a.legend = c
+    },
+    read_wmc_DimensionList: function(a, b) {
+        a.dimensions = {};
+        this.runChildNodes(a.dimensions, b)
+    },
+    read_wmc_Dimension: function(a, b) {
+        var c = {
+                name: b.getAttribute("name").toLowerCase(),
+                units: b.getAttribute("units") || "",
+                unitSymbol: b.getAttribute("unitSymbol") || "",
+                userValue: b.getAttribute("userValue") || "",
+                nearestValue: "1" === b.getAttribute("nearestValue"),
+                multipleValues: "1" === b.getAttribute("multipleValues"),
+                current: "1" === b.getAttribute("current"),
+                "default": b.getAttribute("default") ||
+                    ""
+            },
+            d = this.getChildValue(b);
+        c.values = d.split(",");
+        a[c.name] = c
+    },
+    write: function(a, b) {
+        var c = this.createElementDefaultNS("ViewContext");
+        this.setAttributes(c, {
+            version: this.VERSION,
+            id: b && "string" == typeof b.id ? b.id : OpenLayers.Util.createUniqueID("OpenLayers_Context_")
+        });
+        this.setAttributeNS(c, this.namespaces.xsi, "xsi:schemaLocation", this.schemaLocation);
+        c.appendChild(this.write_wmc_General(a));
+        c.appendChild(this.write_wmc_LayerList(a));
+        return OpenLayers.Format.XML.prototype.write.apply(this, [c])
+    },
+    createElementDefaultNS: function(a,
+        b, c) {
+        a = this.createElementNS(this.namespaces[this.defaultPrefix], a);
+        b && a.appendChild(this.createTextNode(b));
+        c && this.setAttributes(a, c);
+        return a
+    },
+    setAttributes: function(a, b) {
+        var c, d;
+        for (d in b) c = b[d].toString(), c.match(/[A-Z]/) ? this.setAttributeNS(a, null, d, c) : a.setAttribute(d, c)
+    },
+    write_wmc_General: function(a) {
+        var b = this.createElementDefaultNS("General");
+        a.size && b.appendChild(this.createElementDefaultNS("Window", null, {
+            width: a.size.w,
+            height: a.size.h
+        }));
+        var c = a.bounds;
+        b.appendChild(this.createElementDefaultNS("BoundingBox",
+            null, {
+                minx: c.left.toPrecision(18),
+                miny: c.bottom.toPrecision(18),
+                maxx: c.right.toPrecision(18),
+                maxy: c.top.toPrecision(18),
+                SRS: a.projection
+            }));
+        b.appendChild(this.createElementDefaultNS("Title", a.title));
+        a.keywords && b.appendChild(this.write_wmc_KeywordList(a.keywords));
+        a["abstract"] && b.appendChild(this.createElementDefaultNS("Abstract", a["abstract"]));
+        a.logo && b.appendChild(this.write_wmc_URLType("LogoURL", a.logo.href, a.logo));
+        a.descriptionURL && b.appendChild(this.write_wmc_URLType("DescriptionURL", a.descriptionURL));
+        a.contactInformation && b.appendChild(this.write_wmc_ContactInformation(a.contactInformation));
+        b.appendChild(this.write_ol_MapExtension(a));
+        return b
+    },
+    write_wmc_KeywordList: function(a) {
+        for (var b = this.createElementDefaultNS("KeywordList"), c = 0, d = a.length; c < d; c++) b.appendChild(this.createElementDefaultNS("Keyword", a[c]));
+        return b
+    },
+    write_wmc_ContactInformation: function(a) {
+        var b = this.createElementDefaultNS("ContactInformation");
+        a.personPrimary && b.appendChild(this.write_wmc_ContactPersonPrimary(a.personPrimary));
+        a.position && b.appendChild(this.createElementDefaultNS("ContactPosition", a.position));
+        a.contactAddress && b.appendChild(this.write_wmc_ContactAddress(a.contactAddress));
+        a.phone && b.appendChild(this.createElementDefaultNS("ContactVoiceTelephone", a.phone));
+        a.fax && b.appendChild(this.createElementDefaultNS("ContactFacsimileTelephone", a.fax));
+        a.email && b.appendChild(this.createElementDefaultNS("ContactElectronicMailAddress", a.email));
+        return b
+    },
+    write_wmc_ContactPersonPrimary: function(a) {
+        var b = this.createElementDefaultNS("ContactPersonPrimary");
+        a.person && b.appendChild(this.createElementDefaultNS("ContactPerson", a.person));
+        a.organization && b.appendChild(this.createElementDefaultNS("ContactOrganization", a.organization));
+        return b
+    },
+    write_wmc_ContactAddress: function(a) {
+        var b = this.createElementDefaultNS("ContactAddress");
+        a.type && b.appendChild(this.createElementDefaultNS("AddressType", a.type));
+        a.address && b.appendChild(this.createElementDefaultNS("Address", a.address));
+        a.city && b.appendChild(this.createElementDefaultNS("City", a.city));
+        a.stateOrProvince &&
+            b.appendChild(this.createElementDefaultNS("StateOrProvince", a.stateOrProvince));
+        a.postcode && b.appendChild(this.createElementDefaultNS("PostCode", a.postcode));
+        a.country && b.appendChild(this.createElementDefaultNS("Country", a.country));
+        return b
+    },
+    write_ol_MapExtension: function(a) {
+        var b = this.createElementDefaultNS("Extension");
+        if (a = a.maxExtent) {
+            var c = this.createElementNS(this.namespaces.ol, "ol:maxExtent");
+            this.setAttributes(c, {
+                minx: a.left.toPrecision(18),
+                miny: a.bottom.toPrecision(18),
+                maxx: a.right.toPrecision(18),
+                maxy: a.top.toPrecision(18)
+            });
+            b.appendChild(c)
+        }
+        return b
+    },
+    write_wmc_LayerList: function(a) {
+        for (var b = this.createElementDefaultNS("LayerList"), c = 0, d = a.layersContext.length; c < d; ++c) b.appendChild(this.write_wmc_Layer(a.layersContext[c]));
+        return b
+    },
+    write_wmc_Layer: function(a) {
+        var b = this.createElementDefaultNS("Layer", null, {
+            queryable: a.queryable ? "1" : "0",
+            hidden: a.visibility ? "0" : "1"
+        });
+        b.appendChild(this.write_wmc_Server(a));
+        b.appendChild(this.createElementDefaultNS("Name", a.name));
+        b.appendChild(this.createElementDefaultNS("Title",
+            a.title));
+        a["abstract"] && b.appendChild(this.createElementDefaultNS("Abstract", a["abstract"]));
+        a.dataURL && b.appendChild(this.write_wmc_URLType("DataURL", a.dataURL));
+        a.metadataURL && b.appendChild(this.write_wmc_URLType("MetadataURL", a.metadataURL));
+        return b
+    },
+    write_wmc_LayerExtension: function(a) {
+        var b = this.createElementDefaultNS("Extension"),
+            c = a.maxExtent,
+            d = this.createElementNS(this.namespaces.ol, "ol:maxExtent");
+        this.setAttributes(d, {
+            minx: c.left.toPrecision(18),
+            miny: c.bottom.toPrecision(18),
+            maxx: c.right.toPrecision(18),
+            maxy: c.top.toPrecision(18)
+        });
+        b.appendChild(d);
+        a.tileSize && !a.singleTile && (c = this.createElementNS(this.namespaces.ol, "ol:tileSize"), this.setAttributes(c, a.tileSize), b.appendChild(c));
+        for (var c = "transparent numZoomLevels units isBaseLayer opacity displayInLayerSwitcher singleTile".split(" "), e = 0, f = c.length; e < f; ++e)(d = this.createOLPropertyNode(a, c[e])) && b.appendChild(d);
+        return b
+    },
+    createOLPropertyNode: function(a, b) {
+        var c = null;
+        null != a[b] && (c = this.createElementNS(this.namespaces.ol, "ol:" + b), c.appendChild(this.createTextNode(a[b].toString())));
+        return c
+    },
+    write_wmc_Server: function(a) {
+        var a = a.server,
+            b = this.createElementDefaultNS("Server"),
+            c = {
+                service: "OGC:WMS",
+                version: a.version
+            };
+        a.title && (c.title = a.title);
+        this.setAttributes(b, c);
+        b.appendChild(this.write_wmc_OnlineResource(a.url));
+        return b
+    },
+    write_wmc_URLType: function(a, b, c) {
+        a = this.createElementDefaultNS(a);
+        a.appendChild(this.write_wmc_OnlineResource(b));
+        if (c)
+            for (var b = ["width", "height", "format"], d = 0; d < b.length; d++) b[d] in c && a.setAttribute(b[d], c[b[d]]);
+        return a
+    },
+    write_wmc_DimensionList: function(a) {
+        var b =
+            this.createElementDefaultNS("DimensionList"),
+            c;
+        for (c in a.dimensions) {
+            var d = {},
+                e = a.dimensions[c],
+                f;
+            for (f in e) d[f] = "boolean" == typeof e[f] ? Number(e[f]) : e[f];
+            e = "";
+            d.values && (e = d.values.join(","), delete d.values);
+            b.appendChild(this.createElementDefaultNS("Dimension", e, d))
+        }
+        return b
+    },
+    write_wmc_FormatList: function(a) {
+        for (var b = this.createElementDefaultNS("FormatList"), c = 0, d = a.formats.length; c < d; c++) {
+            var e = a.formats[c];
+            b.appendChild(this.createElementDefaultNS("Format", e.value, e.current && !0 == e.current ? {
+                    current: "1"
+                } :
+                null))
+        }
+        return b
+    },
+    write_wmc_StyleList: function(a) {
+        var b = this.createElementDefaultNS("StyleList");
+        if ((a = a.styles) && OpenLayers.Util.isArray(a))
+            for (var c, d = 0, e = a.length; d < e; d++) {
+                var f = a[d],
+                    g = this.createElementDefaultNS("Style", null, f.current && !0 == f.current ? {
+                        current: "1"
+                    } : null);
+                f.href ? (c = this.createElementDefaultNS("SLD"), f.name && c.appendChild(this.createElementDefaultNS("Name", f.name)), f.title && c.appendChild(this.createElementDefaultNS("Title", f.title)), f.legend && c.appendChild(this.write_wmc_URLType("LegendURL",
+                    f.legend.href, f.legend)), f = this.write_wmc_OnlineResource(f.href), c.appendChild(f), g.appendChild(c)) : f.body ? (c = this.createElementDefaultNS("SLD"), f.name && c.appendChild(this.createElementDefaultNS("Name", f.name)), f.title && c.appendChild(this.createElementDefaultNS("Title", f.title)), f.legend && c.appendChild(this.write_wmc_URLType("LegendURL", f.legend.href, f.legend)), f = OpenLayers.Format.XML.prototype.read.apply(this, [f.body]).documentElement, c.ownerDocument && c.ownerDocument.importNode && (f = c.ownerDocument.importNode(f, !0)), c.appendChild(f), g.appendChild(c)) : (g.appendChild(this.createElementDefaultNS("Name", f.name)), g.appendChild(this.createElementDefaultNS("Title", f.title)), f["abstract"] && g.appendChild(this.createElementDefaultNS("Abstract", f["abstract"])), f.legend && g.appendChild(this.write_wmc_URLType("LegendURL", f.legend.href, f.legend)));
+                b.appendChild(g)
+            }
+        return b
+    },
+    write_wmc_OnlineResource: function(a) {
+        var b = this.createElementDefaultNS("OnlineResource");
+        this.setAttributeNS(b, this.namespaces.xlink, "xlink:type",
+            "simple");
+        this.setAttributeNS(b, this.namespaces.xlink, "xlink:href", a);
+        return b
+    },
+    getOnlineResource_href: function(a) {
+        var b = {},
+            a = a.getElementsByTagName("OnlineResource");
+        0 < a.length && this.read_wmc_OnlineResource(b, a[0]);
+        return b.href
+    },
+    CLASS_NAME: "OpenLayers.Format.WMC.v1"
+});
+OpenLayers.Control.PanPanel = OpenLayers.Class(OpenLayers.Control.Panel, {
+    slideFactor: 50,
+    slideRatio: null,
+    initialize: function(a) {
+        OpenLayers.Control.Panel.prototype.initialize.apply(this, [a]);
+        a = {
+            slideFactor: this.slideFactor,
+            slideRatio: this.slideRatio
+        };
+        this.addControls([new OpenLayers.Control.Pan(OpenLayers.Control.Pan.NORTH, a), new OpenLayers.Control.Pan(OpenLayers.Control.Pan.SOUTH, a), new OpenLayers.Control.Pan(OpenLayers.Control.Pan.EAST, a), new OpenLayers.Control.Pan(OpenLayers.Control.Pan.WEST, a)])
+    },
+    CLASS_NAME: "OpenLayers.Control.PanPanel"
+});
+OpenLayers.Control.Attribution = OpenLayers.Class(OpenLayers.Control, {
+    separator: ", ",
+    template: "${layers}",
+    destroy: function() {
+        this.map.events.un({
+            removelayer: this.updateAttribution,
+            addlayer: this.updateAttribution,
+            changelayer: this.updateAttribution,
+            changebaselayer: this.updateAttribution,
+            scope: this
+        });
+        OpenLayers.Control.prototype.destroy.apply(this, arguments)
+    },
+    draw: function() {
+        OpenLayers.Control.prototype.draw.apply(this, arguments);
+        this.map.events.on({
+            changebaselayer: this.updateAttribution,
+            changelayer: this.updateAttribution,
+            addlayer: this.updateAttribution,
+            removelayer: this.updateAttribution,
+            scope: this
+        });
+        this.updateAttribution();
+        return this.div
+    },
+    updateAttribution: function() {
+        var a = [];
+        if (this.map && this.map.layers) {
+            for (var b = 0, c = this.map.layers.length; b < c; b++) {
+                var d = this.map.layers[b];
+                d.attribution && d.getVisibility() && -1 === OpenLayers.Util.indexOf(a, d.attribution) && a.push(d.attribution)
+            }
+            this.div.innerHTML = OpenLayers.String.format(this.template, {
+                layers: a.join(this.separator)
+            })
+        }
+    },
+    CLASS_NAME: "OpenLayers.Control.Attribution"
+});
+OpenLayers.Kinetic = OpenLayers.Class({
+    threshold: 0,
+    deceleration: 0.0035,
+    nbPoints: 100,
+    delay: 200,
+    points: void 0,
+    timerId: void 0,
+    initialize: function(a) {
+        OpenLayers.Util.extend(this, a)
+    },
+    begin: function() {
+        OpenLayers.Animation.stop(this.timerId);
+        this.timerId = void 0;
+        this.points = []
+    },
+    update: function(a) {
+        this.points.unshift({
+            xy: a,
+            tick: (new Date).getTime()
+        });
+        this.points.length > this.nbPoints && this.points.pop()
+    },
+    end: function(a) {
+        for (var b, c = (new Date).getTime(), d = 0, e = this.points.length, f; d < e; d++) {
+            f = this.points[d];
+            if (c -
+                f.tick > this.delay) break;
+            b = f
+        }
+        if (b && (d = (new Date).getTime() - b.tick, c = Math.sqrt(Math.pow(a.x - b.xy.x, 2) + Math.pow(a.y - b.xy.y, 2)), d = c / d, !(0 == d || d < this.threshold))) return c = Math.asin((a.y - b.xy.y) / c), b.xy.x <= a.x && (c = Math.PI - c), {
+            speed: d,
+            theta: c
+        }
+    },
+    move: function(a, b) {
+        var c = a.speed,
+            d = Math.cos(a.theta),
+            e = -Math.sin(a.theta),
+            f = (new Date).getTime(),
+            g = 0,
+            h = 0;
+        this.timerId = OpenLayers.Animation.start(OpenLayers.Function.bind(function() {
+            if (null != this.timerId) {
+                var a = (new Date).getTime() - f,
+                    j = -this.deceleration * Math.pow(a,
+                        2) / 2 + c * a,
+                    k = j * d,
+                    j = j * e,
+                    l, m;
+                l = !1;
+                0 >= -this.deceleration * a + c && (OpenLayers.Animation.stop(this.timerId), this.timerId = null, l = !0);
+                a = k - g;
+                m = j - h;
+                g = k;
+                h = j;
+                b(a, m, l)
+            }
+        }, this))
+    },
+    CLASS_NAME: "OpenLayers.Kinetic"
+});
+OpenLayers.Layer.GeoRSS = OpenLayers.Class(OpenLayers.Layer.Markers, {
+    location: null,
+    features: null,
+    formatOptions: null,
+    selectedFeature: null,
+    icon: null,
+    popupSize: null,
+    useFeedTitle: !0,
+    initialize: function(a, b, c) {
+        OpenLayers.Layer.Markers.prototype.initialize.apply(this, [a, c]);
+        this.location = b;
+        this.features = []
+    },
+    destroy: function() {
+        OpenLayers.Layer.Markers.prototype.destroy.apply(this, arguments);
+        this.clearFeatures();
+        this.features = null
+    },
+    loadRSS: function() {
+        this.loaded || (this.events.triggerEvent("loadstart"), OpenLayers.Request.GET({
+            url: this.location,
+            success: this.parseData,
+            scope: this
+        }), this.loaded = !0)
+    },
+    moveTo: function(a, b, c) {
+        OpenLayers.Layer.Markers.prototype.moveTo.apply(this, arguments);
+        this.visibility && !this.loaded && this.loadRSS()
+    },
+    parseData: function(a) {
+        var b = a.responseXML;
+        if (!b || !b.documentElement) b = OpenLayers.Format.XML.prototype.read(a.responseText);
+        if (this.useFeedTitle) {
+            a = null;
+            try {
+                a = b.getElementsByTagNameNS("*", "title")[0].firstChild.nodeValue
+            } catch (c) {
+                a = b.getElementsByTagName("title")[0].firstChild.nodeValue
+            }
+            a && this.setName(a)
+        }
+        a = {};
+        OpenLayers.Util.extend(a,
+            this.formatOptions);
+        this.map && !this.projection.equals(this.map.getProjectionObject()) && (a.externalProjection = this.projection, a.internalProjection = this.map.getProjectionObject());
+        for (var b = (new OpenLayers.Format.GeoRSS(a)).read(b), a = 0, d = b.length; a < d; a++) {
+            var e = {},
+                f = b[a];
+            if (f.geometry) {
+                var g = f.attributes.title ? f.attributes.title : "Untitled",
+                    h = f.attributes.description ? f.attributes.description : "No description.",
+                    i = f.attributes.link ? f.attributes.link : "",
+                    f = f.geometry.getBounds().getCenterLonLat();
+                e.icon =
+                    null == this.icon ? OpenLayers.Marker.defaultIcon() : this.icon.clone();
+                e.popupSize = this.popupSize ? this.popupSize.clone() : new OpenLayers.Size(250, 120);
+                if (g || h) {
+                    e.title = g;
+                    e.description = h;
+                    var j = '<div class="olLayerGeoRSSClose">[x]</div>',
+                        j = j + '<div class="olLayerGeoRSSTitle">';
+                    i && (j += '<a class="link" href="' + i + '" target="_blank">');
+                    j += g;
+                    i && (j += "</a>");
+                    j += "</div>";
+                    j += '<div style="" class="olLayerGeoRSSDescription">';
+                    j += h;
+                    j += "</div>";
+                    e.popupContentHTML = j
+                }
+                f = new OpenLayers.Feature(this, f, e);
+                this.features.push(f);
+                e = f.createMarker();
+                e.events.register("click", f, this.markerClick);
+                this.addMarker(e)
+            }
+        }
+        this.events.triggerEvent("loadend")
+    },
+    markerClick: function(a) {
+        var b = this == this.layer.selectedFeature;
+        this.layer.selectedFeature = !b ? this : null;
+        for (var c = 0, d = this.layer.map.popups.length; c < d; c++) this.layer.map.removePopup(this.layer.map.popups[c]);
+        b || (b = this.createPopup(), OpenLayers.Event.observe(b.div, "click", OpenLayers.Function.bind(function() {
+                for (var a = 0, b = this.layer.map.popups.length; a < b; a++) this.layer.map.removePopup(this.layer.map.popups[a])
+            },
+            this)), this.layer.map.addPopup(b));
+        OpenLayers.Event.stop(a)
+    },
+    clearFeatures: function() {
+        if (null != this.features)
+            for (; 0 < this.features.length;) {
+                var a = this.features[0];
+                OpenLayers.Util.removeItem(this.features, a);
+                a.destroy()
+            }
+    },
+    CLASS_NAME: "OpenLayers.Layer.GeoRSS"
+});
+OpenLayers.Symbolizer.Point = OpenLayers.Class(OpenLayers.Symbolizer, {
+    initialize: function(a) {
+        OpenLayers.Symbolizer.prototype.initialize.apply(this, arguments)
+    },
+    CLASS_NAME: "OpenLayers.Symbolizer.Point"
+});
+OpenLayers.Symbolizer.Line = OpenLayers.Class(OpenLayers.Symbolizer, {
+    initialize: function(a) {
+        OpenLayers.Symbolizer.prototype.initialize.apply(this, arguments)
+    },
+    CLASS_NAME: "OpenLayers.Symbolizer.Line"
+});
+OpenLayers.Symbolizer.Text = OpenLayers.Class(OpenLayers.Symbolizer, {
+    initialize: function(a) {
+        OpenLayers.Symbolizer.prototype.initialize.apply(this, arguments)
+    },
+    CLASS_NAME: "OpenLayers.Symbolizer.Text"
+});
+OpenLayers.Format.SLD.v1 = OpenLayers.Class(OpenLayers.Format.Filter.v1_0_0, {
+    namespaces: {
+        sld: "http://www.opengis.net/sld",
+        ogc: "http://www.opengis.net/ogc",
+        gml: "http://www.opengis.net/gml",
+        xlink: "http://www.w3.org/1999/xlink",
+        xsi: "http://www.w3.org/2001/XMLSchema-instance"
+    },
+    defaultPrefix: "sld",
+    schemaLocation: null,
+    multipleSymbolizers: !1,
+    featureTypeCounter: null,
+    defaultSymbolizer: {
+        fillColor: "#808080",
+        fillOpacity: 1,
+        strokeColor: "#000000",
+        strokeOpacity: 1,
+        strokeWidth: 1,
+        strokeDashstyle: "solid",
+        pointRadius: 3,
+        graphicName: "square"
+    },
+    read: function(a, b) {
+        var b = OpenLayers.Util.applyDefaults(b, this.options),
+            c = {
+                namedLayers: !0 === b.namedLayersAsArray ? [] : {}
+            };
+        this.readChildNodes(a, c);
+        return c
+    },
+    readers: OpenLayers.Util.applyDefaults({
+        sld: {
+            StyledLayerDescriptor: function(a, b) {
+                b.version = a.getAttribute("version");
+                this.readChildNodes(a, b)
+            },
+            Name: function(a, b) {
+                b.name = this.getChildValue(a)
+            },
+            Title: function(a, b) {
+                b.title = this.getChildValue(a)
+            },
+            Abstract: function(a, b) {
+                b.description = this.getChildValue(a)
+            },
+            NamedLayer: function(a, b) {
+                var c = {
+                    userStyles: [],
+                    namedStyles: []
+                };
+                this.readChildNodes(a, c);
+                for (var d = 0, e = c.userStyles.length; d < e; ++d) c.userStyles[d].layerName = c.name;
+                OpenLayers.Util.isArray(b.namedLayers) ? b.namedLayers.push(c) : b.namedLayers[c.name] = c
+            },
+            NamedStyle: function(a, b) {
+                b.namedStyles.push(this.getChildName(a.firstChild))
+            },
+            UserStyle: function(a, b) {
+                var c = {
+                    defaultsPerSymbolizer: !0,
+                    rules: []
+                };
+                this.featureTypeCounter = -1;
+                this.readChildNodes(a, c);
+                this.multipleSymbolizers ? (delete c.defaultsPerSymbolizer, c = new OpenLayers.Style2(c)) : c = new OpenLayers.Style(this.defaultSymbolizer,
+                    c);
+                b.userStyles.push(c)
+            },
+            IsDefault: function(a, b) {
+                "1" == this.getChildValue(a) && (b.isDefault = !0)
+            },
+            FeatureTypeStyle: function(a, b) {
+                ++this.featureTypeCounter;
+                var c = {
+                    rules: this.multipleSymbolizers ? b.rules : []
+                };
+                this.readChildNodes(a, c);
+                this.multipleSymbolizers || (b.rules = c.rules)
+            },
+            Rule: function(a, b) {
+                var c;
+                this.multipleSymbolizers && (c = {
+                    symbolizers: []
+                });
+                c = new OpenLayers.Rule(c);
+                this.readChildNodes(a, c);
+                b.rules.push(c)
+            },
+            ElseFilter: function(a, b) {
+                b.elseFilter = !0
+            },
+            MinScaleDenominator: function(a, b) {
+                b.minScaleDenominator =
+                    parseFloat(this.getChildValue(a))
+            },
+            MaxScaleDenominator: function(a, b) {
+                b.maxScaleDenominator = parseFloat(this.getChildValue(a))
+            },
+            TextSymbolizer: function(a, b) {
+                var c = {};
+                this.readChildNodes(a, c);
+                this.multipleSymbolizers ? (c.zIndex = this.featureTypeCounter, b.symbolizers.push(new OpenLayers.Symbolizer.Text(c))) : b.symbolizer.Text = OpenLayers.Util.applyDefaults(c, b.symbolizer.Text)
+            },
+            LabelPlacement: function(a, b) {
+                this.readChildNodes(a, b)
+            },
+            PointPlacement: function(a, b) {
+                var c = {};
+                this.readChildNodes(a, c);
+                c.labelRotation =
+                    c.rotation;
+                delete c.rotation;
+                var d, e = b.labelAnchorPointX,
+                    f = b.labelAnchorPointY;
+                e <= 1 / 3 ? d = "l" : e > 1 / 3 && e < 2 / 3 ? d = "c" : e >= 2 / 3 && (d = "r");
+                f <= 1 / 3 ? d += "b" : f > 1 / 3 && f < 2 / 3 ? d += "m" : f >= 2 / 3 && (d += "t");
+                c.labelAlign = d;
+                OpenLayers.Util.applyDefaults(b, c)
+            },
+            AnchorPoint: function(a, b) {
+                this.readChildNodes(a, b)
+            },
+            AnchorPointX: function(a, b) {
+                var c = this.readers.ogc._expression.call(this, a);
+                c && (b.labelAnchorPointX = c)
+            },
+            AnchorPointY: function(a, b) {
+                var c = this.readers.ogc._expression.call(this, a);
+                c && (b.labelAnchorPointY = c)
+            },
+            Displacement: function(a,
+                b) {
+                this.readChildNodes(a, b)
+            },
+            DisplacementX: function(a, b) {
+                var c = this.readers.ogc._expression.call(this, a);
+                c && (b.labelXOffset = c)
+            },
+            DisplacementY: function(a, b) {
+                var c = this.readers.ogc._expression.call(this, a);
+                c && (b.labelYOffset = c)
+            },
+            LinePlacement: function(a, b) {
+                this.readChildNodes(a, b)
+            },
+            PerpendicularOffset: function(a, b) {
+                var c = this.readers.ogc._expression.call(this, a);
+                c && (b.labelPerpendicularOffset = c)
+            },
+            Label: function(a, b) {
+                var c = this.readers.ogc._expression.call(this, a);
+                c && (b.label = c)
+            },
+            Font: function(a, b) {
+                this.readChildNodes(a,
+                    b)
+            },
+            Halo: function(a, b) {
+                var c = {};
+                this.readChildNodes(a, c);
+                b.haloRadius = c.haloRadius;
+                b.haloColor = c.fillColor;
+                b.haloOpacity = c.fillOpacity
+            },
+            Radius: function(a, b) {
+                var c = this.readers.ogc._expression.call(this, a);
+                null != c && (b.haloRadius = c)
+            },
+            RasterSymbolizer: function(a, b) {
+                var c = {};
+                this.readChildNodes(a, c);
+                this.multipleSymbolizers ? (c.zIndex = this.featureTypeCounter, b.symbolizers.push(new OpenLayers.Symbolizer.Raster(c))) : b.symbolizer.Raster = OpenLayers.Util.applyDefaults(c, b.symbolizer.Raster)
+            },
+            Geometry: function(a,
+                b) {
+                b.geometry = {};
+                this.readChildNodes(a, b.geometry)
+            },
+            ColorMap: function(a, b) {
+                b.colorMap = [];
+                this.readChildNodes(a, b.colorMap)
+            },
+            ColorMapEntry: function(a, b) {
+                var c = a.getAttribute("quantity"),
+                    d = a.getAttribute("opacity");
+                b.push({
+                    color: a.getAttribute("color"),
+                    quantity: null !== c ? parseFloat(c) : void 0,
+                    label: a.getAttribute("label") || void 0,
+                    opacity: null !== d ? parseFloat(d) : void 0
+                })
+            },
+            LineSymbolizer: function(a, b) {
+                var c = {};
+                this.readChildNodes(a, c);
+                this.multipleSymbolizers ? (c.zIndex = this.featureTypeCounter, b.symbolizers.push(new OpenLayers.Symbolizer.Line(c))) :
+                    b.symbolizer.Line = OpenLayers.Util.applyDefaults(c, b.symbolizer.Line)
+            },
+            PolygonSymbolizer: function(a, b) {
+                var c = {
+                    fill: !1,
+                    stroke: !1
+                };
+                this.multipleSymbolizers || (c = b.symbolizer.Polygon || c);
+                this.readChildNodes(a, c);
+                this.multipleSymbolizers ? (c.zIndex = this.featureTypeCounter, b.symbolizers.push(new OpenLayers.Symbolizer.Polygon(c))) : b.symbolizer.Polygon = c
+            },
+            PointSymbolizer: function(a, b) {
+                var c = {
+                    fill: !1,
+                    stroke: !1,
+                    graphic: !1
+                };
+                this.multipleSymbolizers || (c = b.symbolizer.Point || c);
+                this.readChildNodes(a, c);
+                this.multipleSymbolizers ?
+                    (c.zIndex = this.featureTypeCounter, b.symbolizers.push(new OpenLayers.Symbolizer.Point(c))) : b.symbolizer.Point = c
+            },
+            Stroke: function(a, b) {
+                b.stroke = !0;
+                this.readChildNodes(a, b)
+            },
+            Fill: function(a, b) {
+                b.fill = !0;
+                this.readChildNodes(a, b)
+            },
+            CssParameter: function(a, b) {
+                var c = a.getAttribute("name"),
+                    d = this.cssMap[c];
+                b.label && ("fill" === c ? d = "fontColor" : "fill-opacity" === c && (d = "fontOpacity"));
+                d && (c = this.readers.ogc._expression.call(this, a)) && (b[d] = c)
+            },
+            Graphic: function(a, b) {
+                b.graphic = !0;
+                var c = {};
+                this.readChildNodes(a, c);
+                for (var d = "stroke strokeColor strokeWidth strokeOpacity strokeLinecap fill fillColor fillOpacity graphicName rotation graphicFormat".split(" "), e, f, g = 0, h = d.length; g < h; ++g) e = d[g], f = c[e], void 0 != f && (b[e] = f);
+                void 0 != c.opacity && (b.graphicOpacity = c.opacity);
+                void 0 != c.size && (isNaN(c.size / 2) ? b.graphicWidth = c.size : b.pointRadius = c.size / 2);
+                void 0 != c.href && (b.externalGraphic = c.href);
+                void 0 != c.rotation && (b.rotation = c.rotation)
+            },
+            ExternalGraphic: function(a, b) {
+                this.readChildNodes(a, b)
+            },
+            Mark: function(a, b) {
+                this.readChildNodes(a,
+                    b)
+            },
+            WellKnownName: function(a, b) {
+                b.graphicName = this.getChildValue(a)
+            },
+            Opacity: function(a, b) {
+                var c = this.readers.ogc._expression.call(this, a);
+                c && (b.opacity = c)
+            },
+            Size: function(a, b) {
+                var c = this.readers.ogc._expression.call(this, a);
+                c && (b.size = c)
+            },
+            Rotation: function(a, b) {
+                var c = this.readers.ogc._expression.call(this, a);
+                c && (b.rotation = c)
+            },
+            OnlineResource: function(a, b) {
+                b.href = this.getAttributeNS(a, this.namespaces.xlink, "href")
+            },
+            Format: function(a, b) {
+                b.graphicFormat = this.getChildValue(a)
+            }
+        }
+    }, OpenLayers.Format.Filter.v1_0_0.prototype.readers),
+    cssMap: {
+        stroke: "strokeColor",
+        "stroke-opacity": "strokeOpacity",
+        "stroke-width": "strokeWidth",
+        "stroke-linecap": "strokeLinecap",
+        "stroke-dasharray": "strokeDashstyle",
+        fill: "fillColor",
+        "fill-opacity": "fillOpacity",
+        "font-family": "fontFamily",
+        "font-size": "fontSize",
+        "font-weight": "fontWeight",
+        "font-style": "fontStyle"
+    },
+    getCssProperty: function(a) {
+        var b = null,
+            c;
+        for (c in this.cssMap)
+            if (this.cssMap[c] == a) {
+                b = c;
+                break
+            }
+        return b
+    },
+    getGraphicFormat: function(a) {
+        var b, c;
+        for (c in this.graphicFormats)
+            if (this.graphicFormats[c].test(a)) {
+                b =
+                    c;
+                break
+            }
+        return b || this.defaultGraphicFormat
+    },
+    defaultGraphicFormat: "image/png",
+    graphicFormats: {
+        "image/jpeg": /\.jpe?g$/i,
+        "image/gif": /\.gif$/i,
+        "image/png": /\.png$/i
+    },
+    write: function(a) {
+        return this.writers.sld.StyledLayerDescriptor.apply(this, [a])
+    },
+    writers: OpenLayers.Util.applyDefaults({
+        sld: {
+            _OGCExpression: function(a, b) {
+                var c = this.createElementNSPlus(a),
+                    d = "string" == typeof b ? b.split("${") : [b];
+                c.appendChild(this.createTextNode(d[0]));
+                for (var e, f, g = 1, h = d.length; g < h; g++) e = d[g], f = e.indexOf("}"), 0 < f ? (this.writeNode("ogc:PropertyName", {
+                    property: e.substring(0, f)
+                }, c), c.appendChild(this.createTextNode(e.substring(++f)))) : c.appendChild(this.createTextNode("${" + e));
+                return c
+            },
+            StyledLayerDescriptor: function(a) {
+                var b = this.createElementNSPlus("sld:StyledLayerDescriptor", {
+                    attributes: {
+                        version: this.VERSION,
+                        "xsi:schemaLocation": this.schemaLocation
+                    }
+                });
+                b.setAttribute("xmlns:ogc", this.namespaces.ogc);
+                b.setAttribute("xmlns:gml", this.namespaces.gml);
+                a.name && this.writeNode("Name", a.name, b);
+                a.title && this.writeNode("Title", a.title, b);
+                a.description &&
+                    this.writeNode("Abstract", a.description, b);
+                if (OpenLayers.Util.isArray(a.namedLayers))
+                    for (var c = 0, d = a.namedLayers.length; c < d; ++c) this.writeNode("NamedLayer", a.namedLayers[c], b);
+                else
+                    for (c in a.namedLayers) this.writeNode("NamedLayer", a.namedLayers[c], b);
+                return b
+            },
+            Name: function(a) {
+                return this.createElementNSPlus("sld:Name", {
+                    value: a
+                })
+            },
+            Title: function(a) {
+                return this.createElementNSPlus("sld:Title", {
+                    value: a
+                })
+            },
+            Abstract: function(a) {
+                return this.createElementNSPlus("sld:Abstract", {
+                    value: a
+                })
+            },
+            NamedLayer: function(a) {
+                var b =
+                    this.createElementNSPlus("sld:NamedLayer");
+                this.writeNode("Name", a.name, b);
+                if (a.namedStyles)
+                    for (var c = 0, d = a.namedStyles.length; c < d; ++c) this.writeNode("NamedStyle", a.namedStyles[c], b);
+                if (a.userStyles) {
+                    c = 0;
+                    for (d = a.userStyles.length; c < d; ++c) this.writeNode("UserStyle", a.userStyles[c], b)
+                }
+                return b
+            },
+            NamedStyle: function(a) {
+                var b = this.createElementNSPlus("sld:NamedStyle");
+                this.writeNode("Name", a, b);
+                return b
+            },
+            UserStyle: function(a) {
+                var b = this.createElementNSPlus("sld:UserStyle");
+                a.name && this.writeNode("Name",
+                    a.name, b);
+                a.title && this.writeNode("Title", a.title, b);
+                a.description && this.writeNode("Abstract", a.description, b);
+                a.isDefault && this.writeNode("IsDefault", a.isDefault, b);
+                if (this.multipleSymbolizers && a.rules) {
+                    for (var c = {
+                            "0": []
+                        }, d = [0], e, f, g, h, i, j = 0, k = a.rules.length; j < k; ++j)
+                        if (e = a.rules[j], e.symbolizers) {
+                            f = {};
+                            for (var l = 0, m = e.symbolizers.length; l < m; ++l) g = e.symbolizers[l], h = g.zIndex, h in f || (i = e.clone(), i.symbolizers = [], f[h] = i), f[h].symbolizers.push(g.clone());
+                            for (h in f) h in c || (d.push(h), c[h] = []), c[h].push(f[h])
+                        } else c[0].push(e.clone());
+                    d.sort();
+                    j = 0;
+                    for (k = d.length; j < k; ++j) e = c[d[j]], 0 < e.length && (i = a.clone(), i.rules = c[d[j]], this.writeNode("FeatureTypeStyle", i, b))
+                } else this.writeNode("FeatureTypeStyle", a, b);
+                return b
+            },
+            IsDefault: function(a) {
+                return this.createElementNSPlus("sld:IsDefault", {
+                    value: a ? "1" : "0"
+                })
+            },
+            FeatureTypeStyle: function(a) {
+                for (var b = this.createElementNSPlus("sld:FeatureTypeStyle"), c = 0, d = a.rules.length; c < d; ++c) this.writeNode("Rule", a.rules[c], b);
+                return b
+            },
+            Rule: function(a) {
+                var b = this.createElementNSPlus("sld:Rule");
+                a.name &&
+                    this.writeNode("Name", a.name, b);
+                a.title && this.writeNode("Title", a.title, b);
+                a.description && this.writeNode("Abstract", a.description, b);
+                a.elseFilter ? this.writeNode("ElseFilter", null, b) : a.filter && this.writeNode("ogc:Filter", a.filter, b);
+                void 0 != a.minScaleDenominator && this.writeNode("MinScaleDenominator", a.minScaleDenominator, b);
+                void 0 != a.maxScaleDenominator && this.writeNode("MaxScaleDenominator", a.maxScaleDenominator, b);
+                var c, d;
+                if (this.multipleSymbolizers && a.symbolizers)
+                    for (var e = 0, f = a.symbolizers.length; e <
+                        f; ++e) d = a.symbolizers[e], c = d.CLASS_NAME.split(".").pop(), this.writeNode(c + "Symbolizer", d, b);
+                else
+                    for (var f = OpenLayers.Style.SYMBOLIZER_PREFIXES, e = 0, g = f.length; e < g; ++e) c = f[e], (d = a.symbolizer[c]) && this.writeNode(c + "Symbolizer", d, b);
+                return b
+            },
+            ElseFilter: function() {
+                return this.createElementNSPlus("sld:ElseFilter")
+            },
+            MinScaleDenominator: function(a) {
+                return this.createElementNSPlus("sld:MinScaleDenominator", {
+                    value: a
+                })
+            },
+            MaxScaleDenominator: function(a) {
+                return this.createElementNSPlus("sld:MaxScaleDenominator", {
+                    value: a
+                })
+            },
+            LineSymbolizer: function(a) {
+                var b = this.createElementNSPlus("sld:LineSymbolizer");
+                this.writeNode("Stroke", a, b);
+                return b
+            },
+            Stroke: function(a) {
+                var b = this.createElementNSPlus("sld:Stroke");
+                void 0 != a.strokeColor && this.writeNode("CssParameter", {
+                    symbolizer: a,
+                    key: "strokeColor"
+                }, b);
+                void 0 != a.strokeOpacity && this.writeNode("CssParameter", {
+                    symbolizer: a,
+                    key: "strokeOpacity"
+                }, b);
+                void 0 != a.strokeWidth && this.writeNode("CssParameter", {
+                    symbolizer: a,
+                    key: "strokeWidth"
+                }, b);
+                void 0 != a.strokeDashstyle && "solid" !==
+                    a.strokeDashstyle && this.writeNode("CssParameter", {
+                        symbolizer: a,
+                        key: "strokeDashstyle"
+                    }, b);
+                void 0 != a.strokeLinecap && this.writeNode("CssParameter", {
+                    symbolizer: a,
+                    key: "strokeLinecap"
+                }, b);
+                return b
+            },
+            CssParameter: function(a) {
+                return this.createElementNSPlus("sld:CssParameter", {
+                    attributes: {
+                        name: this.getCssProperty(a.key)
+                    },
+                    value: a.symbolizer[a.key]
+                })
+            },
+            TextSymbolizer: function(a) {
+                var b = this.createElementNSPlus("sld:TextSymbolizer");
+                null != a.label && this.writeNode("Label", a.label, b);
+                (null != a.fontFamily || null != a.fontSize ||
+                    null != a.fontWeight || null != a.fontStyle) && this.writeNode("Font", a, b);
+                (null != a.labelAnchorPointX || null != a.labelAnchorPointY || null != a.labelAlign || null != a.labelXOffset || null != a.labelYOffset || null != a.labelRotation || null != a.labelPerpendicularOffset) && this.writeNode("LabelPlacement", a, b);
+                (null != a.haloRadius || null != a.haloColor || null != a.haloOpacity) && this.writeNode("Halo", a, b);
+                (null != a.fontColor || null != a.fontOpacity) && this.writeNode("Fill", {
+                    fillColor: a.fontColor,
+                    fillOpacity: a.fontOpacity
+                }, b);
+                return b
+            },
+            LabelPlacement: function(a) {
+                var b =
+                    this.createElementNSPlus("sld:LabelPlacement");
+                (null != a.labelAnchorPointX || null != a.labelAnchorPointY || null != a.labelAlign || null != a.labelXOffset || null != a.labelYOffset || null != a.labelRotation) && null == a.labelPerpendicularOffset && this.writeNode("PointPlacement", a, b);
+                null != a.labelPerpendicularOffset && this.writeNode("LinePlacement", a, b);
+                return b
+            },
+            LinePlacement: function(a) {
+                var b = this.createElementNSPlus("sld:LinePlacement");
+                this.writeNode("PerpendicularOffset", a.labelPerpendicularOffset, b);
+                return b
+            },
+            PerpendicularOffset: function(a) {
+                return this.createElementNSPlus("sld:PerpendicularOffset", {
+                    value: a
+                })
+            },
+            PointPlacement: function(a) {
+                var b = this.createElementNSPlus("sld:PointPlacement");
+                (null != a.labelAnchorPointX || null != a.labelAnchorPointY || null != a.labelAlign) && this.writeNode("AnchorPoint", a, b);
+                (null != a.labelXOffset || null != a.labelYOffset) && this.writeNode("Displacement", a, b);
+                null != a.labelRotation && this.writeNode("Rotation", a.labelRotation, b);
+                return b
+            },
+            AnchorPoint: function(a) {
+                var b = this.createElementNSPlus("sld:AnchorPoint"),
+                    c = a.labelAnchorPointX,
+                    d = a.labelAnchorPointY;
+                null != c && this.writeNode("AnchorPointX",
+                    c, b);
+                null != d && this.writeNode("AnchorPointY", d, b);
+                if (null == c && null == d) {
+                    var e = a.labelAlign.substr(0, 1),
+                        a = a.labelAlign.substr(1, 1);
+                    "l" === e ? c = 0 : "c" === e ? c = 0.5 : "r" === e && (c = 1);
+                    "b" === a ? d = 0 : "m" === a ? d = 0.5 : "t" === a && (d = 1);
+                    this.writeNode("AnchorPointX", c, b);
+                    this.writeNode("AnchorPointY", d, b)
+                }
+                return b
+            },
+            AnchorPointX: function(a) {
+                return this.createElementNSPlus("sld:AnchorPointX", {
+                    value: a
+                })
+            },
+            AnchorPointY: function(a) {
+                return this.createElementNSPlus("sld:AnchorPointY", {
+                    value: a
+                })
+            },
+            Displacement: function(a) {
+                var b = this.createElementNSPlus("sld:Displacement");
+                null != a.labelXOffset && this.writeNode("DisplacementX", a.labelXOffset, b);
+                null != a.labelYOffset && this.writeNode("DisplacementY", a.labelYOffset, b);
+                return b
+            },
+            DisplacementX: function(a) {
+                return this.createElementNSPlus("sld:DisplacementX", {
+                    value: a
+                })
+            },
+            DisplacementY: function(a) {
+                return this.createElementNSPlus("sld:DisplacementY", {
+                    value: a
+                })
+            },
+            Font: function(a) {
+                var b = this.createElementNSPlus("sld:Font");
+                a.fontFamily && this.writeNode("CssParameter", {
+                    symbolizer: a,
+                    key: "fontFamily"
+                }, b);
+                a.fontSize && this.writeNode("CssParameter", {
+                    symbolizer: a,
+                    key: "fontSize"
+                }, b);
+                a.fontWeight && this.writeNode("CssParameter", {
+                    symbolizer: a,
+                    key: "fontWeight"
+                }, b);
+                a.fontStyle && this.writeNode("CssParameter", {
+                    symbolizer: a,
+                    key: "fontStyle"
+                }, b);
+                return b
+            },
+            Label: function(a) {
+                return this.writers.sld._OGCExpression.call(this, "sld:Label", a)
+            },
+            Halo: function(a) {
+                var b = this.createElementNSPlus("sld:Halo");
+                a.haloRadius && this.writeNode("Radius", a.haloRadius, b);
+                (a.haloColor || a.haloOpacity) && this.writeNode("Fill", {
+                    fillColor: a.haloColor,
+                    fillOpacity: a.haloOpacity
+                }, b);
+                return b
+            },
+            Radius: function(a) {
+                return this.createElementNSPlus("sld:Radius", {
+                    value: a
+                })
+            },
+            RasterSymbolizer: function(a) {
+                var b = this.createElementNSPlus("sld:RasterSymbolizer");
+                a.geometry && this.writeNode("Geometry", a.geometry, b);
+                a.opacity && this.writeNode("Opacity", a.opacity, b);
+                a.colorMap && this.writeNode("ColorMap", a.colorMap, b);
+                return b
+            },
+            Geometry: function(a) {
+                var b = this.createElementNSPlus("sld:Geometry");
+                a.property && this.writeNode("ogc:PropertyName", a, b);
+                return b
+            },
+            ColorMap: function(a) {
+                for (var b = this.createElementNSPlus("sld:ColorMap"),
+                        c = 0, d = a.length; c < d; ++c) this.writeNode("ColorMapEntry", a[c], b);
+                return b
+            },
+            ColorMapEntry: function(a) {
+                var b = this.createElementNSPlus("sld:ColorMapEntry");
+                b.setAttribute("color", a.color);
+                void 0 !== a.opacity && b.setAttribute("opacity", parseFloat(a.opacity));
+                void 0 !== a.quantity && b.setAttribute("quantity", parseFloat(a.quantity));
+                void 0 !== a.label && b.setAttribute("label", a.label);
+                return b
+            },
+            PolygonSymbolizer: function(a) {
+                var b = this.createElementNSPlus("sld:PolygonSymbolizer");
+                !1 !== a.fill && this.writeNode("Fill",
+                    a, b);
+                !1 !== a.stroke && this.writeNode("Stroke", a, b);
+                return b
+            },
+            Fill: function(a) {
+                var b = this.createElementNSPlus("sld:Fill");
+                a.fillColor && this.writeNode("CssParameter", {
+                    symbolizer: a,
+                    key: "fillColor"
+                }, b);
+                null != a.fillOpacity && this.writeNode("CssParameter", {
+                    symbolizer: a,
+                    key: "fillOpacity"
+                }, b);
+                return b
+            },
+            PointSymbolizer: function(a) {
+                var b = this.createElementNSPlus("sld:PointSymbolizer");
+                this.writeNode("Graphic", a, b);
+                return b
+            },
+            Graphic: function(a) {
+                var b = this.createElementNSPlus("sld:Graphic");
+                void 0 != a.externalGraphic ?
+                    this.writeNode("ExternalGraphic", a, b) : this.writeNode("Mark", a, b);
+                void 0 != a.graphicOpacity && this.writeNode("Opacity", a.graphicOpacity, b);
+                void 0 != a.pointRadius ? this.writeNode("Size", 2 * a.pointRadius, b) : void 0 != a.graphicWidth && this.writeNode("Size", a.graphicWidth, b);
+                void 0 != a.rotation && this.writeNode("Rotation", a.rotation, b);
+                return b
+            },
+            ExternalGraphic: function(a) {
+                var b = this.createElementNSPlus("sld:ExternalGraphic");
+                this.writeNode("OnlineResource", a.externalGraphic, b);
+                this.writeNode("Format", a.graphicFormat ||
+                    this.getGraphicFormat(a.externalGraphic), b);
+                return b
+            },
+            Mark: function(a) {
+                var b = this.createElementNSPlus("sld:Mark");
+                a.graphicName && this.writeNode("WellKnownName", a.graphicName, b);
+                !1 !== a.fill && this.writeNode("Fill", a, b);
+                !1 !== a.stroke && this.writeNode("Stroke", a, b);
+                return b
+            },
+            WellKnownName: function(a) {
+                return this.createElementNSPlus("sld:WellKnownName", {
+                    value: a
+                })
+            },
+            Opacity: function(a) {
+                return this.createElementNSPlus("sld:Opacity", {
+                    value: a
+                })
+            },
+            Size: function(a) {
+                return this.writers.sld._OGCExpression.call(this,
+                    "sld:Size", a)
+            },
+            Rotation: function(a) {
+                return this.createElementNSPlus("sld:Rotation", {
+                    value: a
+                })
+            },
+            OnlineResource: function(a) {
+                return this.createElementNSPlus("sld:OnlineResource", {
+                    attributes: {
+                        "xlink:type": "simple",
+                        "xlink:href": a
+                    }
+                })
+            },
+            Format: function(a) {
+                return this.createElementNSPlus("sld:Format", {
+                    value: a
+                })
+            }
+        }
+    }, OpenLayers.Format.Filter.v1_0_0.prototype.writers),
+    CLASS_NAME: "OpenLayers.Format.SLD.v1"
+});
+OpenLayers.Layer.WMS = OpenLayers.Class(OpenLayers.Layer.Grid, {
+    DEFAULT_PARAMS: {
+        service: "WMS",
+        version: "1.1.1",
+        request: "GetMap",
+        styles: "",
+        format: "image/jpeg"
+    },
+    isBaseLayer: !0,
+    encodeBBOX: !1,
+    noMagic: !1,
+    yx: {},
+    initialize: function(a, b, c, d) {
+        var e = [],
+            c = OpenLayers.Util.upperCaseObject(c);
+        1.3 <= parseFloat(c.VERSION) && !c.EXCEPTIONS && (c.EXCEPTIONS = "INIMAGE");
+        e.push(a, b, c, d);
+        OpenLayers.Layer.Grid.prototype.initialize.apply(this, e);
+        OpenLayers.Util.applyDefaults(this.params, OpenLayers.Util.upperCaseObject(this.DEFAULT_PARAMS));
+        if (!this.noMagic && this.params.TRANSPARENT && "true" == this.params.TRANSPARENT.toString().toLowerCase()) {
+            if (null == d || !d.isBaseLayer) this.isBaseLayer = !1;
+            "image/jpeg" == this.params.FORMAT && (this.params.FORMAT = OpenLayers.Util.alphaHack() ? "image/gif" : "image/png")
+        }
+    },
+    clone: function(a) {
+        null == a && (a = new OpenLayers.Layer.WMS(this.name, this.url, this.params, this.getOptions()));
+        return a = OpenLayers.Layer.Grid.prototype.clone.apply(this, [a])
+    },
+    reverseAxisOrder: function() {
+        var a = this.projection.getCode();
+        return 1.3 <= parseFloat(this.params.VERSION) &&
+            !(!this.yx[a] && !OpenLayers.Projection.defaults[a].yx)
+    },
+    getURL: function(a) {
+        var a = this.adjustBounds(a),
+            b = this.getImageSize(),
+            c = {},
+            d = this.reverseAxisOrder();
+        c.BBOX = this.encodeBBOX ? a.toBBOX(null, d) : a.toArray(d);
+        c.WIDTH = b.w;
+        c.HEIGHT = b.h;
+        return this.getFullRequestString(c)
+    },
+    mergeNewParams: function(a) {
+        a = [OpenLayers.Util.upperCaseObject(a)];
+        return OpenLayers.Layer.Grid.prototype.mergeNewParams.apply(this, a)
+    },
+    getFullRequestString: function(a, b) {
+        var c = this.map.getProjectionObject(),
+            c = this.projection && this.projection.equals(c) ?
+            this.projection.getCode() : c.getCode(),
+            c = "none" == c ? null : c;
+        1.3 <= parseFloat(this.params.VERSION) ? this.params.CRS = c : this.params.SRS = c;
+        "boolean" == typeof this.params.TRANSPARENT && (a.TRANSPARENT = this.params.TRANSPARENT ? "TRUE" : "FALSE");
+        return OpenLayers.Layer.Grid.prototype.getFullRequestString.apply(this, arguments)
+    },
+    CLASS_NAME: "OpenLayers.Layer.WMS"
+});
+OpenLayers.Format.WMC.v1_1_0 = OpenLayers.Class(OpenLayers.Format.WMC.v1, {
+    VERSION: "1.1.0",
+    schemaLocation: "http://www.opengis.net/context http://schemas.opengis.net/context/1.1.0/context.xsd",
+    initialize: function(a) {
+        OpenLayers.Format.WMC.v1.prototype.initialize.apply(this, [a])
+    },
+    read_sld_MinScaleDenominator: function(a, b) {
+        var c = parseFloat(this.getChildValue(b));
+        0 < c && (a.maxScale = c)
+    },
+    read_sld_MaxScaleDenominator: function(a, b) {
+        a.minScale = parseFloat(this.getChildValue(b))
+    },
+    read_wmc_SRS: function(a, b) {
+        "srs" in
+        a || (a.srs = {});
+        a.srs[this.getChildValue(b)] = !0
+    },
+    write_wmc_Layer: function(a) {
+        var b = OpenLayers.Format.WMC.v1.prototype.write_wmc_Layer.apply(this, [a]);
+        if (a.maxScale) {
+            var c = this.createElementNS(this.namespaces.sld, "sld:MinScaleDenominator");
+            c.appendChild(this.createTextNode(a.maxScale.toPrecision(16)));
+            b.appendChild(c)
+        }
+        a.minScale && (c = this.createElementNS(this.namespaces.sld, "sld:MaxScaleDenominator"), c.appendChild(this.createTextNode(a.minScale.toPrecision(16))), b.appendChild(c));
+        if (a.srs)
+            for (var d in a.srs) b.appendChild(this.createElementDefaultNS("SRS",
+                d));
+        b.appendChild(this.write_wmc_FormatList(a));
+        b.appendChild(this.write_wmc_StyleList(a));
+        a.dimensions && b.appendChild(this.write_wmc_DimensionList(a));
+        b.appendChild(this.write_wmc_LayerExtension(a));
+        return b
+    },
+    CLASS_NAME: "OpenLayers.Format.WMC.v1_1_0"
+});
+OpenLayers.Format.XLS = OpenLayers.Class(OpenLayers.Format.XML.VersionedOGC, {
+    defaultVersion: "1.1.0",
+    stringifyOutput: !0,
+    CLASS_NAME: "OpenLayers.Format.XLS"
+});
+OpenLayers.Format.XLS.v1 = OpenLayers.Class(OpenLayers.Format.XML, {
+    namespaces: {
+        xls: "http://www.opengis.net/xls",
+        gml: "http://www.opengis.net/gml",
+        xsi: "http://www.w3.org/2001/XMLSchema-instance"
+    },
+    regExes: {
+        trimSpace: /^\s*|\s*$/g,
+        removeSpace: /\s*/g,
+        splitSpace: /\s+/,
+        trimComma: /\s*,\s*/g
+    },
+    xy: !0,
+    defaultPrefix: "xls",
+    schemaLocation: null,
+    read: function(a, b) {
+        OpenLayers.Util.applyDefaults(b, this.options);
+        var c = {};
+        this.readChildNodes(a, c);
+        return c
+    },
+    readers: {
+        xls: {
+            XLS: function(a, b) {
+                b.version = a.getAttribute("version");
+                this.readChildNodes(a, b)
+            },
+            Response: function(a, b) {
+                this.readChildNodes(a, b)
+            },
+            GeocodeResponse: function(a, b) {
+                b.responseLists = [];
+                this.readChildNodes(a, b)
+            },
+            GeocodeResponseList: function(a, b) {
+                var c = {
+                    features: [],
+                    numberOfGeocodedAddresses: parseInt(a.getAttribute("numberOfGeocodedAddresses"))
+                };
+                b.responseLists.push(c);
+                this.readChildNodes(a, c)
+            },
+            GeocodedAddress: function(a, b) {
+                var c = new OpenLayers.Feature.Vector;
+                b.features.push(c);
+                this.readChildNodes(a, c);
+                c.geometry = c.components[0]
+            },
+            GeocodeMatchCode: function(a, b) {
+                b.attributes.matchCode = {
+                    accuracy: parseFloat(a.getAttribute("accuracy")),
+                    matchType: a.getAttribute("matchType")
+                }
+            },
+            Address: function(a, b) {
+                var c = {
+                    countryCode: a.getAttribute("countryCode"),
+                    addressee: a.getAttribute("addressee"),
+                    street: [],
+                    place: []
+                };
+                b.attributes.address = c;
+                this.readChildNodes(a, c)
+            },
+            freeFormAddress: function(a, b) {
+                b.freeFormAddress = this.getChildValue(a)
+            },
+            StreetAddress: function(a, b) {
+                this.readChildNodes(a, b)
+            },
+            Building: function(a, b) {
+                b.building = {
+                    number: a.getAttribute("number"),
+                    subdivision: a.getAttribute("subdivision"),
+                    buildingName: a.getAttribute("buildingName")
+                }
+            },
+            Street: function(a, b) {
+                b.street.push(this.getChildValue(a))
+            },
+            Place: function(a, b) {
+                b.place[a.getAttribute("type")] = this.getChildValue(a)
+            },
+            PostalCode: function(a, b) {
+                b.postalCode = this.getChildValue(a)
+            }
+        },
+        gml: OpenLayers.Format.GML.v3.prototype.readers.gml
+    },
+    write: function(a) {
+        return this.writers.xls.XLS.apply(this, [a])
+    },
+    writers: {
+        xls: {
+            XLS: function(a) {
+                var b = this.createElementNSPlus("xls:XLS", {
+                    attributes: {
+                        version: this.VERSION,
+                        "xsi:schemaLocation": this.schemaLocation
+                    }
+                });
+                this.writeNode("RequestHeader", a.header, b);
+                this.writeNode("Request", a, b);
+                return b
+            },
+            RequestHeader: function() {
+                return this.createElementNSPlus("xls:RequestHeader")
+            },
+            Request: function(a) {
+                var b = this.createElementNSPlus("xls:Request", {
+                    attributes: {
+                        methodName: "GeocodeRequest",
+                        requestID: a.requestID || "",
+                        version: this.VERSION
+                    }
+                });
+                this.writeNode("GeocodeRequest", a.addresses, b);
+                return b
+            },
+            GeocodeRequest: function(a) {
+                for (var b = this.createElementNSPlus("xls:GeocodeRequest"), c = 0, d = a.length; c < d; c++) this.writeNode("Address",
+                    a[c], b);
+                return b
+            },
+            Address: function(a) {
+                var b = this.createElementNSPlus("xls:Address", {
+                    attributes: {
+                        countryCode: a.countryCode
+                    }
+                });
+                a.freeFormAddress ? this.writeNode("freeFormAddress", a.freeFormAddress, b) : (a.street && this.writeNode("StreetAddress", a, b), a.municipality && this.writeNode("Municipality", a.municipality, b), a.countrySubdivision && this.writeNode("CountrySubdivision", a.countrySubdivision, b), a.postalCode && this.writeNode("PostalCode", a.postalCode, b));
+                return b
+            },
+            freeFormAddress: function(a) {
+                return this.createElementNSPlus("freeFormAddress", {
+                    value: a
+                })
+            },
+            StreetAddress: function(a) {
+                var b = this.createElementNSPlus("xls:StreetAddress");
+                a.building && this.writeNode(b, "Building", a.building);
+                a = a.street;
+                OpenLayers.Util.isArray(a) || (a = [a]);
+                for (var c = 0, d = a.length; c < d; c++) this.writeNode("Street", a[c], b);
+                return b
+            },
+            Building: function(a) {
+                return this.createElementNSPlus("xls:Building", {
+                    attributes: {
+                        number: a.number,
+                        subdivision: a.subdivision,
+                        buildingName: a.buildingName
+                    }
+                })
+            },
+            Street: function(a) {
+                return this.createElementNSPlus("xls:Street", {
+                    value: a
+                })
+            },
+            Municipality: function(a) {
+                return this.createElementNSPlus("xls:Place", {
+                    attributes: {
+                        type: "Municipality"
+                    },
+                    value: a
+                })
+            },
+            CountrySubdivision: function(a) {
+                return this.createElementNSPlus("xls:Place", {
+                    attributes: {
+                        type: "CountrySubdivision"
+                    },
+                    value: a
+                })
+            },
+            PostalCode: function(a) {
+                return this.createElementNSPlus("xls:PostalCode", {
+                    value: a
+                })
+            }
+        }
+    },
+    CLASS_NAME: "OpenLayers.Format.XLS.v1"
+});
+OpenLayers.Format.XLS.v1_1_0 = OpenLayers.Class(OpenLayers.Format.XLS.v1, {
+    VERSION: "1.1",
+    schemaLocation: "http://www.opengis.net/xls http://schemas.opengis.net/ols/1.1.0/LocationUtilityService.xsd",
+    CLASS_NAME: "OpenLayers.Format.XLS.v1_1_0"
+});
+OpenLayers.Format.XLS.v1_1 = OpenLayers.Format.XLS.v1_1_0;
+OpenLayers.Renderer.SVG = OpenLayers.Class(OpenLayers.Renderer.Elements, {
+    xmlns: "http://www.w3.org/2000/svg",
+    xlinkns: "http://www.w3.org/1999/xlink",
+    MAX_PIXEL: 15E3,
+    translationParameters: null,
+    symbolMetrics: null,
+    initialize: function(a) {
+        this.supported() && (OpenLayers.Renderer.Elements.prototype.initialize.apply(this, arguments), this.translationParameters = {
+            x: 0,
+            y: 0
+        }, this.symbolMetrics = {})
+    },
+    supported: function() {
+        return document.implementation && (document.implementation.hasFeature("org.w3c.svg", "1.0") || document.implementation.hasFeature("http://www.w3.org/TR/SVG11/feature#SVG",
+            "1.1") || document.implementation.hasFeature("http://www.w3.org/TR/SVG11/feature#BasicStructure", "1.1"))
+    },
+    inValidRange: function(a, b, c) {
+        a += c ? 0 : this.translationParameters.x;
+        b += c ? 0 : this.translationParameters.y;
+        return a >= -this.MAX_PIXEL && a <= this.MAX_PIXEL && b >= -this.MAX_PIXEL && b <= this.MAX_PIXEL
+    },
+    setExtent: function(a, b) {
+        var c = OpenLayers.Renderer.Elements.prototype.setExtent.apply(this, arguments),
+            d = this.getResolution(),
+            e = -a.left / d,
+            d = a.top / d;
+        if (b) return this.left = e, this.top = d, this.rendererRoot.setAttributeNS(null,
+            "viewBox", "0 0 " + this.size.w + " " + this.size.h), this.translate(this.xOffset, 0), !0;
+        (e = this.translate(e - this.left + this.xOffset, d - this.top)) || this.setExtent(a, !0);
+        return c && e
+    },
+    translate: function(a, b) {
+        if (this.inValidRange(a, b, !0)) {
+            var c = "";
+            if (a || b) c = "translate(" + a + "," + b + ")";
+            this.root.setAttributeNS(null, "transform", c);
+            this.translationParameters = {
+                x: a,
+                y: b
+            };
+            return !0
+        }
+        return !1
+    },
+    setSize: function(a) {
+        OpenLayers.Renderer.prototype.setSize.apply(this, arguments);
+        this.rendererRoot.setAttributeNS(null, "width", this.size.w);
+        this.rendererRoot.setAttributeNS(null, "height", this.size.h)
+    },
+    getNodeType: function(a, b) {
+        var c = null;
+        switch (a.CLASS_NAME) {
+            case "OpenLayers.Geometry.Point":
+                c = b.externalGraphic ? "image" : this.isComplexSymbol(b.graphicName) ? "svg" : "circle";
+                break;
+            case "OpenLayers.Geometry.Rectangle":
+                c = "rect";
+                break;
+            case "OpenLayers.Geometry.LineString":
+                c = "polyline";
+                break;
+            case "OpenLayers.Geometry.LinearRing":
+                c = "polygon";
+                break;
+            case "OpenLayers.Geometry.Polygon":
+            case "OpenLayers.Geometry.Curve":
+                c = "path"
+        }
+        return c
+    },
+    setStyle: function(a,
+        b, c) {
+        var b = b || a._style,
+            c = c || a._options,
+            d = parseFloat(a.getAttributeNS(null, "r")),
+            e = 1,
+            f;
+        if ("OpenLayers.Geometry.Point" == a._geometryClass && d) {
+            a.style.visibility = "";
+            if (!1 === b.graphic) a.style.visibility = "hidden";
+            else if (b.externalGraphic) {
+                f = this.getPosition(a);
+                b.graphicTitle && (a.setAttributeNS(null, "title", b.graphicTitle), d = a.getElementsByTagName("title"), 0 < d.length ? d[0].firstChild.textContent = b.graphicTitle : (d = this.nodeFactory(null, "title"), d.textContent = b.graphicTitle, a.appendChild(d)));
+                b.graphicWidth &&
+                    b.graphicHeight && a.setAttributeNS(null, "preserveAspectRatio", "none");
+                var d = b.graphicWidth || b.graphicHeight,
+                    g = b.graphicHeight || b.graphicWidth,
+                    d = d ? d : 2 * b.pointRadius,
+                    g = g ? g : 2 * b.pointRadius,
+                    h = void 0 != b.graphicYOffset ? b.graphicYOffset : -(0.5 * g),
+                    i = b.graphicOpacity || b.fillOpacity;
+                a.setAttributeNS(null, "x", (f.x + (void 0 != b.graphicXOffset ? b.graphicXOffset : -(0.5 * d))).toFixed());
+                a.setAttributeNS(null, "y", (f.y + h).toFixed());
+                a.setAttributeNS(null, "width", d);
+                a.setAttributeNS(null, "height", g);
+                a.setAttributeNS(this.xlinkns,
+                    "href", b.externalGraphic);
+                a.setAttributeNS(null, "style", "opacity: " + i);
+                a.onclick = OpenLayers.Renderer.SVG.preventDefault
+            } else if (this.isComplexSymbol(b.graphicName)) {
+                var d = 3 * b.pointRadius,
+                    g = 2 * d,
+                    j = this.importSymbol(b.graphicName);
+                f = this.getPosition(a);
+                e = 3 * this.symbolMetrics[j.id][0] / g;
+                h = a.parentNode;
+                i = a.nextSibling;
+                h && h.removeChild(a);
+                a.firstChild && a.removeChild(a.firstChild);
+                a.appendChild(j.firstChild.cloneNode(!0));
+                a.setAttributeNS(null, "viewBox", j.getAttributeNS(null, "viewBox"));
+                a.setAttributeNS(null,
+                    "width", g);
+                a.setAttributeNS(null, "height", g);
+                a.setAttributeNS(null, "x", f.x - d);
+                a.setAttributeNS(null, "y", f.y - d);
+                i ? h.insertBefore(a, i) : h && h.appendChild(a)
+            } else a.setAttributeNS(null, "r", b.pointRadius);
+            d = b.rotation;
+            if ((void 0 !== d || void 0 !== a._rotation) && f) a._rotation = d, d |= 0, "svg" !== a.nodeName ? a.setAttributeNS(null, "transform", "rotate(" + d + " " + f.x + " " + f.y + ")") : (f = this.symbolMetrics[j.id], a.firstChild.setAttributeNS(null, "transform", "rotate(" + d + " " + f[1] + " " + f[2] + ")"))
+        }
+        c.isFilled ? (a.setAttributeNS(null,
+            "fill", b.fillColor), a.setAttributeNS(null, "fill-opacity", b.fillOpacity)) : a.setAttributeNS(null, "fill", "none");
+        c.isStroked ? (a.setAttributeNS(null, "stroke", b.strokeColor), a.setAttributeNS(null, "stroke-opacity", b.strokeOpacity), a.setAttributeNS(null, "stroke-width", b.strokeWidth * e), a.setAttributeNS(null, "stroke-linecap", b.strokeLinecap || "round"), a.setAttributeNS(null, "stroke-linejoin", "round"), b.strokeDashstyle && a.setAttributeNS(null, "stroke-dasharray", this.dashStyle(b, e))) : a.setAttributeNS(null, "stroke",
+            "none");
+        b.pointerEvents && a.setAttributeNS(null, "pointer-events", b.pointerEvents);
+        null != b.cursor && a.setAttributeNS(null, "cursor", b.cursor);
+        return a
+    },
+    dashStyle: function(a, b) {
+        var c = a.strokeWidth * b,
+            d = a.strokeDashstyle;
+        switch (d) {
+            case "solid":
+                return "none";
+            case "dot":
+                return [1, 4 * c].join();
+            case "dash":
+                return [4 * c, 4 * c].join();
+            case "dashdot":
+                return [4 * c, 4 * c, 1, 4 * c].join();
+            case "longdash":
+                return [8 * c, 4 * c].join();
+            case "longdashdot":
+                return [8 * c, 4 * c, 1, 4 * c].join();
+            default:
+                return OpenLayers.String.trim(d).replace(/\s+/g,
+                    ",")
+        }
+    },
+    createNode: function(a, b) {
+        var c = document.createElementNS(this.xmlns, a);
+        b && c.setAttributeNS(null, "id", b);
+        return c
+    },
+    nodeTypeCompare: function(a, b) {
+        return b == a.nodeName
+    },
+    createRenderRoot: function() {
+        var a = this.nodeFactory(this.container.id + "_svgRoot", "svg");
+        a.style.display = "block";
+        return a
+    },
+    createRoot: function(a) {
+        return this.nodeFactory(this.container.id + a, "g")
+    },
+    createDefs: function() {
+        var a = this.nodeFactory(this.container.id + "_defs", "defs");
+        this.rendererRoot.appendChild(a);
+        return a
+    },
+    drawPoint: function(a,
+        b) {
+        return this.drawCircle(a, b, 1)
+    },
+    drawCircle: function(a, b, c) {
+        var d = this.getResolution(),
+            e = (b.x - this.featureDx) / d + this.left,
+            b = this.top - b.y / d;
+        return this.inValidRange(e, b) ? (a.setAttributeNS(null, "cx", e), a.setAttributeNS(null, "cy", b), a.setAttributeNS(null, "r", c), a) : !1
+    },
+    drawLineString: function(a, b) {
+        var c = this.getComponentsString(b.components);
+        return c.path ? (a.setAttributeNS(null, "points", c.path), c.complete ? a : null) : !1
+    },
+    drawLinearRing: function(a, b) {
+        var c = this.getComponentsString(b.components);
+        return c.path ?
+            (a.setAttributeNS(null, "points", c.path), c.complete ? a : null) : !1
+    },
+    drawPolygon: function(a, b) {
+        for (var c = "", d = !0, e = !0, f, g, h = 0, i = b.components.length; h < i; h++) c += " M", f = this.getComponentsString(b.components[h].components, " "), (g = f.path) ? (c += " " + g, e = f.complete && e) : d = !1;
+        return d ? (a.setAttributeNS(null, "d", c + " z"), a.setAttributeNS(null, "fill-rule", "evenodd"), e ? a : null) : !1
+    },
+    drawRectangle: function(a, b) {
+        var c = this.getResolution(),
+            d = (b.x - this.featureDx) / c + this.left,
+            e = this.top - b.y / c;
+        return this.inValidRange(d, e) ? (a.setAttributeNS(null,
+            "x", d), a.setAttributeNS(null, "y", e), a.setAttributeNS(null, "width", b.width / c), a.setAttributeNS(null, "height", b.height / c), a) : !1
+    },
+    drawText: function(a, b, c) {
+        var d = !!b.labelOutlineWidth;
+        if (d) {
+            var e = OpenLayers.Util.extend({}, b);
+            e.fontColor = e.labelOutlineColor;
+            e.fontStrokeColor = e.labelOutlineColor;
+            e.fontStrokeWidth = b.labelOutlineWidth;
+            delete e.labelOutlineWidth;
+            this.drawText(a, e, c)
+        }
+        var f = this.getResolution(),
+            e = (c.x - this.featureDx) / f + this.left,
+            g = c.y / f - this.top,
+            d = d ? this.LABEL_OUTLINE_SUFFIX : this.LABEL_ID_SUFFIX,
+            f = this.nodeFactory(a + d, "text");
+        f.setAttributeNS(null, "x", e);
+        f.setAttributeNS(null, "y", -g);
+        b.fontColor && f.setAttributeNS(null, "fill", b.fontColor);
+        b.fontStrokeColor && f.setAttributeNS(null, "stroke", b.fontStrokeColor);
+        b.fontStrokeWidth && f.setAttributeNS(null, "stroke-width", b.fontStrokeWidth);
+        b.fontOpacity && f.setAttributeNS(null, "opacity", b.fontOpacity);
+        b.fontFamily && f.setAttributeNS(null, "font-family", b.fontFamily);
+        b.fontSize && f.setAttributeNS(null, "font-size", b.fontSize);
+        b.fontWeight && f.setAttributeNS(null,
+            "font-weight", b.fontWeight);
+        b.fontStyle && f.setAttributeNS(null, "font-style", b.fontStyle);
+        !0 === b.labelSelect ? (f.setAttributeNS(null, "pointer-events", "visible"), f._featureId = a) : f.setAttributeNS(null, "pointer-events", "none");
+        g = b.labelAlign || OpenLayers.Renderer.defaultSymbolizer.labelAlign;
+        f.setAttributeNS(null, "text-anchor", OpenLayers.Renderer.SVG.LABEL_ALIGN[g[0]] || "middle");
+        !0 === OpenLayers.IS_GECKO && f.setAttributeNS(null, "dominant-baseline", OpenLayers.Renderer.SVG.LABEL_ALIGN[g[1]] || "central");
+        for (var h =
+                b.label.split("\n"), i = h.length; f.childNodes.length > i;) f.removeChild(f.lastChild);
+        for (var j = 0; j < i; j++) {
+            var k = this.nodeFactory(a + d + "_tspan_" + j, "tspan");
+            !0 === b.labelSelect && (k._featureId = a, k._geometry = c, k._geometryClass = c.CLASS_NAME);
+            !1 === OpenLayers.IS_GECKO && k.setAttributeNS(null, "baseline-shift", OpenLayers.Renderer.SVG.LABEL_VSHIFT[g[1]] || "-35%");
+            k.setAttribute("x", e);
+            if (0 == j) {
+                var l = OpenLayers.Renderer.SVG.LABEL_VFACTOR[g[1]];
+                null == l && (l = -0.5);
+                k.setAttribute("dy", l * (i - 1) + "em")
+            } else k.setAttribute("dy",
+                "1em");
+            k.textContent = "" === h[j] ? " " : h[j];
+            k.parentNode || f.appendChild(k)
+        }
+        f.parentNode || this.textRoot.appendChild(f)
+    },
+    getComponentsString: function(a, b) {
+        for (var c = [], d = !0, e = a.length, f = [], g, h = 0; h < e; h++) g = a[h], c.push(g), (g = this.getShortString(g)) ? f.push(g) : (0 < h && this.getShortString(a[h - 1]) && f.push(this.clipLine(a[h], a[h - 1])), h < e - 1 && this.getShortString(a[h + 1]) && f.push(this.clipLine(a[h], a[h + 1])), d = !1);
+        return {
+            path: f.join(b || ","),
+            complete: d
+        }
+    },
+    clipLine: function(a, b) {
+        if (b.equals(a)) return "";
+        var c = this.getResolution(),
+            d = this.MAX_PIXEL - this.translationParameters.x,
+            e = this.MAX_PIXEL - this.translationParameters.y,
+            f = (b.x - this.featureDx) / c + this.left,
+            g = this.top - b.y / c,
+            h = (a.x - this.featureDx) / c + this.left,
+            c = this.top - a.y / c,
+            i;
+        if (h < -d || h > d) i = (c - g) / (h - f), h = 0 > h ? -d : d, c = g + (h - f) * i;
+        if (c < -e || c > e) i = (h - f) / (c - g), c = 0 > c ? -e : e, h = f + (c - g) * i;
+        return h + "," + c
+    },
+    getShortString: function(a) {
+        var b = this.getResolution(),
+            c = (a.x - this.featureDx) / b + this.left,
+            a = this.top - a.y / b;
+        return this.inValidRange(c, a) ? c + "," + a : !1
+    },
+    getPosition: function(a) {
+        return {
+            x: parseFloat(a.getAttributeNS(null,
+                "cx")),
+            y: parseFloat(a.getAttributeNS(null, "cy"))
+        }
+    },
+    importSymbol: function(a) {
+        this.defs || (this.defs = this.createDefs());
+        var b = this.container.id + "-" + a,
+            c = document.getElementById(b);
+        if (null != c) return c;
+        var d = OpenLayers.Renderer.symbol[a];
+        if (!d) throw Error(a + " is not a valid symbol name");
+        var a = this.nodeFactory(b, "symbol"),
+            e = this.nodeFactory(null, "polygon");
+        a.appendChild(e);
+        for (var c = new OpenLayers.Bounds(Number.MAX_VALUE, Number.MAX_VALUE, 0, 0), f = [], g, h, i = 0; i < d.length; i += 2) g = d[i], h = d[i + 1], c.left = Math.min(c.left,
+            g), c.bottom = Math.min(c.bottom, h), c.right = Math.max(c.right, g), c.top = Math.max(c.top, h), f.push(g, ",", h);
+        e.setAttributeNS(null, "points", f.join(" "));
+        d = c.getWidth();
+        e = c.getHeight();
+        a.setAttributeNS(null, "viewBox", [c.left - d, c.bottom - e, 3 * d, 3 * e].join(" "));
+        this.symbolMetrics[b] = [Math.max(d, e), c.getCenterLonLat().lon, c.getCenterLonLat().lat];
+        this.defs.appendChild(a);
+        return a
+    },
+    getFeatureIdFromEvent: function(a) {
+        var b = OpenLayers.Renderer.Elements.prototype.getFeatureIdFromEvent.apply(this, arguments);
+        b || (b = a.target,
+            b = b.parentNode && b != this.rendererRoot ? b.parentNode._featureId : void 0);
+        return b
+    },
+    CLASS_NAME: "OpenLayers.Renderer.SVG"
+});
+OpenLayers.Renderer.SVG.LABEL_ALIGN = {
+    l: "start",
+    r: "end",
+    b: "bottom",
+    t: "hanging"
+};
+OpenLayers.Renderer.SVG.LABEL_VSHIFT = {
+    t: "-70%",
+    b: "0"
+};
+OpenLayers.Renderer.SVG.LABEL_VFACTOR = {
+    t: 0,
+    b: -1
+};
+OpenLayers.Renderer.SVG.preventDefault = function(a) {
+    a.preventDefault && a.preventDefault()
+};
+OpenLayers.Format.SLD.v1_0_0 = OpenLayers.Class(OpenLayers.Format.SLD.v1, {
+    VERSION: "1.0.0",
+    schemaLocation: "http://www.opengis.net/sld http://schemas.opengis.net/sld/1.0.0/StyledLayerDescriptor.xsd",
+    CLASS_NAME: "OpenLayers.Format.SLD.v1_0_0"
+});
+OpenLayers.Format.OWSContext = OpenLayers.Class(OpenLayers.Format.Context, {
+    defaultVersion: "0.3.1",
+    getVersion: function(a, b) {
+        var c = OpenLayers.Format.XML.VersionedOGC.prototype.getVersion.apply(this, arguments);
+        "0.3.0" === c && (c = this.defaultVersion);
+        return c
+    },
+    toContext: function(a) {
+        var b = {};
+        "OpenLayers.Map" == a.CLASS_NAME && (b.bounds = a.getExtent(), b.maxExtent = a.maxExtent, b.projection = a.projection, b.size = a.getSize(), b.layers = a.layers);
+        return b
+    },
+    CLASS_NAME: "OpenLayers.Format.OWSContext"
+});
+OpenLayers.Format.OWSContext.v0_3_1 = OpenLayers.Class(OpenLayers.Format.XML, {
+    namespaces: {
+        owc: "http://www.opengis.net/ows-context",
+        gml: "http://www.opengis.net/gml",
+        kml: "http://www.opengis.net/kml/2.2",
+        ogc: "http://www.opengis.net/ogc",
+        ows: "http://www.opengis.net/ows",
+        sld: "http://www.opengis.net/sld",
+        xlink: "http://www.w3.org/1999/xlink",
+        xsi: "http://www.w3.org/2001/XMLSchema-instance"
+    },
+    VERSION: "0.3.1",
+    schemaLocation: "http://www.opengis.net/ows-context http://www.ogcnetwork.net/schemas/owc/0.3.1/owsContext.xsd",
+    defaultPrefix: "owc",
+    extractAttributes: !0,
+    xy: !0,
+    regExes: {
+        trimSpace: /^\s*|\s*$/g,
+        removeSpace: /\s*/g,
+        splitSpace: /\s+/,
+        trimComma: /\s*,\s*/g
+    },
+    featureNS: "http://mapserver.gis.umn.edu/mapserver",
+    featureType: "vector",
+    geometryName: "geometry",
+    nestingLayerLookup: null,
+    initialize: function(a) {
+        OpenLayers.Format.XML.prototype.initialize.apply(this, [a]);
+        OpenLayers.Format.GML.v2.prototype.setGeometryTypes.call(this)
+    },
+    setNestingPath: function(a) {
+        if (a.layersContext)
+            for (var b = 0, c = a.layersContext.length; b < c; b++) {
+                var d =
+                    a.layersContext[b],
+                    e = [],
+                    f = a.title || "";
+                a.metadata && a.metadata.nestingPath && (e = a.metadata.nestingPath.slice());
+                "" != f && e.push(f);
+                d.metadata.nestingPath = e;
+                d.layersContext && this.setNestingPath(d)
+            }
+    },
+    decomposeNestingPath: function(a) {
+        var b = [];
+        if (OpenLayers.Util.isArray(a)) {
+            for (a = a.slice(); 0 < a.length;) b.push(a.slice()), a.pop();
+            b.reverse()
+        }
+        return b
+    },
+    read: function(a) {
+        "string" == typeof a && (a = OpenLayers.Format.XML.prototype.read.apply(this, [a]));
+        a && 9 == a.nodeType && (a = a.documentElement);
+        var b = {};
+        this.readNode(a,
+            b);
+        this.setNestingPath({
+            layersContext: b.layersContext
+        });
+        a = [];
+        this.processLayer(a, b);
+        delete b.layersContext;
+        b.layersContext = a;
+        return b
+    },
+    processLayer: function(a, b) {
+        if (b.layersContext)
+            for (var c = 0, d = b.layersContext.length; c < d; c++) {
+                var e = b.layersContext[c];
+                a.push(e);
+                e.layersContext && this.processLayer(a, e)
+            }
+    },
+    write: function(a, b) {
+        this.nestingLayerLookup = {};
+        b = b || {};
+        OpenLayers.Util.applyDefaults(b, a);
+        var c = this.writeNode("OWSContext", b);
+        this.nestingLayerLookup = null;
+        this.setAttributeNS(c, this.namespaces.xsi,
+            "xsi:schemaLocation", this.schemaLocation);
+        return OpenLayers.Format.XML.prototype.write.apply(this, [c])
+    },
+    readers: {
+        kml: {
+            Document: function(a, b) {
+                b.features = (new OpenLayers.Format.KML({
+                    kmlns: this.namespaces.kml,
+                    extractStyles: !0
+                })).read(a)
+            }
+        },
+        owc: {
+            OWSContext: function(a, b) {
+                this.readChildNodes(a, b)
+            },
+            General: function(a, b) {
+                this.readChildNodes(a, b)
+            },
+            ResourceList: function(a, b) {
+                this.readChildNodes(a, b)
+            },
+            Layer: function(a, b) {
+                var c = {
+                    metadata: {},
+                    visibility: "1" != a.getAttribute("hidden"),
+                    queryable: "1" == a.getAttribute("queryable"),
+                    opacity: null != a.getAttribute("opacity") ? parseFloat(a.getAttribute("opacity")) : null,
+                    name: a.getAttribute("name"),
+                    categoryLayer: null == a.getAttribute("name"),
+                    formats: [],
+                    styles: []
+                };
+                b.layersContext || (b.layersContext = []);
+                b.layersContext.push(c);
+                this.readChildNodes(a, c)
+            },
+            InlineGeometry: function(a, b) {
+                b.features = [];
+                var c = this.getElementsByTagNameNS(a, this.namespaces.gml, "featureMember"),
+                    d;
+                1 <= c.length && (d = c[0]);
+                d && d.firstChild && (c = d.firstChild.nextSibling ? d.firstChild.nextSibling : d.firstChild, this.setNamespace("feature",
+                    c.namespaceURI), this.featureType = c.localName || c.nodeName.split(":").pop(), this.readChildNodes(a, b))
+            },
+            Server: function(a, b) {
+                if (!b.service && !b.version || b.service != OpenLayers.Format.Context.serviceTypes.WMS) b.service = a.getAttribute("service"), b.version = a.getAttribute("version"), this.readChildNodes(a, b)
+            },
+            Name: function(a, b) {
+                b.name = this.getChildValue(a);
+                this.readChildNodes(a, b)
+            },
+            Title: function(a, b) {
+                b.title = this.getChildValue(a);
+                this.readChildNodes(a, b)
+            },
+            StyleList: function(a, b) {
+                this.readChildNodes(a, b.styles)
+            },
+            Style: function(a, b) {
+                var c = {};
+                b.push(c);
+                this.readChildNodes(a, c)
+            },
+            LegendURL: function(a, b) {
+                var c = {};
+                b.legend = c;
+                this.readChildNodes(a, c)
+            },
+            OnlineResource: function(a, b) {
+                b.url = this.getAttributeNS(a, this.namespaces.xlink, "href");
+                this.readChildNodes(a, b)
+            }
+        },
+        ows: OpenLayers.Format.OWSCommon.v1_0_0.prototype.readers.ows,
+        gml: OpenLayers.Format.GML.v2.prototype.readers.gml,
+        sld: OpenLayers.Format.SLD.v1_0_0.prototype.readers.sld,
+        feature: OpenLayers.Format.GML.v2.prototype.readers.feature
+    },
+    writers: {
+        owc: {
+            OWSContext: function(a) {
+                var b =
+                    this.createElementNSPlus("OWSContext", {
+                        attributes: {
+                            version: this.VERSION,
+                            id: a.id || OpenLayers.Util.createUniqueID("OpenLayers_OWSContext_")
+                        }
+                    });
+                this.writeNode("General", a, b);
+                this.writeNode("ResourceList", a, b);
+                return b
+            },
+            General: function(a) {
+                var b = this.createElementNSPlus("General");
+                this.writeNode("ows:BoundingBox", a, b);
+                this.writeNode("ows:Title", a.title || "OpenLayers OWSContext", b);
+                return b
+            },
+            ResourceList: function(a) {
+                for (var b = this.createElementNSPlus("ResourceList"), c = 0, d = a.layers.length; c < d; c++) {
+                    var e =
+                        a.layers[c],
+                        f = this.decomposeNestingPath(e.metadata.nestingPath);
+                    this.writeNode("_Layer", {
+                        layer: e,
+                        subPaths: f
+                    }, b)
+                }
+                return b
+            },
+            Server: function(a) {
+                var b = this.createElementNSPlus("Server", {
+                    attributes: {
+                        version: a.version,
+                        service: a.service
+                    }
+                });
+                this.writeNode("OnlineResource", a, b);
+                return b
+            },
+            OnlineResource: function(a) {
+                return this.createElementNSPlus("OnlineResource", {
+                    attributes: {
+                        "xlink:href": a.url
+                    }
+                })
+            },
+            InlineGeometry: function(a) {
+                var b = this.createElementNSPlus("InlineGeometry");
+                this.writeNode("gml:boundedBy", a.getDataExtent(),
+                    b);
+                for (var c = 0, d = a.features.length; c < d; c++) this.writeNode("gml:featureMember", a.features[c], b);
+                return b
+            },
+            StyleList: function(a) {
+                for (var b = this.createElementNSPlus("StyleList"), c = 0, d = a.length; c < d; c++) this.writeNode("Style", a[c], b);
+                return b
+            },
+            Style: function(a) {
+                var b = this.createElementNSPlus("Style");
+                this.writeNode("Name", a, b);
+                this.writeNode("Title", a, b);
+                a.legend && this.writeNode("LegendURL", a, b);
+                return b
+            },
+            Name: function(a) {
+                return this.createElementNSPlus("Name", {
+                    value: a.name
+                })
+            },
+            Title: function(a) {
+                return this.createElementNSPlus("Title", {
+                    value: a.title
+                })
+            },
+            LegendURL: function(a) {
+                var b = this.createElementNSPlus("LegendURL");
+                this.writeNode("OnlineResource", a.legend, b);
+                return b
+            },
+            _WMS: function(a) {
+                var b = this.createElementNSPlus("Layer", {
+                    attributes: {
+                        name: a.params.LAYERS,
+                        queryable: a.queryable ? "1" : "0",
+                        hidden: a.visibility ? "0" : "1",
+                        opacity: a.hasOwnProperty("opacity") ? a.opacity : null
+                    }
+                });
+                this.writeNode("ows:Title", a.name, b);
+                this.writeNode("ows:OutputFormat", a.params.FORMAT, b);
+                this.writeNode("Server", {
+                    service: OpenLayers.Format.Context.serviceTypes.WMS,
+                    version: a.params.VERSION,
+                    url: a.url
+                }, b);
+                a.metadata.styles && 0 < a.metadata.styles.length && this.writeNode("StyleList", a.metadata.styles, b);
+                return b
+            },
+            _Layer: function(a) {
+                var b, c, d;
+                b = a.layer;
+                c = a.subPaths;
+                d = null;
+                0 < c.length ? (b = c[0].join("/"), c = b.lastIndexOf("/"), d = this.nestingLayerLookup[b], c = 0 < c ? b.substring(c + 1, b.length) : b, d || (d = this.createElementNSPlus("Layer"), this.writeNode("ows:Title", c, d), this.nestingLayerLookup[b] = d), a.subPaths.shift(), this.writeNode("_Layer", a, d)) : (b instanceof OpenLayers.Layer.WMS ?
+                    d = this.writeNode("_WMS", b) : b instanceof OpenLayers.Layer.Vector && (b.protocol instanceof OpenLayers.Protocol.WFS.v1 ? d = this.writeNode("_WFS", b) : b.protocol instanceof OpenLayers.Protocol.HTTP ? b.protocol.format instanceof OpenLayers.Format.GML ? (b.protocol.format.version = "2.1.2", d = this.writeNode("_GML", b)) : b.protocol.format instanceof OpenLayers.Format.KML && (b.protocol.format.version = "2.2", d = this.writeNode("_KML", b)) : (this.setNamespace("feature", this.featureNS), d = this.writeNode("_InlineGeometry", b))),
+                    b.options.maxScale && this.writeNode("sld:MinScaleDenominator", b.options.maxScale, d), b.options.minScale && this.writeNode("sld:MaxScaleDenominator", b.options.minScale, d), this.nestingLayerLookup[b.name] = d);
+                return d
+            },
+            _WFS: function(a) {
+                var b = this.createElementNSPlus("Layer", {
+                    attributes: {
+                        name: a.protocol.featurePrefix + ":" + a.protocol.featureType,
+                        hidden: a.visibility ? "0" : "1"
+                    }
+                });
+                this.writeNode("ows:Title", a.name, b);
+                this.writeNode("Server", {
+                    service: OpenLayers.Format.Context.serviceTypes.WFS,
+                    version: a.protocol.version,
+                    url: a.protocol.url
+                }, b);
+                return b
+            },
+            _InlineGeometry: function(a) {
+                var b = this.createElementNSPlus("Layer", {
+                    attributes: {
+                        name: this.featureType,
+                        hidden: a.visibility ? "0" : "1"
+                    }
+                });
+                this.writeNode("ows:Title", a.name, b);
+                this.writeNode("InlineGeometry", a, b);
+                return b
+            },
+            _GML: function(a) {
+                var b = this.createElementNSPlus("Layer");
+                this.writeNode("ows:Title", a.name, b);
+                this.writeNode("Server", {
+                    service: OpenLayers.Format.Context.serviceTypes.GML,
+                    url: a.protocol.url,
+                    version: a.protocol.format.version
+                }, b);
+                return b
+            },
+            _KML: function(a) {
+                var b =
+                    this.createElementNSPlus("Layer");
+                this.writeNode("ows:Title", a.name, b);
+                this.writeNode("Server", {
+                    service: OpenLayers.Format.Context.serviceTypes.KML,
+                    version: a.protocol.format.version,
+                    url: a.protocol.url
+                }, b);
+                return b
+            }
+        },
+        gml: OpenLayers.Util.applyDefaults({
+            boundedBy: function(a) {
+                var b = this.createElementNSPlus("gml:boundedBy");
+                this.writeNode("gml:Box", a, b);
+                return b
+            }
+        }, OpenLayers.Format.GML.v2.prototype.writers.gml),
+        ows: OpenLayers.Format.OWSCommon.v1_0_0.prototype.writers.ows,
+        sld: OpenLayers.Format.SLD.v1_0_0.prototype.writers.sld,
+        feature: OpenLayers.Format.GML.v2.prototype.writers.feature
+    },
+    CLASS_NAME: "OpenLayers.Format.OWSContext.v0_3_1"
+});
+OpenLayers.Control.ScaleLine = OpenLayers.Class(OpenLayers.Control, {
+    maxWidth: 100,
+    topOutUnits: "km",
+    topInUnits: "m",
+    bottomOutUnits: "mi",
+    bottomInUnits: "ft",
+    eTop: null,
+    eBottom: null,
+    geodesic: !1,
+    draw: function() {
+        OpenLayers.Control.prototype.draw.apply(this, arguments);
+        this.eTop || (this.eTop = document.createElement("div"), this.eTop.className = this.displayClass + "Top", this.div.appendChild(this.eTop), this.eTop.style.visibility = "" == this.topOutUnits || "" == this.topInUnits ? "hidden" : "visible", this.eBottom = document.createElement("div"),
+            this.eBottom.className = this.displayClass + "Bottom", this.div.appendChild(this.eBottom), this.eBottom.style.visibility = "" == this.bottomOutUnits || "" == this.bottomInUnits ? "hidden" : "visible");
+        this.map.events.register("moveend", this, this.update);
+        this.update();
+        return this.div
+    },
+    getBarLen: function(a) {
+        var b = parseInt(Math.log(a) / Math.log(10)),
+            b = Math.pow(10, b),
+            a = parseInt(a / b);
+        return (5 < a ? 5 : 2 < a ? 2 : 1) * b
+    },
+    update: function() {
+        var a = this.map.getResolution();
+        if (a) {
+            var b = this.map.getUnits(),
+                c = OpenLayers.INCHES_PER_UNIT,
+                d = this.maxWidth *
+                a * c[b],
+                e = 1;
+            !0 === this.geodesic && (e = (this.map.getGeodesicPixelSize().w || 1.0E-6) * this.maxWidth / (d / c.km), d *= e);
+            var f, g;
+            1E5 < d ? (f = this.topOutUnits, g = this.bottomOutUnits) : (f = this.topInUnits, g = this.bottomInUnits);
+            var h = d / c[f],
+                i = d / c[g],
+                d = this.getBarLen(h),
+                j = this.getBarLen(i),
+                h = d / c[b] * c[f],
+                i = j / c[b] * c[g],
+                b = h / a / e,
+                a = i / a / e;
+            "visible" == this.eBottom.style.visibility && (this.eBottom.style.width = Math.round(a) + "px", this.eBottom.innerHTML = j + " " + g);
+            "visible" == this.eTop.style.visibility && (this.eTop.style.width = Math.round(b) +
+                "px", this.eTop.innerHTML = d + " " + f)
+        }
+    },
+    CLASS_NAME: "OpenLayers.Control.ScaleLine"
+});
+OpenLayers.Icon = OpenLayers.Class({
+    url: null,
+    size: null,
+    offset: null,
+    calculateOffset: null,
+    imageDiv: null,
+    px: null,
+    initialize: function(a, b, c, d) {
+        this.url = a;
+        this.size = b || {
+            w: 20,
+            h: 20
+        };
+        this.offset = c || {
+            x: -(this.size.w / 2),
+            y: -(this.size.h / 2)
+        };
+        this.calculateOffset = d;
+        a = OpenLayers.Util.createUniqueID("OL_Icon_");
+        this.imageDiv = OpenLayers.Util.createAlphaImageDiv(a)
+    },
+    destroy: function() {
+        this.erase();
+        OpenLayers.Event.stopObservingElement(this.imageDiv.firstChild);
+        this.imageDiv.innerHTML = "";
+        this.imageDiv = null
+    },
+    clone: function() {
+        return new OpenLayers.Icon(this.url,
+            this.size, this.offset, this.calculateOffset)
+    },
+    setSize: function(a) {
+        null != a && (this.size = a);
+        this.draw()
+    },
+    setUrl: function(a) {
+        null != a && (this.url = a);
+        this.draw()
+    },
+    draw: function(a) {
+        OpenLayers.Util.modifyAlphaImageDiv(this.imageDiv, null, null, this.size, this.url, "absolute");
+        this.moveTo(a);
+        return this.imageDiv
+    },
+    erase: function() {
+        null != this.imageDiv && null != this.imageDiv.parentNode && OpenLayers.Element.remove(this.imageDiv)
+    },
+    setOpacity: function(a) {
+        OpenLayers.Util.modifyAlphaImageDiv(this.imageDiv, null, null, null, null,
+            null, null, null, a)
+    },
+    moveTo: function(a) {
+        null != a && (this.px = a);
+        null != this.imageDiv && (null == this.px ? this.display(!1) : (this.calculateOffset && (this.offset = this.calculateOffset(this.size)), OpenLayers.Util.modifyAlphaImageDiv(this.imageDiv, null, {
+            x: this.px.x + this.offset.x,
+            y: this.px.y + this.offset.y
+        })))
+    },
+    display: function(a) {
+        this.imageDiv.style.display = a ? "" : "none"
+    },
+    isDrawn: function() {
+        return this.imageDiv && this.imageDiv.parentNode && 11 != this.imageDiv.parentNode.nodeType
+    },
+    CLASS_NAME: "OpenLayers.Icon"
+});
+OpenLayers.Marker = OpenLayers.Class({
+    icon: null,
+    lonlat: null,
+    events: null,
+    map: null,
+    initialize: function(a, b) {
+        this.lonlat = a;
+        var c = b ? b : OpenLayers.Marker.defaultIcon();
+        null == this.icon ? this.icon = c : (this.icon.url = c.url, this.icon.size = c.size, this.icon.offset = c.offset, this.icon.calculateOffset = c.calculateOffset);
+        this.events = new OpenLayers.Events(this, this.icon.imageDiv)
+    },
+    destroy: function() {
+        this.erase();
+        this.map = null;
+        this.events.destroy();
+        this.events = null;
+        null != this.icon && (this.icon.destroy(), this.icon = null)
+    },
+    draw: function(a) {
+        return this.icon.draw(a)
+    },
+    erase: function() {
+        null != this.icon && this.icon.erase()
+    },
+    moveTo: function(a) {
+        null != a && null != this.icon && this.icon.moveTo(a);
+        this.lonlat = this.map.getLonLatFromLayerPx(a)
+    },
+    isDrawn: function() {
+        return this.icon && this.icon.isDrawn()
+    },
+    onScreen: function() {
+        var a = !1;
+        this.map && (a = this.map.getExtent().containsLonLat(this.lonlat));
+        return a
+    },
+    inflate: function(a) {
+        this.icon && this.icon.setSize({
+            w: this.icon.size.w * a,
+            h: this.icon.size.h * a
+        })
+    },
+    setOpacity: function(a) {
+        this.icon.setOpacity(a)
+    },
+    setUrl: function(a) {
+        this.icon.setUrl(a)
+    },
+    display: function(a) {
+        this.icon.display(a)
+    },
+    CLASS_NAME: "OpenLayers.Marker"
+});
+OpenLayers.Marker.defaultIcon = function() {
+    return new OpenLayers.Icon(OpenLayers.Util.getImageLocation("marker.png"), {
+        w: 21,
+        h: 25
+    }, {
+        x: -10.5,
+        y: -25
+    })
+};
+OpenLayers.Layer.TileCache = OpenLayers.Class(OpenLayers.Layer.Grid, {
+    isBaseLayer: !0,
+    format: "image/png",
+    serverResolutions: null,
+    initialize: function(a, b, c, d) {
+        this.layername = c;
+        OpenLayers.Layer.Grid.prototype.initialize.apply(this, [a, b, {}, d]);
+        this.extension = this.format.split("/")[1].toLowerCase();
+        this.extension = "jpg" == this.extension ? "jpeg" : this.extension
+    },
+    clone: function(a) {
+        null == a && (a = new OpenLayers.Layer.TileCache(this.name, this.url, this.layername, this.getOptions()));
+        return a = OpenLayers.Layer.Grid.prototype.clone.apply(this, [a])
+    },
+    getURL: function(a) {
+        function b(a, b) {
+            for (var a = "" + a, c = [], d = 0; d < b; ++d) c.push("0");
+            return c.join("").substring(0, b - a.length) + a
+        }
+        var c = this.getServerResolution(),
+            d = this.maxExtent,
+            e = this.tileSize,
+            f = Math.round((a.left - d.left) / (c * e.w)),
+            a = Math.round((a.bottom - d.bottom) / (c * e.h)),
+            c = null != this.serverResolutions ? OpenLayers.Util.indexOf(this.serverResolutions, c) : this.map.getZoom(),
+            f = [this.layername, b(c, 2), b(parseInt(f / 1E6), 3), b(parseInt(f / 1E3) % 1E3, 3), b(parseInt(f) % 1E3, 3), b(parseInt(a / 1E6), 3), b(parseInt(a /
+                1E3) % 1E3, 3), b(parseInt(a) % 1E3, 3) + "." + this.extension].join("/"),
+            c = this.url;
+        OpenLayers.Util.isArray(c) && (c = this.selectUrl(f, c));
+        c = "/" == c.charAt(c.length - 1) ? c : c + "/";
+        return c + f
+    },
+    CLASS_NAME: "OpenLayers.Layer.TileCache"
+});
+OpenLayers.Layer.KaMap = OpenLayers.Class(OpenLayers.Layer.Grid, {
+    isBaseLayer: !0,
+    DEFAULT_PARAMS: {
+        i: "jpeg",
+        map: ""
+    },
+    initialize: function(a, b, c, d) {
+        OpenLayers.Layer.Grid.prototype.initialize.apply(this, arguments);
+        this.params = OpenLayers.Util.applyDefaults(this.params, this.DEFAULT_PARAMS)
+    },
+    getURL: function(a) {
+        var a = this.adjustBounds(a),
+            b = this.map.getResolution(),
+            c = Math.round(1E4 * this.map.getScale()) / 1E4,
+            d = Math.round(a.left / b);
+        return this.getFullRequestString({
+            t: -Math.round(a.top / b),
+            l: d,
+            s: c
+        })
+    },
+    calculateGridLayout: function(a,
+        b, c) {
+        var b = c * this.tileSize.w,
+            c = c * this.tileSize.h,
+            d = a.left,
+            e = Math.floor(d / b) - this.buffer,
+            d = -(d / b - e) * this.tileSize.w,
+            e = e * b,
+            a = a.top,
+            f = Math.ceil(a / c) + this.buffer;
+        return {
+            tilelon: b,
+            tilelat: c,
+            tileoffsetlon: e,
+            tileoffsetlat: f * c,
+            tileoffsetx: d,
+            tileoffsety: -(f - a / c + 1) * this.tileSize.h
+        }
+    },
+    clone: function(a) {
+        null == a && (a = new OpenLayers.Layer.KaMap(this.name, this.url, this.params, this.getOptions()));
+        a = OpenLayers.Layer.Grid.prototype.clone.apply(this, [a]);
+        null != this.tileSize && (a.tileSize = this.tileSize.clone());
+        a.grid = [];
+        return a
+    },
+    getTileBounds: function(a) {
+        var b = this.getResolution(),
+            c = b * this.tileSize.w,
+            b = b * this.tileSize.h,
+            d = this.getLonLatFromViewPortPx(a),
+            a = c * Math.floor(d.lon / c),
+            d = b * Math.floor(d.lat / b);
+        return new OpenLayers.Bounds(a, d, a + c, d + b)
+    },
+    CLASS_NAME: "OpenLayers.Layer.KaMap"
+});
+OpenLayers.Control.TransformFeature = OpenLayers.Class(OpenLayers.Control, {
+    geometryTypes: null,
+    layer: null,
+    preserveAspectRatio: !1,
+    rotate: !0,
+    feature: null,
+    renderIntent: "temporary",
+    rotationHandleSymbolizer: null,
+    box: null,
+    center: null,
+    scale: 1,
+    ratio: 1,
+    rotation: 0,
+    handles: null,
+    rotationHandles: null,
+    dragControl: null,
+    irregular: !1,
+    initialize: function(a, b) {
+        OpenLayers.Control.prototype.initialize.apply(this, [b]);
+        this.layer = a;
+        this.rotationHandleSymbolizer || (this.rotationHandleSymbolizer = {
+            stroke: !1,
+            pointRadius: 10,
+            fillOpacity: 0,
+            cursor: "pointer"
+        });
+        this.createBox();
+        this.createControl()
+    },
+    activate: function() {
+        var a = !1;
+        OpenLayers.Control.prototype.activate.apply(this, arguments) && (this.dragControl.activate(), this.layer.addFeatures([this.box]), this.rotate && this.layer.addFeatures(this.rotationHandles), this.layer.addFeatures(this.handles), a = !0);
+        return a
+    },
+    deactivate: function() {
+        var a = !1;
+        OpenLayers.Control.prototype.deactivate.apply(this, arguments) && (this.layer.removeFeatures(this.handles), this.rotate && this.layer.removeFeatures(this.rotationHandles),
+            this.layer.removeFeatures([this.box]), this.dragControl.deactivate(), a = !0);
+        return a
+    },
+    setMap: function(a) {
+        this.dragControl.setMap(a);
+        OpenLayers.Control.prototype.setMap.apply(this, arguments)
+    },
+    setFeature: function(a, b) {
+        var b = OpenLayers.Util.applyDefaults(b, {
+                rotation: 0,
+                scale: 1,
+                ratio: 1
+            }),
+            c = this.rotation,
+            d = this.center;
+        OpenLayers.Util.extend(this, b);
+        if (!1 !== this.events.triggerEvent("beforesetfeature", {
+                feature: a
+            })) {
+            this.feature = a;
+            this.activate();
+            this._setfeature = !0;
+            var e = this.feature.geometry.getBounds();
+            this.box.move(e.getCenterLonLat());
+            this.box.geometry.rotate(-c, d);
+            this._angle = 0;
+            this.rotation ? (c = a.geometry.clone(), c.rotate(-this.rotation, this.center), c = new OpenLayers.Feature.Vector(c.getBounds().toGeometry()), c.geometry.rotate(this.rotation, this.center), this.box.geometry.rotate(this.rotation, this.center), this.box.move(c.geometry.getBounds().getCenterLonLat()), c = c.geometry.components[0].components[0].getBounds().getCenterLonLat()) : c = new OpenLayers.LonLat(e.left, e.bottom);
+            this.handles[0].move(c);
+            delete this._setfeature;
+            this.events.triggerEvent("setfeature", {
+                feature: a
+            })
+        }
+    },
+    unsetFeature: function() {
+        this.active ? this.deactivate() : (this.feature = null, this.rotation = 0, this.ratio = this.scale = 1)
+    },
+    createBox: function() {
+        var a = this;
+        this.center = new OpenLayers.Geometry.Point(0, 0);
+        this.box = new OpenLayers.Feature.Vector(new OpenLayers.Geometry.LineString([new OpenLayers.Geometry.Point(-1, -1), new OpenLayers.Geometry.Point(0, -1), new OpenLayers.Geometry.Point(1, -1), new OpenLayers.Geometry.Point(1, 0), new OpenLayers.Geometry.Point(1, 1), new OpenLayers.Geometry.Point(0, 1), new OpenLayers.Geometry.Point(-1,
+            1), new OpenLayers.Geometry.Point(-1, 0), new OpenLayers.Geometry.Point(-1, -1)]), null, "string" == typeof this.renderIntent ? null : this.renderIntent);
+        this.box.geometry.move = function(b, c) {
+            a._moving = !0;
+            OpenLayers.Geometry.LineString.prototype.move.apply(this, arguments);
+            a.center.move(b, c);
+            delete a._moving
+        };
+        for (var b = function(a, b) {
+                OpenLayers.Geometry.Point.prototype.move.apply(this, arguments);
+                this._rotationHandle && this._rotationHandle.geometry.move(a, b);
+                this._handle.geometry.move(a, b)
+            }, c = function(a, b, c) {
+                OpenLayers.Geometry.Point.prototype.resize.apply(this,
+                    arguments);
+                this._rotationHandle && this._rotationHandle.geometry.resize(a, b, c);
+                this._handle.geometry.resize(a, b, c)
+            }, d = function(a, b) {
+                OpenLayers.Geometry.Point.prototype.rotate.apply(this, arguments);
+                this._rotationHandle && this._rotationHandle.geometry.rotate(a, b);
+                this._handle.geometry.rotate(a, b)
+            }, e = function(b, c) {
+                var d = this.x,
+                    e = this.y;
+                OpenLayers.Geometry.Point.prototype.move.call(this, b, c);
+                if (!a._moving) {
+                    var f = a.dragControl.handlers.drag.evt,
+                        g = !(!a._setfeature && a.preserveAspectRatio) && !(f && f.shiftKey),
+                        h = new OpenLayers.Geometry.Point(d, e),
+                        f = a.center;
+                    this.rotate(-a.rotation, f);
+                    h.rotate(-a.rotation, f);
+                    var i = this.x - f.x,
+                        j = this.y - f.y,
+                        k = i - (this.x - h.x),
+                        l = j - (this.y - h.y);
+                    a.irregular && !a._setfeature && (i -= (this.x - h.x) / 2, j -= (this.y - h.y) / 2);
+                    this.x = d;
+                    this.y = e;
+                    h = 1;
+                    g ? (j = 1.0E-5 > Math.abs(l) ? 1 : j / l, h = (1.0E-5 > Math.abs(k) ? 1 : i / k) / j) : (k = Math.sqrt(k * k + l * l), j = Math.sqrt(i * i + j * j) / k);
+                    a._moving = !0;
+                    a.box.geometry.rotate(-a.rotation, f);
+                    delete a._moving;
+                    a.box.geometry.resize(j, f, h);
+                    a.box.geometry.rotate(a.rotation, f);
+                    a.transformFeature({
+                        scale: j,
+                        ratio: h
+                    });
+                    a.irregular && !a._setfeature && (i = f.clone(), i.x += 1.0E-5 > Math.abs(d - f.x) ? 0 : this.x - d, i.y += 1.0E-5 > Math.abs(e - f.y) ? 0 : this.y - e, a.box.geometry.move(this.x - d, this.y - e), a.transformFeature({
+                        center: i
+                    }))
+                }
+            }, f = function(b, c) {
+                var d = this.x,
+                    e = this.y;
+                OpenLayers.Geometry.Point.prototype.move.call(this, b, c);
+                if (!a._moving) {
+                    var f = a.dragControl.handlers.drag.evt,
+                        f = f && f.shiftKey ? 45 : 1,
+                        g = a.center,
+                        h = this.x - g.x,
+                        i = this.y - g.y;
+                    this.x = d;
+                    this.y = e;
+                    d = Math.atan2(i - c, h - b);
+                    d = Math.atan2(i, h) - d;
+                    d *= 180 / Math.PI;
+                    a._angle = (a._angle +
+                        d) % 360;
+                    d = a.rotation % f;
+                    if (Math.abs(a._angle) >= f || 0 !== d) d = Math.round(a._angle / f) * f - d, a._angle = 0, a.box.geometry.rotate(d, g), a.transformFeature({
+                        rotation: d
+                    })
+                }
+            }, g = Array(8), h = Array(4), i, j, k, l = "sw s se e ne n nw w".split(" "), m = 0; 8 > m; ++m) i = this.box.geometry.components[m], j = new OpenLayers.Feature.Vector(i.clone(), {
+            role: l[m] + "-resize"
+        }, "string" == typeof this.renderIntent ? null : this.renderIntent), 0 == m % 2 && (k = new OpenLayers.Feature.Vector(i.clone(), {
+                role: l[m] + "-rotate"
+            }, "string" == typeof this.rotationHandleSymbolizer ?
+            null : this.rotationHandleSymbolizer), k.geometry.move = f, i._rotationHandle = k, h[m / 2] = k), i.move = b, i.resize = c, i.rotate = d, j.geometry.move = e, i._handle = j, g[m] = j;
+        this.rotationHandles = h;
+        this.handles = g
+    },
+    createControl: function() {
+        var a = this;
+        this.dragControl = new OpenLayers.Control.DragFeature(this.layer, {
+            documentDrag: !0,
+            moveFeature: function(b) {
+                this.feature === a.feature && (this.feature = a.box);
+                OpenLayers.Control.DragFeature.prototype.moveFeature.apply(this, arguments)
+            },
+            onDrag: function(b) {
+                b === a.box && a.transformFeature({
+                    center: a.center
+                })
+            },
+            onStart: function(b) {
+                var c = !a.geometryTypes || -1 !== OpenLayers.Util.indexOf(a.geometryTypes, b.geometry.CLASS_NAME),
+                    d = OpenLayers.Util.indexOf(a.handles, b),
+                    d = d + OpenLayers.Util.indexOf(a.rotationHandles, b);
+                b !== a.feature && (b !== a.box && -2 == d && c) && a.setFeature(b)
+            },
+            onComplete: function() {
+                a.events.triggerEvent("transformcomplete", {
+                    feature: a.feature
+                })
+            }
+        })
+    },
+    drawHandles: function() {
+        for (var a = this.layer, b = 0; 8 > b; ++b) this.rotate && 0 === b % 2 && a.drawFeature(this.rotationHandles[b / 2], this.rotationHandleSymbolizer), a.drawFeature(this.handles[b],
+            this.renderIntent)
+    },
+    transformFeature: function(a) {
+        if (!this._setfeature) {
+            this.scale *= a.scale || 1;
+            this.ratio *= a.ratio || 1;
+            var b = this.rotation;
+            this.rotation = (this.rotation + (a.rotation || 0)) % 360;
+            if (!1 !== this.events.triggerEvent("beforetransform", a)) {
+                var c = this.feature,
+                    d = c.geometry,
+                    e = this.center;
+                d.rotate(-b, e);
+                a.scale || a.ratio ? d.resize(a.scale, e, a.ratio) : a.center && c.move(a.center.getBounds().getCenterLonLat());
+                d.rotate(this.rotation, e);
+                this.layer.drawFeature(c);
+                c.toState(OpenLayers.State.UPDATE);
+                this.events.triggerEvent("transform",
+                    a)
+            }
+        }
+        this.layer.drawFeature(this.box, this.renderIntent);
+        this.drawHandles()
+    },
+    destroy: function() {
+        for (var a, b = 0; 8 > b; ++b) a = this.box.geometry.components[b], a._handle.destroy(), a._handle = null, a._rotationHandle && a._rotationHandle.destroy(), a._rotationHandle = null;
+        this.rotationHandles = this.rotationHandleSymbolizer = this.handles = this.feature = this.center = null;
+        this.box.destroy();
+        this.layer = this.box = null;
+        this.dragControl.destroy();
+        this.dragControl = null;
+        OpenLayers.Control.prototype.destroy.apply(this, arguments)
+    },
+    CLASS_NAME: "OpenLayers.Control.TransformFeature"
+});
+OpenLayers.Handler.Box = OpenLayers.Class(OpenLayers.Handler, {
+    dragHandler: null,
+    boxDivClassName: "olHandlerBoxZoomBox",
+    boxOffsets: null,
+    initialize: function(a, b, c) {
+        OpenLayers.Handler.prototype.initialize.apply(this, arguments);
+        this.dragHandler = new OpenLayers.Handler.Drag(this, {
+            down: this.startBox,
+            move: this.moveBox,
+            out: this.removeBox,
+            up: this.endBox
+        }, {
+            keyMask: this.keyMask
+        })
+    },
+    destroy: function() {
+        OpenLayers.Handler.prototype.destroy.apply(this, arguments);
+        this.dragHandler && (this.dragHandler.destroy(), this.dragHandler =
+            null)
+    },
+    setMap: function(a) {
+        OpenLayers.Handler.prototype.setMap.apply(this, arguments);
+        this.dragHandler && this.dragHandler.setMap(a)
+    },
+    startBox: function() {
+        this.callback("start", []);
+        this.zoomBox = OpenLayers.Util.createDiv("zoomBox", {
+            x: -9999,
+            y: -9999
+        });
+        this.zoomBox.className = this.boxDivClassName;
+        this.zoomBox.style.zIndex = this.map.Z_INDEX_BASE.Popup - 1;
+        this.map.viewPortDiv.appendChild(this.zoomBox);
+        OpenLayers.Element.addClass(this.map.viewPortDiv, "olDrawBox")
+    },
+    moveBox: function(a) {
+        var b = this.dragHandler.start.x,
+            c = this.dragHandler.start.y,
+            d = Math.abs(b - a.x),
+            e = Math.abs(c - a.y),
+            f = this.getBoxOffsets();
+        this.zoomBox.style.width = d + f.width + 1 + "px";
+        this.zoomBox.style.height = e + f.height + 1 + "px";
+        this.zoomBox.style.left = (a.x < b ? b - d - f.left : b - f.left) + "px";
+        this.zoomBox.style.top = (a.y < c ? c - e - f.top : c - f.top) + "px"
+    },
+    endBox: function(a) {
+        var b;
+        if (5 < Math.abs(this.dragHandler.start.x - a.x) || 5 < Math.abs(this.dragHandler.start.y - a.y)) {
+            var c = this.dragHandler.start;
+            b = Math.min(c.y, a.y);
+            var d = Math.max(c.y, a.y),
+                e = Math.min(c.x, a.x),
+                a = Math.max(c.x,
+                    a.x);
+            b = new OpenLayers.Bounds(e, d, a, b)
+        } else b = this.dragHandler.start.clone();
+        this.removeBox();
+        this.callback("done", [b])
+    },
+    removeBox: function() {
+        this.map.viewPortDiv.removeChild(this.zoomBox);
+        this.boxOffsets = this.zoomBox = null;
+        OpenLayers.Element.removeClass(this.map.viewPortDiv, "olDrawBox")
+    },
+    activate: function() {
+        return OpenLayers.Handler.prototype.activate.apply(this, arguments) ? (this.dragHandler.activate(), !0) : !1
+    },
+    deactivate: function() {
+        return OpenLayers.Handler.prototype.deactivate.apply(this, arguments) ?
+            (this.dragHandler.deactivate() && this.zoomBox && this.removeBox(), !0) : !1
+    },
+    getBoxOffsets: function() {
+        if (!this.boxOffsets) {
+            var a = document.createElement("div");
+            a.style.position = "absolute";
+            a.style.border = "1px solid black";
+            a.style.width = "3px";
+            document.body.appendChild(a);
+            var b = 3 == a.clientWidth;
+            document.body.removeChild(a);
+            var a = parseInt(OpenLayers.Element.getStyle(this.zoomBox, "border-left-width")),
+                c = parseInt(OpenLayers.Element.getStyle(this.zoomBox, "border-right-width")),
+                d = parseInt(OpenLayers.Element.getStyle(this.zoomBox,
+                    "border-top-width")),
+                e = parseInt(OpenLayers.Element.getStyle(this.zoomBox, "border-bottom-width"));
+            this.boxOffsets = {
+                left: a,
+                right: c,
+                top: d,
+                bottom: e,
+                width: !1 === b ? a + c : 0,
+                height: !1 === b ? d + e : 0
+            }
+        }
+        return this.boxOffsets
+    },
+    CLASS_NAME: "OpenLayers.Handler.Box"
+});
+OpenLayers.Control.ZoomBox = OpenLayers.Class(OpenLayers.Control, {
+    type: OpenLayers.Control.TYPE_TOOL,
+    out: !1,
+    keyMask: null,
+    alwaysZoom: !1,
+    draw: function() {
+        this.handler = new OpenLayers.Handler.Box(this, {
+            done: this.zoomBox
+        }, {
+            keyMask: this.keyMask
+        })
+    },
+    zoomBox: function(a) {
+        if (a instanceof OpenLayers.Bounds) {
+            var b;
+            if (this.out) {
+                b = Math.abs(a.right - a.left);
+                var c = Math.abs(a.top - a.bottom);
+                b = Math.min(this.map.size.h / c, this.map.size.w / b);
+                var c = this.map.getExtent(),
+                    d = this.map.getLonLatFromPixel(a.getCenterPixel()),
+                    a = d.lon -
+                    c.getWidth() / 2 * b,
+                    e = d.lon + c.getWidth() / 2 * b,
+                    f = d.lat - c.getHeight() / 2 * b;
+                b = d.lat + c.getHeight() / 2 * b;
+                b = new OpenLayers.Bounds(a, f, e, b)
+            } else b = this.map.getLonLatFromPixel({
+                x: a.left,
+                y: a.bottom
+            }), c = this.map.getLonLatFromPixel({
+                x: a.right,
+                y: a.top
+            }), b = new OpenLayers.Bounds(b.lon, b.lat, c.lon, c.lat);
+            c = this.map.getZoom();
+            this.map.zoomToExtent(b);
+            c == this.map.getZoom() && !0 == this.alwaysZoom && this.map.zoomTo(c + (this.out ? -1 : 1))
+        } else this.out ? this.map.setCenter(this.map.getLonLatFromPixel(a), this.map.getZoom() - 1) : this.map.setCenter(this.map.getLonLatFromPixel(a),
+            this.map.getZoom() + 1)
+    },
+    CLASS_NAME: "OpenLayers.Control.ZoomBox"
+});
+OpenLayers.Control.DragPan = OpenLayers.Class(OpenLayers.Control, {
+    type: OpenLayers.Control.TYPE_TOOL,
+    panned: !1,
+    interval: 1,
+    documentDrag: !1,
+    kinetic: null,
+    enableKinetic: !1,
+    kineticInterval: 10,
+    draw: function() {
+        if (this.enableKinetic) {
+            var a = {
+                interval: this.kineticInterval
+            };
+            "object" === typeof this.enableKinetic && (a = OpenLayers.Util.extend(a, this.enableKinetic));
+            this.kinetic = new OpenLayers.Kinetic(a)
+        }
+        this.handler = new OpenLayers.Handler.Drag(this, {
+            move: this.panMap,
+            done: this.panMapDone,
+            down: this.panMapStart
+        }, {
+            interval: this.interval,
+            documentDrag: this.documentDrag
+        })
+    },
+    panMapStart: function() {
+        this.kinetic && this.kinetic.begin()
+    },
+    panMap: function(a) {
+        this.kinetic && this.kinetic.update(a);
+        this.panned = !0;
+        this.map.pan(this.handler.last.x - a.x, this.handler.last.y - a.y, {
+            dragging: !0,
+            animate: !1
+        })
+    },
+    panMapDone: function(a) {
+        if (this.panned) {
+            var b = null;
+            this.kinetic && (b = this.kinetic.end(a));
+            this.map.pan(this.handler.last.x - a.x, this.handler.last.y - a.y, {
+                dragging: !!b,
+                animate: !1
+            });
+            if (b) {
+                var c = this;
+                this.kinetic.move(b, function(a, b, f) {
+                    c.map.pan(a, b, {
+                        dragging: !f,
+                        animate: !1
+                    })
+                })
+            }
+            this.panned = !1
+        }
+    },
+    CLASS_NAME: "OpenLayers.Control.DragPan"
+});
+OpenLayers.Handler.Click = OpenLayers.Class(OpenLayers.Handler, {
+    delay: 300,
+    single: !0,
+    "double": !1,
+    pixelTolerance: 0,
+    dblclickTolerance: 13,
+    stopSingle: !1,
+    stopDouble: !1,
+    timerId: null,
+    touch: !1,
+    down: null,
+    last: null,
+    first: null,
+    rightclickTimerId: null,
+    touchstart: function(a) {
+        this.touch || (this.unregisterMouseListeners(), this.touch = !0);
+        this.down = this.getEventInfo(a);
+        this.last = this.getEventInfo(a);
+        return !0
+    },
+    touchmove: function(a) {
+        this.last = this.getEventInfo(a);
+        return !0
+    },
+    touchend: function(a) {
+        this.down && (a.xy = this.last.xy,
+            a.lastTouches = this.last.touches, this.handleSingle(a), this.down = null);
+        return !0
+    },
+    unregisterMouseListeners: function() {
+        this.map.events.un({
+            mousedown: this.mousedown,
+            mouseup: this.mouseup,
+            click: this.click,
+            dblclick: this.dblclick,
+            scope: this
+        })
+    },
+    mousedown: function(a) {
+        this.down = this.getEventInfo(a);
+        this.last = this.getEventInfo(a);
+        return !0
+    },
+    mouseup: function(a) {
+        var b = !0;
+        this.checkModifiers(a) && (this.control.handleRightClicks && OpenLayers.Event.isRightClick(a)) && (b = this.rightclick(a));
+        return b
+    },
+    rightclick: function(a) {
+        if (this.passesTolerance(a)) {
+            if (null !=
+                this.rightclickTimerId) return this.clearTimer(), this.callback("dblrightclick", [a]), !this.stopDouble;
+            a = this["double"] ? OpenLayers.Util.extend({}, a) : this.callback("rightclick", [a]);
+            a = OpenLayers.Function.bind(this.delayedRightCall, this, a);
+            this.rightclickTimerId = window.setTimeout(a, this.delay)
+        }
+        return !this.stopSingle
+    },
+    delayedRightCall: function(a) {
+        this.rightclickTimerId = null;
+        a && this.callback("rightclick", [a])
+    },
+    click: function(a) {
+        this.last || (this.last = this.getEventInfo(a));
+        this.handleSingle(a);
+        return !this.stopSingle
+    },
+    dblclick: function(a) {
+        this.handleDouble(a);
+        return !this.stopDouble
+    },
+    handleDouble: function(a) {
+        this.passesDblclickTolerance(a) && (this["double"] && this.callback("dblclick", [a]), this.clearTimer())
+    },
+    handleSingle: function(a) {
+        this.passesTolerance(a) && (null != this.timerId ? (this.last.touches && 1 === this.last.touches.length && (this["double"] && OpenLayers.Event.stop(a), this.handleDouble(a)), (!this.last.touches || 2 !== this.last.touches.length) && this.clearTimer()) : (this.first = this.getEventInfo(a), this.queuePotentialClick(this.single ?
+            OpenLayers.Util.extend({}, a) : null)))
+    },
+    queuePotentialClick: function(a) {
+        this.timerId = window.setTimeout(OpenLayers.Function.bind(this.delayedCall, this, a), this.delay)
+    },
+    passesTolerance: function(a) {
+        var b = !0;
+        if (null != this.pixelTolerance && this.down && this.down.xy && (b = this.pixelTolerance >= this.down.xy.distanceTo(a.xy)) && this.touch && this.down.touches.length === this.last.touches.length)
+            for (var a = 0, c = this.down.touches.length; a < c; ++a)
+                if (this.getTouchDistance(this.down.touches[a], this.last.touches[a]) > this.pixelTolerance) {
+                    b = !1;
+                    break
+                }
+        return b
+    },
+    getTouchDistance: function(a, b) {
+        return Math.sqrt(Math.pow(a.clientX - b.clientX, 2) + Math.pow(a.clientY - b.clientY, 2))
+    },
+    passesDblclickTolerance: function() {
+        var a = !0;
+        this.down && this.first && (a = this.down.xy.distanceTo(this.first.xy) <= this.dblclickTolerance);
+        return a
+    },
+    clearTimer: function() {
+        null != this.timerId && (window.clearTimeout(this.timerId), this.timerId = null);
+        null != this.rightclickTimerId && (window.clearTimeout(this.rightclickTimerId), this.rightclickTimerId = null)
+    },
+    delayedCall: function(a) {
+        this.timerId =
+            null;
+        a && this.callback("click", [a])
+    },
+    getEventInfo: function(a) {
+        var b;
+        if (a.touches) {
+            var c = a.touches.length;
+            b = Array(c);
+            for (var d, e = 0; e < c; e++) d = a.touches[e], b[e] = {
+                clientX: d.clientX,
+                clientY: d.clientY
+            }
+        }
+        return {
+            xy: a.xy,
+            touches: b
+        }
+    },
+    deactivate: function() {
+        var a = !1;
+        OpenLayers.Handler.prototype.deactivate.apply(this, arguments) && (this.clearTimer(), this.last = this.first = this.down = null, this.touch = !1, a = !0);
+        return a
+    },
+    CLASS_NAME: "OpenLayers.Handler.Click"
+});
+OpenLayers.Control.Navigation = OpenLayers.Class(OpenLayers.Control, {
+    dragPan: null,
+    dragPanOptions: null,
+    pinchZoom: null,
+    pinchZoomOptions: null,
+    documentDrag: !1,
+    zoomBox: null,
+    zoomBoxEnabled: !0,
+    zoomWheelEnabled: !0,
+    mouseWheelOptions: null,
+    handleRightClicks: !1,
+    zoomBoxKeyMask: OpenLayers.Handler.MOD_SHIFT,
+    autoActivate: !0,
+    initialize: function(a) {
+        this.handlers = {};
+        OpenLayers.Control.prototype.initialize.apply(this, arguments)
+    },
+    destroy: function() {
+        this.deactivate();
+        this.dragPan && this.dragPan.destroy();
+        this.dragPan = null;
+        this.zoomBox && this.zoomBox.destroy();
+        this.zoomBox = null;
+        this.pinchZoom && this.pinchZoom.destroy();
+        this.pinchZoom = null;
+        OpenLayers.Control.prototype.destroy.apply(this, arguments)
+    },
+    activate: function() {
+        this.dragPan.activate();
+        this.zoomWheelEnabled && this.handlers.wheel.activate();
+        this.handlers.click.activate();
+        this.zoomBoxEnabled && this.zoomBox.activate();
+        this.pinchZoom && this.pinchZoom.activate();
+        return OpenLayers.Control.prototype.activate.apply(this, arguments)
+    },
+    deactivate: function() {
+        this.pinchZoom && this.pinchZoom.deactivate();
+        this.zoomBox.deactivate();
+        this.dragPan.deactivate();
+        this.handlers.click.deactivate();
+        this.handlers.wheel.deactivate();
+        return OpenLayers.Control.prototype.deactivate.apply(this, arguments)
+    },
+    draw: function() {
+        this.handleRightClicks && (this.map.viewPortDiv.oncontextmenu = OpenLayers.Function.False);
+        this.handlers.click = new OpenLayers.Handler.Click(this, {
+            click: this.defaultClick,
+            dblclick: this.defaultDblClick,
+            dblrightclick: this.defaultDblRightClick
+        }, {
+            "double": !0,
+            stopDouble: !0
+        });
+        this.dragPan = new OpenLayers.Control.DragPan(OpenLayers.Util.extend({
+            map: this.map,
+            documentDrag: this.documentDrag
+        }, this.dragPanOptions));
+        this.zoomBox = new OpenLayers.Control.ZoomBox({
+            map: this.map,
+            keyMask: this.zoomBoxKeyMask
+        });
+        this.dragPan.draw();
+        this.zoomBox.draw();
+        this.handlers.wheel = new OpenLayers.Handler.MouseWheel(this, {
+            up: this.wheelUp,
+            down: this.wheelDown
+        }, this.mouseWheelOptions);
+        OpenLayers.Control.PinchZoom && (this.pinchZoom = new OpenLayers.Control.PinchZoom(OpenLayers.Util.extend({
+            map: this.map
+        }, this.pinchZoomOptions)))
+    },
+    defaultClick: function(a) {
+        a.lastTouches && 2 == a.lastTouches.length &&
+            this.map.zoomOut()
+    },
+    defaultDblClick: function(a) {
+        this.map.setCenter(this.map.getLonLatFromViewPortPx(a.xy), this.map.zoom + 1)
+    },
+    defaultDblRightClick: function(a) {
+        this.map.setCenter(this.map.getLonLatFromViewPortPx(a.xy), this.map.zoom - 1)
+    },
+    wheelChange: function(a, b) {
+        var c = this.map.getZoom(),
+            d = this.map.getZoom() + Math.round(b),
+            d = Math.max(d, 0),
+            d = Math.min(d, this.map.getNumZoomLevels());
+        if (d !== c) {
+            var e = this.map.getSize(),
+                c = e.w / 2 - a.xy.x,
+                e = a.xy.y - e.h / 2,
+                f = this.map.baseLayer.getResolutionForZoom(d),
+                g = this.map.getLonLatFromPixel(a.xy);
+            this.map.setCenter(new OpenLayers.LonLat(g.lon + c * f, g.lat + e * f), d)
+        }
+    },
+    wheelUp: function(a, b) {
+        this.wheelChange(a, b || 1)
+    },
+    wheelDown: function(a, b) {
+        this.wheelChange(a, b || -1)
+    },
+    disableZoomBox: function() {
+        this.zoomBoxEnabled = !1;
+        this.zoomBox.deactivate()
+    },
+    enableZoomBox: function() {
+        this.zoomBoxEnabled = !0;
+        this.active && this.zoomBox.activate()
+    },
+    disableZoomWheel: function() {
+        this.zoomWheelEnabled = !1;
+        this.handlers.wheel.deactivate()
+    },
+    enableZoomWheel: function() {
+        this.zoomWheelEnabled = !0;
+        this.active && this.handlers.wheel.activate()
+    },
+    CLASS_NAME: "OpenLayers.Control.Navigation"
+});
+OpenLayers.Control.DrawFeature = OpenLayers.Class(OpenLayers.Control, {
+    layer: null,
+    callbacks: null,
+    multi: !1,
+    featureAdded: function() {},
+    handlerOptions: null,
+    initialize: function(a, b, c) {
+        OpenLayers.Control.prototype.initialize.apply(this, [c]);
+        this.callbacks = OpenLayers.Util.extend({
+            done: this.drawFeature,
+            modify: function(a, b) {
+                this.layer.events.triggerEvent("sketchmodified", {
+                    vertex: a,
+                    feature: b
+                })
+            },
+            create: function(a, b) {
+                this.layer.events.triggerEvent("sketchstarted", {
+                    vertex: a,
+                    feature: b
+                })
+            }
+        }, this.callbacks);
+        this.layer =
+            a;
+        this.handlerOptions = this.handlerOptions || {};
+        this.handlerOptions.layerOptions = OpenLayers.Util.applyDefaults(this.handlerOptions.layerOptions, {
+            renderers: a.renderers,
+            rendererOptions: a.rendererOptions
+        });
+        "multi" in this.handlerOptions || (this.handlerOptions.multi = this.multi);
+        if (a = this.layer.styleMap && this.layer.styleMap.styles.temporary) this.handlerOptions.layerOptions = OpenLayers.Util.applyDefaults(this.handlerOptions.layerOptions, {
+            styleMap: new OpenLayers.StyleMap({
+                "default": a
+            })
+        });
+        this.handler = new b(this,
+            this.callbacks, this.handlerOptions)
+    },
+    drawFeature: function(a) {
+        a = new OpenLayers.Feature.Vector(a);
+        !1 !== this.layer.events.triggerEvent("sketchcomplete", {
+            feature: a
+        }) && (a.state = OpenLayers.State.INSERT, this.layer.addFeatures([a]), this.featureAdded(a), this.events.triggerEvent("featureadded", {
+            feature: a
+        }))
+    },
+    insertXY: function(a, b) {
+        this.handler && this.handler.line && this.handler.insertXY(a, b)
+    },
+    insertDeltaXY: function(a, b) {
+        this.handler && this.handler.line && this.handler.insertDeltaXY(a, b)
+    },
+    insertDirectionLength: function(a,
+        b) {
+        this.handler && this.handler.line && this.handler.insertDirectionLength(a, b)
+    },
+    insertDeflectionLength: function(a, b) {
+        this.handler && this.handler.line && this.handler.insertDeflectionLength(a, b)
+    },
+    undo: function() {
+        return this.handler.undo && this.handler.undo()
+    },
+    redo: function() {
+        return this.handler.redo && this.handler.redo()
+    },
+    finishSketch: function() {
+        this.handler.finishGeometry()
+    },
+    cancel: function() {
+        this.handler.cancel()
+    },
+    CLASS_NAME: "OpenLayers.Control.DrawFeature"
+});
+OpenLayers.Handler.Polygon = OpenLayers.Class(OpenLayers.Handler.Path, {
+    holeModifier: null,
+    drawingHole: !1,
+    polygon: null,
+    createFeature: function(a) {
+        a = this.layer.getLonLatFromViewPortPx(a);
+        a = new OpenLayers.Geometry.Point(a.lon, a.lat);
+        this.point = new OpenLayers.Feature.Vector(a);
+        this.line = new OpenLayers.Feature.Vector(new OpenLayers.Geometry.LinearRing([this.point.geometry]));
+        this.polygon = new OpenLayers.Feature.Vector(new OpenLayers.Geometry.Polygon([this.line.geometry]));
+        this.callback("create", [this.point.geometry,
+            this.getSketch()
+        ]);
+        this.point.geometry.clearBounds();
+        this.layer.addFeatures([this.polygon, this.point], {
+            silent: !0
+        })
+    },
+    addPoint: function(a) {
+        if (!this.drawingHole && this.holeModifier && this.evt && this.evt[this.holeModifier])
+            for (var b = this.point.geometry, c = this.control.layer.features, d, e = c.length - 1; 0 <= e; --e)
+                if (d = c[e].geometry, (d instanceof OpenLayers.Geometry.Polygon || d instanceof OpenLayers.Geometry.MultiPolygon) && d.intersects(b)) {
+                    b = c[e];
+                    this.control.layer.removeFeatures([b], {
+                        silent: !0
+                    });
+                    this.control.layer.events.registerPriority("sketchcomplete",
+                        this, this.finalizeInteriorRing);
+                    this.control.layer.events.registerPriority("sketchmodified", this, this.enforceTopology);
+                    b.geometry.addComponent(this.line.geometry);
+                    this.polygon = b;
+                    this.drawingHole = !0;
+                    break
+                }
+        OpenLayers.Handler.Path.prototype.addPoint.apply(this, arguments)
+    },
+    getCurrentPointIndex: function() {
+        return this.line.geometry.components.length - 2
+    },
+    enforceTopology: function(a) {
+        var a = a.vertex,
+            b = this.line.geometry.components;
+        this.polygon.geometry.intersects(a) || (b = b[b.length - 3], a.x = b.x, a.y = b.y)
+    },
+    finishGeometry: function() {
+        this.line.geometry.removeComponent(this.line.geometry.components[this.line.geometry.components.length -
+            2]);
+        this.removePoint();
+        this.finalize()
+    },
+    finalizeInteriorRing: function() {
+        var a = this.line.geometry,
+            b = 0 !== a.getArea();
+        if (b) {
+            for (var c = this.polygon.geometry.components, d = c.length - 2; 0 <= d; --d)
+                if (a.intersects(c[d])) {
+                    b = !1;
+                    break
+                }
+            if (b) {
+                d = c.length - 2;
+                a: for (; 0 < d; --d)
+                    for (var e = c[d].components, f = 0, g = e.length; f < g; ++f)
+                        if (a.containsPoint(e[f])) {
+                            b = !1;
+                            break a
+                        }
+            }
+        }
+        b ? this.polygon.state !== OpenLayers.State.INSERT && (this.polygon.state = OpenLayers.State.UPDATE) : this.polygon.geometry.removeComponent(a);
+        this.restoreFeature();
+        return !1
+    },
+    cancel: function() {
+        this.drawingHole && (this.polygon.geometry.removeComponent(this.line.geometry), this.restoreFeature(!0));
+        return OpenLayers.Handler.Path.prototype.cancel.apply(this, arguments)
+    },
+    restoreFeature: function(a) {
+        this.control.layer.events.unregister("sketchcomplete", this, this.finalizeInteriorRing);
+        this.control.layer.events.unregister("sketchmodified", this, this.enforceTopology);
+        this.layer.removeFeatures([this.polygon], {
+            silent: !0
+        });
+        this.control.layer.addFeatures([this.polygon], {
+            silent: !0
+        });
+        this.drawingHole = !1;
+        a || this.control.layer.events.triggerEvent("sketchcomplete", {
+            feature: this.polygon
+        })
+    },
+    destroyFeature: function(a) {
+        OpenLayers.Handler.Path.prototype.destroyFeature.call(this, a);
+        this.polygon = null
+    },
+    drawFeature: function() {
+        this.layer.drawFeature(this.polygon, this.style);
+        this.layer.drawFeature(this.point, this.style)
+    },
+    getSketch: function() {
+        return this.polygon
+    },
+    getGeometry: function() {
+        var a = this.polygon && this.polygon.geometry;
+        a && this.multi && (a = new OpenLayers.Geometry.MultiPolygon([a]));
+        return a
+    },
+    CLASS_NAME: "OpenLayers.Handler.Polygon"
+});
+OpenLayers.Control.EditingToolbar = OpenLayers.Class(OpenLayers.Control.Panel, {
+    citeCompliant: !1,
+    initialize: function(a, b) {
+        OpenLayers.Control.Panel.prototype.initialize.apply(this, [b]);
+        this.addControls([new OpenLayers.Control.Navigation]);
+        this.addControls([new OpenLayers.Control.DrawFeature(a, OpenLayers.Handler.Point, {
+            displayClass: "olControlDrawFeaturePoint",
+            handlerOptions: {
+                citeCompliant: this.citeCompliant
+            }
+        }), new OpenLayers.Control.DrawFeature(a, OpenLayers.Handler.Path, {
+            displayClass: "olControlDrawFeaturePath",
+            handlerOptions: {
+                citeCompliant: this.citeCompliant
+            }
+        }), new OpenLayers.Control.DrawFeature(a, OpenLayers.Handler.Polygon, {
+            displayClass: "olControlDrawFeaturePolygon",
+            handlerOptions: {
+                citeCompliant: this.citeCompliant
+            }
+        })])
+    },
+    draw: function() {
+        var a = OpenLayers.Control.Panel.prototype.draw.apply(this, arguments);
+        null === this.defaultControl && (this.defaultControl = this.controls[0]);
+        return a
+    },
+    CLASS_NAME: "OpenLayers.Control.EditingToolbar"
+});
+OpenLayers.Strategy.BBOX = OpenLayers.Class(OpenLayers.Strategy, {
+    bounds: null,
+    resolution: null,
+    ratio: 2,
+    resFactor: null,
+    response: null,
+    activate: function() {
+        var a = OpenLayers.Strategy.prototype.activate.call(this);
+        a && (this.layer.events.on({
+            moveend: this.update,
+            refresh: this.update,
+            visibilitychanged: this.update,
+            scope: this
+        }), this.update());
+        return a
+    },
+    deactivate: function() {
+        var a = OpenLayers.Strategy.prototype.deactivate.call(this);
+        a && this.layer.events.un({
+            moveend: this.update,
+            refresh: this.update,
+            visibilitychanged: this.update,
+            scope: this
+        });
+        return a
+    },
+    update: function(a) {
+        var b = this.getMapBounds();
+        if (null !== b && (a && a.force || this.layer.visibility && this.layer.calculateInRange() && this.invalidBounds(b))) this.calculateBounds(b), this.resolution = this.layer.map.getResolution(), this.triggerRead(a)
+    },
+    getMapBounds: function() {
+        if (null === this.layer.map) return null;
+        var a = this.layer.map.getExtent();
+        a && !this.layer.projection.equals(this.layer.map.getProjectionObject()) && (a = a.clone().transform(this.layer.map.getProjectionObject(), this.layer.projection));
+        return a
+    },
+    invalidBounds: function(a) {
+        a || (a = this.getMapBounds());
+        a = !this.bounds || !this.bounds.containsBounds(a);
+        !a && this.resFactor && (a = this.resolution / this.layer.map.getResolution(), a = a >= this.resFactor || a <= 1 / this.resFactor);
+        return a
+    },
+    calculateBounds: function(a) {
+        a || (a = this.getMapBounds());
+        var b = a.getCenterLonLat(),
+            c = a.getWidth() * this.ratio,
+            a = a.getHeight() * this.ratio;
+        this.bounds = new OpenLayers.Bounds(b.lon - c / 2, b.lat - a / 2, b.lon + c / 2, b.lat + a / 2)
+    },
+    triggerRead: function(a) {
+        this.response && !(a && !0 === a.noAbort) &&
+            (this.layer.protocol.abort(this.response), this.layer.events.triggerEvent("loadend"));
+        this.layer.events.triggerEvent("loadstart");
+        this.response = this.layer.protocol.read(OpenLayers.Util.applyDefaults({
+            filter: this.createFilter(),
+            callback: this.merge,
+            scope: this
+        }, a))
+    },
+    createFilter: function() {
+        var a = new OpenLayers.Filter.Spatial({
+            type: OpenLayers.Filter.Spatial.BBOX,
+            value: this.bounds,
+            projection: this.layer.projection
+        });
+        this.layer.filter && (a = new OpenLayers.Filter.Logical({
+            type: OpenLayers.Filter.Logical.AND,
+            filters: [this.layer.filter, a]
+        }));
+        return a
+    },
+    merge: function(a) {
+        this.layer.destroyFeatures();
+        if ((a = a.features) && 0 < a.length) {
+            var b = this.layer.projection,
+                c = this.layer.map.getProjectionObject();
+            if (!c.equals(b))
+                for (var d, e = 0, f = a.length; e < f; ++e)(d = a[e].geometry) && d.transform(b, c);
+            this.layer.addFeatures(a)
+        }
+        this.response = null;
+        this.layer.events.triggerEvent("loadend")
+    },
+    CLASS_NAME: "OpenLayers.Strategy.BBOX"
+});
+OpenLayers.Layer.WorldWind = OpenLayers.Class(OpenLayers.Layer.Grid, {
+    DEFAULT_PARAMS: {},
+    isBaseLayer: !0,
+    lzd: null,
+    zoomLevels: null,
+    initialize: function(a, b, c, d, e, f) {
+        this.lzd = c;
+        this.zoomLevels = d;
+        c = [];
+        c.push(a, b, e, f);
+        OpenLayers.Layer.Grid.prototype.initialize.apply(this, c);
+        this.params = OpenLayers.Util.applyDefaults(this.params, this.DEFAULT_PARAMS)
+    },
+    getZoom: function() {
+        var a = this.map.getZoom();
+        this.map.getMaxExtent();
+        return a -= Math.log(this.maxResolution / (this.lzd / 512)) / Math.log(2)
+    },
+    getURL: function(a) {
+        var a =
+            this.adjustBounds(a),
+            b = this.getZoom(),
+            c = this.map.getMaxExtent(),
+            d = this.lzd / Math.pow(2, this.getZoom()),
+            e = Math.floor((a.left - c.left) / d),
+            a = Math.floor((a.bottom - c.bottom) / d);
+        return this.map.getResolution() <= this.lzd / 512 && this.getZoom() <= this.zoomLevels ? this.getFullRequestString({
+            L: b,
+            X: e,
+            Y: a
+        }) : OpenLayers.Util.getImageLocation("blank.gif")
+    },
+    CLASS_NAME: "OpenLayers.Layer.WorldWind"
+});
+OpenLayers.Protocol.CSW = function(a) {
+    var a = OpenLayers.Util.applyDefaults(a, OpenLayers.Protocol.CSW.DEFAULTS),
+        b = OpenLayers.Protocol.CSW["v" + a.version.replace(/\./g, "_")];
+    if (!b) throw "Unsupported CSW version: " + a.version;
+    return new b(a)
+};
+OpenLayers.Protocol.CSW.DEFAULTS = {
+    version: "2.0.2"
+};
+OpenLayers.Format.WMTSCapabilities = OpenLayers.Class(OpenLayers.Format.XML.VersionedOGC, {
+    defaultVersion: "1.0.0",
+    yx: {
+        "urn:ogc:def:crs:EPSG::4326": !0
+    },
+    createLayer: function(a, b) {
+        var c, d = {
+                layer: !0,
+                matrixSet: !0
+            },
+            e;
+        for (e in d)
+            if (!(e in b)) throw Error("Missing property '" + e + "' in layer configuration.");
+        d = a.contents;
+        e = d.tileMatrixSets[b.matrixSet];
+        for (var f, g = 0, h = d.layers.length; g < h; ++g)
+            if (d.layers[g].identifier === b.layer) {
+                f = d.layers[g];
+                break
+            }
+        if (f && e) {
+            for (var i, g = 0, h = f.styles.length; g < h && !(i = f.styles[g], i.isDefault); ++g);
+            c = new OpenLayers.Layer.WMTS(OpenLayers.Util.applyDefaults(b, {
+                url: "REST" === b.requestEncoding && f.resourceUrl ? f.resourceUrl.tile.template : a.operationsMetadata.GetTile.dcp.http.get[0].url,
+                name: f.title,
+                style: i.identifier,
+                matrixIds: e.matrixIds,
+                tileFullExtent: e.bounds
+            }))
+        }
+        return c
+    },
+    CLASS_NAME: "OpenLayers.Format.WMTSCapabilities"
+});
+OpenLayers.Layer.Google.v3 = {
+    DEFAULTS: {
+        sphericalMercator: !0,
+        projection: "EPSG:900913"
+    },
+    animationEnabled: !0,
+    loadMapObject: function() {
+        this.type || (this.type = google.maps.MapTypeId.ROADMAP);
+        var a, b = OpenLayers.Layer.Google.cache[this.map.id];
+        b ? (a = b.mapObject, ++b.count) : (b = this.map.viewPortDiv, a = document.createElement("div"), a.id = this.map.id + "_GMapContainer", a.style.position = "absolute", a.style.width = "100%", a.style.height = "100%", b.appendChild(a), b = this.map.getCenter(), a = new google.maps.Map(a, {
+            center: b ? new google.maps.LatLng(b.lat,
+                b.lon) : new google.maps.LatLng(0, 0),
+            zoom: this.map.getZoom() || 0,
+            mapTypeId: this.type,
+            disableDefaultUI: !0,
+            keyboardShortcuts: !1,
+            draggable: !1,
+            disableDoubleClickZoom: !0,
+            scrollwheel: !1,
+            streetViewControl: !1
+        }), b = {
+            mapObject: a,
+            count: 1
+        }, OpenLayers.Layer.Google.cache[this.map.id] = b, this.repositionListener = google.maps.event.addListenerOnce(a, "center_changed", OpenLayers.Function.bind(this.repositionMapElements, this)));
+        this.mapObject = a;
+        this.setGMapVisibility(this.visibility)
+    },
+    repositionMapElements: function() {
+        google.maps.event.trigger(this.mapObject,
+            "resize");
+        var a = this.mapObject.getDiv().firstChild;
+        if (!a || 3 > a.childNodes.length) return this.repositionTimer = window.setTimeout(OpenLayers.Function.bind(this.repositionMapElements, this), 250), !1;
+        for (var b = OpenLayers.Layer.Google.cache[this.map.id], c = this.map.viewPortDiv, d = a.children.length - 1; 0 <= d; --d) {
+            if (1000001 == a.children[d].style.zIndex) {
+                var e = a.children[d];
+                c.appendChild(e);
+                e.style.zIndex = "1100";
+                e.style.bottom = "";
+                e.className = "olLayerGoogleCopyright olLayerGoogleV3";
+                e.style.display = "";
+                b.termsOfUse =
+                    e
+            }
+            1E6 == a.children[d].style.zIndex && (e = a.children[d], c.appendChild(e), e.style.zIndex = "1100", e.style.bottom = "", e.className = "olLayerGooglePoweredBy olLayerGoogleV3 gmnoprint", e.style.display = "", b.poweredBy = e);
+            10000002 == a.children[d].style.zIndex && c.appendChild(a.children[d])
+        }
+        this.setGMapVisibility(this.visibility)
+    },
+    onMapResize: function() {
+        if (this.visibility) google.maps.event.trigger(this.mapObject, "resize");
+        else {
+            var a = OpenLayers.Layer.Google.cache[this.map.id];
+            if (!a.resized) {
+                var b = this;
+                google.maps.event.addListenerOnce(this.mapObject,
+                    "tilesloaded",
+                    function() {
+                        google.maps.event.trigger(b.mapObject, "resize");
+                        b.moveTo(b.map.getCenter(), b.map.getZoom());
+                        delete a.resized
+                    })
+            }
+            a.resized = !0
+        }
+    },
+    setGMapVisibility: function(a) {
+        var b = OpenLayers.Layer.Google.cache[this.map.id];
+        if (b) {
+            for (var c = this.type, d = this.map.layers, e, f = d.length - 1; 0 <= f; --f)
+                if (e = d[f], e instanceof OpenLayers.Layer.Google && !0 === e.visibility && !0 === e.inRange) {
+                    c = e.type;
+                    a = !0;
+                    break
+                }
+            d = this.mapObject.getDiv();
+            !0 === a ? (this.mapObject.setMapTypeId(c), d.style.left = "", b.termsOfUse && b.termsOfUse.style &&
+                (b.termsOfUse.style.left = "", b.termsOfUse.style.display = "", b.poweredBy.style.display = ""), b.displayed = this.id) : (delete b.displayed, d.style.left = "-9999px", b.termsOfUse && b.termsOfUse.style && (b.termsOfUse.style.display = "none", b.termsOfUse.style.left = "-9999px", b.poweredBy.style.display = "none"))
+        }
+    },
+    getMapContainer: function() {
+        return this.mapObject.getDiv()
+    },
+    getMapObjectBoundsFromOLBounds: function(a) {
+        var b = null;
+        null != a && (b = this.sphericalMercator ? this.inverseMercator(a.bottom, a.left) : new OpenLayers.LonLat(a.bottom,
+            a.left), a = this.sphericalMercator ? this.inverseMercator(a.top, a.right) : new OpenLayers.LonLat(a.top, a.right), b = new google.maps.LatLngBounds(new google.maps.LatLng(b.lat, b.lon), new google.maps.LatLng(a.lat, a.lon)));
+        return b
+    },
+    getMapObjectLonLatFromMapObjectPixel: function(a) {
+        var b = this.map.getSize(),
+            c = this.getLongitudeFromMapObjectLonLat(this.mapObject.center),
+            d = this.getLatitudeFromMapObjectLonLat(this.mapObject.center),
+            e = this.map.getResolution(),
+            a = new OpenLayers.LonLat(c + (a.x - b.w / 2) * e, d - (a.y - b.h / 2) * e);
+        this.wrapDateLine && (a = a.wrapDateLine(this.maxExtent));
+        return this.getMapObjectLonLatFromLonLat(a.lon, a.lat)
+    },
+    getMapObjectPixelFromMapObjectLonLat: function(a) {
+        var b = this.getLongitudeFromMapObjectLonLat(a),
+            a = this.getLatitudeFromMapObjectLonLat(a),
+            c = this.map.getResolution(),
+            d = this.map.getExtent();
+        return this.getMapObjectPixelFromXY(1 / c * (b - d.left), 1 / c * (d.top - a))
+    },
+    setMapObjectCenter: function(a, b) {
+        if (!1 === this.animationEnabled && b != this.mapObject.zoom) {
+            var c = this.getMapContainer();
+            google.maps.event.addListenerOnce(this.mapObject,
+                "idle",
+                function() {
+                    c.style.visibility = ""
+                });
+            c.style.visibility = "hidden"
+        }
+        this.mapObject.setOptions({
+            center: a,
+            zoom: b
+        })
+    },
+    getMapObjectZoomFromMapObjectBounds: function(a) {
+        return this.mapObject.getBoundsZoomLevel(a)
+    },
+    getMapObjectLonLatFromLonLat: function(a, b) {
+        var c;
+        this.sphericalMercator ? (c = this.inverseMercator(a, b), c = new google.maps.LatLng(c.lat, c.lon)) : c = new google.maps.LatLng(b, a);
+        return c
+    },
+    getMapObjectPixelFromXY: function(a, b) {
+        return new google.maps.Point(a, b)
+    },
+    destroy: function() {
+        this.repositionListener &&
+            google.maps.event.removeListener(this.repositionListener);
+        this.repositionTimer && window.clearTimeout(this.repositionTimer);
+        OpenLayers.Layer.Google.prototype.destroy.apply(this, arguments)
+    }
+};
+OpenLayers.Format.WPSDescribeProcess = OpenLayers.Class(OpenLayers.Format.XML, {
+    VERSION: "1.0.0",
+    namespaces: {
+        wps: "http://www.opengis.net/wps/1.0.0",
+        ows: "http://www.opengis.net/ows/1.1",
+        xsi: "http://www.w3.org/2001/XMLSchema-instance"
+    },
+    schemaLocation: "http://www.opengis.net/wps/1.0.0 http://schemas.opengis.net/wps/1.0.0/wpsAll.xsd",
+    defaultPrefix: "wps",
+    regExes: {
+        trimSpace: /^\s*|\s*$/g,
+        removeSpace: /\s*/g,
+        splitSpace: /\s+/,
+        trimComma: /\s*,\s*/g
+    },
+    read: function(a) {
+        "string" == typeof a && (a = OpenLayers.Format.XML.prototype.read.apply(this, [a]));
+        a && 9 == a.nodeType && (a = a.documentElement);
+        var b = {};
+        this.readNode(a, b);
+        return b
+    },
+    readers: {
+        wps: {
+            ProcessDescriptions: function(a, b) {
+                b.processDescriptions = {};
+                this.readChildNodes(a, b.processDescriptions)
+            },
+            ProcessDescription: function(a, b) {
+                var c = {
+                    processVersion: this.getAttributeNS(a, this.namespaces.wps, "processVersion"),
+                    statusSupported: "true" === a.getAttribute("statusSupported"),
+                    storeSupported: "true" === a.getAttribute("storeSupported")
+                };
+                this.readChildNodes(a, c);
+                b[c.identifier] = c
+            },
+            DataInputs: function(a,
+                b) {
+                b.dataInputs = [];
+                this.readChildNodes(a, b.dataInputs)
+            },
+            ProcessOutputs: function(a, b) {
+                b.processOutputs = [];
+                this.readChildNodes(a, b.processOutputs)
+            },
+            Output: function(a, b) {
+                var c = {};
+                this.readChildNodes(a, c);
+                b.push(c)
+            },
+            ComplexOutput: function(a, b) {
+                b.complexOutput = {};
+                this.readChildNodes(a, b.complexOutput)
+            },
+            Input: function(a, b) {
+                var c = {
+                    maxOccurs: parseInt(a.getAttribute("maxOccurs")),
+                    minOccurs: parseInt(a.getAttribute("minOccurs"))
+                };
+                this.readChildNodes(a, c);
+                b.push(c)
+            },
+            BoundingBoxData: function(a, b) {
+                b.boundingBoxData = {};
+                this.readChildNodes(a, b.boundingBoxData)
+            },
+            CRS: function(a, b) {
+                b.CRSs || (b.CRSs = {});
+                b.CRSs[this.getChildValue(a)] = !0
+            },
+            LiteralData: function(a, b) {
+                b.literalData = {};
+                this.readChildNodes(a, b.literalData)
+            },
+            ComplexData: function(a, b) {
+                b.complexData = {};
+                this.readChildNodes(a, b.complexData)
+            },
+            Default: function(a, b) {
+                b["default"] = {};
+                this.readChildNodes(a, b["default"])
+            },
+            Supported: function(a, b) {
+                b.supported = {};
+                this.readChildNodes(a, b.supported)
+            },
+            Format: function(a, b) {
+                var c = {};
+                this.readChildNodes(a, c);
+                b.formats || (b.formats = {});
+                b.formats[c.mimeType] = !0
+            },
+            MimeType: function(a, b) {
+                b.mimeType = this.getChildValue(a)
+            }
+        },
+        ows: OpenLayers.Format.OWSCommon.v1_1_0.prototype.readers.ows
+    },
+    CLASS_NAME: "OpenLayers.Format.WPSDescribeProcess"
+});
+OpenLayers.Format.CSWGetRecords.v2_0_2 = OpenLayers.Class(OpenLayers.Format.XML, {
+    namespaces: {
+        csw: "http://www.opengis.net/cat/csw/2.0.2",
+        dc: "http://purl.org/dc/elements/1.1/",
+        dct: "http://purl.org/dc/terms/",
+        gmd: "http://www.isotc211.org/2005/gmd",
+        geonet: "http://www.fao.org/geonetwork",
+        ogc: "http://www.opengis.net/ogc",
+        ows: "http://www.opengis.net/ows",
+        xlink: "http://www.w3.org/1999/xlink",
+        xsi: "http://www.w3.org/2001/XMLSchema-instance"
+    },
+    defaultPrefix: "csw",
+    version: "2.0.2",
+    schemaLocation: "http://www.opengis.net/cat/csw/2.0.2 http://schemas.opengis.net/csw/2.0.2/CSW-discovery.xsd",
+    requestId: null,
+    resultType: null,
+    outputFormat: null,
+    outputSchema: null,
+    startPosition: null,
+    maxRecords: null,
+    DistributedSearch: null,
+    ResponseHandler: null,
+    Query: null,
+    regExes: {
+        trimSpace: /^\s*|\s*$/g,
+        removeSpace: /\s*/g,
+        splitSpace: /\s+/,
+        trimComma: /\s*,\s*/g
+    },
+    initialize: function(a) {
+        OpenLayers.Format.XML.prototype.initialize.apply(this, [a])
+    },
+    read: function(a) {
+        "string" == typeof a && (a = OpenLayers.Format.XML.prototype.read.apply(this, [a]));
+        a && 9 == a.nodeType && (a = a.documentElement);
+        var b = {};
+        this.readNode(a, b);
+        return b
+    },
+    readers: {
+        csw: {
+            GetRecordsResponse: function(a, b) {
+                b.records = [];
+                this.readChildNodes(a, b);
+                var c = this.getAttributeNS(a, "", "version");
+                "" != c && (b.version = c)
+            },
+            RequestId: function(a, b) {
+                b.RequestId = this.getChildValue(a)
+            },
+            SearchStatus: function(a, b) {
+                b.SearchStatus = {};
+                var c = this.getAttributeNS(a, "", "timestamp");
+                "" != c && (b.SearchStatus.timestamp = c)
+            },
+            SearchResults: function(a, b) {
+                this.readChildNodes(a, b);
+                for (var c = a.attributes, d = {}, e = 0, f = c.length; e < f; ++e) d[c[e].name] = "numberOfRecordsMatched" == c[e].name || "numberOfRecordsReturned" ==
+                    c[e].name || "nextRecord" == c[e].name ? parseInt(c[e].nodeValue) : c[e].nodeValue;
+                b.SearchResults = d
+            },
+            SummaryRecord: function(a, b) {
+                var c = {
+                    type: "SummaryRecord"
+                };
+                this.readChildNodes(a, c);
+                b.records.push(c)
+            },
+            BriefRecord: function(a, b) {
+                var c = {
+                    type: "BriefRecord"
+                };
+                this.readChildNodes(a, c);
+                b.records.push(c)
+            },
+            DCMIRecord: function(a, b) {
+                var c = {
+                    type: "DCMIRecord"
+                };
+                this.readChildNodes(a, c);
+                b.records.push(c)
+            },
+            Record: function(a, b) {
+                var c = {
+                    type: "Record"
+                };
+                this.readChildNodes(a, c);
+                b.records.push(c)
+            },
+            "*": function(a, b) {
+                var c = a.localName ||
+                    a.nodeName.split(":").pop();
+                b[c] = this.getChildValue(a)
+            }
+        },
+        geonet: {
+            info: function(a, b) {
+                var c = {};
+                this.readChildNodes(a, c);
+                b.gninfo = c
+            }
+        },
+        dc: {
+            "*": function(a, b) {
+                var c = a.localName || a.nodeName.split(":").pop();
+                OpenLayers.Util.isArray(b[c]) || (b[c] = []);
+                for (var d = {}, e = a.attributes, f = 0, g = e.length; f < g; ++f) d[e[f].name] = e[f].nodeValue;
+                d.value = this.getChildValue(a);
+                "" != d.value && b[c].push(d)
+            }
+        },
+        dct: {
+            "*": function(a, b) {
+                var c = a.localName || a.nodeName.split(":").pop();
+                OpenLayers.Util.isArray(b[c]) || (b[c] = []);
+                b[c].push(this.getChildValue(a))
+            }
+        },
+        ows: OpenLayers.Util.applyDefaults({
+            BoundingBox: function(a, b) {
+                b.bounds && (b.BoundingBox = [{
+                    crs: b.projection,
+                    value: [b.bounds.left, b.bounds.bottom, b.bounds.right, b.bounds.top]
+                }], delete b.projection, delete b.bounds);
+                OpenLayers.Format.OWSCommon.v1_0_0.prototype.readers.ows.BoundingBox.apply(this, arguments)
+            }
+        }, OpenLayers.Format.OWSCommon.v1_0_0.prototype.readers.ows)
+    },
+    write: function(a) {
+        a = this.writeNode("csw:GetRecords", a);
+        a.setAttribute("xmlns:gmd", this.namespaces.gmd);
+        return OpenLayers.Format.XML.prototype.write.apply(this, [a])
+    },
+    writers: {
+        csw: {
+            GetRecords: function(a) {
+                a || (a = {});
+                var b = this.createElementNSPlus("csw:GetRecords", {
+                    attributes: {
+                        service: "CSW",
+                        version: this.version,
+                        requestId: a.requestId || this.requestId,
+                        resultType: a.resultType || this.resultType,
+                        outputFormat: a.outputFormat || this.outputFormat,
+                        outputSchema: a.outputSchema || this.outputSchema,
+                        startPosition: a.startPosition || this.startPosition,
+                        maxRecords: a.maxRecords || this.maxRecords
+                    }
+                });
+                if (a.DistributedSearch || this.DistributedSearch) this.writeNode("csw:DistributedSearch",
+                    a.DistributedSearch || this.DistributedSearch, b);
+                var c = a.ResponseHandler || this.ResponseHandler;
+                if (OpenLayers.Util.isArray(c) && 0 < c.length)
+                    for (var d = 0, e = c.length; d < e; d++) this.writeNode("csw:ResponseHandler", c[d], b);
+                this.writeNode("Query", a.Query || this.Query, b);
+                return b
+            },
+            DistributedSearch: function(a) {
+                return this.createElementNSPlus("csw:DistributedSearch", {
+                    attributes: {
+                        hopCount: a.hopCount
+                    }
+                })
+            },
+            ResponseHandler: function(a) {
+                return this.createElementNSPlus("csw:ResponseHandler", {
+                    value: a.value
+                })
+            },
+            Query: function(a) {
+                a ||
+                    (a = {});
+                var b = this.createElementNSPlus("csw:Query", {
+                        attributes: {
+                            typeNames: a.typeNames || "csw:Record"
+                        }
+                    }),
+                    c = a.ElementName;
+                if (OpenLayers.Util.isArray(c) && 0 < c.length)
+                    for (var d = 0, e = c.length; d < e; d++) this.writeNode("csw:ElementName", c[d], b);
+                else this.writeNode("csw:ElementSetName", a.ElementSetName || {
+                    value: "summary"
+                }, b);
+                a.Constraint && this.writeNode("csw:Constraint", a.Constraint, b);
+                a.SortBy && this.writeNode("ogc:SortBy", a.SortBy, b);
+                return b
+            },
+            ElementName: function(a) {
+                return this.createElementNSPlus("csw:ElementName", {
+                    value: a.value
+                })
+            },
+            ElementSetName: function(a) {
+                return this.createElementNSPlus("csw:ElementSetName", {
+                    attributes: {
+                        typeNames: a.typeNames
+                    },
+                    value: a.value
+                })
+            },
+            Constraint: function(a) {
+                var b = this.createElementNSPlus("csw:Constraint", {
+                    attributes: {
+                        version: a.version
+                    }
+                });
+                if (a.Filter) {
+                    var c = new OpenLayers.Format.Filter({
+                        version: a.version
+                    });
+                    b.appendChild(c.write(a.Filter))
+                } else a.CqlText && (a = this.createElementNSPlus("CqlText", {
+                    value: a.CqlText.value
+                }), b.appendChild(a));
+                return b
+            }
+        },
+        ogc: OpenLayers.Format.Filter.v1_1_0.prototype.writers.ogc
+    },
+    CLASS_NAME: "OpenLayers.Format.CSWGetRecords.v2_0_2"
+});
+OpenLayers.Marker.Box = OpenLayers.Class(OpenLayers.Marker, {
+    bounds: null,
+    div: null,
+    initialize: function(a, b, c) {
+        this.bounds = a;
+        this.div = OpenLayers.Util.createDiv();
+        this.div.style.overflow = "hidden";
+        this.events = new OpenLayers.Events(this, this.div);
+        this.setBorder(b, c)
+    },
+    destroy: function() {
+        this.div = this.bounds = null;
+        OpenLayers.Marker.prototype.destroy.apply(this, arguments)
+    },
+    setBorder: function(a, b) {
+        a || (a = "red");
+        b || (b = 2);
+        this.div.style.border = b + "px solid " + a
+    },
+    draw: function(a, b) {
+        OpenLayers.Util.modifyDOMElement(this.div,
+            null, a, b);
+        return this.div
+    },
+    onScreen: function() {
+        var a = !1;
+        this.map && (a = this.map.getExtent().containsBounds(this.bounds, !0, !0));
+        return a
+    },
+    display: function(a) {
+        this.div.style.display = a ? "" : "none"
+    },
+    CLASS_NAME: "OpenLayers.Marker.Box"
+});
+OpenLayers.Format.Text = OpenLayers.Class(OpenLayers.Format, {
+    defaultStyle: null,
+    extractStyles: !0,
+    initialize: function(a) {
+        a = a || {};
+        !1 !== a.extractStyles && (a.defaultStyle = {
+            externalGraphic: OpenLayers.Util.getImageLocation("marker.png"),
+            graphicWidth: 21,
+            graphicHeight: 25,
+            graphicXOffset: -10.5,
+            graphicYOffset: -12.5
+        });
+        OpenLayers.Format.prototype.initialize.apply(this, [a])
+    },
+    read: function(a) {
+        for (var a = a.split("\n"), b, c = [], d = 0; d < a.length - 1; d++) {
+            var e = a[d].replace(/^\s*/, "").replace(/\s*$/, "");
+            if ("#" != e.charAt(0))
+                if (b) {
+                    for (var e =
+                            e.split("\t"), f = new OpenLayers.Geometry.Point(0, 0), g = {}, h = this.defaultStyle ? OpenLayers.Util.applyDefaults({}, this.defaultStyle) : null, i = !1, j = 0; j < e.length; j++)
+                        if (e[j])
+                            if ("point" == b[j]) i = e[j].split(","), f.y = parseFloat(i[0]), f.x = parseFloat(i[1]), i = !0;
+                            else if ("lat" == b[j]) f.y = parseFloat(e[j]), i = !0;
+                    else if ("lon" == b[j]) f.x = parseFloat(e[j]), i = !0;
+                    else if ("title" == b[j]) g.title = e[j];
+                    else if ("image" == b[j] || "icon" == b[j] && h) h.externalGraphic = e[j];
+                    else if ("iconSize" == b[j] && h) {
+                        var k = e[j].split(",");
+                        h.graphicWidth =
+                            parseFloat(k[0]);
+                        h.graphicHeight = parseFloat(k[1])
+                    } else "iconOffset" == b[j] && h ? (k = e[j].split(","), h.graphicXOffset = parseFloat(k[0]), h.graphicYOffset = parseFloat(k[1])) : "description" == b[j] ? g.description = e[j] : "overflow" == b[j] ? g.overflow = e[j] : g[b[j]] = e[j];
+                    i && (this.internalProjection && this.externalProjection && f.transform(this.externalProjection, this.internalProjection), e = new OpenLayers.Feature.Vector(f, g, h), c.push(e))
+                } else b = e.split("\t")
+        }
+        return c
+    },
+    CLASS_NAME: "OpenLayers.Format.Text"
+});
+OpenLayers.Layer.Text = OpenLayers.Class(OpenLayers.Layer.Markers, {
+    location: null,
+    features: null,
+    formatOptions: null,
+    selectedFeature: null,
+    initialize: function(a, b) {
+        OpenLayers.Layer.Markers.prototype.initialize.apply(this, arguments);
+        this.features = []
+    },
+    destroy: function() {
+        OpenLayers.Layer.Markers.prototype.destroy.apply(this, arguments);
+        this.clearFeatures();
+        this.features = null
+    },
+    loadText: function() {
+        !this.loaded && null != this.location && (this.events.triggerEvent("loadstart"), OpenLayers.Request.GET({
+            url: this.location,
+            success: this.parseData,
+            failure: function() {
+                this.events.triggerEvent("loadend")
+            },
+            scope: this
+        }), this.loaded = !0)
+    },
+    moveTo: function(a, b, c) {
+        OpenLayers.Layer.Markers.prototype.moveTo.apply(this, arguments);
+        this.visibility && !this.loaded && this.loadText()
+    },
+    parseData: function(a) {
+        var a = a.responseText,
+            b = {};
+        OpenLayers.Util.extend(b, this.formatOptions);
+        this.map && !this.projection.equals(this.map.getProjectionObject()) && (b.externalProjection = this.projection, b.internalProjection = this.map.getProjectionObject());
+        for (var a =
+                (new OpenLayers.Format.Text(b)).read(a), b = 0, c = a.length; b < c; b++) {
+            var d = {},
+                e = a[b],
+                f, g, h;
+            f = new OpenLayers.LonLat(e.geometry.x, e.geometry.y);
+            e.style.graphicWidth && e.style.graphicHeight && (g = new OpenLayers.Size(e.style.graphicWidth, e.style.graphicHeight));
+            void 0 !== e.style.graphicXOffset && void 0 !== e.style.graphicYOffset && (h = new OpenLayers.Pixel(e.style.graphicXOffset, e.style.graphicYOffset));
+            null != e.style.externalGraphic ? d.icon = new OpenLayers.Icon(e.style.externalGraphic, g, h) : (d.icon = OpenLayers.Marker.defaultIcon(),
+                null != g && d.icon.setSize(g));
+            null != e.attributes.title && null != e.attributes.description && (d.popupContentHTML = "<h2>" + e.attributes.title + "</h2><p>" + e.attributes.description + "</p>");
+            d.overflow = e.attributes.overflow || "auto";
+            d = new OpenLayers.Feature(this, f, d);
+            this.features.push(d);
+            f = d.createMarker();
+            null != e.attributes.title && null != e.attributes.description && f.events.register("click", d, this.markerClick);
+            this.addMarker(f)
+        }
+        this.events.triggerEvent("loadend")
+    },
+    markerClick: function(a) {
+        var b = this == this.layer.selectedFeature;
+        this.layer.selectedFeature = !b ? this : null;
+        for (var c = 0, d = this.layer.map.popups.length; c < d; c++) this.layer.map.removePopup(this.layer.map.popups[c]);
+        b || this.layer.map.addPopup(this.createPopup());
+        OpenLayers.Event.stop(a)
+    },
+    clearFeatures: function() {
+        if (null != this.features)
+            for (; 0 < this.features.length;) {
+                var a = this.features[0];
+                OpenLayers.Util.removeItem(this.features, a);
+                a.destroy()
+            }
+    },
+    CLASS_NAME: "OpenLayers.Layer.Text"
+});
+OpenLayers.Handler.RegularPolygon = OpenLayers.Class(OpenLayers.Handler.Drag, {
+    sides: 4,
+    radius: null,
+    snapAngle: null,
+    snapToggle: "shiftKey",
+    layerOptions: null,
+    persist: !1,
+    irregular: !1,
+    citeCompliant: !1,
+    angle: null,
+    fixedRadius: !1,
+    feature: null,
+    layer: null,
+    origin: null,
+    initialize: function(a, b, c) {
+        if (!c || !c.layerOptions || !c.layerOptions.styleMap) this.style = OpenLayers.Util.extend(OpenLayers.Feature.Vector.style["default"], {});
+        OpenLayers.Handler.Drag.prototype.initialize.apply(this, [a, b, c]);
+        this.options = c ? c : {}
+    },
+    setOptions: function(a) {
+        OpenLayers.Util.extend(this.options,
+            a);
+        OpenLayers.Util.extend(this, a)
+    },
+    activate: function() {
+        var a = !1;
+        OpenLayers.Handler.Drag.prototype.activate.apply(this, arguments) && (a = OpenLayers.Util.extend({
+            displayInLayerSwitcher: !1,
+            calculateInRange: OpenLayers.Function.True,
+            wrapDateLine: this.citeCompliant
+        }, this.layerOptions), this.layer = new OpenLayers.Layer.Vector(this.CLASS_NAME, a), this.map.addLayer(this.layer), a = !0);
+        return a
+    },
+    deactivate: function() {
+        var a = !1;
+        OpenLayers.Handler.Drag.prototype.deactivate.apply(this, arguments) && (this.dragging && this.cancel(),
+            null != this.layer.map && (this.layer.destroy(!1), this.feature && this.feature.destroy()), this.feature = this.layer = null, a = !0);
+        return a
+    },
+    down: function(a) {
+        this.fixedRadius = !!this.radius;
+        a = this.layer.getLonLatFromViewPortPx(a.xy);
+        this.origin = new OpenLayers.Geometry.Point(a.lon, a.lat);
+        if (!this.fixedRadius || this.irregular) this.radius = this.map.getResolution();
+        this.persist && this.clear();
+        this.feature = new OpenLayers.Feature.Vector;
+        this.createGeometry();
+        this.callback("create", [this.origin, this.feature]);
+        this.layer.addFeatures([this.feature], {
+            silent: !0
+        });
+        this.layer.drawFeature(this.feature, this.style)
+    },
+    move: function(a) {
+        var b = this.layer.getLonLatFromViewPortPx(a.xy),
+            b = new OpenLayers.Geometry.Point(b.lon, b.lat);
+        this.irregular ? (a = Math.sqrt(2) * Math.abs(b.y - this.origin.y) / 2, this.radius = Math.max(this.map.getResolution() / 2, a)) : this.fixedRadius ? this.origin = b : (this.calculateAngle(b, a), this.radius = Math.max(this.map.getResolution() / 2, b.distanceTo(this.origin)));
+        this.modifyGeometry();
+        this.irregular && (a = b.x - this.origin.x, b = b.y - this.origin.y, this.feature.geometry.resize(1,
+            this.origin, 0 == b ? a / (this.radius * Math.sqrt(2)) : a / b), this.feature.geometry.move(a / 2, b / 2));
+        this.layer.drawFeature(this.feature, this.style)
+    },
+    up: function(a) {
+        this.finalize();
+        this.start == this.last && this.callback("done", [a.xy])
+    },
+    out: function() {
+        this.finalize()
+    },
+    createGeometry: function() {
+        this.angle = Math.PI * (1 / this.sides - 0.5);
+        this.snapAngle && (this.angle += this.snapAngle * (Math.PI / 180));
+        this.feature.geometry = OpenLayers.Geometry.Polygon.createRegularPolygon(this.origin, this.radius, this.sides, this.snapAngle)
+    },
+    modifyGeometry: function() {
+        var a,
+            b, c = this.feature.geometry.components[0];
+        c.components.length != this.sides + 1 && (this.createGeometry(), c = this.feature.geometry.components[0]);
+        for (var d = 0; d < this.sides; ++d) b = c.components[d], a = this.angle + 2 * d * Math.PI / this.sides, b.x = this.origin.x + this.radius * Math.cos(a), b.y = this.origin.y + this.radius * Math.sin(a), b.clearBounds()
+    },
+    calculateAngle: function(a, b) {
+        var c = Math.atan2(a.y - this.origin.y, a.x - this.origin.x);
+        if (this.snapAngle && this.snapToggle && !b[this.snapToggle]) {
+            var d = Math.PI / 180 * this.snapAngle;
+            this.angle =
+                Math.round(c / d) * d
+        } else this.angle = c
+    },
+    cancel: function() {
+        this.callback("cancel", null);
+        this.finalize()
+    },
+    finalize: function() {
+        this.origin = null;
+        this.radius = this.options.radius
+    },
+    clear: function() {
+        this.layer && (this.layer.renderer.clear(), this.layer.destroyFeatures())
+    },
+    callback: function(a) {
+        this.callbacks[a] && this.callbacks[a].apply(this.control, [this.feature.geometry.clone()]);
+        !this.persist && ("done" == a || "cancel" == a) && this.clear()
+    },
+    CLASS_NAME: "OpenLayers.Handler.RegularPolygon"
+});
+OpenLayers.Control.SLDSelect = OpenLayers.Class(OpenLayers.Control, {
+    clearOnDeactivate: !1,
+    layers: null,
+    callbacks: null,
+    selectionSymbolizer: {
+        Polygon: {
+            fillColor: "#FF0000",
+            stroke: !1
+        },
+        Line: {
+            strokeColor: "#FF0000",
+            strokeWidth: 2
+        },
+        Point: {
+            graphicName: "square",
+            fillColor: "#FF0000",
+            pointRadius: 5
+        }
+    },
+    layerOptions: null,
+    handlerOptions: null,
+    sketchStyle: null,
+    wfsCache: {},
+    layerCache: {},
+    initialize: function(a, b) {
+        OpenLayers.Control.prototype.initialize.apply(this, [b]);
+        this.callbacks = OpenLayers.Util.extend({
+                done: this.select,
+                click: this.select
+            },
+            this.callbacks);
+        this.handlerOptions = this.handlerOptions || {};
+        this.layerOptions = OpenLayers.Util.applyDefaults(this.layerOptions, {
+            displayInLayerSwitcher: !1,
+            tileOptions: {
+                maxGetUrlLength: 2048
+            }
+        });
+        this.sketchStyle && (this.handlerOptions.layerOptions = OpenLayers.Util.applyDefaults(this.handlerOptions.layerOptions, {
+            styleMap: new OpenLayers.StyleMap({
+                "default": this.sketchStyle
+            })
+        }));
+        this.handler = new a(this, this.callbacks, this.handlerOptions)
+    },
+    destroy: function() {
+        for (var a in this.layerCache) delete this.layerCache[a];
+        for (a in this.wfsCache) delete this.wfsCache[a];
+        OpenLayers.Control.prototype.destroy.apply(this, arguments)
+    },
+    coupleLayerVisiblity: function(a) {
+        this.setVisibility(a.object.getVisibility())
+    },
+    createSelectionLayer: function(a) {
+        var b;
+        if (this.layerCache[a.id]) b = this.layerCache[a.id];
+        else {
+            b = new OpenLayers.Layer.WMS(a.name, a.url, a.params, OpenLayers.Util.applyDefaults(this.layerOptions, a.getOptions()));
+            this.layerCache[a.id] = b;
+            if (!1 === this.layerOptions.displayInLayerSwitcher) a.events.on({
+                visibilitychanged: this.coupleLayerVisiblity,
+                scope: b
+            });
+            this.map.addLayer(b)
+        }
+        return b
+    },
+    createSLD: function(a, b, c) {
+        for (var d = {
+                version: "1.0.0",
+                namedLayers: {}
+            }, e = ("" + a.params.LAYERS).split(","), f = 0, g = e.length; f < g; f++) {
+            var h = e[f];
+            d.namedLayers[h] = {
+                name: h,
+                userStyles: []
+            };
+            var i = this.selectionSymbolizer,
+                j = c[f];
+            0 <= j.type.indexOf("Polygon") ? i = {
+                Polygon: this.selectionSymbolizer.Polygon
+            } : 0 <= j.type.indexOf("LineString") ? i = {
+                Line: this.selectionSymbolizer.Line
+            } : 0 <= j.type.indexOf("Point") && (i = {
+                Point: this.selectionSymbolizer.Point
+            });
+            d.namedLayers[h].userStyles.push({
+                name: "default",
+                rules: [new OpenLayers.Rule({
+                    symbolizer: i,
+                    filter: b[f],
+                    maxScaleDenominator: a.options.minScale
+                })]
+            })
+        }
+        return (new OpenLayers.Format.SLD({
+            srsName: this.map.getProjection()
+        })).write(d)
+    },
+    parseDescribeLayer: function(a) {
+        var b = new OpenLayers.Format.WMSDescribeLayer,
+            c = a.responseXML;
+        if (!c || !c.documentElement) c = a.responseText;
+        for (var a = b.read(c), b = [], c = null, d = 0, e = a.length; d < e; d++) "WFS" == a[d].owsType && (b.push(a[d].typeName), c = a[d].owsURL);
+        OpenLayers.Request.GET({
+            url: c,
+            params: {
+                SERVICE: "WFS",
+                TYPENAME: b.toString(),
+                REQUEST: "DescribeFeatureType",
+                VERSION: "1.0.0"
+            },
+            callback: function(a) {
+                var b = new OpenLayers.Format.WFSDescribeFeatureType,
+                    c = a.responseXML;
+                if (!c || !c.documentElement) c = a.responseText;
+                this.control.wfsCache[this.layer.id] = b.read(c);
+                this.control._queue && this.control.applySelection()
+            },
+            scope: this
+        })
+    },
+    getGeometryAttributes: function(a) {
+        for (var b = [], a = this.wfsCache[a.id], c = 0, d = a.featureTypes.length; c < d; c++)
+            for (var e = a.featureTypes[c].properties, f = 0, g = e.length; f < g; f++) {
+                var h = e[f],
+                    i = h.type;
+                (0 <= i.indexOf("LineString") || 0 <= i.indexOf("GeometryAssociationType") ||
+                    0 <= i.indexOf("GeometryPropertyType") || 0 <= i.indexOf("Point") || 0 <= i.indexOf("Polygon")) && b.push(h)
+            }
+        return b
+    },
+    activate: function() {
+        var a = OpenLayers.Control.prototype.activate.call(this);
+        if (a)
+            for (var b = 0, c = this.layers.length; b < c; b++) {
+                var d = this.layers[b];
+                d && !this.wfsCache[d.id] && OpenLayers.Request.GET({
+                    url: d.url,
+                    params: {
+                        SERVICE: "WMS",
+                        VERSION: d.params.VERSION,
+                        LAYERS: d.params.LAYERS,
+                        REQUEST: "DescribeLayer"
+                    },
+                    callback: this.parseDescribeLayer,
+                    scope: {
+                        layer: d,
+                        control: this
+                    }
+                })
+            }
+        return a
+    },
+    deactivate: function() {
+        var a =
+            OpenLayers.Control.prototype.deactivate.call(this);
+        if (a)
+            for (var b = 0, c = this.layers.length; b < c; b++) {
+                var d = this.layers[b];
+                if (d && !0 === this.clearOnDeactivate) {
+                    var e = this.layerCache,
+                        f = e[d.id];
+                    f && (d.events.un({
+                        visibilitychanged: this.coupleLayerVisiblity,
+                        scope: f
+                    }), f.destroy(), delete e[d.id])
+                }
+            }
+        return a
+    },
+    setLayers: function(a) {
+        this.active ? (this.deactivate(), this.layers = a, this.activate()) : this.layers = a
+    },
+    createFilter: function(a, b) {
+        var c = null;
+        this.handler instanceof OpenLayers.Handler.RegularPolygon ? c = !0 === this.handler.irregular ?
+            new OpenLayers.Filter.Spatial({
+                type: OpenLayers.Filter.Spatial.BBOX,
+                property: a.name,
+                value: b.getBounds()
+            }) : new OpenLayers.Filter.Spatial({
+                type: OpenLayers.Filter.Spatial.INTERSECTS,
+                property: a.name,
+                value: b
+            }) : this.handler instanceof OpenLayers.Handler.Polygon ? c = new OpenLayers.Filter.Spatial({
+                type: OpenLayers.Filter.Spatial.INTERSECTS,
+                property: a.name,
+                value: b
+            }) : this.handler instanceof OpenLayers.Handler.Path ? c = 0 <= a.type.indexOf("Point") ? new OpenLayers.Filter.Spatial({
+                type: OpenLayers.Filter.Spatial.DWITHIN,
+                property: a.name,
+                distance: 0.01 * this.map.getExtent().getWidth(),
+                distanceUnits: this.map.getUnits(),
+                value: b
+            }) : new OpenLayers.Filter.Spatial({
+                type: OpenLayers.Filter.Spatial.INTERSECTS,
+                property: a.name,
+                value: b
+            }) : this.handler instanceof OpenLayers.Handler.Click && (c = 0 <= a.type.indexOf("Polygon") ? new OpenLayers.Filter.Spatial({
+                type: OpenLayers.Filter.Spatial.INTERSECTS,
+                property: a.name,
+                value: b
+            }) : new OpenLayers.Filter.Spatial({
+                type: OpenLayers.Filter.Spatial.DWITHIN,
+                property: a.name,
+                distance: 0.01 * this.map.getExtent().getWidth(),
+                distanceUnits: this.map.getUnits(),
+                value: b
+            }));
+        return c
+    },
+    select: function(a) {
+        this._queue = function() {
+            for (var b = 0, c = this.layers.length; b < c; b++) {
+                for (var d = this.layers[b], e = this.getGeometryAttributes(d), f = [], g = 0, h = e.length; g < h; g++) {
+                    var i = e[g];
+                    if (null !== i) {
+                        if (!(a instanceof OpenLayers.Geometry)) {
+                            var j = this.map.getLonLatFromPixel(a.xy);
+                            a = new OpenLayers.Geometry.Point(j.lon, j.lat)
+                        }
+                        i = this.createFilter(i, a);
+                        null !== i && f.push(i)
+                    }
+                }
+                g = this.createSelectionLayer(d);
+                e = this.createSLD(d, f, e);
+                this.events.triggerEvent("selected", {
+                    layer: d,
+                    filters: f
+                });
+                g.mergeNewParams({
+                    SLD_BODY: e
+                });
+                delete this._queue
+            }
+        };
+        this.applySelection()
+    },
+    applySelection: function() {
+        for (var a = !0, b = 0, c = this.layers.length; b < c; b++)
+            if (!this.wfsCache[this.layers[b].id]) {
+                a = !1;
+                break
+            }
+        a && this._queue.call(this)
+    },
+    CLASS_NAME: "OpenLayers.Control.SLDSelect"
+});
+OpenLayers.Control.Scale = OpenLayers.Class(OpenLayers.Control, {
+    element: null,
+    geodesic: !1,
+    initialize: function(a, b) {
+        OpenLayers.Control.prototype.initialize.apply(this, [b]);
+        this.element = OpenLayers.Util.getElement(a)
+    },
+    draw: function() {
+        OpenLayers.Control.prototype.draw.apply(this, arguments);
+        this.element || (this.element = document.createElement("div"), this.div.appendChild(this.element));
+        this.map.events.register("moveend", this, this.updateScale);
+        this.updateScale();
+        return this.div
+    },
+    updateScale: function() {
+        var a;
+        if (!0 === this.geodesic) {
+            if (!this.map.getUnits()) return;
+            a = OpenLayers.INCHES_PER_UNIT;
+            a = (this.map.getGeodesicPixelSize().w || 1.0E-6) * a.km * OpenLayers.DOTS_PER_INCH
+        } else a = this.map.getScale();
+        a && (a = 9500 <= a && 95E4 >= a ? Math.round(a / 1E3) + "K" : 95E4 <= a ? Math.round(a / 1E6) + "M" : Math.round(a), this.element.innerHTML = OpenLayers.i18n("Scale = 1 : ${scaleDenom}", {
+            scaleDenom: a
+        }))
+    },
+    CLASS_NAME: "OpenLayers.Control.Scale"
+});
+OpenLayers.Control.Button = OpenLayers.Class(OpenLayers.Control, {
+    type: OpenLayers.Control.TYPE_BUTTON,
+    trigger: function() {},
+    CLASS_NAME: "OpenLayers.Control.Button"
+});
+OpenLayers.Layer.MapGuide = OpenLayers.Class(OpenLayers.Layer.Grid, {
+    isBaseLayer: !0,
+    useHttpTile: !1,
+    singleTile: !1,
+    useOverlay: !1,
+    useAsyncOverlay: !0,
+    TILE_PARAMS: {
+        operation: "GETTILEIMAGE",
+        version: "1.2.0"
+    },
+    SINGLE_TILE_PARAMS: {
+        operation: "GETMAPIMAGE",
+        format: "PNG",
+        locale: "en",
+        clip: "1",
+        version: "1.0.0"
+    },
+    OVERLAY_PARAMS: {
+        operation: "GETDYNAMICMAPOVERLAYIMAGE",
+        format: "PNG",
+        locale: "en",
+        clip: "1",
+        version: "2.0.0"
+    },
+    FOLDER_PARAMS: {
+        tileColumnsPerFolder: 30,
+        tileRowsPerFolder: 30,
+        format: "png",
+        querystring: null
+    },
+    defaultSize: new OpenLayers.Size(300,
+        300),
+    tileOriginCorner: "tl",
+    initialize: function(a, b, c, d) {
+        OpenLayers.Layer.Grid.prototype.initialize.apply(this, arguments);
+        if (null == d || null == d.isBaseLayer) this.isBaseLayer = "true" != this.transparent && !0 != this.transparent;
+        d && null != d.useOverlay && (this.useOverlay = d.useOverlay);
+        this.singleTile ? this.useOverlay ? (OpenLayers.Util.applyDefaults(this.params, this.OVERLAY_PARAMS), this.useAsyncOverlay || (this.params.version = "1.0.0")) : OpenLayers.Util.applyDefaults(this.params, this.SINGLE_TILE_PARAMS) : (this.useHttpTile ?
+            OpenLayers.Util.applyDefaults(this.params, this.FOLDER_PARAMS) : OpenLayers.Util.applyDefaults(this.params, this.TILE_PARAMS), this.setTileSize(this.defaultSize))
+    },
+    clone: function(a) {
+        null == a && (a = new OpenLayers.Layer.MapGuide(this.name, this.url, this.params, this.getOptions()));
+        return a = OpenLayers.Layer.Grid.prototype.clone.apply(this, [a])
+    },
+    getURL: function(a) {
+        var b;
+        b = a.getCenterLonLat();
+        var c = this.map.getSize();
+        this.singleTile ? (a = {
+            setdisplaydpi: OpenLayers.DOTS_PER_INCH,
+            setdisplayheight: c.h * this.ratio,
+            setdisplaywidth: c.w *
+                this.ratio,
+            setviewcenterx: b.lon,
+            setviewcentery: b.lat,
+            setviewscale: this.map.getScale()
+        }, this.useOverlay && !this.useAsyncOverlay && (b = {}, b = OpenLayers.Util.extend(b, a), b.operation = "GETVISIBLEMAPEXTENT", b.version = "1.0.0", b.session = this.params.session, b.mapName = this.params.mapName, b.format = "text/xml", b = this.getFullRequestString(b), OpenLayers.Request.GET({
+            url: b,
+            async: !1
+        })), b = this.getFullRequestString(a)) : (c = this.map.getResolution(), b = Math.floor((a.left - this.maxExtent.left) / c), b = Math.round(b / this.tileSize.w),
+            a = Math.floor((this.maxExtent.top - a.top) / c), a = Math.round(a / this.tileSize.h), b = this.useHttpTile ? this.getImageFilePath({
+                tilecol: b,
+                tilerow: a,
+                scaleindex: this.resolutions.length - this.map.zoom - 1
+            }) : this.getFullRequestString({
+                tilecol: b,
+                tilerow: a,
+                scaleindex: this.resolutions.length - this.map.zoom - 1
+            }));
+        return b
+    },
+    getFullRequestString: function(a, b) {
+        var c = null == b ? this.url : b;
+        "object" == typeof c && (c = c[Math.floor(Math.random() * c.length)]);
+        var d = c,
+            e = OpenLayers.Util.extend({}, this.params),
+            e = OpenLayers.Util.extend(e, a),
+            f = OpenLayers.Util.upperCaseObject(OpenLayers.Util.getParameters(c)),
+            g;
+        for (g in e) g.toUpperCase() in f && delete e[g];
+        e = OpenLayers.Util.getParameterString(e);
+        e = e.replace(/,/g, "+");
+        "" != e && (f = c.charAt(c.length - 1), d = "&" == f || "?" == f ? d + e : -1 == c.indexOf("?") ? d + ("?" + e) : d + ("&" + e));
+        return d
+    },
+    getImageFilePath: function(a, b) {
+        var c = null == b ? this.url : b;
+        "object" == typeof c && (c = c[Math.floor(Math.random() * c.length)]);
+        var d = "",
+            e = "";
+        0 > a.tilerow && (d = "-");
+        d = 0 == a.tilerow ? d + "0" : d + Math.floor(Math.abs(a.tilerow / this.params.tileRowsPerFolder)) *
+            this.params.tileRowsPerFolder;
+        0 > a.tilecol && (e = "-");
+        e = 0 == a.tilecol ? e + "0" : e + Math.floor(Math.abs(a.tilecol / this.params.tileColumnsPerFolder)) * this.params.tileColumnsPerFolder;
+        d = "/S" + Math.floor(a.scaleindex) + "/" + this.params.basemaplayergroupname + "/R" + d + "/C" + e + "/" + a.tilerow % this.params.tileRowsPerFolder + "_" + a.tilecol % this.params.tileColumnsPerFolder + "." + this.params.format;
+        this.params.querystring && (d += "?" + this.params.querystring);
+        return c + d
+    },
+    calculateGridLayout: function(a, b, c) {
+        var d = c * this.tileSize.w,
+            c =
+            c * this.tileSize.h,
+            e = a.left - b.lon,
+            f = Math.floor(e / d) - this.buffer,
+            a = b.lat - a.top + c,
+            g = Math.floor(a / c) - this.buffer;
+        return {
+            tilelon: d,
+            tilelat: c,
+            tileoffsetlon: b.lon + f * d,
+            tileoffsetlat: b.lat - c * g,
+            tileoffsetx: -(e / d - f) * this.tileSize.w,
+            tileoffsety: (g - a / c) * this.tileSize.h
+        }
+    },
+    CLASS_NAME: "OpenLayers.Layer.MapGuide"
+});
+OpenLayers.Control.Measure = OpenLayers.Class(OpenLayers.Control, {
+    handlerOptions: null,
+    callbacks: null,
+    displaySystem: "metric",
+    geodesic: !1,
+    displaySystemUnits: {
+        geographic: ["dd"],
+        english: ["mi", "ft", "in"],
+        metric: ["km", "m"]
+    },
+    partialDelay: 300,
+    delayedTrigger: null,
+    persist: !1,
+    immediate: !1,
+    initialize: function(a, b) {
+        OpenLayers.Control.prototype.initialize.apply(this, [b]);
+        var c = {
+            done: this.measureComplete,
+            point: this.measurePartial
+        };
+        this.immediate && (c.modify = this.measureImmediate);
+        this.callbacks = OpenLayers.Util.extend(c,
+            this.callbacks);
+        this.handlerOptions = OpenLayers.Util.extend({
+            persist: this.persist
+        }, this.handlerOptions);
+        this.handler = new a(this, this.callbacks, this.handlerOptions)
+    },
+    deactivate: function() {
+        this.cancelDelay();
+        return OpenLayers.Control.prototype.deactivate.apply(this, arguments)
+    },
+    cancel: function() {
+        this.cancelDelay();
+        this.handler.cancel()
+    },
+    setImmediate: function(a) {
+        (this.immediate = a) ? this.callbacks.modify = this.measureImmediate: delete this.callbacks.modify
+    },
+    updateHandler: function(a, b) {
+        var c = this.active;
+        c &&
+            this.deactivate();
+        this.handler = new a(this, this.callbacks, b);
+        c && this.activate()
+    },
+    measureComplete: function(a) {
+        this.cancelDelay();
+        this.measure(a, "measure")
+    },
+    measurePartial: function(a, b) {
+        this.cancelDelay();
+        b = b.clone();
+        this.handler.freehandMode(this.handler.evt) ? this.measure(b, "measurepartial") : this.delayedTrigger = window.setTimeout(OpenLayers.Function.bind(function() {
+            this.delayedTrigger = null;
+            this.measure(b, "measurepartial")
+        }, this), this.partialDelay)
+    },
+    measureImmediate: function(a, b, c) {
+        c && !this.handler.freehandMode(this.handler.evt) &&
+            (this.cancelDelay(), this.measure(b.geometry, "measurepartial"))
+    },
+    cancelDelay: function() {
+        null !== this.delayedTrigger && (window.clearTimeout(this.delayedTrigger), this.delayedTrigger = null)
+    },
+    measure: function(a, b) {
+        var c, d; - 1 < a.CLASS_NAME.indexOf("LineString") ? (c = this.getBestLength(a), d = 1) : (c = this.getBestArea(a), d = 2);
+        this.events.triggerEvent(b, {
+            measure: c[0],
+            units: c[1],
+            order: d,
+            geometry: a
+        })
+    },
+    getBestArea: function(a) {
+        for (var b = this.displaySystemUnits[this.displaySystem], c, d, e = 0, f = b.length; e < f && !(c = b[e], d = this.getArea(a,
+                c), 1 < d); ++e);
+        return [d, c]
+    },
+    getArea: function(a, b) {
+        var c, d;
+        this.geodesic ? (c = a.getGeodesicArea(this.map.getProjectionObject()), d = "m") : (c = a.getArea(), d = this.map.getUnits());
+        var e = OpenLayers.INCHES_PER_UNIT[b];
+        e && (c *= Math.pow(OpenLayers.INCHES_PER_UNIT[d] / e, 2));
+        return c
+    },
+    getBestLength: function(a) {
+        for (var b = this.displaySystemUnits[this.displaySystem], c, d, e = 0, f = b.length; e < f && !(c = b[e], d = this.getLength(a, c), 1 < d); ++e);
+        return [d, c]
+    },
+    getLength: function(a, b) {
+        var c, d;
+        this.geodesic ? (c = a.getGeodesicLength(this.map.getProjectionObject()),
+            d = "m") : (c = a.getLength(), d = this.map.getUnits());
+        var e = OpenLayers.INCHES_PER_UNIT[b];
+        e && (c *= OpenLayers.INCHES_PER_UNIT[d] / e);
+        return c
+    },
+    CLASS_NAME: "OpenLayers.Control.Measure"
+});
+OpenLayers.Format.WMC.v1_0_0 = OpenLayers.Class(OpenLayers.Format.WMC.v1, {
+    VERSION: "1.0.0",
+    schemaLocation: "http://www.opengis.net/context http://schemas.opengis.net/context/1.0.0/context.xsd",
+    initialize: function(a) {
+        OpenLayers.Format.WMC.v1.prototype.initialize.apply(this, [a])
+    },
+    read_wmc_SRS: function(a, b) {
+        var c = this.getChildValue(b);
+        "object" != typeof a.projections && (a.projections = {});
+        for (var c = c.split(/ +/), d = 0, e = c.length; d < e; d++) a.projections[c[d]] = !0
+    },
+    write_wmc_Layer: function(a) {
+        var b = OpenLayers.Format.WMC.v1.prototype.write_wmc_Layer.apply(this, [a]);
+        if (a.srs) {
+            var c = [],
+                d;
+            for (d in a.srs) c.push(d);
+            b.appendChild(this.createElementDefaultNS("SRS", c.join(" ")))
+        }
+        b.appendChild(this.write_wmc_FormatList(a));
+        b.appendChild(this.write_wmc_StyleList(a));
+        a.dimensions && b.appendChild(this.write_wmc_DimensionList(a));
+        b.appendChild(this.write_wmc_LayerExtension(a))
+    },
+    CLASS_NAME: "OpenLayers.Format.WMC.v1_0_0"
+});
+OpenLayers.Popup.Framed = OpenLayers.Class(OpenLayers.Popup.Anchored, {
+    imageSrc: null,
+    imageSize: null,
+    isAlphaImage: !1,
+    positionBlocks: null,
+    blocks: null,
+    fixedRelativePosition: !1,
+    initialize: function(a, b, c, d, e, f, g) {
+        OpenLayers.Popup.Anchored.prototype.initialize.apply(this, arguments);
+        this.fixedRelativePosition && (this.updateRelativePosition(), this.calculateRelativePosition = function() {
+            return this.relativePosition
+        });
+        this.contentDiv.style.position = "absolute";
+        this.contentDiv.style.zIndex = 1;
+        f && (this.closeDiv.style.zIndex =
+            1);
+        this.groupDiv.style.position = "absolute";
+        this.groupDiv.style.top = "0px";
+        this.groupDiv.style.left = "0px";
+        this.groupDiv.style.height = "100%";
+        this.groupDiv.style.width = "100%"
+    },
+    destroy: function() {
+        this.isAlphaImage = this.imageSize = this.imageSrc = null;
+        this.fixedRelativePosition = !1;
+        this.positionBlocks = null;
+        for (var a = 0; a < this.blocks.length; a++) {
+            var b = this.blocks[a];
+            b.image && b.div.removeChild(b.image);
+            b.image = null;
+            b.div && this.groupDiv.removeChild(b.div);
+            b.div = null
+        }
+        this.blocks = null;
+        OpenLayers.Popup.Anchored.prototype.destroy.apply(this,
+            arguments)
+    },
+    setBackgroundColor: function() {},
+    setBorder: function() {},
+    setOpacity: function() {},
+    setSize: function(a) {
+        OpenLayers.Popup.Anchored.prototype.setSize.apply(this, arguments);
+        this.updateBlocks()
+    },
+    updateRelativePosition: function() {
+        this.padding = this.positionBlocks[this.relativePosition].padding;
+        if (this.closeDiv) {
+            var a = this.getContentDivPadding();
+            this.closeDiv.style.right = a.right + this.padding.right + "px";
+            this.closeDiv.style.top = a.top + this.padding.top + "px"
+        }
+        this.updateBlocks()
+    },
+    calculateNewPx: function(a) {
+        var b =
+            OpenLayers.Popup.Anchored.prototype.calculateNewPx.apply(this, arguments);
+        return b = b.offset(this.positionBlocks[this.relativePosition].offset)
+    },
+    createBlocks: function() {
+        this.blocks = [];
+        var a = null,
+            b;
+        for (b in this.positionBlocks) {
+            a = b;
+            break
+        }
+        a = this.positionBlocks[a];
+        for (b = 0; b < a.blocks.length; b++) {
+            var c = {};
+            this.blocks.push(c);
+            c.div = OpenLayers.Util.createDiv(this.id + "_FrameDecorationDiv_" + b, null, null, null, "absolute", null, "hidden", null);
+            c.image = (this.isAlphaImage ? OpenLayers.Util.createAlphaImageDiv : OpenLayers.Util.createImage)(this.id +
+                "_FrameDecorationImg_" + b, null, this.imageSize, this.imageSrc, "absolute", null, null, null);
+            c.div.appendChild(c.image);
+            this.groupDiv.appendChild(c.div)
+        }
+    },
+    updateBlocks: function() {
+        this.blocks || this.createBlocks();
+        if (this.size && this.relativePosition) {
+            for (var a = this.positionBlocks[this.relativePosition], b = 0; b < a.blocks.length; b++) {
+                var c = a.blocks[b],
+                    d = this.blocks[b],
+                    e = c.anchor.left,
+                    f = c.anchor.bottom,
+                    g = c.anchor.right,
+                    h = c.anchor.top,
+                    i = isNaN(c.size.w) ? this.size.w - (g + e) : c.size.w,
+                    j = isNaN(c.size.h) ? this.size.h - (f +
+                        h) : c.size.h;
+                d.div.style.width = (0 > i ? 0 : i) + "px";
+                d.div.style.height = (0 > j ? 0 : j) + "px";
+                d.div.style.left = null != e ? e + "px" : "";
+                d.div.style.bottom = null != f ? f + "px" : "";
+                d.div.style.right = null != g ? g + "px" : "";
+                d.div.style.top = null != h ? h + "px" : "";
+                d.image.style.left = c.position.x + "px";
+                d.image.style.top = c.position.y + "px"
+            }
+            this.contentDiv.style.left = this.padding.left + "px";
+            this.contentDiv.style.top = this.padding.top + "px"
+        }
+    },
+    CLASS_NAME: "OpenLayers.Popup.Framed"
+});
+OpenLayers.Popup.FramedCloud = OpenLayers.Class(OpenLayers.Popup.Framed, {
+    contentDisplayClass: "olFramedCloudPopupContent",
+    autoSize: !0,
+    panMapIfOutOfView: !0,
+    imageSize: new OpenLayers.Size(1276, 736),
+    isAlphaImage: !1,
+    fixedRelativePosition: !1,
+    positionBlocks: {
+        tl: {
+            offset: new OpenLayers.Pixel(44, 0),
+            padding: new OpenLayers.Bounds(8, 40, 8, 9),
+            blocks: [{
+                size: new OpenLayers.Size("auto", "auto"),
+                anchor: new OpenLayers.Bounds(0, 51, 22, 0),
+                position: new OpenLayers.Pixel(0, 0)
+            }, {
+                size: new OpenLayers.Size(22, "auto"),
+                anchor: new OpenLayers.Bounds(null,
+                    50, 0, 0),
+                position: new OpenLayers.Pixel(-1238, 0)
+            }, {
+                size: new OpenLayers.Size("auto", 19),
+                anchor: new OpenLayers.Bounds(0, 32, 22, null),
+                position: new OpenLayers.Pixel(0, -631)
+            }, {
+                size: new OpenLayers.Size(22, 18),
+                anchor: new OpenLayers.Bounds(null, 32, 0, null),
+                position: new OpenLayers.Pixel(-1238, -632)
+            }, {
+                size: new OpenLayers.Size(81, 35),
+                anchor: new OpenLayers.Bounds(null, 0, 0, null),
+                position: new OpenLayers.Pixel(0, -688)
+            }]
+        },
+        tr: {
+            offset: new OpenLayers.Pixel(-45, 0),
+            padding: new OpenLayers.Bounds(8, 40, 8, 9),
+            blocks: [{
+                size: new OpenLayers.Size("auto",
+                    "auto"),
+                anchor: new OpenLayers.Bounds(0, 51, 22, 0),
+                position: new OpenLayers.Pixel(0, 0)
+            }, {
+                size: new OpenLayers.Size(22, "auto"),
+                anchor: new OpenLayers.Bounds(null, 50, 0, 0),
+                position: new OpenLayers.Pixel(-1238, 0)
+            }, {
+                size: new OpenLayers.Size("auto", 19),
+                anchor: new OpenLayers.Bounds(0, 32, 22, null),
+                position: new OpenLayers.Pixel(0, -631)
+            }, {
+                size: new OpenLayers.Size(22, 19),
+                anchor: new OpenLayers.Bounds(null, 32, 0, null),
+                position: new OpenLayers.Pixel(-1238, -631)
+            }, {
+                size: new OpenLayers.Size(81, 35),
+                anchor: new OpenLayers.Bounds(0,
+                    0, null, null),
+                position: new OpenLayers.Pixel(-215, -687)
+            }]
+        },
+        bl: {
+            offset: new OpenLayers.Pixel(45, 0),
+            padding: new OpenLayers.Bounds(8, 9, 8, 40),
+            blocks: [{
+                size: new OpenLayers.Size("auto", "auto"),
+                anchor: new OpenLayers.Bounds(0, 21, 22, 32),
+                position: new OpenLayers.Pixel(0, 0)
+            }, {
+                size: new OpenLayers.Size(22, "auto"),
+                anchor: new OpenLayers.Bounds(null, 21, 0, 32),
+                position: new OpenLayers.Pixel(-1238, 0)
+            }, {
+                size: new OpenLayers.Size("auto", 21),
+                anchor: new OpenLayers.Bounds(0, 0, 22, null),
+                position: new OpenLayers.Pixel(0, -629)
+            }, {
+                size: new OpenLayers.Size(22,
+                    21),
+                anchor: new OpenLayers.Bounds(null, 0, 0, null),
+                position: new OpenLayers.Pixel(-1238, -629)
+            }, {
+                size: new OpenLayers.Size(81, 33),
+                anchor: new OpenLayers.Bounds(null, null, 0, 0),
+                position: new OpenLayers.Pixel(-101, -674)
+            }]
+        },
+        br: {
+            offset: new OpenLayers.Pixel(-44, 0),
+            padding: new OpenLayers.Bounds(8, 9, 8, 40),
+            blocks: [{
+                size: new OpenLayers.Size("auto", "auto"),
+                anchor: new OpenLayers.Bounds(0, 21, 22, 32),
+                position: new OpenLayers.Pixel(0, 0)
+            }, {
+                size: new OpenLayers.Size(22, "auto"),
+                anchor: new OpenLayers.Bounds(null, 21, 0, 32),
+                position: new OpenLayers.Pixel(-1238,
+                    0)
+            }, {
+                size: new OpenLayers.Size("auto", 21),
+                anchor: new OpenLayers.Bounds(0, 0, 22, null),
+                position: new OpenLayers.Pixel(0, -629)
+            }, {
+                size: new OpenLayers.Size(22, 21),
+                anchor: new OpenLayers.Bounds(null, 0, 0, null),
+                position: new OpenLayers.Pixel(-1238, -629)
+            }, {
+                size: new OpenLayers.Size(81, 33),
+                anchor: new OpenLayers.Bounds(0, null, null, 0),
+                position: new OpenLayers.Pixel(-311, -674)
+            }]
+        }
+    },
+    minSize: new OpenLayers.Size(105, 10),
+    maxSize: new OpenLayers.Size(1200, 660),
+    initialize: function(a, b, c, d, e, f, g) {
+        this.imageSrc = OpenLayers.Util.getImageLocation("cloud-popup-relative.png");
+        OpenLayers.Popup.Framed.prototype.initialize.apply(this, arguments);
+        this.contentDiv.className = this.contentDisplayClass
+    },
+    CLASS_NAME: "OpenLayers.Popup.FramedCloud"
+});
+OpenLayers.Tile.Image.IFrame = {
+    useIFrame: null,
+    draw: function() {
+        if (OpenLayers.Tile.Image.prototype.shouldDraw.call(this)) {
+            var a = this.layer.getURL(this.bounds),
+                b = this.useIFrame;
+            this.useIFrame = null !== this.maxGetUrlLength && !this.layer.async && a.length > this.maxGetUrlLength;
+            a = b && !this.useIFrame;
+            b = !b && this.useIFrame;
+            if (a || b) this.imgDiv && this.imgDiv.parentNode === this.frame && this.frame.removeChild(this.imgDiv), this.imgDiv = null, a ? (this.blankImageUrl = this._blankImageUrl, this.frame.removeChild(this.frame.firstChild)) :
+                (this._blankImageUrl = this.blankImageUrl, this.blankImageUrl = "about:blank")
+        }
+        return OpenLayers.Tile.Image.prototype.draw.apply(this, arguments)
+    },
+    getImage: function() {
+        if (!0 === this.useIFrame) {
+            if (!this.frame.childNodes.length) {
+                var a = document.createElement("div"),
+                    b = a.style;
+                b.position = "absolute";
+                b.width = "100%";
+                b.height = "100%";
+                b.zIndex = 1;
+                b.backgroundImage = "url(" + this._blankImageUrl + ")";
+                this.frame.appendChild(a)
+            }
+            a = this.id + "_iFrame";
+            9 > parseFloat(navigator.appVersion.split("MSIE")[1]) ? (b = document.createElement('<iframe name="' +
+                a + '">'), b.style.backgroundColor = "#FFFFFF", b.style.filter = "chroma(color=#FFFFFF)") : (b = document.createElement("iframe"), b.style.backgroundColor = "transparent", b.name = a);
+            b.scrolling = "no";
+            b.marginWidth = "0px";
+            b.marginHeight = "0px";
+            b.frameBorder = "0";
+            b.style.position = "absolute";
+            b.style.width = "100%";
+            b.style.height = "100%";
+            1 > this.layer.opacity && OpenLayers.Util.modifyDOMElement(b, null, null, null, null, null, null, this.layer.opacity);
+            this.frame.appendChild(b);
+            return this.imgDiv = b
+        }
+        return OpenLayers.Tile.Image.prototype.getImage.apply(this,
+            arguments)
+    },
+    createRequestForm: function() {
+        var a = document.createElement("form");
+        a.method = "POST";
+        var b = this.layer.params._OLSALT,
+            b = (b ? b + "_" : "") + this.bounds.toBBOX();
+        a.action = OpenLayers.Util.urlAppend(this.layer.url, b);
+        a.target = this.id + "_iFrame";
+        this.layer.getImageSize();
+        var b = OpenLayers.Util.getParameters(this.url),
+            c, d;
+        for (d in b) c = document.createElement("input"), c.type = "hidden", c.name = d, c.value = b[d], a.appendChild(c);
+        return a
+    },
+    setImgSrc: function(a) {
+        if (!0 === this.useIFrame)
+            if (a) {
+                var b = this.createRequestForm();
+                this.frame.appendChild(b);
+                b.submit();
+                this.frame.removeChild(b)
+            } else this.imgDiv.parentNode === this.frame && (this.frame.removeChild(this.imgDiv), this.imgDiv = null);
+        else OpenLayers.Tile.Image.prototype.setImgSrc.apply(this, arguments)
+    },
+    onImageLoad: function() {
+        OpenLayers.Tile.Image.prototype.onImageLoad.apply(this, arguments);
+        !0 === this.useIFrame && (this.imgDiv.style.opacity = 1, this.frame.style.opacity = this.layer.opacity)
+    },
+    createBackBuffer: function() {
+        var a;
+        !1 === this.useIFrame && (a = OpenLayers.Tile.Image.prototype.createBackBuffer.call(this));
+        return a
+    }
+};
+OpenLayers.Format.SOSCapabilities = OpenLayers.Class(OpenLayers.Format.XML.VersionedOGC, {
+    defaultVersion: "1.0.0",
+    CLASS_NAME: "OpenLayers.Format.SOSCapabilities"
+});
+OpenLayers.Format.SOSCapabilities.v1_0_0 = OpenLayers.Class(OpenLayers.Format.SOSCapabilities, {
+    namespaces: {
+        ows: "http://www.opengis.net/ows/1.1",
+        sos: "http://www.opengis.net/sos/1.0",
+        gml: "http://www.opengis.net/gml",
+        xlink: "http://www.w3.org/1999/xlink"
+    },
+    regExes: {
+        trimSpace: /^\s*|\s*$/g,
+        removeSpace: /\s*/g,
+        splitSpace: /\s+/,
+        trimComma: /\s*,\s*/g
+    },
+    initialize: function(a) {
+        OpenLayers.Format.XML.prototype.initialize.apply(this, [a]);
+        this.options = a
+    },
+    read: function(a) {
+        "string" == typeof a && (a = OpenLayers.Format.XML.prototype.read.apply(this, [a]));
+        a && 9 == a.nodeType && (a = a.documentElement);
+        var b = {};
+        this.readNode(a, b);
+        return b
+    },
+    readers: {
+        gml: OpenLayers.Util.applyDefaults({
+            name: function(a, b) {
+                b.name = this.getChildValue(a)
+            },
+            TimePeriod: function(a, b) {
+                b.timePeriod = {};
+                this.readChildNodes(a, b.timePeriod)
+            },
+            beginPosition: function(a, b) {
+                b.beginPosition = this.getChildValue(a)
+            },
+            endPosition: function(a, b) {
+                b.endPosition = this.getChildValue(a)
+            }
+        }, OpenLayers.Format.GML.v3.prototype.readers.gml),
+        sos: {
+            Capabilities: function(a, b) {
+                this.readChildNodes(a, b)
+            },
+            Contents: function(a,
+                b) {
+                b.contents = {};
+                this.readChildNodes(a, b.contents)
+            },
+            ObservationOfferingList: function(a, b) {
+                b.offeringList = {};
+                this.readChildNodes(a, b.offeringList)
+            },
+            ObservationOffering: function(a, b) {
+                var c = this.getAttributeNS(a, this.namespaces.gml, "id");
+                b[c] = {
+                    procedures: [],
+                    observedProperties: [],
+                    featureOfInterestIds: [],
+                    responseFormats: [],
+                    resultModels: [],
+                    responseModes: []
+                };
+                this.readChildNodes(a, b[c])
+            },
+            time: function(a, b) {
+                b.time = {};
+                this.readChildNodes(a, b.time)
+            },
+            procedure: function(a, b) {
+                b.procedures.push(this.getAttributeNS(a,
+                    this.namespaces.xlink, "href"))
+            },
+            observedProperty: function(a, b) {
+                b.observedProperties.push(this.getAttributeNS(a, this.namespaces.xlink, "href"))
+            },
+            featureOfInterest: function(a, b) {
+                b.featureOfInterestIds.push(this.getAttributeNS(a, this.namespaces.xlink, "href"))
+            },
+            responseFormat: function(a, b) {
+                b.responseFormats.push(this.getChildValue(a))
+            },
+            resultModel: function(a, b) {
+                b.resultModels.push(this.getChildValue(a))
+            },
+            responseMode: function(a, b) {
+                b.responseModes.push(this.getChildValue(a))
+            }
+        },
+        ows: OpenLayers.Format.OWSCommon.v1_1_0.prototype.readers.ows
+    },
+    CLASS_NAME: "OpenLayers.Format.SOSCapabilities.v1_0_0"
+});
+OpenLayers.Handler.Pinch = OpenLayers.Class(OpenLayers.Handler, {
+    started: !1,
+    stopDown: !1,
+    pinching: !1,
+    last: null,
+    start: null,
+    touchstart: function(a) {
+        var b = !0;
+        this.pinching = !1;
+        OpenLayers.Event.isMultiTouch(a) ? (this.started = !0, this.last = this.start = {
+            distance: this.getDistance(a.touches),
+            delta: 0,
+            scale: 1
+        }, this.callback("start", [a, this.start]), b = !this.stopDown) : (this.started = !1, this.last = this.start = null);
+        OpenLayers.Event.stop(a);
+        return b
+    },
+    touchmove: function(a) {
+        if (this.started && OpenLayers.Event.isMultiTouch(a)) {
+            this.pinching = !0;
+            var b = this.getPinchData(a);
+            this.callback("move", [a, b]);
+            this.last = b;
+            OpenLayers.Event.stop(a)
+        }
+        return !0
+    },
+    touchend: function(a) {
+        this.started && (this.pinching = this.started = !1, this.callback("done", [a, this.start, this.last]), this.last = this.start = null);
+        return !0
+    },
+    activate: function() {
+        var a = !1;
+        OpenLayers.Handler.prototype.activate.apply(this, arguments) && (this.pinching = !1, a = !0);
+        return a
+    },
+    deactivate: function() {
+        var a = !1;
+        OpenLayers.Handler.prototype.deactivate.apply(this, arguments) && (this.pinching = this.started = !1, this.last = this.start = null, a = !0);
+        return a
+    },
+    getDistance: function(a) {
+        var b = a[0],
+            a = a[1];
+        return Math.sqrt(Math.pow(b.clientX - a.clientX, 2) + Math.pow(b.clientY - a.clientY, 2))
+    },
+    getPinchData: function(a) {
+        a = this.getDistance(a.touches);
+        return {
+            distance: a,
+            delta: this.last.distance - a,
+            scale: a / this.start.distance
+        }
+    },
+    CLASS_NAME: "OpenLayers.Handler.Pinch"
+});
+OpenLayers.Control.NavToolbar = OpenLayers.Class(OpenLayers.Control.Panel, {
+    initialize: function(a) {
+        OpenLayers.Control.Panel.prototype.initialize.apply(this, [a]);
+        this.addControls([new OpenLayers.Control.Navigation, new OpenLayers.Control.ZoomBox])
+    },
+    draw: function() {
+        var a = OpenLayers.Control.Panel.prototype.draw.apply(this, arguments);
+        null === this.defaultControl && (this.defaultControl = this.controls[0]);
+        return a
+    },
+    CLASS_NAME: "OpenLayers.Control.NavToolbar"
+});
+OpenLayers.Strategy.Refresh = OpenLayers.Class(OpenLayers.Strategy, {
+    force: !1,
+    interval: 0,
+    timer: null,
+    activate: function() {
+        var a = OpenLayers.Strategy.prototype.activate.call(this);
+        a && (!0 === this.layer.visibility && this.start(), this.layer.events.on({
+            visibilitychanged: this.reset,
+            scope: this
+        }));
+        return a
+    },
+    deactivate: function() {
+        var a = OpenLayers.Strategy.prototype.deactivate.call(this);
+        a && this.stop();
+        return a
+    },
+    reset: function() {
+        !0 === this.layer.visibility ? this.start() : this.stop()
+    },
+    start: function() {
+        this.interval && ("number" ===
+            typeof this.interval && 0 < this.interval) && (this.timer = window.setInterval(OpenLayers.Function.bind(this.refresh, this), this.interval))
+    },
+    refresh: function() {
+        this.layer && (this.layer.refresh && "function" == typeof this.layer.refresh) && this.layer.refresh({
+            force: this.force
+        })
+    },
+    stop: function() {
+        null !== this.timer && (window.clearInterval(this.timer), this.timer = null)
+    },
+    CLASS_NAME: "OpenLayers.Strategy.Refresh"
+});
+OpenLayers.Layer.ArcGIS93Rest = OpenLayers.Class(OpenLayers.Layer.Grid, {
+    DEFAULT_PARAMS: {
+        format: "png"
+    },
+    isBaseLayer: !0,
+    initialize: function(a, b, c, d) {
+        var e = [],
+            c = OpenLayers.Util.upperCaseObject(c);
+        e.push(a, b, c, d);
+        OpenLayers.Layer.Grid.prototype.initialize.apply(this, e);
+        OpenLayers.Util.applyDefaults(this.params, OpenLayers.Util.upperCaseObject(this.DEFAULT_PARAMS));
+        if (this.params.TRANSPARENT && "true" == this.params.TRANSPARENT.toString().toLowerCase()) {
+            if (null == d || !d.isBaseLayer) this.isBaseLayer = !1;
+            "jpg" == this.params.FORMAT &&
+                (this.params.FORMAT = OpenLayers.Util.alphaHack() ? "gif" : "png")
+        }
+    },
+    clone: function(a) {
+        null == a && (a = new OpenLayers.Layer.ArcGIS93Rest(this.name, this.url, this.params, this.getOptions()));
+        return a = OpenLayers.Layer.Grid.prototype.clone.apply(this, [a])
+    },
+    getURL: function(a) {
+        var a = this.adjustBounds(a),
+            b = this.projection.getCode().split(":"),
+            b = b[b.length - 1],
+            c = this.getImageSize(),
+            a = {
+                BBOX: a.toBBOX(),
+                SIZE: c.w + "," + c.h,
+                F: "image",
+                BBOXSR: b,
+                IMAGESR: b
+            };
+        if (this.layerDefs) {
+            var b = [],
+                d;
+            for (d in this.layerDefs) this.layerDefs.hasOwnProperty(d) &&
+                this.layerDefs[d] && (b.push(d), b.push(":"), b.push(this.layerDefs[d]), b.push(";"));
+            0 < b.length && (a.LAYERDEFS = b.join(""))
+        }
+        return this.getFullRequestString(a)
+    },
+    setLayerFilter: function(a, b) {
+        this.layerDefs || (this.layerDefs = {});
+        b ? this.layerDefs[a] = b : delete this.layerDefs[a]
+    },
+    clearLayerFilter: function(a) {
+        a ? delete this.layerDefs[a] : delete this.layerDefs
+    },
+    mergeNewParams: function(a) {
+        a = [OpenLayers.Util.upperCaseObject(a)];
+        return OpenLayers.Layer.Grid.prototype.mergeNewParams.apply(this, a)
+    },
+    CLASS_NAME: "OpenLayers.Layer.ArcGIS93Rest"
+});
+OpenLayers.Format.WKT = OpenLayers.Class(OpenLayers.Format, {
+    initialize: function(a) {
+        this.regExes = {
+            typeStr: /^\s*(\w+)\s*\(\s*(.*)\s*\)\s*$/,
+            spaces: /\s+/,
+            parenComma: /\)\s*,\s*\(/,
+            doubleParenComma: /\)\s*\)\s*,\s*\(\s*\(/,
+            trimParens: /^\s*\(?(.*?)\)?\s*$/
+        };
+        OpenLayers.Format.prototype.initialize.apply(this, [a])
+    },
+    read: function(a) {
+        var b, c, a = a.replace(/[\n\r]/g, " ");
+        if (c = this.regExes.typeStr.exec(a))
+            if (a = c[1].toLowerCase(), c = c[2], this.parse[a] && (b = this.parse[a].apply(this, [c])), this.internalProjection && this.externalProjection)
+                if (b &&
+                    "OpenLayers.Feature.Vector" == b.CLASS_NAME) b.geometry.transform(this.externalProjection, this.internalProjection);
+                else if (b && "geometrycollection" != a && "object" == typeof b) {
+            a = 0;
+            for (c = b.length; a < c; a++) b[a].geometry.transform(this.externalProjection, this.internalProjection)
+        }
+        return b
+    },
+    write: function(a) {
+        var b, c;
+        a.constructor == Array ? c = !0 : (a = [a], c = !1);
+        var d = [];
+        c && d.push("GEOMETRYCOLLECTION(");
+        for (var e = 0, f = a.length; e < f; ++e) c && 0 < e && d.push(","), b = a[e].geometry, d.push(this.extractGeometry(b));
+        c && d.push(")");
+        return d.join("")
+    },
+    extractGeometry: function(a) {
+        var b = a.CLASS_NAME.split(".")[2].toLowerCase();
+        if (!this.extract[b]) return null;
+        this.internalProjection && this.externalProjection && (a = a.clone(), a.transform(this.internalProjection, this.externalProjection));
+        return ("collection" == b ? "GEOMETRYCOLLECTION" : b.toUpperCase()) + "(" + this.extract[b].apply(this, [a]) + ")"
+    },
+    extract: {
+        point: function(a) {
+            return a.x + " " + a.y
+        },
+        multipoint: function(a) {
+            for (var b = [], c = 0, d = a.components.length; c < d; ++c) b.push("(" + this.extract.point.apply(this, [a.components[c]]) +
+                ")");
+            return b.join(",")
+        },
+        linestring: function(a) {
+            for (var b = [], c = 0, d = a.components.length; c < d; ++c) b.push(this.extract.point.apply(this, [a.components[c]]));
+            return b.join(",")
+        },
+        multilinestring: function(a) {
+            for (var b = [], c = 0, d = a.components.length; c < d; ++c) b.push("(" + this.extract.linestring.apply(this, [a.components[c]]) + ")");
+            return b.join(",")
+        },
+        polygon: function(a) {
+            for (var b = [], c = 0, d = a.components.length; c < d; ++c) b.push("(" + this.extract.linestring.apply(this, [a.components[c]]) + ")");
+            return b.join(",")
+        },
+        multipolygon: function(a) {
+            for (var b = [], c = 0, d = a.components.length; c < d; ++c) b.push("(" + this.extract.polygon.apply(this, [a.components[c]]) + ")");
+            return b.join(",")
+        },
+        collection: function(a) {
+            for (var b = [], c = 0, d = a.components.length; c < d; ++c) b.push(this.extractGeometry.apply(this, [a.components[c]]));
+            return b.join(",")
+        }
+    },
+    parse: {
+        point: function(a) {
+            a = OpenLayers.String.trim(a).split(this.regExes.spaces);
+            return new OpenLayers.Feature.Vector(new OpenLayers.Geometry.Point(a[0], a[1]))
+        },
+        multipoint: function(a) {
+            for (var b = OpenLayers.String.trim(a).split(","),
+                    c = [], d = 0, e = b.length; d < e; ++d) a = b[d].replace(this.regExes.trimParens, "$1"), c.push(this.parse.point.apply(this, [a]).geometry);
+            return new OpenLayers.Feature.Vector(new OpenLayers.Geometry.MultiPoint(c))
+        },
+        linestring: function(a) {
+            for (var a = OpenLayers.String.trim(a).split(","), b = [], c = 0, d = a.length; c < d; ++c) b.push(this.parse.point.apply(this, [a[c]]).geometry);
+            return new OpenLayers.Feature.Vector(new OpenLayers.Geometry.LineString(b))
+        },
+        multilinestring: function(a) {
+            for (var b = OpenLayers.String.trim(a).split(this.regExes.parenComma),
+                    c = [], d = 0, e = b.length; d < e; ++d) a = b[d].replace(this.regExes.trimParens, "$1"), c.push(this.parse.linestring.apply(this, [a]).geometry);
+            return new OpenLayers.Feature.Vector(new OpenLayers.Geometry.MultiLineString(c))
+        },
+        polygon: function(a) {
+            for (var b, a = OpenLayers.String.trim(a).split(this.regExes.parenComma), c = [], d = 0, e = a.length; d < e; ++d) b = a[d].replace(this.regExes.trimParens, "$1"), b = this.parse.linestring.apply(this, [b]).geometry, b = new OpenLayers.Geometry.LinearRing(b.components), c.push(b);
+            return new OpenLayers.Feature.Vector(new OpenLayers.Geometry.Polygon(c))
+        },
+        multipolygon: function(a) {
+            for (var b = OpenLayers.String.trim(a).split(this.regExes.doubleParenComma), c = [], d = 0, e = b.length; d < e; ++d) a = b[d].replace(this.regExes.trimParens, "$1"), c.push(this.parse.polygon.apply(this, [a]).geometry);
+            return new OpenLayers.Feature.Vector(new OpenLayers.Geometry.MultiPolygon(c))
+        },
+        geometrycollection: function(a) {
+            for (var a = a.replace(/,\s*([A-Za-z])/g, "|$1"), a = OpenLayers.String.trim(a).split("|"), b = [], c = 0, d = a.length; c < d; ++c) b.push(OpenLayers.Format.WKT.prototype.read.apply(this, [a[c]]));
+            return b
+        }
+    },
+    CLASS_NAME: "OpenLayers.Format.WKT"
+});
+OpenLayers.Handler.Hover = OpenLayers.Class(OpenLayers.Handler, {
+    delay: 500,
+    pixelTolerance: null,
+    stopMove: !1,
+    px: null,
+    timerId: null,
+    mousemove: function(a) {
+        this.passesTolerance(a.xy) && (this.clearTimer(), this.callback("move", [a]), this.px = a.xy, a = OpenLayers.Util.extend({}, a), this.timerId = window.setTimeout(OpenLayers.Function.bind(this.delayedCall, this, a), this.delay));
+        return !this.stopMove
+    },
+    mouseout: function(a) {
+        OpenLayers.Util.mouseLeft(a, this.map.viewPortDiv) && (this.clearTimer(), this.callback("move", [a]));
+        return !0
+    },
+    passesTolerance: function(a) {
+        var b = !0;
+        this.pixelTolerance && this.px && Math.sqrt(Math.pow(this.px.x - a.x, 2) + Math.pow(this.px.y - a.y, 2)) < this.pixelTolerance && (b = !1);
+        return b
+    },
+    clearTimer: function() {
+        null != this.timerId && (window.clearTimeout(this.timerId), this.timerId = null)
+    },
+    delayedCall: function(a) {
+        this.callback("pause", [a])
+    },
+    deactivate: function() {
+        var a = !1;
+        OpenLayers.Handler.prototype.deactivate.apply(this, arguments) && (this.clearTimer(), a = !0);
+        return a
+    },
+    CLASS_NAME: "OpenLayers.Handler.Hover"
+});
+OpenLayers.Control.GetFeature = OpenLayers.Class(OpenLayers.Control, {
+    protocol: null,
+    multipleKey: null,
+    toggleKey: null,
+    modifiers: null,
+    multiple: !1,
+    click: !0,
+    single: !0,
+    clickout: !0,
+    toggle: !1,
+    clickTolerance: 5,
+    hover: !1,
+    box: !1,
+    maxFeatures: 10,
+    features: null,
+    hoverFeature: null,
+    handlerOptions: null,
+    handlers: null,
+    hoverResponse: null,
+    filterType: OpenLayers.Filter.Spatial.BBOX,
+    initialize: function(a) {
+        a.handlerOptions = a.handlerOptions || {};
+        OpenLayers.Control.prototype.initialize.apply(this, [a]);
+        this.features = {};
+        this.handlers = {};
+        this.click && (this.handlers.click = new OpenLayers.Handler.Click(this, {
+            click: this.selectClick
+        }, this.handlerOptions.click || {}));
+        this.box && (this.handlers.box = new OpenLayers.Handler.Box(this, {
+            done: this.selectBox
+        }, OpenLayers.Util.extend(this.handlerOptions.box, {
+            boxDivClassName: "olHandlerBoxSelectFeature"
+        })));
+        this.hover && (this.handlers.hover = new OpenLayers.Handler.Hover(this, {
+            move: this.cancelHover,
+            pause: this.selectHover
+        }, OpenLayers.Util.extend(this.handlerOptions.hover, {
+            delay: 250,
+            pixelTolerance: 2
+        })))
+    },
+    activate: function() {
+        if (!this.active)
+            for (var a in this.handlers) this.handlers[a].activate();
+        return OpenLayers.Control.prototype.activate.apply(this, arguments)
+    },
+    deactivate: function() {
+        if (this.active)
+            for (var a in this.handlers) this.handlers[a].deactivate();
+        return OpenLayers.Control.prototype.deactivate.apply(this, arguments)
+    },
+    selectClick: function(a) {
+        var b = this.pixelToBounds(a.xy);
+        this.setModifiers(a);
+        this.request(b, {
+            single: this.single
+        })
+    },
+    selectBox: function(a) {
+        var b;
+        if (a instanceof OpenLayers.Bounds) b =
+            this.map.getLonLatFromPixel({
+                x: a.left,
+                y: a.bottom
+            }), a = this.map.getLonLatFromPixel({
+                x: a.right,
+                y: a.top
+            }), b = new OpenLayers.Bounds(b.lon, b.lat, a.lon, a.lat);
+        else {
+            if (this.click) return;
+            b = this.pixelToBounds(a)
+        }
+        this.setModifiers(this.handlers.box.dragHandler.evt);
+        this.request(b)
+    },
+    selectHover: function(a) {
+        this.request(this.pixelToBounds(a.xy), {
+            single: !0,
+            hover: !0
+        })
+    },
+    cancelHover: function() {
+        this.hoverResponse && (this.protocol.abort(this.hoverResponse), this.hoverResponse = null, OpenLayers.Element.removeClass(this.map.viewPortDiv,
+            "olCursorWait"))
+    },
+    request: function(a, b) {
+        var b = b || {},
+            c = new OpenLayers.Filter.Spatial({
+                type: this.filterType,
+                value: a
+            });
+        OpenLayers.Element.addClass(this.map.viewPortDiv, "olCursorWait");
+        c = this.protocol.read({
+            maxFeatures: !0 == b.single ? this.maxFeatures : void 0,
+            filter: c,
+            callback: function(c) {
+                c.success() && (c.features.length ? !0 == b.single ? this.selectBestFeature(c.features, a.getCenterLonLat(), b) : this.select(c.features) : b.hover ? this.hoverSelect() : (this.events.triggerEvent("clickout"), this.clickout && this.unselectAll()));
+                OpenLayers.Element.removeClass(this.map.viewPortDiv, "olCursorWait")
+            },
+            scope: this
+        });
+        !0 == b.hover && (this.hoverResponse = c)
+    },
+    selectBestFeature: function(a, b, c) {
+        c = c || {};
+        if (a.length) {
+            for (var b = new OpenLayers.Geometry.Point(b.lon, b.lat), d, e, f, g = Number.MAX_VALUE, h = 0; h < a.length && !(d = a[h], d.geometry && (f = b.distanceTo(d.geometry, {
+                    edge: !1
+                }), f < g && (g = f, e = d, 0 == g))); ++h);
+            !0 == c.hover ? this.hoverSelect(e) : this.select(e || a)
+        }
+    },
+    setModifiers: function(a) {
+        this.modifiers = {
+            multiple: this.multiple || this.multipleKey && a[this.multipleKey],
+            toggle: this.toggle || this.toggleKey && a[this.toggleKey]
+        }
+    },
+    select: function(a) {
+        !this.modifiers.multiple && !this.modifiers.toggle && this.unselectAll();
+        OpenLayers.Util.isArray(a) || (a = [a]);
+        var b = this.events.triggerEvent("beforefeaturesselected", {
+            features: a
+        });
+        if (!1 !== b) {
+            for (var c = [], d, e = 0, f = a.length; e < f; ++e) d = a[e], this.features[d.fid || d.id] ? this.modifiers.toggle && this.unselect(this.features[d.fid || d.id]) : (b = this.events.triggerEvent("beforefeatureselected", {
+                feature: d
+            }), !1 !== b && (this.features[d.fid || d.id] = d,
+                c.push(d), this.events.triggerEvent("featureselected", {
+                    feature: d
+                })));
+            this.events.triggerEvent("featuresselected", {
+                features: c
+            })
+        }
+    },
+    hoverSelect: function(a) {
+        var b = a ? a.fid || a.id : null,
+            c = this.hoverFeature ? this.hoverFeature.fid || this.hoverFeature.id : null;
+        c && c != b && (this.events.triggerEvent("outfeature", {
+            feature: this.hoverFeature
+        }), this.hoverFeature = null);
+        b && b != c && (this.events.triggerEvent("hoverfeature", {
+            feature: a
+        }), this.hoverFeature = a)
+    },
+    unselect: function(a) {
+        delete this.features[a.fid || a.id];
+        this.events.triggerEvent("featureunselected", {
+            feature: a
+        })
+    },
+    unselectAll: function() {
+        for (var a in this.features) this.unselect(this.features[a])
+    },
+    setMap: function(a) {
+        for (var b in this.handlers) this.handlers[b].setMap(a);
+        OpenLayers.Control.prototype.setMap.apply(this, arguments)
+    },
+    pixelToBounds: function(a) {
+        var b = a.add(-this.clickTolerance / 2, this.clickTolerance / 2),
+            a = a.add(this.clickTolerance / 2, -this.clickTolerance / 2),
+            b = this.map.getLonLatFromPixel(b),
+            a = this.map.getLonLatFromPixel(a);
+        return new OpenLayers.Bounds(b.lon, b.lat, a.lon, a.lat)
+    },
+    CLASS_NAME: "OpenLayers.Control.GetFeature"
+});
+OpenLayers.Format.QueryStringFilter = function() {
+    function a(a) {
+        a = a.replace(/%/g, "\\%");
+        a = a.replace(/\\\\\.(\*)?/g, function(a, b) {
+            return b ? a : "\\\\_"
+        });
+        a = a.replace(/\\\\\.\*/g, "\\\\%");
+        a = a.replace(/(\\)?\.(\*)?/g, function(a, b, c) {
+            return b || c ? a : "_"
+        });
+        a = a.replace(/(\\)?\.\*/g, function(a, b) {
+            return b ? a : "%"
+        });
+        a = a.replace(/\\\./g, ".");
+        return a = a.replace(/(\\)?\\\*/g, function(a, b) {
+            return b ? a : "*"
+        })
+    }
+    var b = {};
+    b[OpenLayers.Filter.Comparison.EQUAL_TO] = "eq";
+    b[OpenLayers.Filter.Comparison.NOT_EQUAL_TO] = "ne";
+    b[OpenLayers.Filter.Comparison.LESS_THAN] =
+        "lt";
+    b[OpenLayers.Filter.Comparison.LESS_THAN_OR_EQUAL_TO] = "lte";
+    b[OpenLayers.Filter.Comparison.GREATER_THAN] = "gt";
+    b[OpenLayers.Filter.Comparison.GREATER_THAN_OR_EQUAL_TO] = "gte";
+    b[OpenLayers.Filter.Comparison.LIKE] = "ilike";
+    return OpenLayers.Class(OpenLayers.Format, {
+        wildcarded: !1,
+        srsInBBOX: !1,
+        write: function(c, d) {
+            var d = d || {},
+                e = c.CLASS_NAME,
+                e = e.substring(e.lastIndexOf(".") + 1);
+            switch (e) {
+                case "Spatial":
+                    switch (c.type) {
+                        case OpenLayers.Filter.Spatial.BBOX:
+                            d.bbox = c.value.toArray();
+                            this.srsInBBOX && c.projection &&
+                                d.bbox.push(c.projection.getCode());
+                            break;
+                        case OpenLayers.Filter.Spatial.DWITHIN:
+                            d.tolerance = c.distance;
+                        case OpenLayers.Filter.Spatial.WITHIN:
+                            d.lon = c.value.x;
+                            d.lat = c.value.y;
+                            break;
+                        default:
+                            OpenLayers.Console.warn("Unknown spatial filter type " + c.type)
+                    }
+                    break;
+                case "Comparison":
+                    e = b[c.type];
+                    if (void 0 !== e) {
+                        var f = c.value;
+                        c.type == OpenLayers.Filter.Comparison.LIKE && (f = a(f), this.wildcarded && (f = "%" + f + "%"));
+                        d[c.property + "__" + e] = f;
+                        d.queryable = d.queryable || [];
+                        d.queryable.push(c.property)
+                    } else OpenLayers.Console.warn("Unknown comparison filter type " +
+                        c.type);
+                    break;
+                case "Logical":
+                    if (c.type === OpenLayers.Filter.Logical.AND) {
+                        e = 0;
+                        for (f = c.filters.length; e < f; e++) d = this.write(c.filters[e], d)
+                    } else OpenLayers.Console.warn("Unsupported logical filter type " + c.type);
+                    break;
+                default:
+                    OpenLayers.Console.warn("Unknown filter type " + e)
+            }
+            return d
+        },
+        CLASS_NAME: "OpenLayers.Format.QueryStringFilter"
+    })
+}();
+OpenLayers.Control.MousePosition = OpenLayers.Class(OpenLayers.Control, {
+    autoActivate: !true,
+    element: null,
+    prefix: "",
+    separator: ", ",
+    suffix: "",
+    numDigits: 5,
+    granularity: 10,
+    emptyString: "",
+    lastXy: null,
+    displayProjection: null,
+    destroy: function() {
+        this.deactivate();
+        OpenLayers.Control.prototype.destroy.apply(this, arguments)
+    },
+    activate: function() {
+        return OpenLayers.Control.prototype.activate.apply(this, arguments) ? (this.map.events.register("mousemove", this, this.redraw), this.map.events.register("mouseout", this, this.reset),
+            this.redraw(), !0) : !1
+    },
+    deactivate: function() {
+        return OpenLayers.Control.prototype.deactivate.apply(this, arguments) ? (this.map.events.unregister("mousemove", this, this.redraw), this.map.events.unregister("mouseout", this, this.reset), this.element.innerHTML = "", !0) : !1
+    },
+    draw: function() {
+        OpenLayers.Control.prototype.draw.apply(this, arguments);
+        this.element || (this.div.left = "", this.div.top = "", this.element = this.div);
+        return this.div
+    },
+    redraw: function(a) {
+        var b;
+        if (null == a) this.reset();
+        else if (null == this.lastXy || Math.abs(a.xy.x -
+                this.lastXy.x) > this.granularity || Math.abs(a.xy.y - this.lastXy.y) > this.granularity) this.lastXy = a.xy;
+        else if (b = this.map.getLonLatFromPixel(a.xy)) 
+        	this.displayProjection && b.transform(this.map.getProjectionObject(), this.displayProjection), this.lastXy = a.xy, a = this.formatOutput(b), a != this.element.innerHTML && (this.element.innerHTML = a)
+    },
+    reset: function() {
+        null != this.emptyString && (this.element.innerHTML = this.emptyString)
+    },
+    formatOutput: function(a) {
+        var b = parseInt(this.numDigits);
+        return this.prefix + a.lon.toFixed(b) +
+            this.separator + a.lat.toFixed(b) + this.suffix
+    },
+    CLASS_NAME: "OpenLayers.Control.MousePosition"
+});
+OpenLayers.Control.Geolocate = OpenLayers.Class(OpenLayers.Control, {
+    geolocation: navigator.geolocation,
+    bind: !0,
+    watch: !1,
+    geolocationOptions: null,
+    destroy: function() {
+        this.deactivate();
+        OpenLayers.Control.prototype.destroy.apply(this, arguments)
+    },
+    activate: function() {
+        return !this.geolocation ? (this.events.triggerEvent("locationuncapable"), !1) : OpenLayers.Control.prototype.activate.apply(this, arguments) ? (this.watch ? this.watchId = this.geolocation.watchPosition(OpenLayers.Function.bind(this.geolocate, this), OpenLayers.Function.bind(this.failure,
+            this), this.geolocationOptions) : this.getCurrentLocation(), !0) : !1
+    },
+    deactivate: function() {
+        this.active && null !== this.watchId && this.geolocation.clearWatch(this.watchId);
+        return OpenLayers.Control.prototype.deactivate.apply(this, arguments)
+    },
+    geolocate: function(a) {
+        var b = (new OpenLayers.LonLat(a.coords.longitude, a.coords.latitude)).transform(new OpenLayers.Projection("EPSG:4326"), this.map.getProjectionObject());
+        this.bind && this.map.setCenter(b);
+        this.events.triggerEvent("locationupdated", {
+            position: a,
+            point: new OpenLayers.Geometry.Point(b.lon,
+                b.lat)
+        })
+    },
+    getCurrentLocation: function() {
+        if (!this.active || this.watch) return !1;
+        this.geolocation.getCurrentPosition(OpenLayers.Function.bind(this.geolocate, this), OpenLayers.Function.bind(this.failure, this), this.geolocationOptions);
+        return !0
+    },
+    failure: function(a) {
+        this.events.triggerEvent("locationfailed", {
+            error: a
+        })
+    },
+    CLASS_NAME: "OpenLayers.Control.Geolocate"
+});
+OpenLayers.Tile.UTFGrid = OpenLayers.Class(OpenLayers.Tile, {
+    url: null,
+    utfgridResolution: 2,
+    json: null,
+    format: null,
+    destroy: function() {
+        this.clear();
+        OpenLayers.Tile.prototype.destroy.apply(this, arguments)
+    },
+    draw: function() {
+        var a = OpenLayers.Tile.prototype.draw.apply(this, arguments);
+        if (a)
+            if (this.isLoading ? (this.abortLoading(), this.events.triggerEvent("reload")) : (this.isLoading = !0, this.events.triggerEvent("loadstart")), this.url = this.layer.getURL(this.bounds), this.layer.useJSONP) {
+                var b = new OpenLayers.Protocol.Script({
+                    url: this.url,
+                    callback: function(a) {
+                        this.isLoading = false;
+                        this.events.triggerEvent("loadend");
+                        this.json = a.data
+                    },
+                    scope: this
+                });
+                b.read();
+                this.request = b
+            } else this.request = OpenLayers.Request.GET({
+                url: this.url,
+                callback: function(a) {
+                    this.isLoading = false;
+                    this.events.triggerEvent("loadend");
+                    a.status === 200 && this.parseData(a.responseText)
+                },
+                scope: this
+            });
+        else this.unload();
+        return a
+    },
+    abortLoading: function() {
+        this.request && (this.request.abort(), delete this.request);
+        this.isLoading = !1
+    },
+    getFeatureInfo: function(a, b) {
+        var c = null;
+        if (this.json) {
+            var d =
+                this.getFeatureId(a, b);
+            null !== d && (c = {
+                id: d,
+                data: this.json.data[d]
+            })
+        }
+        return c
+    },
+    getFeatureId: function(a, b) {
+        var c = null;
+        if (this.json) {
+            var d = this.utfgridResolution,
+                d = this.indexFromCharCode(this.json.grid[Math.floor(b / d)].charCodeAt(Math.floor(a / d))),
+                e = this.json.keys;
+            !isNaN(d) && d in e && (c = e[d])
+        }
+        return c
+    },
+    indexFromCharCode: function(a) {
+        93 <= a && a--;
+        35 <= a && a--;
+        return a - 32
+    },
+    parseData: function(a) {
+        this.format || (this.format = new OpenLayers.Format.JSON);
+        this.json = this.format.read(a)
+    },
+    clear: function() {
+        this.json = null
+    },
+    CLASS_NAME: "OpenLayers.Tile.UTFGrid"
+});
+OpenLayers.Control.NavigationHistory = OpenLayers.Class(OpenLayers.Control, {
+    type: OpenLayers.Control.TYPE_TOGGLE,
+    previous: null,
+    previousOptions: null,
+    next: null,
+    nextOptions: null,
+    limit: 50,
+    autoActivate: !0,
+    clearOnDeactivate: !1,
+    registry: null,
+    nextStack: null,
+    previousStack: null,
+    listeners: null,
+    restoring: !1,
+    initialize: function(a) {
+        OpenLayers.Control.prototype.initialize.apply(this, [a]);
+        this.registry = OpenLayers.Util.extend({
+            moveend: this.getState
+        }, this.registry);
+        a = {
+            trigger: OpenLayers.Function.bind(this.previousTrigger,
+                this),
+            displayClass: this.displayClass + " " + this.displayClass + "Previous"
+        };
+        OpenLayers.Util.extend(a, this.previousOptions);
+        this.previous = new OpenLayers.Control.Button(a);
+        a = {
+            trigger: OpenLayers.Function.bind(this.nextTrigger, this),
+            displayClass: this.displayClass + " " + this.displayClass + "Next"
+        };
+        OpenLayers.Util.extend(a, this.nextOptions);
+        this.next = new OpenLayers.Control.Button(a);
+        this.clear()
+    },
+    onPreviousChange: function(a) {
+        a && !this.previous.active ? this.previous.activate() : !a && this.previous.active && this.previous.deactivate()
+    },
+    onNextChange: function(a) {
+        a && !this.next.active ? this.next.activate() : !a && this.next.active && this.next.deactivate()
+    },
+    destroy: function() {
+        OpenLayers.Control.prototype.destroy.apply(this);
+        this.previous.destroy();
+        this.next.destroy();
+        this.deactivate();
+        for (var a in this) this[a] = null
+    },
+    setMap: function(a) {
+        this.map = a;
+        this.next.setMap(a);
+        this.previous.setMap(a)
+    },
+    draw: function() {
+        OpenLayers.Control.prototype.draw.apply(this, arguments);
+        this.next.draw();
+        this.previous.draw()
+    },
+    previousTrigger: function() {
+        var a = this.previousStack.shift(),
+            b = this.previousStack.shift();
+        void 0 != b ? (this.nextStack.unshift(a), this.previousStack.unshift(b), this.restoring = !0, this.restore(b), this.restoring = !1, this.onNextChange(this.nextStack[0], this.nextStack.length), this.onPreviousChange(this.previousStack[1], this.previousStack.length - 1)) : this.previousStack.unshift(a);
+        return b
+    },
+    nextTrigger: function() {
+        var a = this.nextStack.shift();
+        void 0 != a && (this.previousStack.unshift(a), this.restoring = !0, this.restore(a), this.restoring = !1, this.onNextChange(this.nextStack[0],
+            this.nextStack.length), this.onPreviousChange(this.previousStack[1], this.previousStack.length - 1));
+        return a
+    },
+    clear: function() {
+        this.previousStack = [];
+        this.previous.deactivate();
+        this.nextStack = [];
+        this.next.deactivate()
+    },
+    getState: function() {
+        return {
+            center: this.map.getCenter(),
+            resolution: this.map.getResolution(),
+            projection: this.map.getProjectionObject(),
+            units: this.map.getProjectionObject().getUnits() || this.map.units || this.map.baseLayer.units
+        }
+    },
+    restore: function(a) {
+        var b, c;
+        if (this.map.getProjectionObject() ==
+            a.projection) c = this.map.getZoomForResolution(a.resolution), b = a.center;
+        else {
+            b = a.center.clone();
+            b.transform(a.projection, this.map.getProjectionObject());
+            c = a.units;
+            var d = this.map.getProjectionObject().getUnits() || this.map.units || this.map.baseLayer.units;
+            c = this.map.getZoomForResolution((c && d ? OpenLayers.INCHES_PER_UNIT[c] / OpenLayers.INCHES_PER_UNIT[d] : 1) * a.resolution)
+        }
+        this.map.setCenter(b, c)
+    },
+    setListeners: function() {
+        this.listeners = {};
+        for (var a in this.registry) this.listeners[a] = OpenLayers.Function.bind(function() {
+            if (!this.restoring) {
+                this.previousStack.unshift(this.registry[a].apply(this,
+                    arguments));
+                if (1 < this.previousStack.length) this.onPreviousChange(this.previousStack[1], this.previousStack.length - 1);
+                this.previousStack.length > this.limit + 1 && this.previousStack.pop();
+                0 < this.nextStack.length && (this.nextStack = [], this.onNextChange(null, 0))
+            }
+            return !0
+        }, this)
+    },
+    activate: function() {
+        var a = !1;
+        if (this.map && OpenLayers.Control.prototype.activate.apply(this)) {
+            null == this.listeners && this.setListeners();
+            for (var b in this.listeners) this.map.events.register(b, this, this.listeners[b]);
+            a = !0;
+            0 == this.previousStack.length &&
+                this.initStack()
+        }
+        return a
+    },
+    initStack: function() {
+        this.map.getCenter() && this.listeners.moveend()
+    },
+    deactivate: function() {
+        var a = !1;
+        if (this.map && OpenLayers.Control.prototype.deactivate.apply(this)) {
+            for (var b in this.listeners) this.map.events.unregister(b, this, this.listeners[b]);
+            this.clearOnDeactivate && this.clear();
+            a = !0
+        }
+        return a
+    },
+    CLASS_NAME: "OpenLayers.Control.NavigationHistory"
+});
+OpenLayers.Protocol.HTTP = OpenLayers.Class(OpenLayers.Protocol, {
+    url: null,
+    headers: null,
+    params: null,
+    callback: null,
+    scope: null,
+    readWithPOST: !1,
+    updateWithPOST: !1,
+    deleteWithPOST: !1,
+    wildcarded: !1,
+    srsInBBOX: !1,
+    initialize: function(a) {
+        a = a || {};
+        this.params = {};
+        this.headers = {};
+        OpenLayers.Protocol.prototype.initialize.apply(this, arguments);
+        if (!this.filterToParams && OpenLayers.Format.QueryStringFilter) {
+            var b = new OpenLayers.Format.QueryStringFilter({
+                wildcarded: this.wildcarded,
+                srsInBBOX: this.srsInBBOX
+            });
+            this.filterToParams =
+                function(a, d) {
+                    return b.write(a, d)
+                }
+        }
+    },
+    destroy: function() {
+        this.headers = this.params = null;
+        OpenLayers.Protocol.prototype.destroy.apply(this)
+    },
+    read: function(a) {
+        OpenLayers.Protocol.prototype.read.apply(this, arguments);
+        a = a || {};
+        a.params = OpenLayers.Util.applyDefaults(a.params, this.options.params);
+        a = OpenLayers.Util.applyDefaults(a, this.options);
+        a.filter && this.filterToParams && (a.params = this.filterToParams(a.filter, a.params));
+        var b = void 0 !== a.readWithPOST ? a.readWithPOST : this.readWithPOST,
+            c = new OpenLayers.Protocol.Response({
+                requestType: "read"
+            });
+        b ? (b = a.headers || {}, b["Content-Type"] = "application/x-www-form-urlencoded", c.priv = OpenLayers.Request.POST({
+            url: a.url,
+            callback: this.createCallback(this.handleRead, c, a),
+            data: OpenLayers.Util.getParameterString(a.params),
+            headers: b
+        })) : c.priv = OpenLayers.Request.GET({
+            url: a.url,
+            callback: this.createCallback(this.handleRead, c, a),
+            params: a.params,
+            headers: a.headers
+        });
+        return c
+    },
+    handleRead: function(a, b) {
+        this.handleResponse(a, b)
+    },
+    create: function(a, b) {
+        var b = OpenLayers.Util.applyDefaults(b, this.options),
+            c = new OpenLayers.Protocol.Response({
+                reqFeatures: a,
+                requestType: "create"
+            });
+        c.priv = OpenLayers.Request.POST({
+            url: b.url,
+            callback: this.createCallback(this.handleCreate, c, b),
+            headers: b.headers,
+            data: this.format.write(a)
+        });
+        return c
+    },
+    handleCreate: function(a, b) {
+        this.handleResponse(a, b)
+    },
+    update: function(a, b) {
+        var b = b || {},
+            c = b.url || a.url || this.options.url + "/" + a.fid,
+            b = OpenLayers.Util.applyDefaults(b, this.options),
+            d = new OpenLayers.Protocol.Response({
+                reqFeatures: a,
+                requestType: "update"
+            });
+        d.priv = OpenLayers.Request[this.updateWithPOST ? "POST" : "PUT"]({
+            url: c,
+            callback: this.createCallback(this.handleUpdate,
+                d, b),
+            headers: b.headers,
+            data: this.format.write(a)
+        });
+        return d
+    },
+    handleUpdate: function(a, b) {
+        this.handleResponse(a, b)
+    },
+    "delete": function(a, b) {
+        var b = b || {},
+            c = b.url || a.url || this.options.url + "/" + a.fid,
+            b = OpenLayers.Util.applyDefaults(b, this.options),
+            d = new OpenLayers.Protocol.Response({
+                reqFeatures: a,
+                requestType: "delete"
+            }),
+            e = this.deleteWithPOST ? "POST" : "DELETE",
+            c = {
+                url: c,
+                callback: this.createCallback(this.handleDelete, d, b),
+                headers: b.headers
+            };
+        this.deleteWithPOST && (c.data = this.format.write(a));
+        d.priv = OpenLayers.Request[e](c);
+        return d
+    },
+    handleDelete: function(a, b) {
+        this.handleResponse(a, b)
+    },
+    handleResponse: function(a, b) {
+        var c = a.priv;
+        b.callback && (200 <= c.status && 300 > c.status ? ("delete" != a.requestType && (a.features = this.parseFeatures(c)), a.code = OpenLayers.Protocol.Response.SUCCESS) : a.code = OpenLayers.Protocol.Response.FAILURE, b.callback.call(b.scope, a))
+    },
+    parseFeatures: function(a) {
+        var b = a.responseXML;
+        if (!b || !b.documentElement) b = a.responseText;
+        return !b || 0 >= b.length ? null : this.format.read(b)
+    },
+    commit: function(a, b) {
+        function c(a) {
+            for (var b =
+                    a.features ? a.features.length : 0, c = Array(b), e = 0; e < b; ++e) c[e] = a.features[e].fid;
+            o.insertIds = c;
+            d.apply(this, [a])
+        }
+
+        function d(a) {
+            this.callUserCallback(a, b);
+            n = n && a.success();
+            f++;
+            f >= m && b.callback && (o.code = n ? OpenLayers.Protocol.Response.SUCCESS : OpenLayers.Protocol.Response.FAILURE, b.callback.apply(b.scope, [o]))
+        }
+        var b = OpenLayers.Util.applyDefaults(b, this.options),
+            e = [],
+            f = 0,
+            g = {};
+        g[OpenLayers.State.INSERT] = [];
+        g[OpenLayers.State.UPDATE] = [];
+        g[OpenLayers.State.DELETE] = [];
+        for (var h, i, j = [], k = 0, l = a.length; k < l; ++k)
+            if (h =
+                a[k], i = g[h.state]) i.push(h), j.push(h);
+        var m = (0 < g[OpenLayers.State.INSERT].length ? 1 : 0) + g[OpenLayers.State.UPDATE].length + g[OpenLayers.State.DELETE].length,
+            n = !0,
+            o = new OpenLayers.Protocol.Response({
+                reqFeatures: j
+            });
+        h = g[OpenLayers.State.INSERT];
+        0 < h.length && e.push(this.create(h, OpenLayers.Util.applyDefaults({
+            callback: c,
+            scope: this
+        }, b.create)));
+        h = g[OpenLayers.State.UPDATE];
+        for (k = h.length - 1; 0 <= k; --k) e.push(this.update(h[k], OpenLayers.Util.applyDefaults({
+            callback: d,
+            scope: this
+        }, b.update)));
+        h = g[OpenLayers.State.DELETE];
+        for (k = h.length - 1; 0 <= k; --k) e.push(this["delete"](h[k], OpenLayers.Util.applyDefaults({
+            callback: d,
+            scope: this
+        }, b["delete"])));
+        return e
+    },
+    abort: function(a) {
+        a && a.priv.abort()
+    },
+    callUserCallback: function(a, b) {
+        var c = b[a.requestType];
+        c && c.callback && c.callback.call(c.scope, a)
+    },
+    CLASS_NAME: "OpenLayers.Protocol.HTTP"
+});
+OpenLayers.Strategy.Cluster = OpenLayers.Class(OpenLayers.Strategy, {
+    distance: 20,
+    threshold: null,
+    features: null,
+    clusters: null,
+    clustering: !1,
+    resolution: null,
+    activate: function() {
+        var a = OpenLayers.Strategy.prototype.activate.call(this);
+        if (a) this.layer.events.on({
+            beforefeaturesadded: this.cacheFeatures,
+            moveend: this.cluster,
+            scope: this
+        });
+        return a
+    },
+    deactivate: function() {
+        var a = OpenLayers.Strategy.prototype.deactivate.call(this);
+        a && (this.clearCache(), this.layer.events.un({
+            beforefeaturesadded: this.cacheFeatures,
+            moveend: this.cluster,
+            scope: this
+        }));
+        return a
+    },
+    cacheFeatures: function(a) {
+        var b = !0;
+        this.clustering || (this.clearCache(), this.features = a.features, this.cluster(), b = !1);
+        return b
+    },
+    clearCache: function() {
+        this.features = null
+    },
+    cluster: function(a) {
+        if ((!a || a.zoomChanged) && this.features)
+            if (a = this.layer.map.getResolution(), a != this.resolution || !this.clustersExist()) {
+                this.resolution = a;
+                for (var a = [], b, c, d, e = 0; e < this.features.length; ++e)
+                    if (b = this.features[e], b.geometry) {
+                        c = !1;
+                        for (var f = a.length - 1; 0 <= f; --f)
+                            if (d = a[f], this.shouldCluster(d, b)) {
+                                this.addToCluster(d,
+                                    b);
+                                c = !0;
+                                break
+                            }
+                        c || a.push(this.createCluster(this.features[e]))
+                    }
+                this.layer.removeAllFeatures();
+                if (0 < a.length) {
+                    if (1 < this.threshold) {
+                        b = a.slice();
+                        a = [];
+                        e = 0;
+                        for (d = b.length; e < d; ++e) c = b[e], c.attributes.count < this.threshold ? Array.prototype.push.apply(a, c.cluster) : a.push(c)
+                    }
+                    this.clustering = !0;
+                    this.layer.addFeatures(a);
+                    this.clustering = !1
+                }
+                this.clusters = a
+            }
+    },
+    clustersExist: function() {
+        var a = !1;
+        if (this.clusters && 0 < this.clusters.length && this.clusters.length == this.layer.features.length)
+            for (var a = !0, b = 0; b < this.clusters.length; ++b)
+                if (this.clusters[b] !=
+                    this.layer.features[b]) {
+                    a = !1;
+                    break
+                }
+        return a
+    },
+    shouldCluster: function(a, b) {
+        var c = a.geometry.getBounds().getCenterLonLat(),
+            d = b.geometry.getBounds().getCenterLonLat();
+        return Math.sqrt(Math.pow(c.lon - d.lon, 2) + Math.pow(c.lat - d.lat, 2)) / this.resolution <= this.distance
+    },
+    addToCluster: function(a, b) {
+        a.cluster.push(b);
+        a.attributes.count += 1
+    },
+    createCluster: function(a) {
+        var b = a.geometry.getBounds().getCenterLonLat(),
+            b = new OpenLayers.Feature.Vector(new OpenLayers.Geometry.Point(b.lon, b.lat), {
+                count: 1
+            });
+        b.cluster = [a];
+        return b
+    },
+    CLASS_NAME: "OpenLayers.Strategy.Cluster"
+});
+OpenLayers.Strategy.Filter = OpenLayers.Class(OpenLayers.Strategy, {
+    filter: null,
+    cache: null,
+    caching: !1,
+    activate: function() {
+        var a = OpenLayers.Strategy.prototype.activate.apply(this, arguments);
+        a && (this.cache = [], this.layer.events.on({
+            beforefeaturesadded: this.handleAdd,
+            beforefeaturesremoved: this.handleRemove,
+            scope: this
+        }));
+        return a
+    },
+    deactivate: function() {
+        this.cache = null;
+        this.layer && this.layer.events && this.layer.events.un({
+            beforefeaturesadded: this.handleAdd,
+            beforefeaturesremoved: this.handleRemove,
+            scope: this
+        });
+        return OpenLayers.Strategy.prototype.deactivate.apply(this, arguments)
+    },
+    handleAdd: function(a) {
+        if (!this.caching && this.filter) {
+            var b = a.features;
+            a.features = [];
+            for (var c, d = 0, e = b.length; d < e; ++d) c = b[d], this.filter.evaluate(c) ? a.features.push(c) : this.cache.push(c)
+        }
+    },
+    handleRemove: function() {
+        this.caching || (this.cache = [])
+    },
+    setFilter: function(a) {
+        this.filter = a;
+        a = this.cache;
+        this.cache = [];
+        this.handleAdd({
+            features: this.layer.features
+        });
+        0 < this.cache.length && (this.caching = !0, this.layer.removeFeatures(this.cache.slice()),
+            this.caching = !1);
+        0 < a.length && (a = {
+            features: a
+        }, this.handleAdd(a), 0 < a.features.length && (this.caching = !0, this.layer.addFeatures(a.features), this.caching = !1))
+    },
+    CLASS_NAME: "OpenLayers.Strategy.Filter"
+});
+OpenLayers.Protocol.SOS = function(a) {
+    var a = OpenLayers.Util.applyDefaults(a, OpenLayers.Protocol.SOS.DEFAULTS),
+        b = OpenLayers.Protocol.SOS["v" + a.version.replace(/\./g, "_")];
+    if (!b) throw "Unsupported SOS version: " + a.version;
+    return new b(a)
+};
+OpenLayers.Protocol.SOS.DEFAULTS = {
+    version: "1.0.0"
+};
+OpenLayers.Format.WFSDescribeFeatureType = OpenLayers.Class(OpenLayers.Format.XML, {
+    namespaces: {
+        xsd: "http://www.w3.org/2001/XMLSchema"
+    },
+    readers: {
+        xsd: {
+            schema: function(a, b) {
+                var c = [],
+                    d = {};
+                this.readChildNodes(a, {
+                    complexTypes: c,
+                    customTypes: d
+                });
+                for (var e = a.attributes, f, g, h = 0, i = e.length; h < i; ++h) f = e[h], g = f.name, 0 == g.indexOf("xmlns") ? this.setNamespace(g.split(":")[1] || "", f.value) : b[g] = f.value;
+                b.featureTypes = c;
+                b.targetPrefix = this.namespaceAlias[b.targetNamespace];
+                h = 0;
+                for (i = c.length; h < i; ++h) e = c[h], f = d[e.typeName],
+                    d[e.typeName] && (e.typeName = f.name)
+            },
+            complexType: function(a, b) {
+                var c = {
+                    typeName: a.getAttribute("name")
+                };
+                this.readChildNodes(a, c);
+                b.complexTypes.push(c)
+            },
+            complexContent: function(a, b) {
+                this.readChildNodes(a, b)
+            },
+            extension: function(a, b) {
+                this.readChildNodes(a, b)
+            },
+            sequence: function(a, b) {
+                var c = {
+                    elements: []
+                };
+                this.readChildNodes(a, c);
+                b.properties = c.elements
+            },
+            element: function(a, b) {
+                if (b.elements) {
+                    for (var c = {}, d = a.attributes, e, f = 0, g = d.length; f < g; ++f) e = d[f], c[e.name] = e.value;
+                    d = c.type;
+                    d || (d = {}, this.readChildNodes(a,
+                        d), c.restriction = d, c.type = d.base);
+                    c.localType = (d.base || d).split(":").pop();
+                    b.elements.push(c)
+                }
+                b.complexTypes && (d = a.getAttribute("type"), c = d.split(":").pop(), b.customTypes[c] = {
+                    name: a.getAttribute("name"),
+                    type: d
+                })
+            },
+            simpleType: function(a, b) {
+                this.readChildNodes(a, b)
+            },
+            restriction: function(a, b) {
+                b.base = a.getAttribute("base");
+                this.readRestriction(a, b)
+            }
+        }
+    },
+    readRestriction: function(a, b) {
+        for (var c = a.childNodes, d, e, f = 0, g = c.length; f < g; ++f) d = c[f], 1 == d.nodeType && (e = d.nodeName.split(":").pop(), d = d.getAttribute("value"),
+            b[e] ? ("string" == typeof b[e] && (b[e] = [b[e]]), b[e].push(d)) : b[e] = d)
+    },
+    read: function(a) {
+        "string" == typeof a && (a = OpenLayers.Format.XML.prototype.read.apply(this, [a]));
+        a && 9 == a.nodeType && (a = a.documentElement);
+        var b = {};
+        this.readNode(a, b);
+        return b
+    },
+    CLASS_NAME: "OpenLayers.Format.WFSDescribeFeatureType"
+});
+OpenLayers.Format.GeoRSS = OpenLayers.Class(OpenLayers.Format.XML, {
+    rssns: "http://backend.userland.com/rss2",
+    featureNS: "http://mapserver.gis.umn.edu/mapserver",
+    georssns: "http://www.georss.org/georss",
+    geons: "http://www.w3.org/2003/01/geo/wgs84_pos#",
+    featureTitle: "Untitled",
+    featureDescription: "No Description",
+    gmlParser: null,
+    xy: !1,
+    createGeometryFromItem: function(a) {
+        var b = this.getElementsByTagNameNS(a, this.georssns, "point"),
+            c = this.getElementsByTagNameNS(a, this.geons, "lat"),
+            d = this.getElementsByTagNameNS(a,
+                this.geons, "long"),
+            e = this.getElementsByTagNameNS(a, this.georssns, "line"),
+            f = this.getElementsByTagNameNS(a, this.georssns, "polygon"),
+            g = this.getElementsByTagNameNS(a, this.georssns, "where"),
+            a = this.getElementsByTagNameNS(a, this.georssns, "box");
+        if (0 < b.length || 0 < c.length && 0 < d.length) {
+            0 < b.length ? (c = OpenLayers.String.trim(b[0].firstChild.nodeValue).split(/\s+/), 2 != c.length && (c = OpenLayers.String.trim(b[0].firstChild.nodeValue).split(/\s*,\s*/))) : c = [parseFloat(c[0].firstChild.nodeValue), parseFloat(d[0].firstChild.nodeValue)];
+            var h = new OpenLayers.Geometry.Point(c[1], c[0])
+        } else if (0 < e.length) {
+            c = OpenLayers.String.trim(this.getChildValue(e[0])).split(/\s+/);
+            d = [];
+            e = 0;
+            for (f = c.length; e < f; e += 2) b = new OpenLayers.Geometry.Point(c[e + 1], c[e]), d.push(b);
+            h = new OpenLayers.Geometry.LineString(d)
+        } else if (0 < f.length) {
+            c = OpenLayers.String.trim(this.getChildValue(f[0])).split(/\s+/);
+            d = [];
+            e = 0;
+            for (f = c.length; e < f; e += 2) b = new OpenLayers.Geometry.Point(c[e + 1], c[e]), d.push(b);
+            h = new OpenLayers.Geometry.Polygon([new OpenLayers.Geometry.LinearRing(d)])
+        } else 0 <
+            g.length ? (this.gmlParser || (this.gmlParser = new OpenLayers.Format.GML({
+                xy: this.xy
+            })), h = this.gmlParser.parseFeature(g[0]).geometry) : 0 < a.length && (c = OpenLayers.String.trim(a[0].firstChild.nodeValue).split(/\s+/), d = [], 3 < c.length && (b = new OpenLayers.Geometry.Point(c[1], c[0]), d.push(b), b = new OpenLayers.Geometry.Point(c[1], c[2]), d.push(b), b = new OpenLayers.Geometry.Point(c[3], c[2]), d.push(b), b = new OpenLayers.Geometry.Point(c[3], c[0]), d.push(b), b = new OpenLayers.Geometry.Point(c[1], c[0]), d.push(b)), h = new OpenLayers.Geometry.Polygon([new OpenLayers.Geometry.LinearRing(d)]));
+        h && (this.internalProjection && this.externalProjection) && h.transform(this.externalProjection, this.internalProjection);
+        return h
+    },
+    createFeatureFromItem: function(a) {
+        var b = this.createGeometryFromItem(a),
+            c = this._getChildValue(a, "*", "title", this.featureTitle),
+            d = this._getChildValue(a, "*", "description", this._getChildValue(a, "*", "content", this._getChildValue(a, "*", "summary", this.featureDescription))),
+            e = this._getChildValue(a, "*", "link");
+        if (!e) try {
+            e = this.getElementsByTagNameNS(a, "*", "link")[0].getAttribute("href")
+        } catch (f) {
+            e =
+                null
+        }
+        a = this._getChildValue(a, "*", "id", null);
+        b = new OpenLayers.Feature.Vector(b, {
+            title: c,
+            description: d,
+            link: e
+        });
+        b.fid = a;
+        return b
+    },
+    _getChildValue: function(a, b, c, d) {
+        return (a = this.getElementsByTagNameNS(a, b, c)) && a[0] && a[0].firstChild && a[0].firstChild.nodeValue ? this.getChildValue(a[0]) : void 0 == d ? "" : d
+    },
+    read: function(a) {
+        "string" == typeof a && (a = OpenLayers.Format.XML.prototype.read.apply(this, [a]));
+        var b = null,
+            b = this.getElementsByTagNameNS(a, "*", "item");
+        0 == b.length && (b = this.getElementsByTagNameNS(a, "*", "entry"));
+        for (var a = b.length, c = Array(a), d = 0; d < a; d++) c[d] = this.createFeatureFromItem(b[d]);
+        return c
+    },
+    write: function(a) {
+        var b;
+        if (OpenLayers.Util.isArray(a)) {
+            b = this.createElementNS(this.rssns, "rss");
+            for (var c = 0, d = a.length; c < d; c++) b.appendChild(this.createFeatureXML(a[c]))
+        } else b = this.createFeatureXML(a);
+        return OpenLayers.Format.XML.prototype.write.apply(this, [b])
+    },
+    createFeatureXML: function(a) {
+        var b = this.buildGeometryNode(a.geometry),
+            c = this.createElementNS(this.rssns, "item"),
+            d = this.createElementNS(this.rssns, "title");
+        d.appendChild(this.createTextNode(a.attributes.title ? a.attributes.title : ""));
+        var e = this.createElementNS(this.rssns, "description");
+        e.appendChild(this.createTextNode(a.attributes.description ? a.attributes.description : ""));
+        c.appendChild(d);
+        c.appendChild(e);
+        a.attributes.link && (d = this.createElementNS(this.rssns, "link"), d.appendChild(this.createTextNode(a.attributes.link)), c.appendChild(d));
+        for (var f in a.attributes) "link" == f || ("title" == f || "description" == f) || (d = this.createTextNode(a.attributes[f]), e = f, -1 !=
+            f.search(":") && (e = f.split(":")[1]), e = this.createElementNS(this.featureNS, "feature:" + e), e.appendChild(d), c.appendChild(e));
+        c.appendChild(b);
+        return c
+    },
+    buildGeometryNode: function(a) {
+        this.internalProjection && this.externalProjection && (a = a.clone(), a.transform(this.internalProjection, this.externalProjection));
+        var b;
+        if ("OpenLayers.Geometry.Polygon" == a.CLASS_NAME) b = this.createElementNS(this.georssns, "georss:polygon"), b.appendChild(this.buildCoordinatesNode(a.components[0]));
+        else if ("OpenLayers.Geometry.LineString" ==
+            a.CLASS_NAME) b = this.createElementNS(this.georssns, "georss:line"), b.appendChild(this.buildCoordinatesNode(a));
+        else if ("OpenLayers.Geometry.Point" == a.CLASS_NAME) b = this.createElementNS(this.georssns, "georss:point"), b.appendChild(this.buildCoordinatesNode(a));
+        else throw "Couldn't parse " + a.CLASS_NAME;
+        return b
+    },
+    buildCoordinatesNode: function(a) {
+        var b = null;
+        a.components && (b = a.components);
+        if (b) {
+            for (var a = b.length, c = Array(a), d = 0; d < a; d++) c[d] = b[d].y + " " + b[d].x;
+            b = c.join(" ")
+        } else b = a.y + " " + a.x;
+        return this.createTextNode(b)
+    },
+    CLASS_NAME: "OpenLayers.Format.GeoRSS"
+});
+OpenLayers.Format.WPSCapabilities = OpenLayers.Class(OpenLayers.Format.XML.VersionedOGC, {
+    defaultVersion: "1.0.0",
+    CLASS_NAME: "OpenLayers.Format.WPSCapabilities"
+});
+OpenLayers.Format.WPSCapabilities.v1_0_0 = OpenLayers.Class(OpenLayers.Format.XML, {
+    namespaces: {
+        ows: "http://www.opengis.net/ows/1.1",
+        wps: "http://www.opengis.net/wps/1.0.0",
+        xlink: "http://www.w3.org/1999/xlink"
+    },
+    regExes: {
+        trimSpace: /^\s*|\s*$/g,
+        removeSpace: /\s*/g,
+        splitSpace: /\s+/,
+        trimComma: /\s*,\s*/g
+    },
+    initialize: function(a) {
+        OpenLayers.Format.XML.prototype.initialize.apply(this, [a])
+    },
+    read: function(a) {
+        "string" == typeof a && (a = OpenLayers.Format.XML.prototype.read.apply(this, [a]));
+        a && 9 == a.nodeType && (a = a.documentElement);
+        var b = {};
+        this.readNode(a, b);
+        return b
+    },
+    readers: {
+        wps: {
+            Capabilities: function(a, b) {
+                this.readChildNodes(a, b)
+            },
+            ProcessOfferings: function(a, b) {
+                b.processOfferings = {};
+                this.readChildNodes(a, b.processOfferings)
+            },
+            Process: function(a, b) {
+                var c = {
+                    processVersion: this.getAttributeNS(a, this.namespaces.wps, "processVersion")
+                };
+                this.readChildNodes(a, c);
+                b[c.identifier] = c
+            },
+            Languages: function(a, b) {
+                b.languages = [];
+                this.readChildNodes(a, b.languages)
+            },
+            Default: function(a, b) {
+                var c = {
+                    isDefault: !0
+                };
+                this.readChildNodes(a, c);
+                b.push(c)
+            },
+            Supported: function(a, b) {
+                var c = {};
+                this.readChildNodes(a, c);
+                b.push(c)
+            }
+        },
+        ows: OpenLayers.Format.OWSCommon.v1_1_0.prototype.readers.ows
+    },
+    CLASS_NAME: "OpenLayers.Format.WPSCapabilities.v1_0_0"
+});
+OpenLayers.Control.PinchZoom = OpenLayers.Class(OpenLayers.Control, {
+    type: OpenLayers.Control.TYPE_TOOL,
+    containerCenter: null,
+    pinchOrigin: null,
+    currentCenter: null,
+    autoActivate: !0,
+    initialize: function(a) {
+        OpenLayers.Control.prototype.initialize.apply(this, arguments);
+        this.handler = new OpenLayers.Handler.Pinch(this, {
+            start: this.pinchStart,
+            move: this.pinchMove,
+            done: this.pinchDone
+        }, this.handlerOptions)
+    },
+    activate: function() {
+        var a = OpenLayers.Control.prototype.activate.apply(this, arguments);
+        a && (this.map.events.on({
+            moveend: this.updateContainerCenter,
+            scope: this
+        }), this.updateContainerCenter());
+        return a
+    },
+    deactivate: function() {
+        var a = OpenLayers.Control.prototype.deactivate.apply(this, arguments);
+        this.map && this.map.events && this.map.events.un({
+            moveend: this.updateContainerCenter,
+            scope: this
+        });
+        return a
+    },
+    updateContainerCenter: function() {
+        var a = this.map.layerContainerDiv;
+        this.containerCenter = {
+            x: parseInt(a.style.left, 10) + 50,
+            y: parseInt(a.style.top, 10) + 50
+        }
+    },
+    pinchStart: function(a) {
+        this.currentCenter = this.pinchOrigin = a.xy
+    },
+    pinchMove: function(a, b) {
+        var c = b.scale,
+            d = this.containerCenter,
+            e = this.pinchOrigin,
+            f = a.xy,
+            g = Math.round(f.x - e.x + (c - 1) * (d.x - e.x)),
+            d = Math.round(f.y - e.y + (c - 1) * (d.y - e.y));
+        this.applyTransform("translate(" + g + "px, " + d + "px) scale(" + c + ")");
+        this.currentCenter = f
+    },
+    applyTransform: function(a) {
+        var b = this.map.layerContainerDiv.style;
+        b["-webkit-transform"] = a;
+        b["-moz-transform"] = a
+    },
+    pinchDone: function(a, b, c) {
+        this.applyTransform("");
+        a = this.map.getZoomForResolution(this.map.getResolution() / c.scale, !0);
+        if (a !== this.map.getZoom() || !this.currentCenter.equals(this.pinchOrigin)) {
+            var b =
+                this.map.getResolutionForZoom(a),
+                c = this.map.getLonLatFromPixel(this.pinchOrigin),
+                d = this.currentCenter,
+                e = this.map.getSize();
+            c.lon += b * (e.w / 2 - d.x);
+            c.lat -= b * (e.h / 2 - d.y);
+            this.map.div.clientWidth = this.map.div.clientWidth;
+            this.map.setCenter(c, a)
+        }
+    },
+    CLASS_NAME: "OpenLayers.Control.PinchZoom"
+});
+OpenLayers.Control.TouchNavigation = OpenLayers.Class(OpenLayers.Control, {
+    dragPan: null,
+    dragPanOptions: null,
+    pinchZoom: null,
+    pinchZoomOptions: null,
+    clickHandlerOptions: null,
+    documentDrag: !1,
+    autoActivate: !0,
+    initialize: function(a) {
+        this.handlers = {};
+        OpenLayers.Control.prototype.initialize.apply(this, arguments)
+    },
+    destroy: function() {
+        this.deactivate();
+        this.dragPan && this.dragPan.destroy();
+        this.dragPan = null;
+        this.pinchZoom && (this.pinchZoom.destroy(), delete this.pinchZoom);
+        OpenLayers.Control.prototype.destroy.apply(this,
+            arguments)
+    },
+    activate: function() {
+        return OpenLayers.Control.prototype.activate.apply(this, arguments) ? (this.dragPan.activate(), this.handlers.click.activate(), this.pinchZoom.activate(), !0) : !1
+    },
+    deactivate: function() {
+        return OpenLayers.Control.prototype.deactivate.apply(this, arguments) ? (this.dragPan.deactivate(), this.handlers.click.deactivate(), this.pinchZoom.deactivate(), !0) : !1
+    },
+    draw: function() {
+        var a = {
+                click: this.defaultClick,
+                dblclick: this.defaultDblClick
+            },
+            b = OpenLayers.Util.extend({
+                "double": !0,
+                stopDouble: !0,
+                pixelTolerance: 2
+            }, this.clickHandlerOptions);
+        this.handlers.click = new OpenLayers.Handler.Click(this, a, b);
+        this.dragPan = new OpenLayers.Control.DragPan(OpenLayers.Util.extend({
+            map: this.map,
+            documentDrag: this.documentDrag
+        }, this.dragPanOptions));
+        this.dragPan.draw();
+        this.pinchZoom = new OpenLayers.Control.PinchZoom(OpenLayers.Util.extend({
+            map: this.map
+        }, this.pinchZoomOptions))
+    },
+    defaultClick: function(a) {
+        a.lastTouches && 2 == a.lastTouches.length && this.map.zoomOut()
+    },
+    defaultDblClick: function(a) {
+        this.map.setCenter(this.map.getLonLatFromViewPortPx(a.xy),
+            this.map.zoom + 1)
+    },
+    CLASS_NAME: "OpenLayers.Control.TouchNavigation"
+});
+OpenLayers.Style2 = OpenLayers.Class({
+    id: null,
+    name: null,
+    title: null,
+    description: null,
+    layerName: null,
+    isDefault: !1,
+    rules: null,
+    initialize: function(a) {
+        OpenLayers.Util.extend(this, a);
+        this.id = OpenLayers.Util.createUniqueID(this.CLASS_NAME + "_")
+    },
+    destroy: function() {
+        for (var a = 0, b = this.rules.length; a < b; a++) this.rules[a].destroy();
+        delete this.rules
+    },
+    clone: function() {
+        var a = OpenLayers.Util.extend({}, this);
+        if (this.rules) {
+            a.rules = [];
+            for (var b = 0, c = this.rules.length; b < c; ++b) a.rules.push(this.rules[b].clone())
+        }
+        return new OpenLayers.Style2(a)
+    },
+    CLASS_NAME: "OpenLayers.Style2"
+});
+OpenLayers.Format.WFS = OpenLayers.Class(OpenLayers.Format.GML, {
+    layer: null,
+    wfsns: "http://www.opengis.net/wfs",
+    ogcns: "http://www.opengis.net/ogc",
+    initialize: function(a, b) {
+        OpenLayers.Format.GML.prototype.initialize.apply(this, [a]);
+        this.layer = b;
+        this.layer.featureNS && (this.featureNS = this.layer.featureNS);
+        this.layer.options.geometry_column && (this.geometryName = this.layer.options.geometry_column);
+        this.layer.options.typename && (this.featureName = this.layer.options.typename)
+    },
+    write: function(a) {
+        var b = this.createElementNS(this.wfsns,
+            "wfs:Transaction");
+        b.setAttribute("version", "1.0.0");
+        b.setAttribute("service", "WFS");
+        for (var c = 0; c < a.length; c++) switch (a[c].state) {
+            case OpenLayers.State.INSERT:
+                b.appendChild(this.insert(a[c]));
+                break;
+            case OpenLayers.State.UPDATE:
+                b.appendChild(this.update(a[c]));
+                break;
+            case OpenLayers.State.DELETE:
+                b.appendChild(this.remove(a[c]))
+        }
+        return OpenLayers.Format.XML.prototype.write.apply(this, [b])
+    },
+    createFeatureXML: function(a) {
+        var b = this.buildGeometryNode(a.geometry),
+            c = this.createElementNS(this.featureNS, "feature:" +
+                this.geometryName);
+        c.appendChild(b);
+        b = this.createElementNS(this.featureNS, "feature:" + this.featureName);
+        b.appendChild(c);
+        for (var d in a.attributes) {
+            var c = this.createTextNode(a.attributes[d]),
+                e = d; - 1 != d.search(":") && (e = d.split(":")[1]);
+            e = this.createElementNS(this.featureNS, "feature:" + e);
+            e.appendChild(c);
+            b.appendChild(e)
+        }
+        return b
+    },
+    insert: function(a) {
+        var b = this.createElementNS(this.wfsns, "wfs:Insert");
+        b.appendChild(this.createFeatureXML(a));
+        return b
+    },
+    update: function(a) {
+        a.fid || OpenLayers.Console.userError(OpenLayers.i18n("noFID"));
+        var b = this.createElementNS(this.wfsns, "wfs:Update");
+        b.setAttribute("typeName", this.featurePrefix + ":" + this.featureName);
+        b.setAttribute("xmlns:" + this.featurePrefix, this.featureNS);
+        var c = this.createElementNS(this.wfsns, "wfs:Property"),
+            d = this.createElementNS(this.wfsns, "wfs:Name"),
+            e = this.createTextNode(this.geometryName);
+        d.appendChild(e);
+        c.appendChild(d);
+        d = this.createElementNS(this.wfsns, "wfs:Value");
+        e = this.buildGeometryNode(a.geometry);
+        a.layer && e.setAttribute("srsName", a.layer.projection.getCode());
+        d.appendChild(e);
+        c.appendChild(d);
+        b.appendChild(c);
+        for (var f in a.attributes) c = this.createElementNS(this.wfsns, "wfs:Property"), d = this.createElementNS(this.wfsns, "wfs:Name"), d.appendChild(this.createTextNode(f)), c.appendChild(d), d = this.createElementNS(this.wfsns, "wfs:Value"), d.appendChild(this.createTextNode(a.attributes[f])), c.appendChild(d), b.appendChild(c);
+        c = this.createElementNS(this.ogcns, "ogc:Filter");
+        f = this.createElementNS(this.ogcns, "ogc:FeatureId");
+        f.setAttribute("fid", a.fid);
+        c.appendChild(f);
+        b.appendChild(c);
+        return b
+    },
+    remove: function(a) {
+        if (!a.fid) return OpenLayers.Console.userError(OpenLayers.i18n("noFID")), !1;
+        var b = this.createElementNS(this.wfsns, "wfs:Delete");
+        b.setAttribute("typeName", this.featurePrefix + ":" + this.featureName);
+        b.setAttribute("xmlns:" + this.featurePrefix, this.featureNS);
+        var c = this.createElementNS(this.ogcns, "ogc:Filter"),
+            d = this.createElementNS(this.ogcns, "ogc:FeatureId");
+        d.setAttribute("fid", a.fid);
+        c.appendChild(d);
+        b.appendChild(c);
+        return b
+    },
+    destroy: function() {
+        this.layer =
+            null
+    },
+    CLASS_NAME: "OpenLayers.Format.WFS"
+});
+OpenLayers.Format.SLD.v1_0_0_GeoServer = OpenLayers.Class(OpenLayers.Format.SLD.v1_0_0, {
+    version: "1.0.0",
+    profile: "GeoServer",
+    readers: OpenLayers.Util.applyDefaults({
+        sld: OpenLayers.Util.applyDefaults({
+            Priority: function(a, b) {
+                var c = this.readers.ogc._expression.call(this, a);
+                c && (b.priority = c)
+            },
+            VendorOption: function(a, b) {
+                b.vendorOptions || (b.vendorOptions = {});
+                b.vendorOptions[a.getAttribute("name")] = this.getChildValue(a)
+            }
+        }, OpenLayers.Format.SLD.v1_0_0.prototype.readers.sld)
+    }, OpenLayers.Format.SLD.v1_0_0.prototype.readers),
+    writers: OpenLayers.Util.applyDefaults({
+        sld: OpenLayers.Util.applyDefaults({
+            Priority: function(a) {
+                return this.writers.sld._OGCExpression.call(this, "sld:Priority", a)
+            },
+            VendorOption: function(a) {
+                return this.createElementNSPlus("sld:VendorOption", {
+                    attributes: {
+                        name: a.name
+                    },
+                    value: a.value
+                })
+            },
+            TextSymbolizer: function(a) {
+                var b = OpenLayers.Format.SLD.v1_0_0.prototype.writers.sld.TextSymbolizer.apply(this, arguments);
+                !1 !== a.graphic && (a.externalGraphic || a.graphicName) && this.writeNode("Graphic", a, b);
+                "priority" in a &&
+                    this.writeNode("Priority", a.priority, b);
+                return this.addVendorOptions(b, a)
+            },
+            PointSymbolizer: function(a) {
+                return this.addVendorOptions(OpenLayers.Format.SLD.v1_0_0.prototype.writers.sld.PointSymbolizer.apply(this, arguments), a)
+            },
+            LineSymbolizer: function(a) {
+                return this.addVendorOptions(OpenLayers.Format.SLD.v1_0_0.prototype.writers.sld.LineSymbolizer.apply(this, arguments), a)
+            },
+            PolygonSymbolizer: function(a) {
+                return this.addVendorOptions(OpenLayers.Format.SLD.v1_0_0.prototype.writers.sld.PolygonSymbolizer.apply(this,
+                    arguments), a)
+            }
+        }, OpenLayers.Format.SLD.v1_0_0.prototype.writers.sld)
+    }, OpenLayers.Format.SLD.v1_0_0.prototype.writers),
+    addVendorOptions: function(a, b) {
+        if (b.vendorOptions)
+            for (var c in b.vendorOptions) this.writeNode("VendorOption", {
+                name: c,
+                value: b.vendorOptions[c]
+            }, a);
+        return a
+    },
+    CLASS_NAME: "OpenLayers.Format.SLD.v1_0_0_GeoServer"
+});
+OpenLayers.Layer.Boxes = OpenLayers.Class(OpenLayers.Layer.Markers, {
+    drawMarker: function(a) {
+        var b = this.map.getLayerPxFromLonLat({
+                lon: a.bounds.left,
+                lat: a.bounds.top
+            }),
+            c = this.map.getLayerPxFromLonLat({
+                lon: a.bounds.right,
+                lat: a.bounds.bottom
+            });
+        null == c || null == b ? a.display(!1) : (b = a.draw(b, {
+            w: Math.max(1, c.x - b.x),
+            h: Math.max(1, c.y - b.y)
+        }), a.drawn || (this.div.appendChild(b), a.drawn = !0))
+    },
+    removeMarker: function(a) {
+        OpenLayers.Util.removeItem(this.markers, a);
+        null != a.div && a.div.parentNode == this.div && this.div.removeChild(a.div)
+    },
+    CLASS_NAME: "OpenLayers.Layer.Boxes"
+});
+OpenLayers.Format.WFSCapabilities.v1_0_0 = OpenLayers.Class(OpenLayers.Format.WFSCapabilities.v1, {
+    readers: {
+        wfs: OpenLayers.Util.applyDefaults({
+            Service: function(a, b) {
+                b.service = {};
+                this.readChildNodes(a, b.service)
+            },
+            Fees: function(a, b) {
+                var c = this.getChildValue(a);
+                c && "none" != c.toLowerCase() && (b.fees = c)
+            },
+            AccessConstraints: function(a, b) {
+                var c = this.getChildValue(a);
+                c && "none" != c.toLowerCase() && (b.accessConstraints = c)
+            },
+            OnlineResource: function(a, b) {
+                var c = this.getChildValue(a);
+                c && "none" != c.toLowerCase() && (b.onlineResource =
+                    c)
+            },
+            Keywords: function(a, b) {
+                var c = this.getChildValue(a);
+                c && "none" != c.toLowerCase() && (b.keywords = c.split(", "))
+            },
+            Capability: function(a, b) {
+                b.capability = {};
+                this.readChildNodes(a, b.capability)
+            },
+            Request: function(a, b) {
+                b.request = {};
+                this.readChildNodes(a, b.request)
+            },
+            GetFeature: function(a, b) {
+                b.getfeature = {
+                    href: {},
+                    formats: []
+                };
+                this.readChildNodes(a, b.getfeature)
+            },
+            ResultFormat: function(a, b) {
+                for (var c = a.childNodes, d, e = 0; e < c.length; e++) d = c[e], 1 == d.nodeType && b.formats.push(d.nodeName)
+            },
+            DCPType: function(a, b) {
+                this.readChildNodes(a,
+                    b)
+            },
+            HTTP: function(a, b) {
+                this.readChildNodes(a, b.href)
+            },
+            Get: function(a, b) {
+                b.get = a.getAttribute("onlineResource")
+            },
+            Post: function(a, b) {
+                b.post = a.getAttribute("onlineResource")
+            },
+            SRS: function(a, b) {
+                var c = this.getChildValue(a);
+                c && (b.srs = c)
+            }
+        }, OpenLayers.Format.WFSCapabilities.v1.prototype.readers.wfs)
+    },
+    CLASS_NAME: "OpenLayers.Format.WFSCapabilities.v1_0_0"
+});
+OpenLayers.Format.WMSCapabilities = OpenLayers.Class(OpenLayers.Format.XML.VersionedOGC, {
+    defaultVersion: "1.1.1",
+    profile: null,
+    CLASS_NAME: "OpenLayers.Format.WMSCapabilities"
+});
+OpenLayers.Format.WMSCapabilities.v1 = OpenLayers.Class(OpenLayers.Format.XML, {
+    namespaces: {
+        wms: "http://www.opengis.net/wms",
+        xlink: "http://www.w3.org/1999/xlink",
+        xsi: "http://www.w3.org/2001/XMLSchema-instance"
+    },
+    defaultPrefix: "wms",
+    read: function(a) {
+        "string" == typeof a && (a = OpenLayers.Format.XML.prototype.read.apply(this, [a]));
+        var b = a;
+        a && 9 == a.nodeType && (a = a.documentElement);
+        var c = {};
+        this.readNode(a, c);
+        void 0 === c.service && (a = new OpenLayers.Format.OGCExceptionReport, c.error = a.read(b));
+        return c
+    },
+    readers: {
+        wms: {
+            Service: function(a,
+                b) {
+                b.service = {};
+                this.readChildNodes(a, b.service)
+            },
+            Name: function(a, b) {
+                b.name = this.getChildValue(a)
+            },
+            Title: function(a, b) {
+                b.title = this.getChildValue(a)
+            },
+            Abstract: function(a, b) {
+                b["abstract"] = this.getChildValue(a)
+            },
+            BoundingBox: function(a) {
+                var b = {};
+                b.bbox = [parseFloat(a.getAttribute("minx")), parseFloat(a.getAttribute("miny")), parseFloat(a.getAttribute("maxx")), parseFloat(a.getAttribute("maxy"))];
+                a = {
+                    x: parseFloat(a.getAttribute("resx")),
+                    y: parseFloat(a.getAttribute("resy"))
+                };
+                if (!isNaN(a.x) || !isNaN(a.y)) b.res =
+                    a;
+                return b
+            },
+            OnlineResource: function(a, b) {
+                b.href = this.getAttributeNS(a, this.namespaces.xlink, "href")
+            },
+            ContactInformation: function(a, b) {
+                b.contactInformation = {};
+                this.readChildNodes(a, b.contactInformation)
+            },
+            ContactPersonPrimary: function(a, b) {
+                b.personPrimary = {};
+                this.readChildNodes(a, b.personPrimary)
+            },
+            ContactPerson: function(a, b) {
+                b.person = this.getChildValue(a)
+            },
+            ContactOrganization: function(a, b) {
+                b.organization = this.getChildValue(a)
+            },
+            ContactPosition: function(a, b) {
+                b.position = this.getChildValue(a)
+            },
+            ContactAddress: function(a,
+                b) {
+                b.contactAddress = {};
+                this.readChildNodes(a, b.contactAddress)
+            },
+            AddressType: function(a, b) {
+                b.type = this.getChildValue(a)
+            },
+            Address: function(a, b) {
+                b.address = this.getChildValue(a)
+            },
+            City: function(a, b) {
+                b.city = this.getChildValue(a)
+            },
+            StateOrProvince: function(a, b) {
+                b.stateOrProvince = this.getChildValue(a)
+            },
+            PostCode: function(a, b) {
+                b.postcode = this.getChildValue(a)
+            },
+            Country: function(a, b) {
+                b.country = this.getChildValue(a)
+            },
+            ContactVoiceTelephone: function(a, b) {
+                b.phone = this.getChildValue(a)
+            },
+            ContactFacsimileTelephone: function(a,
+                b) {
+                b.fax = this.getChildValue(a)
+            },
+            ContactElectronicMailAddress: function(a, b) {
+                b.email = this.getChildValue(a)
+            },
+            Fees: function(a, b) {
+                var c = this.getChildValue(a);
+                c && "none" != c.toLowerCase() && (b.fees = c)
+            },
+            AccessConstraints: function(a, b) {
+                var c = this.getChildValue(a);
+                c && "none" != c.toLowerCase() && (b.accessConstraints = c)
+            },
+            Capability: function(a, b) {
+                b.capability = {
+                    nestedLayers: [],
+                    layers: []
+                };
+                this.readChildNodes(a, b.capability)
+            },
+            Request: function(a, b) {
+                b.request = {};
+                this.readChildNodes(a, b.request)
+            },
+            GetCapabilities: function(a,
+                b) {
+                b.getcapabilities = {
+                    formats: []
+                };
+                this.readChildNodes(a, b.getcapabilities)
+            },
+            Format: function(a, b) {
+                OpenLayers.Util.isArray(b.formats) ? b.formats.push(this.getChildValue(a)) : b.format = this.getChildValue(a)
+            },
+            DCPType: function(a, b) {
+                this.readChildNodes(a, b)
+            },
+            HTTP: function(a, b) {
+                this.readChildNodes(a, b)
+            },
+            Get: function(a, b) {
+                b.get = {};
+                this.readChildNodes(a, b.get);
+                b.href || (b.href = b.get.href)
+            },
+            Post: function(a, b) {
+                b.post = {};
+                this.readChildNodes(a, b.post);
+                b.href || (b.href = b.get.href)
+            },
+            GetMap: function(a, b) {
+                b.getmap = {
+                    formats: []
+                };
+                this.readChildNodes(a, b.getmap)
+            },
+            GetFeatureInfo: function(a, b) {
+                b.getfeatureinfo = {
+                    formats: []
+                };
+                this.readChildNodes(a, b.getfeatureinfo)
+            },
+            Exception: function(a, b) {
+                b.exception = {
+                    formats: []
+                };
+                this.readChildNodes(a, b.exception)
+            },
+            Layer: function(a, b) {
+                var c, d;
+                b.capability ? (d = b.capability, c = b) : d = b;
+                var e = a.getAttributeNode("queryable"),
+                    f = e && e.specified ? a.getAttribute("queryable") : null,
+                    g = (e = a.getAttributeNode("cascaded")) && e.specified ? a.getAttribute("cascaded") : null,
+                    e = (e = a.getAttributeNode("opaque")) && e.specified ?
+                    a.getAttribute("opaque") : null,
+                    h = a.getAttribute("noSubsets"),
+                    i = a.getAttribute("fixedWidth"),
+                    j = a.getAttribute("fixedHeight"),
+                    k = c || {},
+                    l = OpenLayers.Util.extend;
+                c = {
+                    nestedLayers: [],
+                    styles: c ? [].concat(c.styles) : [],
+                    srs: c ? l({}, k.srs) : {},
+                    metadataURLs: [],
+                    bbox: c ? l({}, k.bbox) : {},
+                    llbbox: k.llbbox,
+                    dimensions: c ? l({}, k.dimensions) : {},
+                    authorityURLs: c ? l({}, k.authorityURLs) : {},
+                    identifiers: {},
+                    keywords: [],
+                    queryable: f && "" !== f ? "1" === f || "true" === f : k.queryable || !1,
+                    cascaded: null !== g ? parseInt(g) : k.cascaded || 0,
+                    opaque: e ? "1" ===
+                        e || "true" === e : k.opaque || !1,
+                    noSubsets: null !== h ? "1" === h || "true" === h : k.noSubsets || !1,
+                    fixedWidth: null != i ? parseInt(i) : k.fixedWidth || 0,
+                    fixedHeight: null != j ? parseInt(j) : k.fixedHeight || 0,
+                    minScale: k.minScale,
+                    maxScale: k.maxScale,
+                    attribution: k.attribution
+                };
+                b.nestedLayers.push(c);
+                c.capability = d;
+                this.readChildNodes(a, c);
+                delete c.capability;
+                if (c.name && (f = c.name.split(":"), g = d.request, e = g.getfeatureinfo, 0 < f.length && (c.prefix = f[0]), d.layers.push(c), void 0 === c.formats && (c.formats = g.getmap.formats), void 0 === c.infoFormats &&
+                        e)) c.infoFormats = e.formats
+            },
+            Attribution: function(a, b) {
+                b.attribution = {};
+                this.readChildNodes(a, b.attribution)
+            },
+            LogoURL: function(a, b) {
+                b.logo = {
+                    width: a.getAttribute("width"),
+                    height: a.getAttribute("height")
+                };
+                this.readChildNodes(a, b.logo)
+            },
+            Style: function(a, b) {
+                var c = {};
+                b.styles.push(c);
+                this.readChildNodes(a, c)
+            },
+            LegendURL: function(a, b) {
+                var c = {
+                    width: a.getAttribute("width"),
+                    height: a.getAttribute("height")
+                };
+                b.legend = c;
+                this.readChildNodes(a, c)
+            },
+            MetadataURL: function(a, b) {
+                var c = {
+                    type: a.getAttribute("type")
+                };
+                b.metadataURLs.push(c);
+                this.readChildNodes(a, c)
+            },
+            DataURL: function(a, b) {
+                b.dataURL = {};
+                this.readChildNodes(a, b.dataURL)
+            },
+            FeatureListURL: function(a, b) {
+                b.featureListURL = {};
+                this.readChildNodes(a, b.featureListURL)
+            },
+            AuthorityURL: function(a, b) {
+                var c = a.getAttribute("name"),
+                    d = {};
+                this.readChildNodes(a, d);
+                b.authorityURLs[c] = d.href
+            },
+            Identifier: function(a, b) {
+                var c = a.getAttribute("authority");
+                b.identifiers[c] = this.getChildValue(a)
+            },
+            KeywordList: function(a, b) {
+                this.readChildNodes(a, b)
+            },
+            SRS: function(a, b) {
+                b.srs[this.getChildValue(a)] = !0
+            }
+        }
+    },
+    CLASS_NAME: "OpenLayers.Format.WMSCapabilities.v1"
+});
+OpenLayers.Format.WMSCapabilities.v1_3 = OpenLayers.Class(OpenLayers.Format.WMSCapabilities.v1, {
+    readers: {
+        wms: OpenLayers.Util.applyDefaults({
+            WMS_Capabilities: function(a, b) {
+                this.readChildNodes(a, b)
+            },
+            LayerLimit: function(a, b) {
+                b.layerLimit = parseInt(this.getChildValue(a))
+            },
+            MaxWidth: function(a, b) {
+                b.maxWidth = parseInt(this.getChildValue(a))
+            },
+            MaxHeight: function(a, b) {
+                b.maxHeight = parseInt(this.getChildValue(a))
+            },
+            BoundingBox: function(a, b) {
+                var c = OpenLayers.Format.WMSCapabilities.v1.prototype.readers.wms.BoundingBox.apply(this, [a, b]);
+                c.srs = a.getAttribute("CRS");
+                b.bbox[c.srs] = c
+            },
+            CRS: function(a, b) {
+                this.readers.wms.SRS.apply(this, [a, b])
+            },
+            EX_GeographicBoundingBox: function(a, b) {
+                b.llbbox = [];
+                this.readChildNodes(a, b.llbbox)
+            },
+            westBoundLongitude: function(a, b) {
+                b[0] = this.getChildValue(a)
+            },
+            eastBoundLongitude: function(a, b) {
+                b[2] = this.getChildValue(a)
+            },
+            southBoundLatitude: function(a, b) {
+                b[1] = this.getChildValue(a)
+            },
+            northBoundLatitude: function(a, b) {
+                b[3] = this.getChildValue(a)
+            },
+            MinScaleDenominator: function(a, b) {
+                b.maxScale = parseFloat(this.getChildValue(a)).toPrecision(16)
+            },
+            MaxScaleDenominator: function(a, b) {
+                b.minScale = parseFloat(this.getChildValue(a)).toPrecision(16)
+            },
+            Dimension: function(a, b) {
+                var c = {
+                    name: a.getAttribute("name").toLowerCase(),
+                    units: a.getAttribute("units"),
+                    unitsymbol: a.getAttribute("unitSymbol"),
+                    nearestVal: "1" === a.getAttribute("nearestValue"),
+                    multipleVal: "1" === a.getAttribute("multipleValues"),
+                    "default": a.getAttribute("default") || "",
+                    current: "1" === a.getAttribute("current"),
+                    values: this.getChildValue(a).split(",")
+                };
+                b.dimensions[c.name] = c
+            },
+            Keyword: function(a,
+                b) {
+                var c = {
+                    value: this.getChildValue(a),
+                    vocabulary: a.getAttribute("vocabulary")
+                };
+                b.keywords && b.keywords.push(c)
+            }
+        }, OpenLayers.Format.WMSCapabilities.v1.prototype.readers.wms),
+        sld: {
+            UserDefinedSymbolization: function(a, b) {
+                this.readers.wms.UserDefinedSymbolization.apply(this, [a, b]);
+                b.userSymbols.inlineFeature = 1 == parseInt(a.getAttribute("InlineFeature"));
+                b.userSymbols.remoteWCS = 1 == parseInt(a.getAttribute("RemoteWCS"))
+            },
+            DescribeLayer: function(a, b) {
+                this.readers.wms.DescribeLayer.apply(this, [a, b])
+            },
+            GetLegendGraphic: function(a,
+                b) {
+                this.readers.wms.GetLegendGraphic.apply(this, [a, b])
+            }
+        }
+    },
+    CLASS_NAME: "OpenLayers.Format.WMSCapabilities.v1_3"
+});
+OpenLayers.Layer.Zoomify = OpenLayers.Class(OpenLayers.Layer.Grid, {
+    size: null,
+    isBaseLayer: !0,
+    standardTileSize: 256,
+    tileOriginCorner: "tl",
+    numberOfTiers: 0,
+    tileCountUpToTier: null,
+    tierSizeInTiles: null,
+    tierImageSize: null,
+    initialize: function(a, b, c, d) {
+        this.initializeZoomify(c);
+        OpenLayers.Layer.Grid.prototype.initialize.apply(this, [a, b, c, {}, d])
+    },
+    initializeZoomify: function(a) {
+        var a = a.clone(),
+            b = new OpenLayers.Size(Math.ceil(a.w / this.standardTileSize), Math.ceil(a.h / this.standardTileSize));
+        this.tierSizeInTiles = [b];
+        for (this.tierImageSize = [a]; a.w > this.standardTileSize || a.h > this.standardTileSize;) a = new OpenLayers.Size(Math.floor(a.w / 2), Math.floor(a.h / 2)), b = new OpenLayers.Size(Math.ceil(a.w / this.standardTileSize), Math.ceil(a.h / this.standardTileSize)), this.tierSizeInTiles.push(b), this.tierImageSize.push(a);
+        this.tierSizeInTiles.reverse();
+        this.tierImageSize.reverse();
+        this.numberOfTiers = this.tierSizeInTiles.length;
+        this.tileCountUpToTier = [0];
+        for (a = 1; a < this.numberOfTiers; a++) this.tileCountUpToTier.push(this.tierSizeInTiles[a -
+            1].w * this.tierSizeInTiles[a - 1].h + this.tileCountUpToTier[a - 1])
+    },
+    destroy: function() {
+        OpenLayers.Layer.Grid.prototype.destroy.apply(this, arguments);
+        this.tileCountUpToTier.length = 0;
+        this.tierSizeInTiles.length = 0;
+        this.tierImageSize.length = 0
+    },
+    clone: function(a) {
+        null == a && (a = new OpenLayers.Layer.Zoomify(this.name, this.url, this.size, this.options));
+        return a = OpenLayers.Layer.Grid.prototype.clone.apply(this, [a])
+    },
+    getURL: function(a) {
+        var a = this.adjustBounds(a),
+            b = this.map.getResolution(),
+            c = Math.round((a.left - this.tileOrigin.lon) /
+                (b * this.tileSize.w)),
+            a = Math.round((this.tileOrigin.lat - a.top) / (b * this.tileSize.h)),
+            b = this.map.getZoom(),
+            c = "TileGroup" + Math.floor((c + a * this.tierSizeInTiles[b].w + this.tileCountUpToTier[b]) / 256) + "/" + b + "-" + c + "-" + a + ".jpg",
+            a = this.url;
+        OpenLayers.Util.isArray(a) && (a = this.selectUrl(c, a));
+        return a + c
+    },
+    getImageSize: function() {
+        if (0 < arguments.length) {
+            var a = this.adjustBounds(arguments[0]),
+                b = this.map.getResolution(),
+                c = Math.round((a.left - this.tileOrigin.lon) / (b * this.tileSize.w)),
+                a = Math.round((this.tileOrigin.lat -
+                    a.top) / (b * this.tileSize.h)),
+                b = this.map.getZoom(),
+                d = this.standardTileSize,
+                e = this.standardTileSize;
+            c == this.tierSizeInTiles[b].w - 1 && (d = this.tierImageSize[b].w % this.standardTileSize);
+            a == this.tierSizeInTiles[b].h - 1 && (e = this.tierImageSize[b].h % this.standardTileSize);
+            return new OpenLayers.Size(d, e)
+        }
+        return this.tileSize
+    },
+    setMap: function(a) {
+        OpenLayers.Layer.Grid.prototype.setMap.apply(this, arguments);
+        this.tileOrigin = new OpenLayers.LonLat(this.map.maxExtent.left, this.map.maxExtent.top)
+    },
+    calculateGridLayout: function(a,
+        b, c) {
+        var d = c * this.tileSize.w,
+            c = c * this.tileSize.h,
+            e = a.left - b.lon,
+            f = Math.floor(e / d) - this.buffer,
+            a = b.lat - a.top + c,
+            g = Math.floor(a / c) - this.buffer;
+        return {
+            tilelon: d,
+            tilelat: c,
+            tileoffsetlon: b.lon + f * d,
+            tileoffsetlat: b.lat - c * g,
+            tileoffsetx: -(e / d - f) * this.tileSize.w,
+            tileoffsety: (g - a / c) * this.tileSize.h
+        }
+    },
+    CLASS_NAME: "OpenLayers.Layer.Zoomify"
+});
+OpenLayers.Layer.MapServer = OpenLayers.Class(OpenLayers.Layer.Grid, {
+    DEFAULT_PARAMS: {
+        mode: "map",
+        map_imagetype: "png"
+    },
+    initialize: function(a, b, c, d) {
+        OpenLayers.Layer.Grid.prototype.initialize.apply(this, arguments);
+        this.params = OpenLayers.Util.applyDefaults(this.params, this.DEFAULT_PARAMS);
+        if (null == d || null == d.isBaseLayer) this.isBaseLayer = "true" != this.params.transparent && !0 != this.params.transparent
+    },
+    clone: function(a) {
+        null == a && (a = new OpenLayers.Layer.MapServer(this.name, this.url, this.params, this.getOptions()));
+        return a = OpenLayers.Layer.Grid.prototype.clone.apply(this, [a])
+    },
+    getURL: function(a) {
+        var a = this.adjustBounds(a),
+            a = [a.left, a.bottom, a.right, a.top],
+            b = this.getImageSize();
+        return this.getFullRequestString({
+            mapext: a,
+            imgext: a,
+            map_size: [b.w, b.h],
+            imgx: b.w / 2,
+            imgy: b.h / 2,
+            imgxy: [b.w, b.h]
+        })
+    },
+    getFullRequestString: function(a, b) {
+        var c = null == b ? this.url : b,
+            d = OpenLayers.Util.extend({}, this.params),
+            d = OpenLayers.Util.extend(d, a),
+            e = OpenLayers.Util.getParameterString(d);
+        OpenLayers.Util.isArray(c) && (c = this.selectUrl(e, c));
+        var e = OpenLayers.Util.upperCaseObject(OpenLayers.Util.getParameters(c)),
+            f;
+        for (f in d) f.toUpperCase() in e && delete d[f];
+        e = OpenLayers.Util.getParameterString(d);
+        d = c;
+        e = e.replace(/,/g, "+");
+        "" != e && (f = c.charAt(c.length - 1), d = "&" == f || "?" == f ? d + e : -1 == c.indexOf("?") ? d + ("?" + e) : d + ("&" + e));
+        return d
+    },
+    CLASS_NAME: "OpenLayers.Layer.MapServer"
+});
+OpenLayers.Renderer.VML = OpenLayers.Class(OpenLayers.Renderer.Elements, {
+    xmlns: "urn:schemas-microsoft-com:vml",
+    symbolCache: {},
+    offset: null,
+    initialize: function(a) {
+        if (this.supported()) {
+            if (!document.namespaces.olv) {
+                document.namespaces.add("olv", this.xmlns);
+                for (var b = document.createStyleSheet(), c = "shape rect oval fill stroke imagedata group textbox".split(" "), d = 0, e = c.length; d < e; d++) b.addRule("olv\\:" + c[d], "behavior: url(#default#VML); position: absolute; display: inline-block;")
+            }
+            OpenLayers.Renderer.Elements.prototype.initialize.apply(this,
+                arguments)
+        }
+    },
+    supported: function() {
+        return !!document.namespaces
+    },
+    setExtent: function(a, b) {
+        var c = OpenLayers.Renderer.Elements.prototype.setExtent.apply(this, arguments),
+            d = this.getResolution(),
+            e = a.left / d | 0,
+            d = a.top / d - this.size.h | 0;
+        b || !this.offset ? (this.offset = {
+            x: e,
+            y: d
+        }, d = e = 0) : (e -= this.offset.x, d -= this.offset.y);
+        this.root.coordorigin = e - this.xOffset + " " + d;
+        for (var e = [this.root, this.vectorRoot, this.textRoot], f = 0, g = e.length; f < g; ++f) d = e[f], d.coordsize = this.size.w + " " + this.size.h;
+        this.root.style.flip = "y";
+        return c
+    },
+    setSize: function(a) {
+        OpenLayers.Renderer.prototype.setSize.apply(this, arguments);
+        for (var b = [this.rendererRoot, this.root, this.vectorRoot, this.textRoot], c = this.size.w + "px", d = this.size.h + "px", e, f = 0, g = b.length; f < g; ++f) e = b[f], e.style.width = c, e.style.height = d
+    },
+    getNodeType: function(a, b) {
+        var c = null;
+        switch (a.CLASS_NAME) {
+            case "OpenLayers.Geometry.Point":
+                c = b.externalGraphic ? "olv:rect" : this.isComplexSymbol(b.graphicName) ? "olv:shape" : "olv:oval";
+                break;
+            case "OpenLayers.Geometry.Rectangle":
+                c = "olv:rect";
+                break;
+            case "OpenLayers.Geometry.LineString":
+            case "OpenLayers.Geometry.LinearRing":
+            case "OpenLayers.Geometry.Polygon":
+            case "OpenLayers.Geometry.Curve":
+                c =
+                    "olv:shape"
+        }
+        return c
+    },
+    setStyle: function(a, b, c, d) {
+        var b = b || a._style,
+            c = c || a._options,
+            e = b.fillColor;
+        if ("OpenLayers.Geometry.Point" === a._geometryClass)
+            if (b.externalGraphic) {
+                c.isFilled = !0;
+                b.graphicTitle && (a.title = b.graphicTitle);
+                var e = b.graphicWidth || b.graphicHeight,
+                    f = b.graphicHeight || b.graphicWidth,
+                    e = e ? e : 2 * b.pointRadius,
+                    f = f ? f : 2 * b.pointRadius,
+                    g = this.getResolution(),
+                    h = void 0 != b.graphicXOffset ? b.graphicXOffset : -(0.5 * e),
+                    i = void 0 != b.graphicYOffset ? b.graphicYOffset : -(0.5 * f);
+                a.style.left = ((d.x - this.featureDx) /
+                    g - this.offset.x + h | 0) + "px";
+                a.style.top = (d.y / g - this.offset.y - (i + f) | 0) + "px";
+                a.style.width = e + "px";
+                a.style.height = f + "px";
+                a.style.flip = "y";
+                e = "none";
+                c.isStroked = !1
+            } else this.isComplexSymbol(b.graphicName) ? (f = this.importSymbol(b.graphicName), a.path = f.path, a.coordorigin = f.left + "," + f.bottom, f = f.size, a.coordsize = f + "," + f, this.drawCircle(a, d, b.pointRadius), a.style.flip = "y") : this.drawCircle(a, d, b.pointRadius);
+        c.isFilled ? a.fillcolor = e : a.filled = "false";
+        d = a.getElementsByTagName("fill");
+        d = 0 == d.length ? null : d[0];
+        if (c.isFilled) {
+            d ||
+                (d = this.createNode("olv:fill", a.id + "_fill"));
+            d.opacity = b.fillOpacity;
+            if ("OpenLayers.Geometry.Point" === a._geometryClass && b.externalGraphic && (b.graphicOpacity && (d.opacity = b.graphicOpacity), d.src = b.externalGraphic, d.type = "frame", !b.graphicWidth || !b.graphicHeight)) d.aspect = "atmost";
+            d.parentNode != a && a.appendChild(d)
+        } else d && a.removeChild(d);
+        e = b.rotation;
+        if (void 0 !== e || void 0 !== a._rotation) a._rotation = e, b.externalGraphic ? (this.graphicRotate(a, h, i, b), d.opacity = 0) : "OpenLayers.Geometry.Point" === a._geometryClass &&
+            (a.style.rotation = e || 0);
+        h = a.getElementsByTagName("stroke");
+        h = 0 == h.length ? null : h[0];
+        if (c.isStroked) {
+            if (h || (h = this.createNode("olv:stroke", a.id + "_stroke"), a.appendChild(h)), h.on = !0, h.color = b.strokeColor, h.weight = b.strokeWidth + "px", h.opacity = b.strokeOpacity, h.endcap = "butt" == b.strokeLinecap ? "flat" : b.strokeLinecap || "round", b.strokeDashstyle) h.dashstyle = this.dashStyle(b)
+        } else a.stroked = !1, h && (h.on = !1);
+        "inherit" != b.cursor && null != b.cursor && (a.style.cursor = b.cursor);
+        return a
+    },
+    graphicRotate: function(a, b, c,
+        d) {
+        var d = d || a._style,
+            e = d.rotation || 0,
+            f, g;
+        if (!d.graphicWidth || !d.graphicHeight) {
+            var h = new Image;
+            h.onreadystatechange = OpenLayers.Function.bind(function() {
+                if ("complete" == h.readyState || "interactive" == h.readyState) f = h.width / h.height, g = Math.max(2 * d.pointRadius, d.graphicWidth || 0, d.graphicHeight || 0), b *= f, d.graphicWidth = g * f, d.graphicHeight = g, this.graphicRotate(a, b, c, d)
+            }, this);
+            h.src = d.externalGraphic
+        } else {
+            g = Math.max(d.graphicWidth, d.graphicHeight);
+            f = d.graphicWidth / d.graphicHeight;
+            var i = Math.round(d.graphicWidth ||
+                    g * f),
+                j = Math.round(d.graphicHeight || g);
+            a.style.width = i + "px";
+            a.style.height = j + "px";
+            var k = document.getElementById(a.id + "_image");
+            k || (k = this.createNode("olv:imagedata", a.id + "_image"), a.appendChild(k));
+            k.style.width = i + "px";
+            k.style.height = j + "px";
+            k.src = d.externalGraphic;
+            k.style.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(src='', sizingMethod='scale')";
+            k = e * Math.PI / 180;
+            e = Math.sin(k);
+            k = Math.cos(k);
+            e = "progid:DXImageTransform.Microsoft.Matrix(M11=" + k + ",M12=" + -e + ",M21=" + e + ",M22=" + k + ",SizingMethod='auto expand')\n";
+            (k = d.graphicOpacity || d.fillOpacity) && 1 != k && (e += "progid:DXImageTransform.Microsoft.BasicImage(opacity=" + k + ")\n");
+            a.style.filter = e;
+            e = new OpenLayers.Geometry.Point(-b, -c);
+            i = (new OpenLayers.Bounds(0, 0, i, j)).toGeometry();
+            i.rotate(d.rotation, e);
+            i = i.getBounds();
+            a.style.left = Math.round(parseInt(a.style.left) + i.left) + "px";
+            a.style.top = Math.round(parseInt(a.style.top) - i.bottom) + "px"
+        }
+    },
+    postDraw: function(a) {
+        a.style.visibility = "visible";
+        var b = a._style.fillColor,
+            c = a._style.strokeColor;
+        "none" == b && a.fillcolor != b &&
+            (a.fillcolor = b);
+        "none" == c && a.strokecolor != c && (a.strokecolor = c)
+    },
+    setNodeDimension: function(a, b) {
+        var c = b.getBounds();
+        if (c) {
+            var d = this.getResolution(),
+                c = new OpenLayers.Bounds((c.left - this.featureDx) / d - this.offset.x | 0, c.bottom / d - this.offset.y | 0, (c.right - this.featureDx) / d - this.offset.x | 0, c.top / d - this.offset.y | 0);
+            a.style.left = c.left + "px";
+            a.style.top = c.top + "px";
+            a.style.width = c.getWidth() + "px";
+            a.style.height = c.getHeight() + "px";
+            a.coordorigin = c.left + " " + c.top;
+            a.coordsize = c.getWidth() + " " + c.getHeight()
+        }
+    },
+    dashStyle: function(a) {
+        a =
+            a.strokeDashstyle;
+        switch (a) {
+            case "solid":
+            case "dot":
+            case "dash":
+            case "dashdot":
+            case "longdash":
+            case "longdashdot":
+                return a;
+            default:
+                return a = a.split(/[ ,]/), 2 == a.length ? 1 * a[0] >= 2 * a[1] ? "longdash" : 1 == a[0] || 1 == a[1] ? "dot" : "dash" : 4 == a.length ? 1 * a[0] >= 2 * a[1] ? "longdashdot" : "dashdot" : "solid"
+        }
+    },
+    createNode: function(a, b) {
+        var c = document.createElement(a);
+        b && (c.id = b);
+        c.unselectable = "on";
+        c.onselectstart = OpenLayers.Function.False;
+        return c
+    },
+    nodeTypeCompare: function(a, b) {
+        var c = b,
+            d = c.indexOf(":"); - 1 != d && (c = c.substr(d +
+            1));
+        var e = a.nodeName,
+            d = e.indexOf(":"); - 1 != d && (e = e.substr(d + 1));
+        return c == e
+    },
+    createRenderRoot: function() {
+        return this.nodeFactory(this.container.id + "_vmlRoot", "div")
+    },
+    createRoot: function(a) {
+        return this.nodeFactory(this.container.id + a, "olv:group")
+    },
+    drawPoint: function(a, b) {
+        return this.drawCircle(a, b, 1)
+    },
+    drawCircle: function(a, b, c) {
+        if (!isNaN(b.x) && !isNaN(b.y)) {
+            var d = this.getResolution();
+            a.style.left = ((b.x - this.featureDx) / d - this.offset.x | 0) - c + "px";
+            a.style.top = (b.y / d - this.offset.y | 0) - c + "px";
+            b = 2 * c;
+            a.style.width =
+                b + "px";
+            a.style.height = b + "px";
+            return a
+        }
+        return !1
+    },
+    drawLineString: function(a, b) {
+        return this.drawLine(a, b, !1)
+    },
+    drawLinearRing: function(a, b) {
+        return this.drawLine(a, b, !0)
+    },
+    drawLine: function(a, b, c) {
+        this.setNodeDimension(a, b);
+        for (var d = this.getResolution(), e = b.components.length, f = Array(e), g, h, i = 0; i < e; i++) g = b.components[i], h = (g.x - this.featureDx) / d - this.offset.x | 0, g = g.y / d - this.offset.y | 0, f[i] = " " + h + "," + g + " l ";
+        a.path = "m" + f.join("") + (c ? " x e" : " e");
+        return a
+    },
+    drawPolygon: function(a, b) {
+        this.setNodeDimension(a,
+            b);
+        var c = this.getResolution(),
+            d = [],
+            e, f, g, h, i, j, k, l, m, n;
+        e = 0;
+        for (f = b.components.length; e < f; e++) {
+            d.push("m");
+            g = b.components[e].components;
+            h = 0 === e;
+            j = i = null;
+            k = 0;
+            for (l = g.length; k < l; k++) m = g[k], n = (m.x - this.featureDx) / c - this.offset.x | 0, m = m.y / c - this.offset.y | 0, n = " " + n + "," + m, d.push(n), 0 == k && d.push(" l"), h || (i ? i != n && (j ? j != n && (h = !0) : j = n) : i = n);
+            d.push(h ? " x " : " ")
+        }
+        d.push("e");
+        a.path = d.join("");
+        return a
+    },
+    drawRectangle: function(a, b) {
+        var c = this.getResolution();
+        a.style.left = ((b.x - this.featureDx) / c - this.offset.x | 0) +
+            "px";
+        a.style.top = (b.y / c - this.offset.y | 0) + "px";
+        a.style.width = (b.width / c | 0) + "px";
+        a.style.height = (b.height / c | 0) + "px";
+        return a
+    },
+    drawText: function(a, b, c) {
+        var d = this.nodeFactory(a + this.LABEL_ID_SUFFIX, "olv:rect"),
+            e = this.nodeFactory(a + this.LABEL_ID_SUFFIX + "_textbox", "olv:textbox"),
+            f = this.getResolution();
+        d.style.left = ((c.x - this.featureDx) / f - this.offset.x | 0) + "px";
+        d.style.top = (c.y / f - this.offset.y | 0) + "px";
+        d.style.flip = "y";
+        e.innerText = b.label;
+        "inherit" != b.cursor && null != b.cursor && (e.style.cursor = b.cursor);
+        b.fontColor &&
+            (e.style.color = b.fontColor);
+        b.fontOpacity && (e.style.filter = "alpha(opacity=" + 100 * b.fontOpacity + ")");
+        b.fontFamily && (e.style.fontFamily = b.fontFamily);
+        b.fontSize && (e.style.fontSize = b.fontSize);
+        b.fontWeight && (e.style.fontWeight = b.fontWeight);
+        b.fontStyle && (e.style.fontStyle = b.fontStyle);
+        !0 === b.labelSelect && (d._featureId = a, e._featureId = a, e._geometry = c, e._geometryClass = c.CLASS_NAME);
+        e.style.whiteSpace = "nowrap";
+        e.inset = "1px,0px,0px,0px";
+        d.parentNode || (d.appendChild(e), this.textRoot.appendChild(d));
+        b = b.labelAlign ||
+            "cm";
+        1 == b.length && (b += "m");
+        a = e.clientWidth * OpenLayers.Renderer.VML.LABEL_SHIFT[b.substr(0, 1)];
+        e = e.clientHeight * OpenLayers.Renderer.VML.LABEL_SHIFT[b.substr(1, 1)];
+        d.style.left = parseInt(d.style.left) - a - 1 + "px";
+        d.style.top = parseInt(d.style.top) + e + "px"
+    },
+    moveRoot: function(a) {
+        var b = this.map.getLayer(a.container.id);
+        b instanceof OpenLayers.Layer.Vector.RootContainer && (b = this.map.getLayer(this.container.id));
+        b && b.renderer.clear();
+        OpenLayers.Renderer.Elements.prototype.moveRoot.apply(this, arguments);
+        b && b.redraw()
+    },
+    importSymbol: function(a) {
+        var b = this.container.id + "-" + a,
+            c = this.symbolCache[b];
+        if (c) return c;
+        c = OpenLayers.Renderer.symbol[a];
+        if (!c) throw Error(a + " is not a valid symbol name");
+        for (var a = new OpenLayers.Bounds(Number.MAX_VALUE, Number.MAX_VALUE, 0, 0), d = ["m"], e = 0; e < c.length; e += 2) {
+            var f = c[e],
+                g = c[e + 1];
+            a.left = Math.min(a.left, f);
+            a.bottom = Math.min(a.bottom, g);
+            a.right = Math.max(a.right, f);
+            a.top = Math.max(a.top, g);
+            d.push(f);
+            d.push(g);
+            0 == e && d.push("l")
+        }
+        d.push("x e");
+        c = d.join(" ");
+        d = (a.getWidth() - a.getHeight()) / 2;
+        0 < d ? (a.bottom -= d, a.top += d) : (a.left += d, a.right -= d);
+        c = {
+            path: c,
+            size: a.getWidth(),
+            left: a.left,
+            bottom: a.bottom
+        };
+        return this.symbolCache[b] = c
+    },
+    CLASS_NAME: "OpenLayers.Renderer.VML"
+});
+OpenLayers.Renderer.VML.LABEL_SHIFT = {
+    l: 0,
+    c: 0.5,
+    r: 1,
+    t: 0,
+    m: 0.5,
+    b: 1
+};
+OpenLayers.Control.CacheRead = OpenLayers.Class(OpenLayers.Control, {
+    fetchEvent: "tileloadstart",
+    layers: null,
+    autoActivate: !0,
+    setMap: function(a) {
+        OpenLayers.Control.prototype.setMap.apply(this, arguments);
+        var b, c = this.layers || a.layers;
+        for (b = c.length - 1; 0 <= b; --b) this.addLayer({
+            layer: c[b]
+        });
+        if (!this.layers) a.events.on({
+            addlayer: this.addLayer,
+            removeLayer: this.removeLayer,
+            scope: this
+        })
+    },
+    addLayer: function(a) {
+        a.layer.events.register(this.fetchEvent, this, this.fetch)
+    },
+    removeLayer: function(a) {
+        a.layer.events.unregister(this.fetchEvent,
+            this, this.fetch)
+    },
+    fetch: function(a) {
+        if (this.active && window.localStorage && a.tile instanceof OpenLayers.Tile.Image) {
+            var b = a.tile,
+                c = b.url;
+            !b.layer.crossOriginKeyword && (OpenLayers.ProxyHost && 0 === c.indexOf(OpenLayers.ProxyHost)) && (c = OpenLayers.Control.CacheWrite.urlMap[c]);
+            if (c = window.localStorage.getItem("olCache_" + c)) b.url = c, "tileerror" === a.type && b.setImgSrc(c)
+        }
+    },
+    destroy: function() {
+        if (this.layers || this.map) {
+            var a, b = this.layers || this.map.layers;
+            for (a = b.length - 1; 0 <= a; --a) this.removeLayer({
+                layer: b[a]
+            })
+        }
+        this.map &&
+            this.map.events.un({
+                addlayer: this.addLayer,
+                removeLayer: this.removeLayer,
+                scope: this
+            });
+        OpenLayers.Control.prototype.destroy.apply(this, arguments)
+    },
+    CLASS_NAME: "OpenLayers.Control.CacheRead"
+});
+OpenLayers.Protocol.WFS.v1_0_0 = OpenLayers.Class(OpenLayers.Protocol.WFS.v1, {
+    version: "1.0.0",
+    CLASS_NAME: "OpenLayers.Protocol.WFS.v1_0_0"
+});
+OpenLayers.Format.WMSGetFeatureInfo = OpenLayers.Class(OpenLayers.Format.XML, {
+    layerIdentifier: "_layer",
+    featureIdentifier: "_feature",
+    regExes: {
+        trimSpace: /^\s*|\s*$/g,
+        removeSpace: /\s*/g,
+        splitSpace: /\s+/,
+        trimComma: /\s*,\s*/g
+    },
+    gmlFormat: null,
+    read: function(a) {
+        "string" == typeof a && (a = OpenLayers.Format.XML.prototype.read.apply(this, [a]));
+        var b = a.documentElement;
+        if (b) var c = this["read_" + b.nodeName],
+            a = c ? c.call(this, b) : (new OpenLayers.Format.GML(this.options ? this.options : {})).read(a);
+        return a
+    },
+    read_msGMLOutput: function(a) {
+        var b = [];
+        if (a = this.getSiblingNodesByTagCriteria(a, this.layerIdentifier))
+            for (var c = 0, d = a.length; c < d; ++c) {
+                var e = a[c],
+                    f = e.nodeName;
+                e.prefix && (f = f.split(":")[1]);
+                f = f.replace(this.layerIdentifier, "");
+                if (e = this.getSiblingNodesByTagCriteria(e, this.featureIdentifier))
+                    for (var g = 0; g < e.length; g++) {
+                        var h = e[g],
+                            i = this.parseGeometry(h),
+                            h = this.parseAttributes(h),
+                            h = new OpenLayers.Feature.Vector(i.geometry, h, null);
+                        h.bounds = i.bounds;
+                        h.type = f;
+                        b.push(h)
+                    }
+            }
+        return b
+    },
+    read_FeatureInfoResponse: function(a) {
+        for (var b = [], a = this.getElementsByTagNameNS(a,
+                "*", "FIELDS"), c = 0, d = a.length; c < d; c++) {
+            var e = a[c],
+                f = {},
+                g, h = e.attributes.length;
+            if (0 < h)
+                for (g = 0; g < h; g++) {
+                    var i = e.attributes[g];
+                    f[i.nodeName] = i.nodeValue
+                } else {
+                    e = e.childNodes;
+                    g = 0;
+                    for (h = e.length; g < h; ++g) i = e[g], 3 != i.nodeType && (f[i.getAttribute("name")] = i.getAttribute("value"))
+                }
+            b.push(new OpenLayers.Feature.Vector(null, f, null))
+        }
+        return b
+    },
+    getSiblingNodesByTagCriteria: function(a, b) {
+        var c = [],
+            d, e, f, g;
+        if (a && a.hasChildNodes()) {
+            d = a.childNodes;
+            f = d.length;
+            for (var h = 0; h < f; h++) {
+                for (g = d[h]; g && 1 != g.nodeType;) g = g.nextSibling,
+                    h++;
+                e = g ? g.nodeName : "";
+                0 < e.length && -1 < e.indexOf(b) ? c.push(g) : (e = this.getSiblingNodesByTagCriteria(g, b), 0 < e.length && (0 == c.length ? c = e : c.push(e)))
+            }
+        }
+        return c
+    },
+    parseAttributes: function(a) {
+        var b = {};
+        if (1 == a.nodeType)
+            for (var a = a.childNodes, c = a.length, d = 0; d < c; ++d) {
+                var e = a[d];
+                if (1 == e.nodeType) {
+                    var f = e.childNodes,
+                        e = e.prefix ? e.nodeName.split(":")[1] : e.nodeName;
+                    if (0 == f.length) b[e] = null;
+                    else if (1 == f.length && (f = f[0], 3 == f.nodeType || 4 == f.nodeType)) f = f.nodeValue.replace(this.regExes.trimSpace, ""), b[e] = f
+                }
+            }
+        return b
+    },
+    parseGeometry: function(a) {
+        this.gmlFormat || (this.gmlFormat = new OpenLayers.Format.GML);
+        var a = this.gmlFormat.parseFeature(a),
+            b, c = null;
+        a && (b = a.geometry && a.geometry.clone(), c = a.bounds && a.bounds.clone(), a.destroy());
+        return {
+            geometry: b,
+            bounds: c
+        }
+    },
+    CLASS_NAME: "OpenLayers.Format.WMSGetFeatureInfo"
+});
+OpenLayers.Control.WMTSGetFeatureInfo = OpenLayers.Class(OpenLayers.Control, {
+    hover: !1,
+    requestEncoding: "KVP",
+    drillDown: !1,
+    maxFeatures: 10,
+    clickCallback: "click",
+    layers: null,
+    queryVisible: !0,
+    infoFormat: "text/html",
+    vendorParams: {},
+    format: null,
+    formatOptions: null,
+    handlerOptions: null,
+    handler: null,
+    hoverRequest: null,
+    pending: 0,
+    initialize: function(a) {
+        a = a || {};
+        a.handlerOptions = a.handlerOptions || {};
+        OpenLayers.Control.prototype.initialize.apply(this, [a]);
+        this.format || (this.format = new OpenLayers.Format.WMSGetFeatureInfo(a.formatOptions));
+        !0 === this.drillDown && (this.hover = !1);
+        this.hover ? this.handler = new OpenLayers.Handler.Hover(this, {
+            move: this.cancelHover,
+            pause: this.getInfoForHover
+        }, OpenLayers.Util.extend(this.handlerOptions.hover || {}, {
+            delay: 250
+        })) : (a = {}, a[this.clickCallback] = this.getInfoForClick, this.handler = new OpenLayers.Handler.Click(this, a, this.handlerOptions.click || {}))
+    },
+    getInfoForClick: function(a) {
+        this.request(a.xy, {})
+    },
+    getInfoForHover: function(a) {
+        this.request(a.xy, {
+            hover: !0
+        })
+    },
+    cancelHover: function() {
+        this.hoverRequest && (--this.pending,
+            0 >= this.pending && (OpenLayers.Element.removeClass(this.map.viewPortDiv, "olCursorWait"), this.pending = 0), this.hoverRequest.abort(), this.hoverRequest = null)
+    },
+    findLayers: function() {
+        for (var a = this.layers || this.map.layers, b = [], c, d = a.length - 1; 0 <= d; --d)
+            if (c = a[d], c instanceof OpenLayers.Layer.WMTS && c.requestEncoding === this.requestEncoding && (!this.queryVisible || c.getVisibility()))
+                if (b.push(c), !this.drillDown || this.hover) break;
+        return b
+    },
+    buildRequestOptions: function(a, b) {
+        var c = this.map.getLonLatFromPixel(b),
+            d =
+            a.getURL(new OpenLayers.Bounds(c.lon, c.lat, c.lon, c.lat)),
+            d = OpenLayers.Util.getParameters(d),
+            c = a.getTileInfo(c);
+        OpenLayers.Util.extend(d, {
+            service: "WMTS",
+            version: a.version,
+            request: "GetFeatureInfo",
+            infoFormat: this.infoFormat,
+            i: c.i,
+            j: c.j
+        });
+        OpenLayers.Util.applyDefaults(d, this.vendorParams);
+        return {
+            url: OpenLayers.Util.isArray(a.url) ? a.url[0] : a.url,
+            params: OpenLayers.Util.upperCaseObject(d),
+            callback: function(c) {
+                this.handleResponse(b, c, a)
+            },
+            scope: this
+        }
+    },
+    request: function(a, b) {
+        var b = b || {},
+            c = this.findLayers();
+        if (0 < c.length) {
+            for (var d, e, f = 0, g = c.length; f < g; f++) e = c[f], d = this.events.triggerEvent("beforegetfeatureinfo", {
+                xy: a,
+                layer: e
+            }), !1 !== d && (++this.pending, d = this.buildRequestOptions(e, a), d = OpenLayers.Request.GET(d), !0 === b.hover && (this.hoverRequest = d));
+            0 < this.pending && OpenLayers.Element.addClass(this.map.viewPortDiv, "olCursorWait")
+        }
+    },
+    handleResponse: function(a, b, c) {
+        --this.pending;
+        0 >= this.pending && (OpenLayers.Element.removeClass(this.map.viewPortDiv, "olCursorWait"), this.pending = 0);
+        if (b.status && (200 > b.status ||
+                300 <= b.status)) this.events.triggerEvent("exception", {
+            xy: a,
+            request: b,
+            layer: c
+        });
+        else {
+            var d = b.responseXML;
+            if (!d || !d.documentElement) d = b.responseText;
+            var e, f;
+            try {
+                e = this.format.read(d)
+            } catch (g) {
+                f = !0, this.events.triggerEvent("exception", {
+                    xy: a,
+                    request: b,
+                    error: g,
+                    layer: c
+                })
+            }
+            f || this.events.triggerEvent("getfeatureinfo", {
+                text: b.responseText,
+                features: e,
+                request: b,
+                xy: a,
+                layer: c
+            })
+        }
+    },
+    CLASS_NAME: "OpenLayers.Control.WMTSGetFeatureInfo"
+});
+OpenLayers.Strategy.Paging = OpenLayers.Class(OpenLayers.Strategy, {
+    features: null,
+    length: 10,
+    num: null,
+    paging: !1,
+    activate: function() {
+        var a = OpenLayers.Strategy.prototype.activate.call(this);
+        if (a) this.layer.events.on({
+            beforefeaturesadded: this.cacheFeatures,
+            scope: this
+        });
+        return a
+    },
+    deactivate: function() {
+        var a = OpenLayers.Strategy.prototype.deactivate.call(this);
+        a && (this.clearCache(), this.layer.events.un({
+            beforefeaturesadded: this.cacheFeatures,
+            scope: this
+        }));
+        return a
+    },
+    cacheFeatures: function(a) {
+        this.paging || (this.clearCache(),
+            this.features = a.features, this.pageNext(a))
+    },
+    clearCache: function() {
+        if (this.features)
+            for (var a = 0; a < this.features.length; ++a) this.features[a].destroy();
+        this.num = this.features = null
+    },
+    pageCount: function() {
+        return Math.ceil((this.features ? this.features.length : 0) / this.length)
+    },
+    pageNum: function() {
+        return this.num
+    },
+    pageLength: function(a) {
+        a && 0 < a && (this.length = a);
+        return this.length
+    },
+    pageNext: function(a) {
+        var b = !1;
+        this.features && (null === this.num && (this.num = -1), b = this.page((this.num + 1) * this.length, a));
+        return b
+    },
+    pagePrevious: function() {
+        var a = !1;
+        this.features && (null === this.num && (this.num = this.pageCount()), a = this.page((this.num - 1) * this.length));
+        return a
+    },
+    page: function(a, b) {
+        var c = !1;
+        if (this.features && 0 <= a && a < this.features.length) {
+            var d = Math.floor(a / this.length);
+            d != this.num && (this.paging = !0, c = this.features.slice(a, a + this.length), this.layer.removeFeatures(this.layer.features), this.num = d, b && b.features ? b.features = c : this.layer.addFeatures(c), this.paging = !1, c = !0)
+        }
+        return c
+    },
+    CLASS_NAME: "OpenLayers.Strategy.Paging"
+});
+OpenLayers.Protocol.CSW.v2_0_2 = OpenLayers.Class(OpenLayers.Protocol, {
+    formatOptions: null,
+    initialize: function(a) {
+        OpenLayers.Protocol.prototype.initialize.apply(this, [a]);
+        a.format || (this.format = new OpenLayers.Format.CSWGetRecords.v2_0_2(OpenLayers.Util.extend({}, this.formatOptions)))
+    },
+    destroy: function() {
+        this.options && !this.options.format && this.format.destroy();
+        this.format = null;
+        OpenLayers.Protocol.prototype.destroy.apply(this)
+    },
+    read: function(a) {
+        a = OpenLayers.Util.extend({}, a);
+        OpenLayers.Util.applyDefaults(a,
+            this.options || {});
+        var b = new OpenLayers.Protocol.Response({
+                requestType: "read"
+            }),
+            c = this.format.write(a.params);
+        b.priv = OpenLayers.Request.POST({
+            url: a.url,
+            callback: this.createCallback(this.handleRead, b, a),
+            params: a.params,
+            headers: a.headers,
+            data: c
+        });
+        return b
+    },
+    handleRead: function(a, b) {
+        if (b.callback) {
+            var c = a.priv;
+            200 <= c.status && 300 > c.status ? (a.data = this.parseData(c), a.code = OpenLayers.Protocol.Response.SUCCESS) : a.code = OpenLayers.Protocol.Response.FAILURE;
+            b.callback.call(b.scope, a)
+        }
+    },
+    parseData: function(a) {
+        var b =
+            a.responseXML;
+        if (!b || !b.documentElement) b = a.responseText;
+        return !b || 0 >= b.length ? null : this.format.read(b)
+    },
+    CLASS_NAME: "OpenLayers.Protocol.CSW.v2_0_2"
+});
+OpenLayers.Format.WMSCapabilities.v1_1 = OpenLayers.Class(OpenLayers.Format.WMSCapabilities.v1, {
+    readers: {
+        wms: OpenLayers.Util.applyDefaults({
+                WMT_MS_Capabilities: function(a, b) {
+                    this.readChildNodes(a, b)
+                },
+                Keyword: function(a, b) {
+                    b.keywords && b.keywords.push(this.getChildValue(a))
+                },
+                DescribeLayer: function(a, b) {
+                    b.describelayer = {
+                        formats: []
+                    };
+                    this.readChildNodes(a, b.describelayer)
+                },
+                GetLegendGraphic: function(a, b) {
+                    b.getlegendgraphic = {
+                        formats: []
+                    };
+                    this.readChildNodes(a, b.getlegendgraphic)
+                },
+                GetStyles: function(a, b) {
+                    b.getstyles = {
+                        formats: []
+                    };
+                    this.readChildNodes(a, b.getstyles)
+                },
+                PutStyles: function(a, b) {
+                    b.putstyles = {
+                        formats: []
+                    };
+                    this.readChildNodes(a, b.putstyles)
+                },
+                UserDefinedSymbolization: function(a, b) {
+                    var c = {
+                        supportSLD: 1 == parseInt(a.getAttribute("SupportSLD")),
+                        userLayer: 1 == parseInt(a.getAttribute("UserLayer")),
+                        userStyle: 1 == parseInt(a.getAttribute("UserStyle")),
+                        remoteWFS: 1 == parseInt(a.getAttribute("RemoteWFS"))
+                    };
+                    b.userSymbols = c
+                },
+                LatLonBoundingBox: function(a, b) {
+                    b.llbbox = [parseFloat(a.getAttribute("minx")), parseFloat(a.getAttribute("miny")),
+                        parseFloat(a.getAttribute("maxx")), parseFloat(a.getAttribute("maxy"))
+                    ]
+                },
+                BoundingBox: function(a, b) {
+                    var c = OpenLayers.Format.WMSCapabilities.v1.prototype.readers.wms.BoundingBox.apply(this, [a, b]);
+                    c.srs = a.getAttribute("SRS");
+                    b.bbox[c.srs] = c
+                },
+                ScaleHint: function(a, b) {
+                    var c = a.getAttribute("min"),
+                        d = a.getAttribute("max"),
+                        e = Math.pow(2, 0.5),
+                        f = OpenLayers.INCHES_PER_UNIT.m;
+                    b.maxScale = parseFloat((c / e * f * OpenLayers.DOTS_PER_INCH).toPrecision(13));
+                    b.minScale = parseFloat((d / e * f * OpenLayers.DOTS_PER_INCH).toPrecision(13))
+                },
+                Dimension: function(a, b) {
+                    var c = {
+                        name: a.getAttribute("name").toLowerCase(),
+                        units: a.getAttribute("units"),
+                        unitsymbol: a.getAttribute("unitSymbol")
+                    };
+                    b.dimensions[c.name] = c
+                },
+                Extent: function(a, b) {
+                    var c = a.getAttribute("name").toLowerCase();
+                    if (c in b.dimensions) {
+                        c = b.dimensions[c];
+                        c.nearestVal = "1" === a.getAttribute("nearestValue");
+                        c.multipleVal = "1" === a.getAttribute("multipleValues");
+                        c.current = "1" === a.getAttribute("current");
+                        c["default"] = a.getAttribute("default") || "";
+                        var d = this.getChildValue(a);
+                        c.values = d.split(",")
+                    }
+                }
+            },
+            OpenLayers.Format.WMSCapabilities.v1.prototype.readers.wms)
+    },
+    CLASS_NAME: "OpenLayers.Format.WMSCapabilities.v1_1"
+});
+OpenLayers.Control.Graticule = OpenLayers.Class(OpenLayers.Control, {
+    autoActivate: !0,
+    intervals: [45, 30, 20, 10, 5, 2, 1, 0.5, 0.2, 0.1, 0.05, 0.01, 0.005, 0.002, 0.001],
+    displayInLayerSwitcher: !0,
+    visible: !0,
+    numPoints: 50,
+    targetSize: 200,
+    layerName: null,
+    labelled: !0,
+    labelFormat: "dm",
+    lineSymbolizer: {
+        strokeColor: "#333",
+        strokeWidth: 1,
+        strokeOpacity: 0.5
+    },
+    labelSymbolizer: {},
+    gratLayer: null,
+    initialize: function(a) {
+        a = a || {};
+        a.layerName = a.layerName || OpenLayers.i18n("Graticule");
+        OpenLayers.Control.prototype.initialize.apply(this, [a]);
+        this.labelSymbolizer.stroke = !1;
+        this.labelSymbolizer.fill = !1;
+        this.labelSymbolizer.label = "${label}";
+        this.labelSymbolizer.labelAlign = "${labelAlign}";
+        this.labelSymbolizer.labelXOffset = "${xOffset}";
+        this.labelSymbolizer.labelYOffset = "${yOffset}"
+    },
+    destroy: function() {
+        this.deactivate();
+        OpenLayers.Control.prototype.destroy.apply(this, arguments);
+        this.gratLayer && (this.gratLayer.destroy(), this.gratLayer = null)
+    },
+    draw: function() {
+        OpenLayers.Control.prototype.draw.apply(this, arguments);
+        if (!this.gratLayer) {
+            var a = new OpenLayers.Style({}, {
+                rules: [new OpenLayers.Rule({
+                    symbolizer: {
+                        Point: this.labelSymbolizer,
+                        Line: this.lineSymbolizer
+                    }
+                })]
+            });
+            this.gratLayer = new OpenLayers.Layer.Vector(this.layerName, {
+                styleMap: new OpenLayers.StyleMap({
+                    "default": a
+                }),
+                visibility: this.visible,
+                displayInLayerSwitcher: this.displayInLayerSwitcher
+            })
+        }
+        return this.div
+    },
+    activate: function() {
+        return OpenLayers.Control.prototype.activate.apply(this, arguments) ? (this.map.addLayer(this.gratLayer), this.map.events.register("moveend", this, this.update), this.update(), !0) : !1
+    },
+    deactivate: function() {
+        return OpenLayers.Control.prototype.deactivate.apply(this,
+            arguments) ? (this.map.events.unregister("moveend", this, this.update), this.map.removeLayer(this.gratLayer), !0) : !1
+    },
+    update: function() {
+        var a = this.map.getExtent();
+        if (a) {
+            this.gratLayer.destroyFeatures();
+            var b = new OpenLayers.Projection("EPSG:4326"),
+                c = this.map.getProjectionObject(),
+                d = this.map.getResolution();
+            c.proj && "longlat" == c.proj.projName && (this.numPoints = 1);
+            var e = this.map.getCenter(),
+                f = new OpenLayers.Pixel(e.lon, e.lat);
+            OpenLayers.Projection.transform(f, c, b);
+            for (var e = this.targetSize * d, e = e * e, g, d = 0; d < this.intervals.length; ++d) {
+                g =
+                    this.intervals[d];
+                var h = g / 2,
+                    i = f.offset({
+                        x: -h,
+                        y: -h
+                    }),
+                    h = f.offset({
+                        x: h,
+                        y: h
+                    });
+                OpenLayers.Projection.transform(i, b, c);
+                OpenLayers.Projection.transform(h, b, c);
+                if ((i.x - h.x) * (i.x - h.x) + (i.y - h.y) * (i.y - h.y) <= e) break
+            }
+            f.x = Math.floor(f.x / g) * g;
+            f.y = Math.floor(f.y / g) * g;
+            var d = 0,
+                e = [f.clone()],
+                h = f.clone(),
+                j;
+            do h = h.offset({
+                x: 0,
+                y: g
+            }), j = OpenLayers.Projection.transform(h.clone(), b, c), e.unshift(h); while (a.containsPixel(j) && 1E3 > ++d);
+            h = f.clone();
+            do h = h.offset({
+                x: 0,
+                y: -g
+            }), j = OpenLayers.Projection.transform(h.clone(), b, c), e.push(h);
+            while (a.containsPixel(j) && 1E3 > ++d);
+            d = 0;
+            i = [f.clone()];
+            h = f.clone();
+            do h = h.offset({
+                x: -g,
+                y: 0
+            }), j = OpenLayers.Projection.transform(h.clone(), b, c), i.unshift(h); while (a.containsPixel(j) && 1E3 > ++d);
+            h = f.clone();
+            do h = h.offset({
+                x: g,
+                y: 0
+            }), j = OpenLayers.Projection.transform(h.clone(), b, c), i.push(h); while (a.containsPixel(j) && 1E3 > ++d);
+            g = [];
+            for (d = 0; d < i.length; ++d) {
+                j = i[d].x;
+                for (var f = [], k = null, l = Math.min(e[0].y, 90), h = Math.max(e[e.length - 1].y, -90), m = (l - h) / this.numPoints, l = h, h = 0; h <= this.numPoints; ++h) {
+                    var n = new OpenLayers.Geometry.Point(j,
+                        l);
+                    n.transform(b, c);
+                    f.push(n);
+                    l += m;
+                    n.y >= a.bottom && !k && (k = n)
+                }
+                this.labelled && (k = new OpenLayers.Geometry.Point(k.x, a.bottom), j = {
+                    value: j,
+                    label: this.labelled ? OpenLayers.Util.getFormattedLonLat(j, "lon", this.labelFormat) : "",
+                    labelAlign: "cb",
+                    xOffset: 0,
+                    yOffset: 2
+                }, this.gratLayer.addFeatures(new OpenLayers.Feature.Vector(k, j)));
+                f = new OpenLayers.Geometry.LineString(f);
+                g.push(new OpenLayers.Feature.Vector(f))
+            }
+            for (h = 0; h < e.length; ++h)
+                if (l = e[h].y, !(-90 > l || 90 < l)) {
+                    f = [];
+                    d = i[0].x;
+                    m = (i[i.length - 1].x - d) / this.numPoints;
+                    j = d;
+                    k = null;
+                    for (d = 0; d <= this.numPoints; ++d) n = new OpenLayers.Geometry.Point(j, l), n.transform(b, c), f.push(n), j += m, n.x < a.right && (k = n);
+                    this.labelled && (k = new OpenLayers.Geometry.Point(a.right, k.y), j = {
+                        value: l,
+                        label: this.labelled ? OpenLayers.Util.getFormattedLonLat(l, "lat", this.labelFormat) : "",
+                        labelAlign: "rb",
+                        xOffset: -2,
+                        yOffset: 2
+                    }, this.gratLayer.addFeatures(new OpenLayers.Feature.Vector(k, j)));
+                    f = new OpenLayers.Geometry.LineString(f);
+                    g.push(new OpenLayers.Feature.Vector(f))
+                }
+            this.gratLayer.addFeatures(g)
+        }
+    },
+    CLASS_NAME: "OpenLayers.Control.Graticule"
+});
+OpenLayers.Layer.UTFGrid = OpenLayers.Class(OpenLayers.Layer.XYZ, {
+    isBaseLayer: !1,
+    projection: new OpenLayers.Projection("EPSG:900913"),
+    useJSONP: !1,
+    tileClass: OpenLayers.Tile.UTFGrid,
+    initialize: function(a) {
+        OpenLayers.Layer.Grid.prototype.initialize.apply(this, [a.name, a.url, {}, a]);
+        this.tileOptions = OpenLayers.Util.extend({
+            utfgridResolution: this.utfgridResolution
+        }, this.tileOptions)
+    },
+    clone: function(a) {
+        null == a && (a = new OpenLayers.Layer.UTFGrid(this.getOptions()));
+        return a = OpenLayers.Layer.Grid.prototype.clone.apply(this, [a])
+    },
+    getFeatureInfo: function(a) {
+        var b = null,
+            a = this.getTileData(a);
+        a.tile && (b = a.tile.getFeatureInfo(a.i, a.j));
+        return b
+    },
+    getFeatureId: function(a) {
+        var b = null,
+            a = this.getTileData(a);
+        a.tile && (b = a.tile.getFeatureId(a.i, a.j));
+        return b
+    },
+    CLASS_NAME: "OpenLayers.Layer.UTFGrid"
+});
+OpenLayers.Layer.ArcGISCache = OpenLayers.Class(OpenLayers.Layer.XYZ, {
+    url: null,
+    tileOrigin: null,
+    tileSize: new OpenLayers.Size(256, 256),
+    useArcGISServer: !0,
+    type: "png",
+    useScales: !1,
+    overrideDPI: !1,
+    initialize: function(a, b, c) {
+        OpenLayers.Layer.XYZ.prototype.initialize.apply(this, arguments);
+        this.resolutions && (this.serverResolutions = this.resolutions, this.maxExtent = this.getMaxExtentForResolution(this.resolutions[0]));
+        if (this.layerInfo) {
+            var d = this.layerInfo,
+                e = new OpenLayers.Bounds(d.fullExtent.xmin, d.fullExtent.ymin,
+                    d.fullExtent.xmax, d.fullExtent.ymax);
+            this.projection = "EPSG:" + d.spatialReference.wkid;
+            this.sphericalMercator = 102100 == d.spatialReference.wkid;
+            this.units = "esriFeet" == d.units ? "ft" : "m";
+            if (d.tileInfo) {
+                this.tileSize = new OpenLayers.Size(d.tileInfo.width || d.tileInfo.cols, d.tileInfo.height || d.tileInfo.rows);
+                this.tileOrigin = new OpenLayers.LonLat(d.tileInfo.origin.x, d.tileInfo.origin.y);
+                var f = new OpenLayers.Geometry.Point(e.left, e.top),
+                    e = new OpenLayers.Geometry.Point(e.right, e.bottom);
+                this.useScales ? this.scales = [] : this.resolutions = [];
+                this.lods = [];
+                for (var g in d.tileInfo.lods)
+                    if (d.tileInfo.lods.hasOwnProperty(g)) {
+                        var h = d.tileInfo.lods[g];
+                        this.useScales ? this.scales.push(h.scale) : this.resolutions.push(h.resolution);
+                        var i = this.getContainingTileCoords(f, h.resolution);
+                        h.startTileCol = i.x;
+                        h.startTileRow = i.y;
+                        i = this.getContainingTileCoords(e, h.resolution);
+                        h.endTileCol = i.x;
+                        h.endTileRow = i.y;
+                        this.lods.push(h)
+                    }
+                this.maxExtent = this.calculateMaxExtentWithLOD(this.lods[0]);
+                this.serverResolutions = this.resolutions;
+                this.overrideDPI &&
+                    d.tileInfo.dpi && (OpenLayers.DOTS_PER_INCH = d.tileInfo.dpi)
+            }
+        }
+    },
+    getContainingTileCoords: function(a, b) {
+        return new OpenLayers.Pixel(Math.max(Math.floor((a.x - this.tileOrigin.lon) / (this.tileSize.w * b)), 0), Math.max(Math.floor((this.tileOrigin.lat - a.y) / (this.tileSize.h * b)), 0))
+    },
+    calculateMaxExtentWithLOD: function(a) {
+        var b = this.tileOrigin.lon + a.startTileCol * this.tileSize.w * a.resolution,
+            c = this.tileOrigin.lat - a.startTileRow * this.tileSize.h * a.resolution;
+        return new OpenLayers.Bounds(b, c - (a.endTileRow - a.startTileRow +
+            1) * this.tileSize.h * a.resolution, b + (a.endTileCol - a.startTileCol + 1) * this.tileSize.w * a.resolution, c)
+    },
+    calculateMaxExtentWithExtent: function(a, b) {
+        var c = new OpenLayers.Geometry.Point(a.left, a.top),
+            d = new OpenLayers.Geometry.Point(a.right, a.bottom),
+            c = this.getContainingTileCoords(c, b),
+            d = this.getContainingTileCoords(d, b);
+        return this.calculateMaxExtentWithLOD({
+            resolution: b,
+            startTileCol: c.x,
+            startTileRow: c.y,
+            endTileCol: d.x,
+            endTileRow: d.y
+        })
+    },
+    getUpperLeftTileCoord: function(a) {
+        return this.getContainingTileCoords(new OpenLayers.Geometry.Point(this.maxExtent.left,
+            this.maxExtent.top), a)
+    },
+    getLowerRightTileCoord: function(a) {
+        return this.getContainingTileCoords(new OpenLayers.Geometry.Point(this.maxExtent.right, this.maxExtent.bottom), a)
+    },
+    getMaxExtentForResolution: function(a) {
+        var b = this.getUpperLeftTileCoord(a),
+            c = this.getLowerRightTileCoord(a),
+            d = this.tileOrigin.lon + b.x * this.tileSize.w * a,
+            e = this.tileOrigin.lat - b.y * this.tileSize.h * a;
+        return new OpenLayers.Bounds(d, e - (c.y - b.y + 1) * this.tileSize.h * a, d + (c.x - b.x + 1) * this.tileSize.w * a, e)
+    },
+    clone: function(a) {
+        null == a && (a = new OpenLayers.Layer.ArcGISCache(this.name,
+            this.url, this.options));
+        return OpenLayers.Layer.XYZ.prototype.clone.apply(this, [a])
+    },
+    getMaxExtent: function() {
+        return this.maxExtent = this.getMaxExtentForResolution(this.map.getResolution())
+    },
+    getTileOrigin: function() {
+        var a = this.getMaxExtent();
+        return new OpenLayers.LonLat(a.left, a.bottom)
+    },
+    getURL: function(a) {
+        var b = this.getResolution(),
+            c = this.tileOrigin.lon + b * this.tileSize.w / 2,
+            d = this.tileOrigin.lat - b * this.tileSize.h / 2,
+            a = a.getCenterLonLat(),
+            c = Math.round(Math.abs((a.lon - c) / (b * this.tileSize.w))),
+            d = Math.round(Math.abs((d -
+                a.lat) / (b * this.tileSize.h))),
+            a = this.map.getZoom();
+        if (this.lods) {
+            if (b = this.lods[this.map.getZoom()], c < b.startTileCol || c > b.endTileCol || d < b.startTileRow || d > b.endTileRow) return null
+        } else {
+            var e = this.getUpperLeftTileCoord(b),
+                b = this.getLowerRightTileCoord(b);
+            if (c < e.x || c >= b.x || d < e.y || d >= b.y) return null
+        }
+        b = this.url;
+        e = "" + c + d + a;
+        OpenLayers.Util.isArray(b) && (b = this.selectUrl(e, b));
+        this.useArcGISServer ? b += "/tile/${z}/${y}/${x}" : (c = "C" + this.zeroPad(c, 8, 16), d = "R" + this.zeroPad(d, 8, 16), a = "L" + this.zeroPad(a, 2, 16), b =
+            b + "/${z}/${y}/${x}." + this.type);
+        b = OpenLayers.String.format(b, {
+            x: c,
+            y: d,
+            z: a
+        });
+        return OpenLayers.Util.urlAppend(b, OpenLayers.Util.getParameterString(this.params))
+    },
+    zeroPad: function(a, b, c) {
+        for (a = a.toString(c || 10); a.length < b;) a = "0" + a;
+        return a
+    },
+    CLASS_NAME: "OpenLayers.Layer.ArcGISCache"
+});
+OpenLayers.Control.WMSGetFeatureInfo = OpenLayers.Class(OpenLayers.Control, {
+    hover: !1,
+    drillDown: !1,
+    maxFeatures: 10,
+    clickCallback: "click",
+    output: "features",
+    layers: null,
+    queryVisible: !1,
+    url: null,
+    layerUrls: null,
+    infoFormat: "text/html",
+    vendorParams: {},
+    format: null,
+    formatOptions: null,
+    handlerOptions: null,
+    handler: null,
+    hoverRequest: null,
+    initialize: function(a) {
+        a = a || {};
+        a.handlerOptions = a.handlerOptions || {};
+        OpenLayers.Control.prototype.initialize.apply(this, [a]);
+        this.format || (this.format = new OpenLayers.Format.WMSGetFeatureInfo(a.formatOptions));
+        !0 === this.drillDown && (this.hover = !1);
+        this.hover ? this.handler = new OpenLayers.Handler.Hover(this, {
+            move: this.cancelHover,
+            pause: this.getInfoForHover
+        }, OpenLayers.Util.extend(this.handlerOptions.hover || {}, {
+            delay: 250
+        })) : (a = {}, a[this.clickCallback] = this.getInfoForClick, this.handler = new OpenLayers.Handler.Click(this, a, this.handlerOptions.click || {}))
+    },
+    getInfoForClick: function(a) {
+        this.events.triggerEvent("beforegetfeatureinfo", {
+            xy: a.xy
+        });
+        OpenLayers.Element.addClass(this.map.viewPortDiv, "olCursorWait");
+        this.request(a.xy, {})
+    },
+    getInfoForHover: function(a) {
+        this.events.triggerEvent("beforegetfeatureinfo", {
+            xy: a.xy
+        });
+        this.request(a.xy, {
+            hover: !0
+        })
+    },
+    cancelHover: function() {
+        this.hoverRequest && (this.hoverRequest.abort(), this.hoverRequest = null)
+    },
+    findLayers: function() {
+        for (var a = this.layers || this.map.layers, b = [], c, d, e = a.length - 1; 0 <= e; --e)
+            if (c = a[e], c instanceof OpenLayers.Layer.WMS && (!this.queryVisible || c.getVisibility())) d = OpenLayers.Util.isArray(c.url) ? c.url[0] : c.url, !1 === this.drillDown && !this.url && (this.url = d), (!0 === this.drillDown ||
+                this.urlMatches(d)) && b.push(c);
+        return b
+    },
+    urlMatches: function(a) {
+        var b = OpenLayers.Util.isEquivalentUrl(this.url, a);
+        if (!b && this.layerUrls)
+            for (var c = 0, d = this.layerUrls.length; c < d; ++c)
+                if (OpenLayers.Util.isEquivalentUrl(this.layerUrls[c], a)) {
+                    b = !0;
+                    break
+                }
+        return b
+    },
+    buildWMSOptions: function(a, b, c, d) {
+        for (var e = [], f = [], g = 0, h = b.length; g < h; g++) null != b[g].params.LAYERS && (e = e.concat(b[g].params.LAYERS), f = f.concat(this.getStyleNames(b[g])));
+        b = b[0];
+        g = this.map.getProjection();
+        (h = b.projection) && h.equals(this.map.getProjectionObject()) &&
+            (g = h.getCode());
+        d = OpenLayers.Util.extend({
+            service: "WMS",
+            version: b.params.VERSION,
+            request: "GetFeatureInfo",
+            exceptions: b.params.EXCEPTIONS,
+            bbox: this.map.getExtent().toBBOX(null, b.reverseAxisOrder()),
+            feature_count: this.maxFeatures,
+            height: this.map.getSize().h,
+            width: this.map.getSize().w,
+            format: d,
+            info_format: b.params.INFO_FORMAT || this.infoFormat
+        }, 1.3 <= parseFloat(b.params.VERSION) ? {
+            crs: g,
+            i: parseInt(c.x),
+            j: parseInt(c.y)
+        } : {
+            srs: g,
+            x: parseInt(c.x),
+            y: parseInt(c.y)
+        });
+        0 != e.length && (d = OpenLayers.Util.extend({
+            layers: e,
+            query_layers: e,
+            styles: f
+        }, d));
+        OpenLayers.Util.applyDefaults(d, this.vendorParams);
+        return {
+            url: a,
+            params: OpenLayers.Util.upperCaseObject(d),
+            callback: function(b) {
+                this.handleResponse(c, b, a)
+            },
+            scope: this
+        }
+    },
+    getStyleNames: function(a) {
+        return a.params.STYLES ? a.params.STYLES : OpenLayers.Util.isArray(a.params.LAYERS) ? Array(a.params.LAYERS.length) : a.params.LAYERS.replace(/[^,]/g, "")
+    },
+    request: function(a, b) {
+        var c = this.findLayers();
+        if (0 == c.length) this.events.triggerEvent("nogetfeatureinfo"), OpenLayers.Element.removeClass(this.map.viewPortDiv,
+            "olCursorWait");
+        else if (b = b || {}, !1 === this.drillDown) {
+            var c = this.buildWMSOptions(this.url, c, a, c[0].params.FORMAT),
+                d = OpenLayers.Request.GET(c);
+            !0 === b.hover && (this.hoverRequest = d)
+        } else {
+            this._numRequests = this._requestCount = 0;
+            this.features = [];
+            for (var d = {}, e, f = 0, g = c.length; f < g; f++) {
+                var h = c[f];
+                e = OpenLayers.Util.isArray(h.url) ? h.url[0] : h.url;
+                e in d ? d[e].push(h) : (this._numRequests++, d[e] = [h])
+            }
+            for (e in d) c = d[e], c = this.buildWMSOptions(e, c, a, c[0].params.FORMAT), OpenLayers.Request.GET(c)
+        }
+    },
+    triggerGetFeatureInfo: function(a,
+        b, c) {
+        this.events.triggerEvent("getfeatureinfo", {
+            text: a.responseText,
+            features: c,
+            request: a,
+            xy: b
+        });
+        OpenLayers.Element.removeClass(this.map.viewPortDiv, "olCursorWait")
+    },
+    handleResponse: function(a, b, c) {
+        var d = b.responseXML;
+        if (!d || !d.documentElement) d = b.responseText;
+        d = this.format.read(d);
+        !1 === this.drillDown ? this.triggerGetFeatureInfo(b, a, d) : (this._requestCount++, this._features = "object" === this.output ? (this._features || []).concat({
+                url: c,
+                features: d
+            }) : (this._features || []).concat(d), this._requestCount === this._numRequests &&
+            (this.triggerGetFeatureInfo(b, a, this._features.concat()), delete this._features, delete this._requestCount, delete this._numRequests))
+    },
+    CLASS_NAME: "OpenLayers.Control.WMSGetFeatureInfo"
+});
+OpenLayers.Format.WMSCapabilities.v1_3_0 = OpenLayers.Class(OpenLayers.Format.WMSCapabilities.v1_3, {
+    version: "1.3.0",
+    CLASS_NAME: "OpenLayers.Format.WMSCapabilities.v1_3_0"
+});
+OpenLayers.Format.SOSGetFeatureOfInterest = OpenLayers.Class(OpenLayers.Format.XML, {
+    VERSION: "1.0.0",
+    namespaces: {
+        sos: "http://www.opengis.net/sos/1.0",
+        gml: "http://www.opengis.net/gml",
+        sa: "http://www.opengis.net/sampling/1.0",
+        xsi: "http://www.w3.org/2001/XMLSchema-instance"
+    },
+    schemaLocation: "http://www.opengis.net/sos/1.0 http://schemas.opengis.net/sos/1.0.0/sosAll.xsd",
+    defaultPrefix: "sos",
+    regExes: {
+        trimSpace: /^\s*|\s*$/g,
+        removeSpace: /\s*/g,
+        splitSpace: /\s+/,
+        trimComma: /\s*,\s*/g
+    },
+    read: function(a) {
+        "string" ==
+        typeof a && (a = OpenLayers.Format.XML.prototype.read.apply(this, [a]));
+        a && 9 == a.nodeType && (a = a.documentElement);
+        var b = {
+            features: []
+        };
+        this.readNode(a, b);
+        for (var a = [], c = 0, d = b.features.length; c < d; c++) {
+            var e = b.features[c];
+            this.internalProjection && (this.externalProjection && e.components[0]) && e.components[0].transform(this.externalProjection, this.internalProjection);
+            e = new OpenLayers.Feature.Vector(e.components[0], e.attributes);
+            a.push(e)
+        }
+        return a
+    },
+    readers: {
+        sa: {
+            SamplingPoint: function(a, b) {
+                if (!b.attributes) {
+                    var c = {
+                        attributes: {}
+                    };
+                    b.features.push(c);
+                    b = c
+                }
+                b.attributes.id = this.getAttributeNS(a, this.namespaces.gml, "id");
+                this.readChildNodes(a, b)
+            },
+            position: function(a, b) {
+                this.readChildNodes(a, b)
+            }
+        },
+        gml: OpenLayers.Util.applyDefaults({
+            FeatureCollection: function(a, b) {
+                this.readChildNodes(a, b)
+            },
+            featureMember: function(a, b) {
+                var c = {
+                    attributes: {}
+                };
+                b.features.push(c);
+                this.readChildNodes(a, c)
+            },
+            name: function(a, b) {
+                b.attributes.name = this.getChildValue(a)
+            },
+            pos: function(a, b) {
+                this.externalProjection || (this.externalProjection = new OpenLayers.Projection(a.getAttribute("srsName")));
+                OpenLayers.Format.GML.v3.prototype.readers.gml.pos.apply(this, [a, b])
+            }
+        }, OpenLayers.Format.GML.v3.prototype.readers.gml)
+    },
+    writers: {
+        sos: {
+            GetFeatureOfInterest: function(a) {
+                for (var b = this.createElementNSPlus("GetFeatureOfInterest", {
+                        attributes: {
+                            version: this.VERSION,
+                            service: "SOS",
+                            "xsi:schemaLocation": this.schemaLocation
+                        }
+                    }), c = 0, d = a.fois.length; c < d; c++) this.writeNode("FeatureOfInterestId", {
+                    foi: a.fois[c]
+                }, b);
+                return b
+            },
+            FeatureOfInterestId: function(a) {
+                return this.createElementNSPlus("FeatureOfInterestId", {
+                    value: a.foi
+                })
+            }
+        }
+    },
+    CLASS_NAME: "OpenLayers.Format.SOSGetFeatureOfInterest"
+});
+OpenLayers.Format.SOSGetObservation = OpenLayers.Class(OpenLayers.Format.XML, {
+    namespaces: {
+        ows: "http://www.opengis.net/ows",
+        gml: "http://www.opengis.net/gml",
+        sos: "http://www.opengis.net/sos/1.0",
+        ogc: "http://www.opengis.net/ogc",
+        om: "http://www.opengis.net/om/1.0",
+        sa: "http://www.opengis.net/sampling/1.0",
+        xlink: "http://www.w3.org/1999/xlink",
+        xsi: "http://www.w3.org/2001/XMLSchema-instance"
+    },
+    regExes: {
+        trimSpace: /^\s*|\s*$/g,
+        removeSpace: /\s*/g,
+        splitSpace: /\s+/,
+        trimComma: /\s*,\s*/g
+    },
+    VERSION: "1.0.0",
+    schemaLocation: "http://www.opengis.net/sos/1.0 http://schemas.opengis.net/sos/1.0.0/sosGetObservation.xsd",
+    defaultPrefix: "sos",
+    read: function(a) {
+        "string" == typeof a && (a = OpenLayers.Format.XML.prototype.read.apply(this, [a]));
+        a && 9 == a.nodeType && (a = a.documentElement);
+        var b = {
+            measurements: [],
+            observations: []
+        };
+        this.readNode(a, b);
+        return b
+    },
+    write: function(a) {
+        a = this.writeNode("sos:GetObservation", a);
+        a.setAttribute("xmlns:om", this.namespaces.om);
+        a.setAttribute("xmlns:ogc", this.namespaces.ogc);
+        this.setAttributeNS(a, this.namespaces.xsi, "xsi:schemaLocation", this.schemaLocation);
+        return OpenLayers.Format.XML.prototype.write.apply(this, [a])
+    },
+    readers: {
+        om: {
+            ObservationCollection: function(a, b) {
+                b.id = this.getAttributeNS(a, this.namespaces.gml, "id");
+                this.readChildNodes(a, b)
+            },
+            member: function(a, b) {
+                this.readChildNodes(a, b)
+            },
+            Measurement: function(a, b) {
+                var c = {};
+                b.measurements.push(c);
+                this.readChildNodes(a, c)
+            },
+            Observation: function(a, b) {
+                var c = {};
+                b.observations.push(c);
+                this.readChildNodes(a, c)
+            },
+            samplingTime: function(a, b) {
+                var c = {};
+                b.samplingTime = c;
+                this.readChildNodes(a, c)
+            },
+            observedProperty: function(a, b) {
+                b.observedProperty = this.getAttributeNS(a, this.namespaces.xlink,
+                    "href");
+                this.readChildNodes(a, b)
+            },
+            procedure: function(a, b) {
+                b.procedure = this.getAttributeNS(a, this.namespaces.xlink, "href");
+                this.readChildNodes(a, b)
+            },
+            featureOfInterest: function(a, b) {
+                var c = {
+                    features: []
+                };
+                b.fois = [];
+                b.fois.push(c);
+                this.readChildNodes(a, c);
+                for (var d = [], e = 0, f = c.features.length; e < f; e++) {
+                    var g = c.features[e];
+                    d.push(new OpenLayers.Feature.Vector(g.components[0], g.attributes))
+                }
+                c.features = d
+            },
+            result: function(a, b) {
+                var c = {};
+                b.result = c;
+                "" !== this.getChildValue(a) ? (c.value = this.getChildValue(a), c.uom =
+                    a.getAttribute("uom")) : this.readChildNodes(a, c)
+            }
+        },
+        sa: OpenLayers.Format.SOSGetFeatureOfInterest.prototype.readers.sa,
+        gml: OpenLayers.Util.applyDefaults({
+            TimeInstant: function(a, b) {
+                var c = {};
+                b.timeInstant = c;
+                this.readChildNodes(a, c)
+            },
+            timePosition: function(a, b) {
+                b.timePosition = this.getChildValue(a)
+            }
+        }, OpenLayers.Format.SOSGetFeatureOfInterest.prototype.readers.gml)
+    },
+    writers: {
+        sos: {
+            GetObservation: function(a) {
+                var b = this.createElementNSPlus("GetObservation", {
+                    attributes: {
+                        version: this.VERSION,
+                        service: "SOS"
+                    }
+                });
+                this.writeNode("offering",
+                    a, b);
+                a.eventTime && this.writeNode("eventTime", a, b);
+                for (var c in a.procedures) this.writeNode("procedure", a.procedures[c], b);
+                for (var d in a.observedProperties) this.writeNode("observedProperty", a.observedProperties[d], b);
+                a.foi && this.writeNode("featureOfInterest", a.foi, b);
+                this.writeNode("responseFormat", a, b);
+                a.resultModel && this.writeNode("resultModel", a, b);
+                a.responseMode && this.writeNode("responseMode", a, b);
+                return b
+            },
+            featureOfInterest: function(a) {
+                var b = this.createElementNSPlus("featureOfInterest");
+                this.writeNode("ObjectID",
+                    a.objectId, b);
+                return b
+            },
+            ObjectID: function(a) {
+                return this.createElementNSPlus("ObjectID", {
+                    value: a
+                })
+            },
+            responseFormat: function(a) {
+                return this.createElementNSPlus("responseFormat", {
+                    value: a.responseFormat
+                })
+            },
+            procedure: function(a) {
+                return this.createElementNSPlus("procedure", {
+                    value: a
+                })
+            },
+            offering: function(a) {
+                return this.createElementNSPlus("offering", {
+                    value: a.offering
+                })
+            },
+            observedProperty: function(a) {
+                return this.createElementNSPlus("observedProperty", {
+                    value: a
+                })
+            },
+            eventTime: function(a) {
+                var b = this.createElementNSPlus("eventTime");
+                "latest" === a.eventTime && this.writeNode("ogc:TM_Equals", a, b);
+                return b
+            },
+            resultModel: function(a) {
+                return this.createElementNSPlus("resultModel", {
+                    value: a.resultModel
+                })
+            },
+            responseMode: function(a) {
+                return this.createElementNSPlus("responseMode", {
+                    value: a.responseMode
+                })
+            }
+        },
+        ogc: {
+            TM_Equals: function(a) {
+                var b = this.createElementNSPlus("ogc:TM_Equals");
+                this.writeNode("ogc:PropertyName", {
+                    property: "urn:ogc:data:time:iso8601"
+                }, b);
+                "latest" === a.eventTime && this.writeNode("gml:TimeInstant", {
+                    value: "latest"
+                }, b);
+                return b
+            },
+            PropertyName: function(a) {
+                return this.createElementNSPlus("ogc:PropertyName", {
+                    value: a.property
+                })
+            }
+        },
+        gml: {
+            TimeInstant: function(a) {
+                var b = this.createElementNSPlus("gml:TimeInstant");
+                this.writeNode("gml:timePosition", a, b);
+                return b
+            },
+            timePosition: function(a) {
+                return this.createElementNSPlus("gml:timePosition", {
+                    value: a.value
+                })
+            }
+        }
+    },
+    CLASS_NAME: "OpenLayers.Format.SOSGetObservation"
+});
+OpenLayers.Control.UTFGrid = OpenLayers.Class(OpenLayers.Control, {
+    autoActivate: !0,
+    layers: null,
+    defaultHandlerOptions: {
+        delay: 300,
+        pixelTolerance: 4,
+        stopMove: !1,
+        single: !0,
+        "double": !1,
+        stopSingle: !1,
+        stopDouble: !1
+    },
+    handlerMode: "click",
+    setHandler: function(a) {
+        this.handlerMode = a;
+        this.resetHandler()
+    },
+    resetHandler: function() {
+        this.handler && (this.handler.deactivate(), this.handler.destroy(), this.handler = null);
+        "hover" == this.handlerMode ? this.handler = new OpenLayers.Handler.Hover(this, {
+                pause: this.handleEvent,
+                move: this.reset
+            },
+            this.handlerOptions) : "click" == this.handlerMode ? this.handler = new OpenLayers.Handler.Click(this, {
+            click: this.handleEvent
+        }, this.handlerOptions) : "move" == this.handlerMode && (this.handler = new OpenLayers.Handler.Hover(this, {
+            pause: this.handleEvent,
+            move: this.handleEvent
+        }, this.handlerOptions));
+        return this.handler ? !0 : !1
+    },
+    initialize: function(a) {
+        a = a || {};
+        a.handlerOptions = a.handlerOptions || this.defaultHandlerOptions;
+        OpenLayers.Control.prototype.initialize.apply(this, [a]);
+        this.resetHandler()
+    },
+    handleEvent: function(a) {
+        if (null ==
+            a) this.reset();
+        else {
+            var b = this.map.getLonLatFromPixel(a.xy);
+            if (b) {
+                var c = this.findLayers();
+                if (0 < c.length) {
+                    for (var d = {}, e, f, g = 0, h = c.length; g < h; g++) e = c[g], f = OpenLayers.Util.indexOf(this.map.layers, e), d[f] = e.getFeatureInfo(b);
+                    this.callback(d, b, a.xy)
+                }
+            }
+        }
+    },
+    callback: function() {},
+    reset: function() {
+        this.callback(null)
+    },
+    findLayers: function() {
+        for (var a = this.layers || this.map.layers, b = [], c, d = a.length - 1; 0 <= d; --d) c = a[d], c instanceof OpenLayers.Layer.UTFGrid && b.push(c);
+        return b
+    },
+    CLASS_NAME: "OpenLayers.Control.UTFGrid"
+});
+OpenLayers.Format.CQL = function() {
+    function a(a) {
+        function b() {
+            var a = e.pop();
+            switch (a.type) {
+                case "LOGICAL":
+                    var c = b(),
+                        g = b();
+                    return new OpenLayers.Filter.Logical({
+                        filters: [g, c],
+                        type: f[a.text.toUpperCase()]
+                    });
+                case "NOT":
+                    return c = b(), new OpenLayers.Filter.Logical({
+                        filters: [c],
+                        type: OpenLayers.Filter.Logical.NOT
+                    });
+                case "BETWEEN":
+                    return e.pop(), g = b(), a = b(), c = b(), new OpenLayers.Filter.Comparison({
+                        property: c,
+                        lowerBoundary: a,
+                        upperBoundary: g,
+                        type: OpenLayers.Filter.Comparison.BETWEEN
+                    });
+                case "COMPARISON":
+                    return g =
+                        b(), c = b(), new OpenLayers.Filter.Comparison({
+                            property: c,
+                            value: g,
+                            type: d[a.text.toUpperCase()]
+                        });
+                case "VALUE":
+                    return /^'.*'$/.test(a.text) ? a.text.substr(1, a.text.length - 2) : Number(a.text);
+                case "SPATIAL":
+                    switch (a.text.toUpperCase()) {
+                        case "BBOX":
+                            var c = b(),
+                                a = b(),
+                                g = b(),
+                                h = b(),
+                                i = b();
+                            return new OpenLayers.Filter.Spatial({
+                                type: OpenLayers.Filter.Spatial.BBOX,
+                                property: i,
+                                value: OpenLayers.Bounds.fromArray([h, g, a, c])
+                            });
+                        case "INTERSECTS":
+                            return g = b(), c = b(), new OpenLayers.Filter.Spatial({
+                                type: OpenLayers.Filter.Spatial.INTERSECTS,
+                                property: c,
+                                value: g
+                            });
+                        case "WITHIN":
+                            return g = b(), c = b(), new OpenLayers.Filter.Spatial({
+                                type: OpenLayers.Filter.Spatial.WITHIN,
+                                property: c,
+                                value: g
+                            });
+                        case "CONTAINS":
+                            return g = b(), c = b(), new OpenLayers.Filter.Spatial({
+                                type: OpenLayers.Filter.Spatial.CONTAINS,
+                                property: c,
+                                value: g
+                            });
+                        case "DWITHIN":
+                            return a = b(), g = b(), c = b(), new OpenLayers.Filter.Spatial({
+                                type: OpenLayers.Filter.Spatial.DWITHIN,
+                                value: g,
+                                property: c,
+                                distance: Number(a)
+                            })
+                    }
+                case "GEOMETRY":
+                    return OpenLayers.Geometry.fromWKT(a.text);
+                default:
+                    return a.text
+            }
+        }
+        for (var c = [], e = []; a.length;) {
+            var g = a.shift();
+            switch (g.type) {
+                case "PROPERTY":
+                case "GEOMETRY":
+                case "VALUE":
+                    e.push(g);
+                    break;
+                case "COMPARISON":
+                case "BETWEEN":
+                case "LOGICAL":
+                    for (var i = h[g.type]; 0 < c.length && h[c[c.length - 1].type] <= i;) e.push(c.pop());
+                    c.push(g);
+                    break;
+                case "SPATIAL":
+                case "NOT":
+                case "LPAREN":
+                    c.push(g);
+                    break;
+                case "RPAREN":
+                    for (; 0 < c.length && "LPAREN" != c[c.length - 1].type;) e.push(c.pop());
+                    c.pop();
+                    0 < c.length && "SPATIAL" == c[c.length - 1].type && e.push(c.pop());
+                case "COMMA":
+                case "END":
+                    break;
+                default:
+                    throw Error("Unknown token type " +
+                        g.type);
+            }
+        }
+        for (; 0 < c.length;) e.push(c.pop());
+        a = b();
+        if (0 < e.length) {
+            a = "Remaining tokens after building AST: \n";
+            for (c = e.length - 1; 0 <= c; c--) a += e[c].type + ": " + e[c].text + "\n";
+            throw Error(a);
+        }
+        return a
+    }
+    var b = {
+            PROPERTY: /^[_a-zA-Z]\w*/,
+            COMPARISON: /^(=|<>|<=|<|>=|>|LIKE)/i,
+            COMMA: /^,/,
+            LOGICAL: /^(AND|OR)/i,
+            VALUE: /^('\w+'|\d+(\.\d*)?|\.\d+)/,
+            LPAREN: /^\(/,
+            RPAREN: /^\)/,
+            SPATIAL: /^(BBOX|INTERSECTS|DWITHIN|WITHIN|CONTAINS)/i,
+            NOT: /^NOT/i,
+            BETWEEN: /^BETWEEN/i,
+            GEOMETRY: function(a) {
+                var b = /^(POINT|LINESTRING|POLYGON|MULTIPOINT|MULTILINESTRING|MULTIPOLYGON|GEOMETRYCOLLECTION)/.exec(a);
+                if (b) {
+                    var c = a.length,
+                        b = a.indexOf("(", b[0].length);
+                    if (-1 < b)
+                        for (var d = 1; b < c && 0 < d;) switch (b++, a.charAt(b)) {
+                            case "(":
+                                d++;
+                                break;
+                            case ")":
+                                d--
+                        }
+                    return [a.substr(0, b + 1)]
+                }
+            },
+            END: /^$/
+        },
+        c = {
+            LPAREN: ["GEOMETRY", "SPATIAL", "PROPERTY", "VALUE", "LPAREN"],
+            RPAREN: ["NOT", "LOGICAL", "END", "RPAREN"],
+            PROPERTY: ["COMPARISON", "BETWEEN", "COMMA"],
+            BETWEEN: ["VALUE"],
+            COMPARISON: ["VALUE"],
+            COMMA: ["GEOMETRY", "VALUE", "PROPERTY"],
+            VALUE: ["LOGICAL", "COMMA", "RPAREN", "END"],
+            SPATIAL: ["LPAREN"],
+            LOGICAL: ["NOT", "VALUE", "SPATIAL", "PROPERTY", "LPAREN"],
+            NOT: ["PROPERTY", "LPAREN"],
+            GEOMETRY: ["COMMA", "RPAREN"]
+        },
+        d = {
+            "=": OpenLayers.Filter.Comparison.EQUAL_TO,
+            "<>": OpenLayers.Filter.Comparison.NOT_EQUAL_TO,
+            "<": OpenLayers.Filter.Comparison.LESS_THAN,
+            "<=": OpenLayers.Filter.Comparison.LESS_THAN_OR_EQUAL_TO,
+            ">": OpenLayers.Filter.Comparison.GREATER_THAN,
+            ">=": OpenLayers.Filter.Comparison.GREATER_THAN_OR_EQUAL_TO,
+            LIKE: OpenLayers.Filter.Comparison.LIKE,
+            BETWEEN: OpenLayers.Filter.Comparison.BETWEEN
+        },
+        e = {},
+        f = {
+            AND: OpenLayers.Filter.Logical.AND,
+            OR: OpenLayers.Filter.Logical.OR
+        },
+        g = {},
+        h = {
+            RPAREN: 3,
+            LOGICAL: 2,
+            COMPARISON: 1
+        },
+        i;
+    for (i in d) d.hasOwnProperty(i) && (e[d[i]] = i);
+    for (i in f) f.hasOwnProperty(i) && (g[f[i]] = i);
+    return OpenLayers.Class(OpenLayers.Format, {
+        read: function(d) {
+            var e = d,
+                d = [],
+                f, g = ["NOT", "GEOMETRY", "SPATIAL", "PROPERTY", "LPAREN"];
+            do {
+                a: {
+                    f = g;
+                    for (var h = void 0, g = void 0, i = f.length, h = 0; h < i; h++) {
+                        var g = f[h],
+                            p = b[g] instanceof RegExp ? b[g].exec(e) : (0, b[g])(e);
+                        if (p) {
+                            f = p[0];
+                            e = e.substr(f.length).replace(/^\s*/, "");
+                            f = {
+                                type: g,
+                                text: f,
+                                remainder: e
+                            };
+                            break a
+                        }
+                    }
+                    d = "ERROR: In parsing: [" + e + "], expected one of: ";
+                    for (h = 0; h < i; h++) g = f[h], d += "\n    " + g + ": " + b[g];
+                    throw Error(d);
+                }
+                e = f.remainder;g = c[f.type];
+                if ("END" != f.type && !g) throw Error("No follows list for " + f.type);d.push(f)
+            } while ("END" != f.type);
+            d = a(d);
+            this.keepData && (this.data = d);
+            return d
+        },
+        write: function(a) {
+            if (a instanceof OpenLayers.Geometry) return a.toString();
+            switch (a.CLASS_NAME) {
+                case "OpenLayers.Filter.Spatial":
+                    switch (a.type) {
+                        case OpenLayers.Filter.Spatial.BBOX:
+                            return "BBOX(" + a.property + "," + a.value.toBBOX() + ")";
+                        case OpenLayers.Filter.Spatial.DWITHIN:
+                            return "DWITHIN(" +
+                                a.property + ", " + this.write(a.value) + ", " + a.distance + ")";
+                        case OpenLayers.Filter.Spatial.WITHIN:
+                            return "WITHIN(" + a.property + ", " + this.write(a.value) + ")";
+                        case OpenLayers.Filter.Spatial.INTERSECTS:
+                            return "INTERSECTS(" + a.property + ", " + this.write(a.value) + ")";
+                        case OpenLayers.Filter.Spatial.CONTAINS:
+                            return "CONTAINS(" + a.property + ", " + this.write(a.value) + ")";
+                        default:
+                            throw Error("Unknown spatial filter type: " + a.type);
+                    }
+                case "OpenLayers.Filter.Logical":
+                    if (a.type == OpenLayers.Filter.Logical.NOT) return "NOT (" + this.write(a.filters[0]) +
+                        ")";
+                    for (var b = "(", c = !0, d = 0; d < a.filters.length; d++) c ? c = !1 : b += ") " + g[a.type] + " (", b += this.write(a.filters[d]);
+                    return b + ")";
+                case "OpenLayers.Filter.Comparison":
+                    return a.type == OpenLayers.Filter.Comparison.BETWEEN ? a.property + " BETWEEN " + this.write(a.lowerBoundary) + " AND " + this.write(a.upperBoundary) : a.property + " " + e[a.type] + " " + this.write(a.value);
+                case void 0:
+                    if ("string" === typeof a) return "'" + a + "'";
+                    if ("number" === typeof a) return "" + a;
+                default:
+                    throw Error("Can't encode: " + a.CLASS_NAME + " " + a);
+            }
+        },
+        CLASS_NAME: "OpenLayers.Format.CQL"
+    })
+}();
+OpenLayers.Control.Split = OpenLayers.Class(OpenLayers.Control, {
+    layer: null,
+    source: null,
+    sourceOptions: null,
+    tolerance: null,
+    edge: !0,
+    deferDelete: !1,
+    mutual: !0,
+    targetFilter: null,
+    sourceFilter: null,
+    handler: null,
+    initialize: function(a) {
+        OpenLayers.Control.prototype.initialize.apply(this, [a]);
+        this.options = a || {};
+        this.options.source && this.setSource(this.options.source)
+    },
+    setSource: function(a) {
+        this.active ? (this.deactivate(), this.handler && (this.handler.destroy(), delete this.handler), this.source = a, this.activate()) : this.source =
+            a
+    },
+    activate: function() {
+        var a = OpenLayers.Control.prototype.activate.call(this);
+        if (a)
+            if (this.source) {
+                if (this.source.events) this.source.events.on({
+                    sketchcomplete: this.onSketchComplete,
+                    afterfeaturemodified: this.afterFeatureModified,
+                    scope: this
+                })
+            } else this.handler || (this.handler = new OpenLayers.Handler.Path(this, {
+                done: function(a) {
+                    this.onSketchComplete({
+                        feature: new OpenLayers.Feature.Vector(a)
+                    })
+                }
+            }, {
+                layerOptions: this.sourceOptions
+            })), this.handler.activate();
+        return a
+    },
+    deactivate: function() {
+        var a = OpenLayers.Control.prototype.deactivate.call(this);
+        a && this.source && this.source.events && this.layer.events.un({
+            sketchcomplete: this.onSketchComplete,
+            afterfeaturemodified: this.afterFeatureModified,
+            scope: this
+        });
+        return a
+    },
+    onSketchComplete: function(a) {
+        this.feature = null;
+        return !this.considerSplit(a.feature)
+    },
+    afterFeatureModified: function(a) {
+        a.modified && "function" === typeof a.feature.geometry.split && (this.feature = a.feature, this.considerSplit(a.feature))
+    },
+    removeByGeometry: function(a, b) {
+        for (var c = 0, d = a.length; c < d; ++c)
+            if (a[c].geometry === b) {
+                a.splice(c, 1);
+                break
+            }
+    },
+    isEligible: function(a) {
+        return a.geometry ? a.state !== OpenLayers.State.DELETE && "function" === typeof a.geometry.split && this.feature !== a && (!this.targetFilter || this.targetFilter.evaluate(a.attributes)) : !1
+    },
+    considerSplit: function(a) {
+        var b = !1,
+            c = !1;
+        if (!this.sourceFilter || this.sourceFilter.evaluate(a.attributes)) {
+            for (var d = this.layer && this.layer.features || [], e, f, g = [], h = [], i = this.layer === this.source && this.mutual, j = {
+                    edge: this.edge,
+                    tolerance: this.tolerance,
+                    mutual: i
+                }, k = [a.geometry], l, m, n, o = 0, p = d.length; o < p; ++o)
+                if (l =
+                    d[o], this.isEligible(l)) {
+                    m = [l.geometry];
+                    for (var q = 0; q < k.length; ++q) {
+                        n = k[q];
+                        for (var r = 0; r < m.length; ++r)
+                            if (e = m[r], n.getBounds().intersectsBounds(e.getBounds()) && (e = n.split(e, j)))
+                                if (f = this.events.triggerEvent("beforesplit", {
+                                        source: a,
+                                        target: l
+                                    }), !1 !== f && (i && (f = e[0], 1 < f.length && (f.unshift(q, 1), Array.prototype.splice.apply(k, f), q += f.length - 3), e = e[1]), 1 < e.length)) e.unshift(r, 1), Array.prototype.splice.apply(m, e), r += e.length - 3
+                    }
+                    m && 1 < m.length && (this.geomsToFeatures(l, m), this.events.triggerEvent("split", {
+                        original: l,
+                        features: m
+                    }), Array.prototype.push.apply(g, m), h.push(l), c = !0)
+                }
+            k && 1 < k.length && (this.geomsToFeatures(a, k), this.events.triggerEvent("split", {
+                original: a,
+                features: k
+            }), Array.prototype.push.apply(g, k), h.push(a), b = !0);
+            if (b || c) {
+                if (this.deferDelete) {
+                    d = [];
+                    o = 0;
+                    for (p = h.length; o < p; ++o) c = h[o], c.state === OpenLayers.State.INSERT ? d.push(c) : (c.state = OpenLayers.State.DELETE, this.layer.drawFeature(c));
+                    this.layer.destroyFeatures(d, {
+                        silent: !0
+                    });
+                    o = 0;
+                    for (p = g.length; o < p; ++o) g[o].state = OpenLayers.State.INSERT
+                } else this.layer.destroyFeatures(h, {
+                    silent: !0
+                });
+                this.layer.addFeatures(g, {
+                    silent: !0
+                });
+                this.events.triggerEvent("aftersplit", {
+                    source: a,
+                    features: g
+                })
+            }
+        }
+        return b
+    },
+    geomsToFeatures: function(a, b) {
+        var c = a.clone();
+        delete c.geometry;
+        for (var d, e = 0, f = b.length; e < f; ++e) d = c.clone(), d.geometry = b[e], d.state = OpenLayers.State.INSERT, b[e] = d
+    },
+    destroy: function() {
+        this.active && this.deactivate();
+        OpenLayers.Control.prototype.destroy.call(this)
+    },
+    CLASS_NAME: "OpenLayers.Control.Split"
+});
+OpenLayers.Layer.WMTS = OpenLayers.Class(OpenLayers.Layer.Grid, {
+    isBaseLayer: !0,
+    version: "1.0.0",
+    requestEncoding: "KVP",
+    url: null,
+    layer: null,
+    matrixSet: null,
+    style: null,
+    format: "image/jpeg",
+    tileOrigin: null,
+    tileFullExtent: null,
+    formatSuffix: null,
+    matrixIds: null,
+    dimensions: null,
+    params: null,
+    zoomOffset: 0,
+    serverResolutions: null,
+    formatSuffixMap: {
+        "image/png": "png",
+        "image/png8": "png",
+        "image/png24": "png",
+        "image/png32": "png",
+        png: "png",
+        "image/jpeg": "jpg",
+        "image/jpg": "jpg",
+        jpeg: "jpg",
+        jpg: "jpg"
+    },
+    matrix: null,
+    initialize: function(a) {
+        var b = {
+                url: !0,
+                layer: !0,
+                style: !0,
+                matrixSet: !0
+            },
+            c;
+        for (c in b)
+            if (!(c in a)) throw Error("Missing property '" + c + "' in layer configuration.");
+        a.params = OpenLayers.Util.upperCaseObject(a.params);
+        OpenLayers.Layer.Grid.prototype.initialize.apply(this, [a.name, a.url, a.params, a]);
+        this.formatSuffix || (this.formatSuffix = this.formatSuffixMap[this.format] || this.format.split("/").pop());
+        if (this.matrixIds && (a = this.matrixIds.length) && "string" === typeof this.matrixIds[0]) {
+            b = this.matrixIds;
+            this.matrixIds = Array(a);
+            for (c = 0; c < a; ++c) this.matrixIds[c] = {
+                identifier: b[c]
+            }
+        }
+    },
+    setMap: function() {
+        OpenLayers.Layer.Grid.prototype.setMap.apply(this, arguments);
+        this.updateMatrixProperties()
+    },
+    updateMatrixProperties: function() {
+        if (this.matrix = this.getMatrix())
+            if (this.matrix.topLeftCorner && (this.tileOrigin = this.matrix.topLeftCorner), this.matrix.tileWidth && this.matrix.tileHeight && (this.tileSize = new OpenLayers.Size(this.matrix.tileWidth, this.matrix.tileHeight)), this.tileOrigin || (this.tileOrigin = new OpenLayers.LonLat(this.maxExtent.left, this.maxExtent.top)), !this.tileFullExtent) this.tileFullExtent =
+                this.maxExtent
+    },
+    moveTo: function(a, b, c) {
+        (b || !this.matrix) && this.updateMatrixProperties();
+        return OpenLayers.Layer.Grid.prototype.moveTo.apply(this, arguments)
+    },
+    clone: function(a) {
+        null == a && (a = new OpenLayers.Layer.WMTS(this.options));
+        return a = OpenLayers.Layer.Grid.prototype.clone.apply(this, [a])
+    },
+    getIdentifier: function() {
+        return this.getServerZoom()
+    },
+    getMatrix: function() {
+        var a;
+        if (!this.matrixIds || 0 === this.matrixIds.length) a = {
+            identifier: this.getIdentifier()
+        };
+        else if ("scaleDenominator" in this.matrixIds[0])
+            for (var b =
+                    OpenLayers.METERS_PER_INCH * OpenLayers.INCHES_PER_UNIT[this.units] * this.getServerResolution() / 2.8E-4, c = Number.POSITIVE_INFINITY, d, e = 0, f = this.matrixIds.length; e < f; ++e) d = Math.abs(1 - this.matrixIds[e].scaleDenominator / b), d < c && (c = d, a = this.matrixIds[e]);
+        else a = this.matrixIds[this.getIdentifier()];
+        return a
+    },
+    getTileInfo: function(a) {
+        var b = this.getServerResolution(),
+            c = (a.lon - this.tileOrigin.lon) / (b * this.tileSize.w),
+            a = (this.tileOrigin.lat - a.lat) / (b * this.tileSize.h),
+            b = Math.floor(c),
+            d = Math.floor(a);
+        return {
+            col: b,
+            row: d,
+            i: Math.floor((c - b) * this.tileSize.w),
+            j: Math.floor((a - d) * this.tileSize.h)
+        }
+    },
+    getURL: function(a) {
+        var a = this.adjustBounds(a),
+            b = "";
+        if (!this.tileFullExtent || this.tileFullExtent.intersectsBounds(a)) {
+            var c = this.getTileInfo(a.getCenterLonLat()),
+                a = this.dimensions;
+            if ("REST" === this.requestEncoding.toUpperCase())
+                if (b = this.params, "string" === typeof this.url && -1 !== this.url.indexOf("{")) {
+                    var d = this.url.replace(/\{/g, "${"),
+                        c = {
+                            style: this.style,
+                            Style: this.style,
+                            TileMatrixSet: this.matrixSet,
+                            TileMatrix: this.matrix.identifier,
+                            TileRow: c.row,
+                            TileCol: c.col
+                        };
+                    if (a) {
+                        var e, f;
+                        for (f = a.length - 1; 0 <= f; --f) e = a[f], c[e] = b[e.toUpperCase()]
+                    }
+                    b = OpenLayers.String.format(d, c)
+                } else {
+                    d = this.version + "/" + this.layer + "/" + this.style + "/";
+                    if (a)
+                        for (f = 0; f < a.length; f++) b[a[f]] && (d = d + b[a[f]] + "/");
+                    d = d + this.matrixSet + "/" + this.matrix.identifier + "/" + c.row + "/" + c.col + "." + this.formatSuffix;
+                    b = OpenLayers.Util.isArray(this.url) ? this.selectUrl(d, this.url) : this.url;
+                    b.match(/\/$/) || (b += "/");
+                    b += d
+                } else "KVP" === this.requestEncoding.toUpperCase() && (b = {
+                SERVICE: "WMTS",
+                REQUEST: "GetTile",
+                VERSION: this.version,
+                LAYER: this.layer,
+                STYLE: this.style,
+                TILEMATRIXSET: this.matrixSet,
+                TILEMATRIX: this.matrix.identifier,
+                TILEROW: c.row,
+                TILECOL: c.col,
+                FORMAT: this.format
+            }, b = OpenLayers.Layer.Grid.prototype.getFullRequestString.apply(this, [b]))
+        }
+        return b
+    },
+    mergeNewParams: function(a) {
+        if ("KVP" === this.requestEncoding.toUpperCase()) return OpenLayers.Layer.Grid.prototype.mergeNewParams.apply(this, [OpenLayers.Util.upperCaseObject(a)])
+    },
+    CLASS_NAME: "OpenLayers.Layer.WMTS"
+});
+OpenLayers.Protocol.SOS.v1_0_0 = OpenLayers.Class(OpenLayers.Protocol, {
+    fois: null,
+    formatOptions: null,
+    initialize: function(a) {
+        OpenLayers.Protocol.prototype.initialize.apply(this, [a]);
+        a.format || (this.format = new OpenLayers.Format.SOSGetFeatureOfInterest(this.formatOptions))
+    },
+    destroy: function() {
+        this.options && !this.options.format && this.format.destroy();
+        this.format = null;
+        OpenLayers.Protocol.prototype.destroy.apply(this)
+    },
+    read: function(a) {
+        a = OpenLayers.Util.extend({}, a);
+        OpenLayers.Util.applyDefaults(a, this.options || {});
+        var b = new OpenLayers.Protocol.Response({
+                requestType: "read"
+            }),
+            c = this.format,
+            c = OpenLayers.Format.XML.prototype.write.apply(c, [c.writeNode("sos:GetFeatureOfInterest", {
+                fois: this.fois
+            })]);
+        b.priv = OpenLayers.Request.POST({
+            url: a.url,
+            callback: this.createCallback(this.handleRead, b, a),
+            data: c
+        });
+        return b
+    },
+    handleRead: function(a, b) {
+        if (b.callback) {
+            var c = a.priv;
+            200 <= c.status && 300 > c.status ? (a.features = this.parseFeatures(c), a.code = OpenLayers.Protocol.Response.SUCCESS) : a.code = OpenLayers.Protocol.Response.FAILURE;
+            b.callback.call(b.scope, a)
+        }
+    },
+    parseFeatures: function(a) {
+        var b = a.responseXML;
+        if (!b || !b.documentElement) b = a.responseText;
+        return !b || 0 >= b.length ? null : this.format.read(b)
+    },
+    CLASS_NAME: "OpenLayers.Protocol.SOS.v1_0_0"
+});
+OpenLayers.Layer.KaMapCache = OpenLayers.Class(OpenLayers.Layer.KaMap, {
+    IMAGE_EXTENSIONS: {
+        jpeg: "jpg",
+        gif: "gif",
+        png: "png",
+        png8: "png",
+        png24: "png",
+        dithered: "png"
+    },
+    DEFAULT_FORMAT: "jpeg",
+    initialize: function(a, b, c, d) {
+        OpenLayers.Layer.KaMap.prototype.initialize.apply(this, arguments);
+        this.extension = this.IMAGE_EXTENSIONS[this.params.i.toLowerCase() || this.DEFAULT_FORMAT]
+    },
+    getURL: function(a) {
+        var a = this.adjustBounds(a),
+            b = this.map.getResolution(),
+            c = Math.round(1E4 * this.map.getScale()) / 1E4,
+            d = Math.round(a.left / b),
+            a = -Math.round(a.top / b),
+            b = Math.floor(d / this.tileSize.w / this.params.metaTileSize.w) * this.tileSize.w * this.params.metaTileSize.w,
+            e = Math.floor(a / this.tileSize.h / this.params.metaTileSize.h) * this.tileSize.h * this.params.metaTileSize.h,
+            c = ["/", this.params.map, "/", c, "/", this.params.g.replace(/\s/g, "_"), "/def/t", e, "/l", b, "/t", a, "l", d, ".", this.extension],
+            d = this.url;
+        OpenLayers.Util.isArray(d) && (d = this.selectUrl(c.join(""), d));
+        return d + c.join("")
+    },
+    CLASS_NAME: "OpenLayers.Layer.KaMapCache"
+});
+OpenLayers.Protocol.WFS.v1_1_0 = OpenLayers.Class(OpenLayers.Protocol.WFS.v1, {
+    version: "1.1.0",
+    initialize: function(a) {
+        OpenLayers.Protocol.WFS.v1.prototype.initialize.apply(this, arguments);
+        this.outputFormat && !this.readFormat && ("gml2" == this.outputFormat.toLowerCase() ? this.readFormat = new OpenLayers.Format.GML.v2({
+            featureType: this.featureType,
+            featureNS: this.featureNS,
+            geometryName: this.geometryName
+        }) : "json" == this.outputFormat.toLowerCase() && (this.readFormat = new OpenLayers.Format.GeoJSON))
+    },
+    CLASS_NAME: "OpenLayers.Protocol.WFS.v1_1_0"
+});
+OpenLayers.Format.WMSCapabilities.v1_1_1 = OpenLayers.Class(OpenLayers.Format.WMSCapabilities.v1_1, {
+    version: "1.1.1",
+    readers: {
+        wms: OpenLayers.Util.applyDefaults({
+            SRS: function(a, b) {
+                b.srs[this.getChildValue(a)] = !0
+            }
+        }, OpenLayers.Format.WMSCapabilities.v1_1.prototype.readers.wms)
+    },
+    CLASS_NAME: "OpenLayers.Format.WMSCapabilities.v1_1_1"
+});
+OpenLayers.Format.WMSCapabilities.v1_1_1_WMSC = OpenLayers.Class(OpenLayers.Format.WMSCapabilities.v1_1_1, {
+    version: "1.1.1",
+    profile: "WMSC",
+    readers: {
+        wms: OpenLayers.Util.applyDefaults({
+            VendorSpecificCapabilities: function(a, b) {
+                b.vendorSpecific = {
+                    tileSets: []
+                };
+                this.readChildNodes(a, b.vendorSpecific)
+            },
+            TileSet: function(a, b) {
+                var c = {
+                    srs: {},
+                    bbox: {},
+                    resolutions: []
+                };
+                this.readChildNodes(a, c);
+                b.tileSets.push(c)
+            },
+            Resolutions: function(a, b) {
+                for (var c = this.getChildValue(a).split(" "), d = 0, e = c.length; d < e; d++) "" != c[d] && b.resolutions.push(parseFloat(c[d]))
+            },
+            Width: function(a, b) {
+                b.width = parseInt(this.getChildValue(a))
+            },
+            Height: function(a, b) {
+                b.height = parseInt(this.getChildValue(a))
+            },
+            Layers: function(a, b) {
+                b.layers = this.getChildValue(a)
+            },
+            Styles: function(a, b) {
+                b.styles = this.getChildValue(a)
+            }
+        }, OpenLayers.Format.WMSCapabilities.v1_1_1.prototype.readers.wms)
+    },
+    CLASS_NAME: "OpenLayers.Format.WMSCapabilities.v1_1_1_WMSC"
+});
+OpenLayers.Format.WMSCapabilities.v1_1_0 = OpenLayers.Class(OpenLayers.Format.WMSCapabilities.v1_1, {
+    version: "1.1.0",
+    readers: {
+        wms: OpenLayers.Util.applyDefaults({
+            SRS: function(a, b) {
+                for (var c = this.getChildValue(a).split(/ +/), d = 0, e = c.length; d < e; d++) b.srs[c[d]] = !0
+            }
+        }, OpenLayers.Format.WMSCapabilities.v1_1.prototype.readers.wms)
+    },
+    CLASS_NAME: "OpenLayers.Format.WMSCapabilities.v1_1_0"
+});
+OpenLayers.Control.LayerSwitcher = OpenLayers.Class(OpenLayers.Control, {
+    roundedCorner: !1,
+    roundedCornerColor: "darkblue",
+    layerStates: null,
+    layersDiv: null,
+    baseLayersDiv: null,
+    baseLayers: null,
+    dataLbl: null,
+    dataLayersDiv: null,
+    dataLayers: null,
+    minimizeDiv: null,
+    maximizeDiv: null,
+    ascending: !0,
+    initialize: function(a) {
+        OpenLayers.Control.prototype.initialize.apply(this, arguments);
+        this.layerStates = [];
+        this.roundedCorner && OpenLayers.Console.warn("roundedCorner option is deprecated")
+    },
+    destroy: function() {
+        this.clearLayersArray("base");
+        this.clearLayersArray("data");
+        this.map.events.un({
+            buttonclick: this.onButtonClick,
+            addlayer: this.redraw,
+            changelayer: this.redraw,
+            removelayer: this.redraw,
+            changebaselayer: this.redraw,
+            scope: this
+        });
+        this.events.unregister("buttonclick", this, this.onButtonClick);
+        OpenLayers.Control.prototype.destroy.apply(this, arguments)
+    },
+    setMap: function(a) {
+        OpenLayers.Control.prototype.setMap.apply(this, arguments);
+        this.map.events.on({
+            addlayer: this.redraw,
+            changelayer: this.redraw,
+            removelayer: this.redraw,
+            changebaselayer: this.redraw,
+            scope: this
+        });
+        this.outsideViewport ? (this.events.attachToElement(this.div), this.events.register("buttonclick", this, this.onButtonClick)) : this.map.events.register("buttonclick", this, this.onButtonClick)
+    },
+    draw: function() {
+        OpenLayers.Control.prototype.draw.apply(this);
+        this.loadContents();
+        this.outsideViewport || this.minimizeControl();
+        this.redraw();
+        return this.div
+    },
+    onButtonClick: function(a) {
+        a = a.buttonElement;
+        a === this.minimizeDiv ? this.minimizeControl() : a === this.maximizeDiv ? this.maximizeControl() : a._layerSwitcher ===
+            this.id && (a["for"] && (a = document.getElementById(a["for"])), a.disabled || ("radio" == a.type ? (a.checked = !0, this.map.setBaseLayer(this.map.getLayer(a._layer))) : (a.checked = !a.checked, this.updateMap())))
+    },
+    clearLayersArray: function(a) {
+        this[a + "LayersDiv"].innerHTML = "";
+        this[a + "Layers"] = []
+    },
+    checkRedraw: function() {
+        var a = !1;
+        if (!this.layerStates.length || this.map.layers.length != this.layerStates.length) a = !0;
+        else
+            for (var b = 0, c = this.layerStates.length; b < c; b++) {
+                var d = this.layerStates[b],
+                    e = this.map.layers[b];
+                if (d.name !=
+                    e.name || d.inRange != e.inRange || d.id != e.id || d.visibility != e.visibility) {
+                    a = !0;
+                    break
+                }
+            }
+        return a
+    },
+    redraw: function() {
+        if (!this.checkRedraw()) return this.div;
+        this.clearLayersArray("base");
+        this.clearLayersArray("data");
+        var a = !1,
+            b = !1,
+            c = this.map.layers.length;
+        this.layerStates = Array(c);
+        for (var d = 0; d < c; d++) {
+            var e = this.map.layers[d];
+            this.layerStates[d] = {
+                name: e.name,
+                visibility: e.visibility,
+                inRange: e.inRange,
+                id: e.id
+            }
+        }
+        var f = this.map.layers.slice();
+        this.ascending || f.reverse();
+        d = 0;
+        for (c = f.length; d < c; d++) {
+            var e = f[d],
+                g = e.isBaseLayer;
+            if (e.displayInLayerSwitcher) {
+                g ? b = !0 : a = !0;
+                var h = g ? e == this.map.baseLayer : e.getVisibility(),
+                    i = document.createElement("input");
+                i.id = this.id + "_input_" + e.name;
+                i.name = g ? this.id + "_baseLayers" : e.name;
+                i.type = g ? "radio" : "checkbox";
+                i.value = e.name;
+                i.checked = h;
+                i.defaultChecked = h;
+                i.className = "olButton";
+                i._layer = e.id;
+                i._layerSwitcher = this.id;
+                !g && !e.inRange && (i.disabled = !0);
+                h = document.createElement("label");
+                h["for"] = i.id;
+                OpenLayers.Element.addClass(h, "labelSpan olButton");
+                h._layer = e.id;
+                h._layerSwitcher =
+                    this.id;
+                !g && !e.inRange && (h.style.color = "gray");
+                h.innerHTML = e.name;
+                h.style.verticalAlign = g ? "bottom" : "baseline";
+                var j = document.createElement("br");
+                (g ? this.baseLayers : this.dataLayers).push({
+                    layer: e,
+                    inputElem: i,
+                    labelSpan: h
+                });
+                e = g ? this.baseLayersDiv : this.dataLayersDiv;
+                e.appendChild(i);
+                e.appendChild(h);
+                e.appendChild(j)
+            }
+        }
+        this.dataLbl.style.display = a ? "" : "none";
+        this.baseLbl.style.display = b ? "" : "none";
+        return this.div
+    },
+    updateMap: function() {
+        for (var a = 0, b = this.baseLayers.length; a < b; a++) {
+            var c = this.baseLayers[a];
+            c.inputElem.checked && this.map.setBaseLayer(c.layer, !1)
+        }
+        a = 0;
+        for (b = this.dataLayers.length; a < b; a++) c = this.dataLayers[a], c.layer.setVisibility(c.inputElem.checked)
+    },
+    maximizeControl: function(a) {
+        this.div.style.width = "";
+        this.div.style.height = "";
+        this.showControls(!1);
+        null != a && OpenLayers.Event.stop(a)
+    },
+    minimizeControl: function(a) {
+        this.div.style.width = "0px";
+        this.div.style.height = "0px";
+        this.showControls(!0);
+        null != a && OpenLayers.Event.stop(a)
+    },
+    showControls: function(a) {
+        this.maximizeDiv.style.display = a ? "" : "none";
+        this.minimizeDiv.style.display = a ? "none" : "";
+        this.layersDiv.style.display = a ? "none" : ""
+    },
+    loadContents: function() {
+        this.layersDiv = document.createElement("div");
+        this.layersDiv.id = this.id + "_layersDiv";
+        OpenLayers.Element.addClass(this.layersDiv, "layersDiv");
+        this.baseLbl = document.createElement("div");
+        this.baseLbl.innerHTML = OpenLayers.i18n("Base Layer");
+        OpenLayers.Element.addClass(this.baseLbl, "baseLbl");
+        this.baseLayersDiv = document.createElement("div");
+        OpenLayers.Element.addClass(this.baseLayersDiv, "baseLayersDiv");
+        this.dataLbl = document.createElement("div");
+        this.dataLbl.innerHTML = OpenLayers.i18n("Overlays");
+        OpenLayers.Element.addClass(this.dataLbl, "dataLbl");
+        this.dataLayersDiv = document.createElement("div");
+        OpenLayers.Element.addClass(this.dataLayersDiv, "dataLayersDiv");
+        this.ascending ? (this.layersDiv.appendChild(this.baseLbl), this.layersDiv.appendChild(this.baseLayersDiv), this.layersDiv.appendChild(this.dataLbl), this.layersDiv.appendChild(this.dataLayersDiv)) : (this.layersDiv.appendChild(this.dataLbl), this.layersDiv.appendChild(this.dataLayersDiv),
+            this.layersDiv.appendChild(this.baseLbl), this.layersDiv.appendChild(this.baseLayersDiv));
+        this.div.appendChild(this.layersDiv);
+        this.roundedCorner && (OpenLayers.Rico.Corner.round(this.div, {
+            corners: "tl bl",
+            bgColor: "transparent",
+            color: this.roundedCornerColor,
+            blend: !1
+        }), OpenLayers.Rico.Corner.changeOpacity(this.layersDiv, 0.75));
+        var a = OpenLayers.Util.getImageLocation("layer-switcher-maximize.png");
+        this.maximizeDiv = OpenLayers.Util.createAlphaImageDiv("OpenLayers_Control_MaximizeDiv", null, null, a, "absolute");
+        OpenLayers.Element.addClass(this.maximizeDiv, "maximizeDiv olButton");
+        this.maximizeDiv.style.display = "none";
+        this.div.appendChild(this.maximizeDiv);
+        a = OpenLayers.Util.getImageLocation("layer-switcher-minimize.png");
+        this.minimizeDiv = OpenLayers.Util.createAlphaImageDiv("OpenLayers_Control_MinimizeDiv", null, null, a, "absolute");
+        OpenLayers.Element.addClass(this.minimizeDiv, "minimizeDiv olButton");
+        this.minimizeDiv.style.display = "none";
+        this.div.appendChild(this.minimizeDiv)
+    },
+    CLASS_NAME: "OpenLayers.Control.LayerSwitcher"
+});
+OpenLayers.Format.Atom = OpenLayers.Class(OpenLayers.Format.XML, {
+    namespaces: {
+        atom: "http://www.w3.org/2005/Atom",
+        georss: "http://www.georss.org/georss"
+    },
+    feedTitle: "untitled",
+    defaultEntryTitle: "untitled",
+    gmlParser: null,
+    xy: !1,
+    read: function(a) {
+        "string" == typeof a && (a = OpenLayers.Format.XML.prototype.read.apply(this, [a]));
+        return this.parseFeatures(a)
+    },
+    write: function(a) {
+        var b;
+        if (OpenLayers.Util.isArray(a)) {
+            b = this.createElementNSPlus("atom:feed");
+            b.appendChild(this.createElementNSPlus("atom:title", {
+                value: this.feedTitle
+            }));
+            for (var c = 0, d = a.length; c < d; c++) b.appendChild(this.buildEntryNode(a[c]))
+        } else b = this.buildEntryNode(a);
+        return OpenLayers.Format.XML.prototype.write.apply(this, [b])
+    },
+    buildContentNode: function(a) {
+        var b = this.createElementNSPlus("atom:content", {
+            attributes: {
+                type: a.type || null
+            }
+        });
+        if (a.src) b.setAttribute("src", a.src);
+        else if ("text" == a.type || null == a.type) b.appendChild(this.createTextNode(a.value));
+        else if ("html" == a.type) {
+            if ("string" != typeof a.value) throw "HTML content must be in form of an escaped string";
+            b.appendChild(this.createTextNode(a.value))
+        } else "xhtml" ==
+            a.type ? b.appendChild(a.value) : "xhtml" == a.type || a.type.match(/(\+|\/)xml$/) ? b.appendChild(a.value) : b.appendChild(this.createTextNode(a.value));
+        return b
+    },
+    buildEntryNode: function(a) {
+        var b = a.attributes,
+            c = b.atom || {},
+            d = this.createElementNSPlus("atom:entry");
+        if (c.authors)
+            for (var e = OpenLayers.Util.isArray(c.authors) ? c.authors : [c.authors], f = 0, g = e.length; f < g; f++) d.appendChild(this.buildPersonConstructNode("author", e[f]));
+        if (c.categories)
+            for (var e = OpenLayers.Util.isArray(c.categories) ? c.categories : [c.categories],
+                    h, f = 0, g = e.length; f < g; f++) h = e[f], d.appendChild(this.createElementNSPlus("atom:category", {
+                attributes: {
+                    term: h.term,
+                    scheme: h.scheme || null,
+                    label: h.label || null
+                }
+            }));
+        c.content && d.appendChild(this.buildContentNode(c.content));
+        if (c.contributors) {
+            e = OpenLayers.Util.isArray(c.contributors) ? c.contributors : [c.contributors];
+            f = 0;
+            for (g = e.length; f < g; f++) d.appendChild(this.buildPersonConstructNode("contributor", e[f]))
+        }
+        a.fid && d.appendChild(this.createElementNSPlus("atom:id", {
+            value: a.fid
+        }));
+        if (c.links) {
+            e = OpenLayers.Util.isArray(c.links) ?
+                c.links : [c.links];
+            f = 0;
+            for (g = e.length; f < g; f++) h = e[f], d.appendChild(this.createElementNSPlus("atom:link", {
+                attributes: {
+                    href: h.href,
+                    rel: h.rel || null,
+                    type: h.type || null,
+                    hreflang: h.hreflang || null,
+                    title: h.title || null,
+                    length: h.length || null
+                }
+            }))
+        }
+        c.published && d.appendChild(this.createElementNSPlus("atom:published", {
+            value: c.published
+        }));
+        c.rights && d.appendChild(this.createElementNSPlus("atom:rights", {
+            value: c.rights
+        }));
+        if (c.summary || b.description) d.appendChild(this.createElementNSPlus("atom:summary", {
+            value: c.summary ||
+                b.description
+        }));
+        d.appendChild(this.createElementNSPlus("atom:title", {
+            value: c.title || b.title || this.defaultEntryTitle
+        }));
+        c.updated && d.appendChild(this.createElementNSPlus("atom:updated", {
+            value: c.updated
+        }));
+        a.geometry && (b = this.createElementNSPlus("georss:where"), b.appendChild(this.buildGeometryNode(a.geometry)), d.appendChild(b));
+        return d
+    },
+    initGmlParser: function() {
+        this.gmlParser = new OpenLayers.Format.GML.v3({
+            xy: this.xy,
+            featureNS: "http://example.com#feature",
+            internalProjection: this.internalProjection,
+            externalProjection: this.externalProjection
+        })
+    },
+    buildGeometryNode: function(a) {
+        this.gmlParser || this.initGmlParser();
+        return this.gmlParser.writeNode("feature:_geometry", a).firstChild
+    },
+    buildPersonConstructNode: function(a, b) {
+        var c = ["uri", "email"],
+            d = this.createElementNSPlus("atom:" + a);
+        d.appendChild(this.createElementNSPlus("atom:name", {
+            value: b.name
+        }));
+        for (var e = 0, f = c.length; e < f; e++) b[c[e]] && d.appendChild(this.createElementNSPlus("atom:" + c[e], {
+            value: b[c[e]]
+        }));
+        return d
+    },
+    getFirstChildValue: function(a, b, c,
+        d) {
+        return (a = this.getElementsByTagNameNS(a, b, c)) && 0 < a.length ? this.getChildValue(a[0], d) : d
+    },
+    parseFeature: function(a) {
+        var b = {},
+            c = null,
+            d = null,
+            e = null,
+            f = this.namespaces.atom;
+        this.parsePersonConstructs(a, "author", b);
+        d = this.getElementsByTagNameNS(a, f, "category");
+        0 < d.length && (b.categories = []);
+        for (var g = 0, h = d.length; g < h; g++) {
+            c = {};
+            c.term = d[g].getAttribute("term");
+            if (e = d[g].getAttribute("scheme")) c.scheme = e;
+            if (e = d[g].getAttribute("label")) c.label = e;
+            b.categories.push(c)
+        }
+        d = this.getElementsByTagNameNS(a, f, "content");
+        if (0 < d.length) {
+            c = {};
+            if (e = d[0].getAttribute("type")) c.type = e;
+            (e = d[0].getAttribute("src")) ? c.src = e: (c.value = "text" == c.type || "html" == c.type || null == c.type ? this.getFirstChildValue(a, f, "content", null) : "xhtml" == c.type || c.type.match(/(\+|\/)xml$/) ? this.getChildEl(d[0]) : this.getFirstChildValue(a, f, "content", null), b.content = c)
+        }
+        this.parsePersonConstructs(a, "contributor", b);
+        b.id = this.getFirstChildValue(a, f, "id", null);
+        d = this.getElementsByTagNameNS(a, f, "link");
+        0 < d.length && (b.links = Array(d.length));
+        for (var i = ["rel",
+                "type", "hreflang", "title", "length"
+            ], g = 0, h = d.length; g < h; g++) {
+            c = {};
+            c.href = d[g].getAttribute("href");
+            for (var j = 0, k = i.length; j < k; j++)(e = d[g].getAttribute(i[j])) && (c[i[j]] = e);
+            b.links[g] = c
+        }
+        if (c = this.getFirstChildValue(a, f, "published", null)) b.published = c;
+        if (c = this.getFirstChildValue(a, f, "rights", null)) b.rights = c;
+        if (c = this.getFirstChildValue(a, f, "summary", null)) b.summary = c;
+        b.title = this.getFirstChildValue(a, f, "title", null);
+        b.updated = this.getFirstChildValue(a, f, "updated", null);
+        c = {
+            title: b.title,
+            description: b.summary,
+            atom: b
+        };
+        a = this.parseLocations(a)[0];
+        a = new OpenLayers.Feature.Vector(a, c);
+        a.fid = b.id;
+        return a
+    },
+    parseFeatures: function(a) {
+        var b = [],
+            c = this.getElementsByTagNameNS(a, this.namespaces.atom, "entry");
+        0 == c.length && (c = [a]);
+        for (var a = 0, d = c.length; a < d; a++) b.push(this.parseFeature(c[a]));
+        return b
+    },
+    parseLocations: function(a) {
+        var b = this.namespaces.georss,
+            c = {
+                components: []
+            },
+            d = this.getElementsByTagNameNS(a, b, "where");
+        if (d && 0 < d.length) {
+            this.gmlParser || this.initGmlParser();
+            for (var e = 0, f = d.length; e < f; e++) this.gmlParser.readChildNodes(d[e],
+                c)
+        }
+        c = c.components;
+        if ((d = this.getElementsByTagNameNS(a, b, "point")) && 0 < d.length) {
+            e = 0;
+            for (f = d.length; e < f; e++) {
+                var g = OpenLayers.String.trim(d[e].firstChild.nodeValue).split(/\s+/);
+                2 != g.length && (g = OpenLayers.String.trim(d[e].firstChild.nodeValue).split(/\s*,\s*/));
+                c.push(new OpenLayers.Geometry.Point(g[1], g[0]))
+            }
+        }
+        var h = this.getElementsByTagNameNS(a, b, "line");
+        if (h && 0 < h.length)
+            for (var i, e = 0, f = h.length; e < f; e++) {
+                d = OpenLayers.String.trim(h[e].firstChild.nodeValue).split(/\s+/);
+                i = [];
+                for (var j = 0, k = d.length; j <
+                    k; j += 2) g = new OpenLayers.Geometry.Point(d[j + 1], d[j]), i.push(g);
+                c.push(new OpenLayers.Geometry.LineString(i))
+            }
+        if ((a = this.getElementsByTagNameNS(a, b, "polygon")) && 0 < a.length) {
+            e = 0;
+            for (f = a.length; e < f; e++) {
+                d = OpenLayers.String.trim(a[e].firstChild.nodeValue).split(/\s+/);
+                i = [];
+                j = 0;
+                for (k = d.length; j < k; j += 2) g = new OpenLayers.Geometry.Point(d[j + 1], d[j]), i.push(g);
+                c.push(new OpenLayers.Geometry.Polygon([new OpenLayers.Geometry.LinearRing(c)]))
+            }
+        }
+        if (this.internalProjection && this.externalProjection) {
+            e = 0;
+            for (f = c.length; e <
+                f; e++) c[e] && c[e].transform(this.externalProjection, this.internalProjection)
+        }
+        return c
+    },
+    parsePersonConstructs: function(a, b, c) {
+        for (var d = [], e = this.namespaces.atom, a = this.getElementsByTagNameNS(a, e, b), f = ["uri", "email"], g = 0, h = a.length; g < h; g++) {
+            var i = {};
+            i.name = this.getFirstChildValue(a[g], e, "name", null);
+            for (var j = 0, k = f.length; j < k; j++) {
+                var l = this.getFirstChildValue(a[g], e, f[j], null);
+                l && (i[f[j]] = l)
+            }
+            d.push(i)
+        }
+        0 < d.length && (c[b + "s"] = d)
+    },
+    CLASS_NAME: "OpenLayers.Format.Atom"
+});
+OpenLayers.Control.KeyboardDefaults = OpenLayers.Class(OpenLayers.Control, {
+    autoActivate: !0,
+    slideFactor: 75,
+    observeElement: null,
+    draw: function() {
+        this.handler = new OpenLayers.Handler.Keyboard(this, {
+            keydown: this.defaultKeyPress
+        }, {
+            observeElement: this.observeElement || document
+        })
+    },
+    defaultKeyPress: function(a) {
+        var b, c = !0;
+        switch (a.keyCode) {
+            case OpenLayers.Event.KEY_LEFT:
+                this.map.pan(-this.slideFactor, 0);
+                break;
+            case OpenLayers.Event.KEY_RIGHT:
+                this.map.pan(this.slideFactor, 0);
+                break;
+            case OpenLayers.Event.KEY_UP:
+                this.map.pan(0, -this.slideFactor);
+                break;
+            case OpenLayers.Event.KEY_DOWN:
+                this.map.pan(0, this.slideFactor);
+                break;
+            case 33:
+                b = this.map.getSize();
+                this.map.pan(0, -0.75 * b.h);
+                break;
+            case 34:
+                b = this.map.getSize();
+                this.map.pan(0, 0.75 * b.h);
+                break;
+            case 35:
+                b = this.map.getSize();
+                this.map.pan(0.75 * b.w, 0);
+                break;
+            case 36:
+                b = this.map.getSize();
+                this.map.pan(-0.75 * b.w, 0);
+                break;
+            case 43:
+            case 61:
+            case 187:
+            case 107:
+                this.map.zoomIn();
+                break;
+            case 45:
+            case 109:
+            case 189:
+            case 95:
+                this.map.zoomOut();
+                break;
+            default:
+                c = !1
+        }
+        c && OpenLayers.Event.stop(a)
+    },
+    CLASS_NAME: "OpenLayers.Control.KeyboardDefaults"
+});
+OpenLayers.Format.WMTSCapabilities.v1_0_0 = OpenLayers.Class(OpenLayers.Format.OWSCommon.v1_1_0, {
+    version: "1.0.0",
+    namespaces: {
+        ows: "http://www.opengis.net/ows/1.1",
+        wmts: "http://www.opengis.net/wmts/1.0",
+        xlink: "http://www.w3.org/1999/xlink"
+    },
+    yx: null,
+    defaultPrefix: "wmts",
+    initialize: function(a) {
+        OpenLayers.Format.XML.prototype.initialize.apply(this, [a]);
+        this.options = a;
+        a = OpenLayers.Util.extend({}, OpenLayers.Format.WMTSCapabilities.prototype.yx);
+        this.yx = OpenLayers.Util.extend(a, this.yx)
+    },
+    read: function(a) {
+        "string" ==
+        typeof a && (a = OpenLayers.Format.XML.prototype.read.apply(this, [a]));
+        a && 9 == a.nodeType && (a = a.documentElement);
+        var b = {};
+        this.readNode(a, b);
+        b.version = this.version;
+        return b
+    },
+    readers: {
+        wmts: {
+            Capabilities: function(a, b) {
+                this.readChildNodes(a, b)
+            },
+            Contents: function(a, b) {
+                b.contents = {};
+                b.contents.layers = [];
+                b.contents.tileMatrixSets = {};
+                this.readChildNodes(a, b.contents)
+            },
+            Layer: function(a, b) {
+                var c = {
+                    styles: [],
+                    formats: [],
+                    dimensions: [],
+                    tileMatrixSetLinks: [],
+                    layers: []
+                };
+                this.readChildNodes(a, c);
+                b.layers.push(c)
+            },
+            Style: function(a,
+                b) {
+                var c = {};
+                c.isDefault = "true" === a.getAttribute("isDefault");
+                this.readChildNodes(a, c);
+                b.styles.push(c)
+            },
+            Format: function(a, b) {
+                b.formats.push(this.getChildValue(a))
+            },
+            TileMatrixSetLink: function(a, b) {
+                var c = {};
+                this.readChildNodes(a, c);
+                b.tileMatrixSetLinks.push(c)
+            },
+            TileMatrixSet: function(a, b) {
+                if (b.layers) {
+                    var c = {
+                        matrixIds: []
+                    };
+                    this.readChildNodes(a, c);
+                    b.tileMatrixSets[c.identifier] = c
+                } else b.tileMatrixSet = this.getChildValue(a)
+            },
+            TileMatrix: function(a, b) {
+                var c = {
+                    supportedCRS: b.supportedCRS
+                };
+                this.readChildNodes(a,
+                    c);
+                b.matrixIds.push(c)
+            },
+            ScaleDenominator: function(a, b) {
+                b.scaleDenominator = parseFloat(this.getChildValue(a))
+            },
+            TopLeftCorner: function(a, b) {
+                var c = this.getChildValue(a).split(" "),
+                    d;
+                b.supportedCRS && (d = !!this.yx[b.supportedCRS.replace(/urn:ogc:def:crs:(\w+):.+:(\w+)$/, "urn:ogc:def:crs:$1::$2")]);
+                b.topLeftCorner = d ? new OpenLayers.LonLat(c[1], c[0]) : new OpenLayers.LonLat(c[0], c[1])
+            },
+            TileWidth: function(a, b) {
+                b.tileWidth = parseInt(this.getChildValue(a))
+            },
+            TileHeight: function(a, b) {
+                b.tileHeight = parseInt(this.getChildValue(a))
+            },
+            MatrixWidth: function(a, b) {
+                b.matrixWidth = parseInt(this.getChildValue(a))
+            },
+            MatrixHeight: function(a, b) {
+                b.matrixHeight = parseInt(this.getChildValue(a))
+            },
+            ResourceURL: function(a, b) {
+                b.resourceUrl = b.resourceUrl || {};
+                b.resourceUrl[a.getAttribute("resourceType")] = {
+                    format: a.getAttribute("format"),
+                    template: a.getAttribute("template")
+                }
+            },
+            WSDL: function(a, b) {
+                b.wsdl = {};
+                b.wsdl.href = a.getAttribute("xlink:href")
+            },
+            ServiceMetadataURL: function(a, b) {
+                b.serviceMetadataUrl = {};
+                b.serviceMetadataUrl.href = a.getAttribute("xlink:href")
+            },
+            LegendURL: function(a, b) {
+                b.legend = {};
+                b.legend.href = a.getAttribute("xlink:href");
+                b.legend.format = a.getAttribute("format")
+            },
+            Dimension: function(a, b) {
+                var c = {
+                    values: []
+                };
+                this.readChildNodes(a, c);
+                b.dimensions.push(c)
+            },
+            Default: function(a, b) {
+                b["default"] = this.getChildValue(a)
+            },
+            Value: function(a, b) {
+                b.values.push(this.getChildValue(a))
+            }
+        },
+        ows: OpenLayers.Format.OWSCommon.v1_1_0.prototype.readers.ows
+    },
+    CLASS_NAME: "OpenLayers.Format.WMTSCapabilities.v1_0_0"
+});
\ No newline at end of file
diff --git a/PanoramicView/img/.DS_Store b/PanoramicView/img/.DS_Store
new file mode 100644
index 0000000000000000000000000000000000000000..5222d092f845a15e0c520d22acf56bcef52cdcd4
Binary files /dev/null and b/PanoramicView/img/.DS_Store differ
diff --git a/PanoramicView/img/east-mini.png b/PanoramicView/img/east-mini.png
new file mode 100644
index 0000000000000000000000000000000000000000..ecedc5ef9f2ea756eaebb78e187b543c221760b2
Binary files /dev/null and b/PanoramicView/img/east-mini.png differ
diff --git a/PanoramicView/img/layer-switcher-maximize.png b/PanoramicView/img/layer-switcher-maximize.png
new file mode 100644
index 0000000000000000000000000000000000000000..f346086b38eb98effa931eb7c50ab5a221cf06c0
Binary files /dev/null and b/PanoramicView/img/layer-switcher-maximize.png differ
diff --git a/PanoramicView/img/layer-switcher-minimize.png b/PanoramicView/img/layer-switcher-minimize.png
new file mode 100644
index 0000000000000000000000000000000000000000..b4aab0bf784076f86893d0c28a8cae36ec6c113e
Binary files /dev/null and b/PanoramicView/img/layer-switcher-minimize.png differ
diff --git a/PanoramicView/img/north-mini.png b/PanoramicView/img/north-mini.png
new file mode 100644
index 0000000000000000000000000000000000000000..dfd7211ffc7bf3ec82c490c7e9f522a872eb5c2b
Binary files /dev/null and b/PanoramicView/img/north-mini.png differ
diff --git a/PanoramicView/img/slider.png b/PanoramicView/img/slider.png
new file mode 100644
index 0000000000000000000000000000000000000000..433536422ead435c8e9e5b9dd1f209c7087994c3
Binary files /dev/null and b/PanoramicView/img/slider.png differ
diff --git a/PanoramicView/img/south-mini.png b/PanoramicView/img/south-mini.png
new file mode 100644
index 0000000000000000000000000000000000000000..2970875c4c2588c1345cc2c782cc40e7dfb667e3
Binary files /dev/null and b/PanoramicView/img/south-mini.png differ
diff --git a/PanoramicView/img/west-mini.png b/PanoramicView/img/west-mini.png
new file mode 100644
index 0000000000000000000000000000000000000000..363cd3d7b2e9aaa24625d57fb59293a063a55158
Binary files /dev/null and b/PanoramicView/img/west-mini.png differ
diff --git a/PanoramicView/img/zoom-minus-mini.png b/PanoramicView/img/zoom-minus-mini.png
new file mode 100644
index 0000000000000000000000000000000000000000..8f0d77fff1cc3f68b512dce21bd789d7f59f2f62
Binary files /dev/null and b/PanoramicView/img/zoom-minus-mini.png differ
diff --git a/PanoramicView/img/zoom-plus-mini.png b/PanoramicView/img/zoom-plus-mini.png
new file mode 100644
index 0000000000000000000000000000000000000000..a73ab4e951b38fde6f1f39124efb1fa01fdc01b2
Binary files /dev/null and b/PanoramicView/img/zoom-plus-mini.png differ
diff --git a/PanoramicView/img/zoombar.png b/PanoramicView/img/zoombar.png
new file mode 100644
index 0000000000000000000000000000000000000000..47110ab3e5a5e3e9d01a9f6ad1ae4aa08d4e3a28
Binary files /dev/null and b/PanoramicView/img/zoombar.png differ
diff --git a/PanoramicView/logo.jpg b/PanoramicView/logo.jpg
new file mode 100644
index 0000000000000000000000000000000000000000..1c69280004d285a2cffba12f58d40aa4c7ebcf97
Binary files /dev/null and b/PanoramicView/logo.jpg differ
diff --git a/PanoramicView/logo.png b/PanoramicView/logo.png
new file mode 100644
index 0000000000000000000000000000000000000000..a18c9f489a994bf29eeaefc6bb2719116fcd6bfe
Binary files /dev/null and b/PanoramicView/logo.png differ
diff --git a/PanoramicView/openlayers.html b/PanoramicView/openlayers.html
new file mode 100644
index 0000000000000000000000000000000000000000..e73c533e858dc6c7af39e5038a9218ae5950da12
--- /dev/null
+++ b/PanoramicView/openlayers.html
@@ -0,0 +1,441 @@
+<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
+        <html xmlns="http://www.w3.org/1999/xhtml"
+          <head>
+            <meta http-equiv='imagetoolbar' content='no'/>
+            <style type="text/css"> v\:* {behavior:url(#default#VML);}
+                html, body { overflow: hidden; padding: 0; height: 100%; width: 100%; font-family: 'Lucida Grande',Geneva,Arial,Verdana,sans-serif; }
+                body { margin: 10px; background: #fff; }
+                h1 { margin: 0; padding: 6px; border:0; font-size: 20pt; }
+            #header { height: 50px; padding: 0;/* background-color: #eee;*/ border: 1px solid #888; }
+            #subheader { height: 12px; text-align: right; font-size: 10px; color: #555;}
+            #map { height: 95%; border: 1px solid #888; }
+            .olImageLoadError { display: none; }
+            .olControlLayerSwitcher .layersDiv { border-radius: 10px 0 0 10px; } 
+        </style>
+            <script src="OpenLayers.js"></script>
+            <script>
+            
+            
+              OpenLayers.Control.Click = OpenLayers.Class(OpenLayers.Control, {                
+                defaultHandlerOptions: {
+                    'single': true,
+                    'double': false,
+                    'pixelTolerance': 0,
+                    'stopSingle': false,
+                    'stopDouble': false
+                },
+
+                initialize: function(options) {
+                    this.handlerOptions = OpenLayers.Util.extend(
+                        {}, this.defaultHandlerOptions
+                    );
+                    OpenLayers.Control.prototype.initialize.apply(
+                        this, arguments
+                    ); 
+                    this.handler = new OpenLayers.Handler.Click(
+                        this, {
+                            'click': this.trigger
+                        }, this.handlerOptions
+                    );
+                }, 
+
+                trigger: function(e) {
+                    var lonlat = map.getLonLatFromPixel(e.xy);
+                                              
+				    var b = map.getLonLatFromPixel(e.xy);
+				        
+				    displayProjection= null;
+					displayProjection && b.transform(map.getProjectionObject(), displayProjection);
+	        		var ret=b.lon.toFixed(b) +" , " + b.lat.toFixed(b);
+				  	step_x=-0.001333333333333333;
+                	step_y=0.001333333333333333;
+					ori_lat=3.0125822852714919;
+                	ori_lon=181.94317626951325; 
+					
+
+                		
+                	d=map.getMaxExtent({
+                    	restricted: !0
+                	});
+         			var tmp = new OpenLayers.LonLat( ((e.xy.x - map.minPx.x) * map.getResolution() + d.left)*step_x, ((map.minPx.y - e.xy.y) * map.getResolution() + d.top)*step_y);
+					
+    			    var lon_final_tmp = OpenLayers.Util.toFloat(tmp.lon)+ori_lon;
+      				lon_final=lon_final_tmp<0?360+lon_final_tmp:lon_final_tmp;
+					var lat_final = OpenLayers.Util.toFloat(tmp.lat)+ori_lat;
+        				
+        				
+        			document.getElementById("valuediv").value=lon_final.toFixed(4) +"," + lat_final.toFixed(4);
+        				
+        			//	if (lat_final<2.22813 && lat_final> -2.22813 && lon_final_tmp< 67.6027 && lon_final_tmp>-71.18)					        
+        		 	//		alert("You clicked near " + lon_final + " , " + lat_final);
+					//	else
+					//	  OpenLayers.Util.getElement("valuediv").innerHTML = "";
+
+                                              
+
+        				
+                                              
+                }
+
+            });
+  
+              var map;
+              
+               var mapBounds = new OpenLayers.Bounds( 0.0, -4398.0, 270674.0, 0.0);
+
+//              var mapBounds = new OpenLayers.Bounds(0.0, -4274.0, 155805.0, 0.0);
+
+              var mapMinZoom = 0;
+              var mapMaxZoom = 10;
+              var emptyTileURL = "http://www.maptiler.org/img/none.png";
+              OpenLayers.IMAGE_RELOAD_ATTEMPTS = 3;
+
+              function init(){
+              var graticuleCtl1;
+              
+               graticuleCtl1 = new OpenLayers.Control.Graticule({
+                            lineSymbolizer:{strokeColor: "#ff0000", strokeWidth: 1, strokeOpacity: 0.8},
+
+                    labelled: true
+                });
+              
+              
+                  var options = {
+                      div: "map",
+                      controls: [
+                   //     graticuleCtl1,
+            			 new OpenLayers.Control.OverviewMap(),
+						],
+                      maxExtent: new OpenLayers.Bounds( 0.0, -4398.0, 270674.0, 0.0),
+                      maxResolution: 2048.000000,
+                      numZoomLevels: 11
+                  };
+  
+                    map = new OpenLayers.Map(options);
+
+  			    
+  			    map.events.register("mousemove", map, function(e) {
+          		     var position = this.events.getMousePosition(e);
+					
+						var a={x:position.x,y:position.y};
+				        var b = map.getLonLatFromPixel(a);
+
+				        displayProjection= null;
+
+	        			displayProjection && b.transform(map.getProjectionObject(), displayProjection);
+	        			
+        				var ret=b.lon.toFixed(b) +" , " + b.lat.toFixed(b)
+				        
+
+
+				      					step_x=-0.001333333333333333;
+                	step_y=0.001333333333333333;
+					ori_lat=3.0125822852714919;
+                	ori_lon=181.94317626951325; 
+                	                		
+                		d=map.getMaxExtent({
+	                   		restricted: !0
+    		            });
+         	
+         			    var tmp = new OpenLayers.LonLat( ((a.x - map.minPx.x) * map.getResolution() + d.left)*step_x, ((map.minPx.y - a.y) * map.getResolution() + d.top)*step_y);
+
+  	   				    var lon_final_tmp = OpenLayers.Util.toFloat(tmp.lon)+ori_lon;
+      				    lon_final=lon_final_tmp<0?360+lon_final_tmp:lon_final_tmp;
+        			    var lat_final = OpenLayers.Util.toFloat(tmp.lat)+ori_lat;
+        				
+        			if (lat_final<3.08588 && lat_final> -2.90 && lon_final_tmp< 181.943 && lon_final_tmp>-183.943)					        
+	              		  OpenLayers.Util.getElement("valuediv").innerHTML = lon_final_tmp.toFixed(4)+", "+lat_final.toFixed(4);
+	              		//  OpenLayers.Util.getElement("valuediv").innerHTML = a.x+", "+a.y;
+						else
+					  OpenLayers.Util.getElement("valuediv").innerHTML = "";
+
+
+          		  });
+
+                  var layer = new OpenLayers.Layer.TMS("TMS Layer", "",
+                  {
+                      serviceVersion: '.',
+                      layername: '.',
+                      alpha: true,
+                      type: 'png',
+                      getURL: getURL
+                  });
+
+                  map.addLayer(layer);
+                  
+            	 var polygonLayer = new OpenLayers.Layer.Vector("Polygon Layer");
+                 map.addLayer(polygonLayer);
+		        // map.zoomToExtent(mapBounds);
+
+               var mapBoundsInitialZoom = new OpenLayers.Bounds(135.337, 16000.0, 135.337, 20000.0);
+		         map.zoomToExtent(mapBoundsInitialZoom);
+
+        
+                 map.addControls([new OpenLayers.Control.PanZoomBar(),
+                                   new OpenLayers.Control.Navigation(),
+                                   new OpenLayers.Control.MousePosition(),
+                                   new OpenLayers.Control.ArgParser(),
+                                   new OpenLayers.Control.Attribution()]);
+
+                  map.addControl(new OpenLayers.Control.LayerSwitcher());
+      
+            
+      
+      
+       		pointControl = new OpenLayers.Control.DrawFeature(polygonLayer,  OpenLayers.Handler.Point);
+
+
+            
+            map.addControl(pointControl);
+            
+            // register a listener on each control
+  			pointControl.events.register('featureadded', pointControl, function(f)
+  			{
+  				if (polygonLayer.features.length >1)
+  				{
+  					polygonLayer.removeFeatures(polygonLayer.features[0]);
+  				}
+				v = OpenLayers.Util.getElement("valuediv").innerHTML;
+				OpenLayers.Util.getElement("selected_point").innerHTML = v;
+				OpenLayers.Util.getElement("selected_radius").innerHTML = "";
+
+			    window.status="";
+
+   			});
+
+
+			polygonControl = new OpenLayers.Control.DrawFeature(polygonLayer, OpenLayers.Handler.RegularPolygon, {
+            	              handlerOptions: {
+            	                sides: 4,
+                                irregular: true
+                	            }
+                	        });
+			
+			map.addControl(polygonControl);
+
+ 		 // register a listener on each control
+  			polygonControl.events.register('featureadded', polygonControl, function(f)
+  			{
+  				
+  						centerPixel=f.feature.geometry.getBounds().getCenterPixel();							
+						//lonlat del centro
+						var lonlat={lon:centerPixel.x,lat:centerPixel.y};
+						//lonlat del pixel top left
+						var lonlat_top={lon:f.feature.geometry.getBounds().left,lat:f.feature.geometry.getBounds().top};
+						//lonlat del pixel bot
+						var lonlat_bot={lon:f.feature.geometry.getBounds().left,lat:f.feature.geometry.getBounds().bottom};
+						//lonlat del pixel top right
+						var lonlat_right={lon:f.feature.geometry.getBounds().right,lat:f.feature.geometry.getBounds().top};
+
+
+
+
+						var a=map.getPixelFromLonLat(lonlat);
+	        			var b = map.getLonLatFromPixel(a);
+	        			
+	        			var a_top=map.getPixelFromLonLat(lonlat_top);
+	        			var b_top = map.getLonLatFromPixel(a_top);
+	        			
+	        			var a_bot=map.getPixelFromLonLat(lonlat_bot);
+	        			var b_bot = map.getLonLatFromPixel(a_bot);
+
+						var a_right = map.getPixelFromLonLat(lonlat_right);
+	        			var b_right = map.getLonLatFromPixel(a_right);
+
+				        //displayProjection= null;
+
+	        			//displayProjection && b.transform(map.getProjectionObject(), displayProjection);
+	        			
+	        			
+
+	        			  //var tmp = parseInt(10);
+        			//	var ret=b.lon.toFixed(b) +" , " + b.lat.toFixed(b)
+				        
+				 	
+                	//ori_lon=181.943; 
+					//ori_lat=2.8514;
+					//ori_lat=3.08588;
+					step_x=-0.001333333333333333;
+                	step_y=0.001333333333333333;
+					ori_lat=3.0125822852714919;
+                	ori_lon=181.94317626951325; 
+
+                		
+                	                		
+                		d=map.getMaxExtent({
+	                   		restricted: !0
+    		            });
+         	
+         	
+         				//COMPUTE CENTER GLON/GLAT
+         			    var tmp = new OpenLayers.LonLat( ((a.x - map.minPx.x) * map.getResolution() + d.left)*step_x, ((map.minPx.y - a.y) * map.getResolution() + d.top)*step_y);
+  	   				    var lon_final = OpenLayers.Util.toFloat(tmp.lon)+ori_lon;
+      				    //var lon_final=lon_final_tmp<0?360+lon_final_tmp:lon_final_tmp;
+        			    var lat_final = OpenLayers.Util.toFloat(tmp.lat)+ori_lat;
+
+						//COMPUTE TOP GLON/GLAT
+         			    var tmp_top = new OpenLayers.LonLat( ((a_top.x - map.minPx.x) * map.getResolution() + d.left)*step_x, ((map.minPx.y - a_top.y) * map.getResolution() + d.top)*step_y);
+  	   				    var lon_final_top = OpenLayers.Util.toFloat(tmp_top.lon)+ori_lon;
+      				   // var lon_final_top=lon_final_tmp<0?360+lon_final_tmp:lon_final_tmp;
+        			    var lat_final_top = OpenLayers.Util.toFloat(tmp_top.lat)+ori_lat;
+
+						//COMPUTE BOTTOM GLON/GLAT
+         			    var tmp_bot = new OpenLayers.LonLat( ((a_bot.x - map.minPx.x) * map.getResolution() + d.left)*step_x, ((map.minPx.y - a_bot.y) * map.getResolution() + d.top)*step_y);
+  	   				    var lon_final_bot = OpenLayers.Util.toFloat(tmp_bot.lon)+ori_lon;
+      				    //var lon_final_bot=lon_final_tmp<0?360+lon_final_tmp:lon_final_tmp;
+        			    var lat_final_bot = OpenLayers.Util.toFloat(tmp_bot.lat)+ori_lat;
+
+						//COMPUTE right GLON/GLAT
+         			    var tmp_right = new OpenLayers.LonLat( ((a_right.x - map.minPx.x) * map.getResolution() + d.left)*step_x, ((map.minPx.y - a_right.y) * map.getResolution() + d.top)*step_y);
+  	   				    var lon_final_right = OpenLayers.Util.toFloat(tmp_right.lon)+ori_lon;
+      				    //var lon_final_right = lon_final_tmp<0?360+lon_final_tmp:lon_final_tmp;
+        			    var lat_final_right = OpenLayers.Util.toFloat(tmp_right.lat)+ori_lat;
+
+
+						var db=Math.abs(lat_final_top-lat_final_bot);
+						var dl=Math.abs(lon_final_top-lon_final_right);
+
+			/*
+    				  	console.log("CENTER: "+lon_final.toFixed(4) +"," + lat_final.toFixed(4) );
+    				  	console.log("TOP: "+lon_final_top.toFixed(4) +"," + lat_final_top.toFixed(4) );
+    				  	console.log("BOT: "+lon_final_bot.toFixed(4) +"," + lat_final_bot.toFixed(4) );
+    				  	console.log("RIGHT: "+lon_final_right.toFixed(4) +"," + lat_final_right.toFixed(4) );*/
+						console.log("db: "+db.toFixed(4) +" dl: "+dl.toFixed(4) );
+			
+  				
+  				
+  				
+  				
+
+  				if (polygonLayer.features.length >1)
+  				{
+  					polygonLayer.removeFeatures(polygonLayer.features[0]);
+  				}
+				OpenLayers.Util.getElement("selected_point").innerHTML = lon_final.toFixed(4) +"," + lat_final.toFixed(4);
+				OpenLayers.Util.getElement("selected_radius").innerHTML = dl.toFixed(4) +"," + db.toFixed(4);
+			    window.status="";
+
+
+   			});
+
+
+     
+
+      
+		activatePointSelection(false);
+		activateRectangularSelection(false);
+        // activatePointSelection(true);
+        //activateRectangularSelection(true);
+         
+         var click = new OpenLayers.Control.Click();       
+         map.addControl(click);
+         click.activate();
+           
+        }
+
+     
+     
+     function activateRectangularSelection(e)
+     {
+     	if(e)
+		{          	
+	       	 polygonControl.activate();
+	       	 pointControl.deactivate();
+        }
+        else
+	    {
+	    	polygonControl.deactivate();
+		}
+     }
+     
+     
+    function activatePointSelection(e)
+          {
+          	if(e)
+			{          	
+	        	 pointControl.activate();
+	        	 polygonControl.deactivate();
+        	}
+        	 else
+	        {
+	        	 pointControl.deactivate();
+		  	}
+		  }
+          
+          
+      function getURL(bounds) {
+                  bounds = this.adjustBounds(bounds);
+                  var res = this.getServerResolution();
+
+                  var x = Math.round((bounds.left - this.tileOrigin.lon) / (res * this.tileSize.w));
+                  var y = Math.round((bounds.bottom - this.tileOrigin.lat) / (res * this.tileSize.h));
+                  var z = this.getServerZoom();
+                  var path = this.serviceVersion + "/" + this.layername + "/" + z + "/" + x + "/" + y + "." + this.type; 
+                  var url = this.url;
+        
+                  
+                  if (OpenLayers.Util.isArray(url)) {
+                      url = this.selectUrl(path, url);
+                  }
+                  if (mapBounds.intersectsBounds(bounds) && (z >= mapMinZoom) && (z <= mapMaxZoom)) {
+                      return url + path;
+                  } else {
+                      return emptyTileURL;
+                  }
+              }
+          
+      function getWindowHeight() {
+                if (self.innerHeight) return self.innerHeight;
+                    if (document.documentElement && document.documentElement.clientHeight)
+                        return document.documentElement.clientHeight;
+                    if (document.body) return document.body.clientHeight;
+                        return 0;
+                }
+
+       function getWindowWidth() {
+                    if (self.innerWidth) return self.innerWidth;
+                    if (document.documentElement && document.documentElement.clientWidth)
+                        return document.documentElement.clientWidth;
+                    if (document.body) return document.body.clientWidth;
+                        return 0;
+                }
+
+    function resize() {  
+                    var map = document.getElementById("map");  
+                    var header = document.getElementById("header");  
+                    var subheader = document.getElementById("subheader");  
+                    map.style.height = (getWindowHeight()-80) + "px";
+                    map.style.width = (getWindowWidth()-20) + "px";
+                    header.style.width = (getWindowWidth()-20) + "px";
+                    subheader.style.width = (getWindowWidth()-20) + "px";
+                    if (map.updateSize) { map.updateSize(); };
+                }
+
+                onresize=function(){ resize(); };
+
+
+             </script>
+              </head>
+              <body onload="init()">
+                <div id="header">
+                	<img src="./logo.png" alt="logo" height="50px">
+                    <div id="valuediv" style="float:right" value=""></div>
+                    <div id="selected_point" style="display:none;" value=""></div>
+                    <div id="selected_radius" style="display:none;" value=""></div>
+
+                </div>
+                <div id="subheader">
+                	<!--
+                		Generated by <a href="http://www.maptiler.org/">MapTiler</a>/<a href="http://www.klokan.cz/projects/gdal2tiles/">GDAL2Tiles</a>, Copyright &copy; 2008 <a href="http://www.klokan.cz/">Klokan Petr Pridal</a>,  <a href="http://www.gdal.org/">GDAL</a> &amp; <a href="http://www.osgeo.org/">OSGeo</a> <a href="http://code.google.com/soc/">GSoC</a>
+               		-->
+                <!-- PLEASE, LET THIS NOTE ABOUT AUTHOR AND PROJECT SOMEWHERE ON YOUR WEBSITE, OR AT LEAST IN THE COMMENT IN HTML. THANK YOU -->
+                </div>
+       
+                
+                
+        	<div id="map"></div>
+        		<script type="text/javascript" >
+                	resize();                
+                </script>
+              </body>
+            </html>
\ No newline at end of file
diff --git a/PanoramicView/style.css b/PanoramicView/style.css
new file mode 100644
index 0000000000000000000000000000000000000000..8e0abb70f4b1317b58894d8cf659a938091d4433
--- /dev/null
+++ b/PanoramicView/style.css
@@ -0,0 +1,484 @@
+div.olMap {
+    z-index: 0;
+    padding: 0 !important;
+    margin: 0 !important;
+    cursor: default;
+}
+
+div.olMapViewport {
+    text-align: left;
+}
+
+div.olLayerDiv {
+   -moz-user-select: none;
+   -khtml-user-select: none;
+}
+
+.olLayerGoogleCopyright {
+    left: 2px;
+    bottom: 2px;
+}
+.olLayerGoogleV3.olLayerGoogleCopyright {
+    right: auto !important;
+}
+.olLayerGooglePoweredBy {
+    left: 2px;
+    bottom: 15px;
+}
+.olLayerGoogleV3.olLayerGooglePoweredBy {
+    bottom: 15px !important;
+}
+.olControlAttribution {
+    font-size: smaller;
+    right: 3px;
+    bottom: 4.5em;
+    position: absolute;
+    display: block;
+}
+.olControlScale {
+    right: 3px;
+    bottom: 3em;
+    display: block;
+    position: absolute;
+    font-size: smaller;
+}
+.olControlScaleLine {
+   display: block;
+   position: absolute;
+   left: 10px;
+   bottom: 15px;
+   font-size: xx-small;
+}
+.olControlScaleLineBottom {
+   border: solid 2px black;
+   border-bottom: none;
+   margin-top:-2px;
+   text-align: center;
+}
+.olControlScaleLineTop {
+   border: solid 2px black;
+   border-top: none;
+   text-align: center;
+}
+
+.olControlPermalink {
+    right: 3px;
+    bottom: 1.5em;
+    display: block;
+    position: absolute;
+    font-size: smaller;
+}
+
+div.olControlMousePosition {
+    bottom: 0;
+    right: 3px;
+    display: block;
+    position: absolute;
+    font-family: Arial;
+    font-size: smaller;
+}
+
+.olControlOverviewMapContainer {
+    position: absolute;
+    bottom: 0;
+    right: 0;
+}
+
+.olControlOverviewMapElement {
+    padding: 10px 18px 10px 10px;
+    background-color: #00008B;
+    -moz-border-radius: 1em 0 0 0;
+}
+
+.olControlOverviewMapMinimizeButton,
+.olControlOverviewMapMaximizeButton {
+    height: 18px;
+    width: 18px;
+    right: 0;
+    bottom: 80px;
+    cursor: pointer;
+}
+
+.olControlOverviewMapExtentRectangle {
+    overflow: hidden;
+    background-image: url("img/blank.gif");
+    cursor: move;
+    border: 2px dotted red;
+}
+.olControlOverviewMapRectReplacement {
+    overflow: hidden;
+    cursor: move;
+    background-image: url("img/overview_replacement.gif");
+    background-repeat: no-repeat;
+    background-position: center;
+}
+
+.olLayerGeoRSSDescription {
+    float:left;
+    width:100%;
+    overflow:auto;
+    font-size:1.0em;
+}
+.olLayerGeoRSSClose {
+    float:right;
+    color:gray;
+    font-size:1.2em;
+    margin-right:6px;
+    font-family:sans-serif;
+}
+.olLayerGeoRSSTitle {
+    float:left;font-size:1.2em;
+}
+
+.olPopupContent {
+    padding:5px;
+    overflow: auto;
+}
+
+.olControlNavigationHistory {
+   background-image: url("img/navigation_history.png");
+   background-repeat: no-repeat;
+   width:  24px;
+   height: 24px;
+
+}
+.olControlNavigationHistoryPreviousItemActive {
+  background-position: 0 0;
+}
+.olControlNavigationHistoryPreviousItemInactive {
+   background-position: 0 -24px;
+}
+.olControlNavigationHistoryNextItemActive {
+   background-position: -24px 0;
+}
+.olControlNavigationHistoryNextItemInactive {
+   background-position: -24px -24px;
+}
+
+div.olControlSaveFeaturesItemActive {
+    background-image: url(img/save_features_on.png);
+    background-repeat: no-repeat;
+    background-position: 0 1px;
+}
+div.olControlSaveFeaturesItemInactive {
+    background-image: url(img/save_features_off.png);
+    background-repeat: no-repeat;
+    background-position: 0 1px;
+}
+
+.olHandlerBoxZoomBox {
+    border: 2px solid red;
+    position: absolute;
+    background-color: white;
+    opacity: 0.50;
+    font-size: 1px;
+    filter: alpha(opacity=50);
+}
+.olHandlerBoxSelectFeature {
+    border: 2px solid blue;
+    position: absolute;
+    background-color: white;
+    opacity: 0.50;
+    font-size: 1px;
+    filter: alpha(opacity=50);
+}
+
+.olControlPanPanel {
+    top: 10px;
+    left: 5px;
+}
+
+.olControlPanPanel div {
+    background-image: url(img/pan-panel.png);
+    height: 18px;
+    width: 18px;
+    cursor: pointer;
+    position: absolute;
+}
+
+.olControlPanPanel .olControlPanNorthItemInactive {
+    top: 0;
+    left: 9px;
+    background-position: 0 0;
+}
+.olControlPanPanel .olControlPanSouthItemInactive {
+    top: 36px;
+    left: 9px;
+    background-position: 18px 0;
+}
+.olControlPanPanel .olControlPanWestItemInactive {
+    position: absolute;
+    top: 18px;
+    left: 0;
+    background-position: 0 18px;
+}
+.olControlPanPanel .olControlPanEastItemInactive {
+    top: 18px;
+    left: 18px;
+    background-position: 18px 18px;
+}
+
+.olControlZoomPanel {
+    top: 71px;
+    left: 14px;
+}
+
+.olControlZoomPanel div {
+    background-image: url(img/zoom-panel.png);
+    position: absolute;
+    height: 18px;
+    width: 18px;
+    cursor: pointer;
+}
+
+.olControlZoomPanel .olControlZoomInItemInactive {
+    top: 0;
+    left: 0;
+    background-position: 0 0;
+}
+
+.olControlZoomPanel .olControlZoomToMaxExtentItemInactive {
+    top: 18px;
+    left: 0;
+    background-position: 0 -18px;
+}
+
+.olControlZoomPanel .olControlZoomOutItemInactive {
+    top: 36px;
+    left: 0;
+    background-position: 0 18px;
+}
+
+/*
+ * When a potential text is bigger than the image it move the image
+ * with some headers (closes #3154)
+ */
+.olControlPanZoomBar div {
+    font-size: 1px;
+}
+
+.olPopupCloseBox {
+  background: url("img/close.gif") no-repeat;
+  cursor: pointer;
+}
+
+.olFramedCloudPopupContent {
+    padding: 5px;
+    overflow: auto;
+}
+
+.olControlNoSelect {
+ -moz-user-select: none;
+ -khtml-user-select: none;
+}
+
+.olImageLoadError {
+    background-color: pink;
+    opacity: 0.5;
+    filter: alpha(opacity=50); /* IE */
+}
+
+/**
+ * Cursor styles
+ */
+
+.olCursorWait {
+    cursor: wait;
+}
+.olDragDown {
+    cursor: move;
+}
+.olDrawBox {
+    cursor: crosshair;
+}
+.olControlDragFeatureOver {
+    cursor: move;
+}
+.olControlDragFeatureActive.olControlDragFeatureOver.olDragDown {
+    cursor: -moz-grabbing;
+}
+
+/**
+ * Layer switcher
+ */
+.olControlLayerSwitcher {
+    position: absolute;
+    top: 25px;
+    right: 0;
+    width: 20em;
+    font-family: sans-serif;
+    font-weight: bold;
+    margin-top: 3px;
+    margin-left: 3px;
+    margin-bottom: 3px;
+    font-size: smaller;
+    color: white;
+    background-color: transparent;
+}
+
+.olControlLayerSwitcher .layersDiv {
+    padding-top: 5px;
+    padding-left: 10px;
+    padding-bottom: 5px;
+    padding-right: 10px;
+    background-color: darkblue;
+}
+
+.olControlLayerSwitcher .layersDiv .baseLbl,
+.olControlLayerSwitcher .layersDiv .dataLbl {
+    margin-top: 3px;
+    margin-left: 3px;
+    margin-bottom: 3px;
+}
+
+.olControlLayerSwitcher .layersDiv .baseLayersDiv,
+.olControlLayerSwitcher .layersDiv .dataLayersDiv {
+    padding-left: 10px;
+}
+
+.olControlLayerSwitcher .maximizeDiv,
+.olControlLayerSwitcher .minimizeDiv {
+    width: 18px;
+    height: 18px;
+    top: 5px;
+    right: 0;
+    cursor: pointer;
+}
+
+.olBingAttribution {
+    color: #DDD;
+}
+.olBingAttribution.road {
+    color: #333;
+}
+
+.olGoogleAttribution.hybrid, .olGoogleAttribution.satellite {
+    color: #EEE;
+}
+.olGoogleAttribution {
+    color: #333;
+}
+span.olGoogleAttribution a {
+    color: #77C;
+}
+span.olGoogleAttribution.hybrid a, span.olGoogleAttribution.satellite a {
+    color: #EEE;
+}
+
+/**
+ * Editing and navigation icons.
+ * (using the editing_tool_bar.png sprint image)
+ */
+.olControlNavToolbar ,
+.olControlEditingToolbar {
+    margin: 5px 5px 0 0;
+}
+.olControlNavToolbar div,
+.olControlEditingToolbar div {
+    background-image: url("img/editing_tool_bar.png");
+    background-repeat: no-repeat;
+    margin: 0 0 5px 5px;
+    width: 24px;
+    height: 22px;
+    cursor: pointer
+}
+/* positions */
+.olControlEditingToolbar {
+    right: 0;
+    top: 0;
+}
+.olControlNavToolbar {
+    top: 295px;
+    left: 9px;
+}
+/* layouts */
+.olControlEditingToolbar div {
+    float: right;
+}
+/* individual controls */
+.olControlNavToolbar .olControlNavigationItemInactive,
+.olControlEditingToolbar .olControlNavigationItemInactive {
+    background-position: -103px -1px;
+}
+.olControlNavToolbar .olControlNavigationItemActive ,
+.olControlEditingToolbar .olControlNavigationItemActive  {
+    background-position: -103px -24px;
+}
+.olControlNavToolbar .olControlZoomBoxItemInactive {
+    background-position: -128px -1px;
+}
+.olControlNavToolbar .olControlZoomBoxItemActive  {
+    background-position: -128px -24px;
+}
+.olControlEditingToolbar .olControlDrawFeaturePointItemInactive {
+    background-position: -77px -1px;
+}
+.olControlEditingToolbar .olControlDrawFeaturePointItemActive {
+    background-position: -77px -24px;
+}
+.olControlEditingToolbar .olControlDrawFeaturePathItemInactive {
+    background-position: -51px -1px;
+}
+.olControlEditingToolbar .olControlDrawFeaturePathItemActive {
+    background-position: -51px -24px;
+}
+.olControlEditingToolbar .olControlDrawFeaturePolygonItemInactive{
+    background-position: -26px -1px;
+}
+.olControlEditingToolbar .olControlDrawFeaturePolygonItemActive {
+    background-position: -26px -24px;
+}
+
+div.olControlZoom {
+    position: absolute;
+    top: 8px;
+    left: 8px;
+    background: rgba(255,255,255,0.4);
+    border-radius: 4px;
+    padding: 2px;
+}
+div.olControlZoom a {
+    display: block;
+    margin: 1px;
+    padding: 0;
+    color: white;
+    font-size: 18px;
+    font-family: 'Lucida Grande', Verdana, Geneva, Lucida, Arial, Helvetica, sans-serif;
+    font-weight: bold;
+    text-decoration: none;
+    text-align: center;
+    height: 22px;
+    width:22px;
+    line-height: 19px;
+    background: #130085; /* fallback for IE - IE6 requires background shorthand*/
+    background: rgba(0, 60, 136, 0.5);
+    filter: alpha(opacity=80);
+}
+div.olControlZoom a:hover {
+    background: #130085; /* fallback for IE */
+    background: rgba(0, 60, 136, 0.7);
+    filter: alpha(opacity=100);
+}
+@media only screen and (max-width: 600px) {
+    div.olControlZoom a:hover {
+        background: rgba(0, 60, 136, 0.5);
+    }
+}
+a.olControlZoomIn {
+    border-radius: 4px 4px 0 0;
+}
+a.olControlZoomOut {
+    border-radius: 0 0 4px 4px;
+}
+
+
+/**
+ * Animations
+ */
+
+.olLayerGrid .olTileImage {
+    -webkit-transition: opacity 0.2s linear;
+    -moz-transition: opacity 0.2s linear;
+    -o-transition: opacity 0.2s linear;
+    transition: opacity 0.2s linear;
+}
diff --git a/PanoramicView/tilemapresource.xml b/PanoramicView/tilemapresource.xml
new file mode 100644
index 0000000000000000000000000000000000000000..7eea67abc11746f7a926ddd7414a7b5fc33c3db3
--- /dev/null
+++ b/PanoramicView/tilemapresource.xml
@@ -0,0 +1,24 @@
+<?xml version="1.0" encoding="utf-8"?>
+    <TileMap version="1.0.0" tilemapservice="http://tms.osgeo.org/1.0.0">
+      <Title>HiGal Pano Inner Galaxy Full Resolution.tif</Title>
+      <Abstract></Abstract>
+      <SRS></SRS>
+      <BoundingBox minx="0.00000000000000" miny="-4398.00000000000000" maxx="270674.00000000000000" maxy="0.00000000000000"/>
+      <Origin x="0.00000000000000" y="-4398.00000000000000"/>
+      <TileFormat width="256" height="256" mime-type="image/png" extension="png"/>
+      <TileSets profile="raster">
+        <TileSet href="0" units-per-pixel="2048.00000000000000" order="0"/>
+        <TileSet href="1" units-per-pixel="1024.00000000000000" order="1"/>
+        <TileSet href="2" units-per-pixel="512.00000000000000" order="2"/>
+        <TileSet href="3" units-per-pixel="256.00000000000000" order="3"/>
+        <TileSet href="4" units-per-pixel="128.00000000000000" order="4"/>
+        <TileSet href="5" units-per-pixel="64.00000000000000" order="5"/>
+        <TileSet href="6" units-per-pixel="32.00000000000000" order="6"/>
+        <TileSet href="7" units-per-pixel="16.00000000000000" order="7"/>
+        <TileSet href="8" units-per-pixel="8.00000000000000" order="8"/>
+        <TileSet href="9" units-per-pixel="4.00000000000000" order="9"/>
+        <TileSet href="10" units-per-pixel="2.00000000000000" order="10"/>
+        <TileSet href="11" units-per-pixel="1.00000000000000" order="11"/>
+      </TileSets>
+    </TileMap>
+    
\ No newline at end of file