!function(t){"object"==typeof exports&&"undefined"!=typeof module?module.exports=t():"function"==typeof define&&define.amd?define([],t):("undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:this).Custom=t()}(function(){return function i(a,n,s){function o(e,t){if(!n[e]){if(!a[e]){var r="function"==typeof require&&require;if(!t&&r)return r(e,!0);if(l)return l(e,!0);throw(r=new Error("Cannot find module '"+e+"'")).code="MODULE_NOT_FOUND",r}r=n[e]={exports:{}},a[e][0].call(r.exports,function(t){return o(a[e][1][t]||t)},r,r.exports,i,a,n,s)}return n[e].exports}for(var l="function"==typeof require&&require,t=0;t<s.length;t++)o(s[t]);return o}({1:[function(t,e,r){"use strict";r.byteLength=function(t){var e=h(t),t=e[0],e=e[1];return 3*(t+e)/4-e},r.toByteArray=function(t){var e,r,i=h(t),a=i[0],i=i[1],n=new u(function(t,e){return 3*(t+e)/4-e}(a,i)),s=0,o=0<i?a-4:a;for(r=0;r<o;r+=4)e=l[t.charCodeAt(r)]<<18|l[t.charCodeAt(r+1)]<<12|l[t.charCodeAt(r+2)]<<6|l[t.charCodeAt(r+3)],n[s++]=e>>16&255,n[s++]=e>>8&255,n[s++]=255&e;2===i&&(e=l[t.charCodeAt(r)]<<2|l[t.charCodeAt(r+1)]>>4,n[s++]=255&e);1===i&&(e=l[t.charCodeAt(r)]<<10|l[t.charCodeAt(r+1)]<<4|l[t.charCodeAt(r+2)]>>2,n[s++]=e>>8&255,n[s++]=255&e);return n},r.fromByteArray=function(t){for(var e,r=t.length,i=r%3,a=[],n=0,s=r-i;n<s;n+=16383)a.push(function(t,e,r){for(var i,a=[],n=e;n<r;n+=3)i=(t[n]<<16&16711680)+(t[n+1]<<8&65280)+(255&t[n+2]),a.push(function(t){return o[t>>18&63]+o[t>>12&63]+o[t>>6&63]+o[63&t]}(i));return a.join("")}(t,n,s<n+16383?s:n+16383));1==i?(e=t[r-1],a.push(o[e>>2]+o[e<<4&63]+"==")):2==i&&(e=(t[r-2]<<8)+t[r-1],a.push(o[e>>10]+o[e>>4&63]+o[e<<2&63]+"="));return a.join("")};for(var o=[],l=[],u="undefined"!=typeof Uint8Array?Uint8Array:Array,i="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",a=0,n=i.length;a<n;++a)o[a]=i[a],l[i.charCodeAt(a)]=a;function h(t){var e=t.length;if(0<e%4)throw new Error("Invalid string. Length must be a multiple of 4");t=t.indexOf("=");return[t=-1===t?e:t,t===e?0:4-t%4]}l["-".charCodeAt(0)]=62,l["_".charCodeAt(0)]=63},{}],2:[function(z,t,F){!function(t){!function(){"use strict";var o=z("base64-js"),n=z("ieee754");F.Buffer=d,F.SlowBuffer=function(t){+t!=t&&(t=0);return d.alloc(+t)},F.INSPECT_MAX_BYTES=50;var e=2147483647;function a(t){if(e<t)throw new RangeError('The value "'+t+'" is invalid for option "size"');t=new Uint8Array(t);return t.__proto__=d.prototype,t}function d(t,e,r){if("number"!=typeof t)return i(t,e,r);if("string"==typeof e)throw new TypeError('The "string" argument must be of type string. Received type number');return l(t)}function i(t,e,r){if("string"==typeof t)return function(t,e){"string"==typeof e&&""!==e||(e="utf8");if(!d.isEncoding(e))throw new TypeError("Unknown encoding: "+e);var r=0|f(t,e),i=a(r),e=i.write(t,e);e!==r&&(i=i.slice(0,e));return i}(t,e);if(ArrayBuffer.isView(t))return u(t);if(null==t)throw TypeError("The first argument must be one of type string, Buffer, ArrayBuffer, Array, or Array-like Object. Received type "+typeof t);if(g(t,ArrayBuffer)||t&&g(t.buffer,ArrayBuffer))return function(t,e,r){if(e<0||t.byteLength<e)throw new RangeError('"offset" is outside of buffer bounds');if(t.byteLength<e+(r||0))throw new RangeError('"length" is outside of buffer bounds');r=void 0===e&&void 0===r?new Uint8Array(t):void 0===r?new Uint8Array(t,e):new Uint8Array(t,e,r);return r.__proto__=d.prototype,r}(t,e,r);if("number"==typeof t)throw new TypeError('The "value" argument must not be of type number. Received type number');var i=t.valueOf&&t.valueOf();if(null!=i&&i!==t)return d.from(i,e,r);i=function(t){if(d.isBuffer(t)){var e=0|h(t.length),r=a(e);return 0===r.length?r:(t.copy(r,0,0,e),r)}if(void 0!==t.length)return"number"!=typeof t.length||w(t.length)?a(0):u(t);if("Buffer"===t.type&&Array.isArray(t.data))return u(t.data)}(t);if(i)return i;if("undefined"!=typeof Symbol&&null!=Symbol.toPrimitive&&"function"==typeof t[Symbol.toPrimitive])return d.from(t[Symbol.toPrimitive]("string"),e,r);throw new TypeError("The first argument must be one of type string, Buffer, ArrayBuffer, Array, or Array-like Object. Received type "+typeof t)}function s(t){if("number"!=typeof t)throw new TypeError('"size" argument must be of type number');if(t<0)throw new RangeError('The value "'+t+'" is invalid for option "size"')}function l(t){return s(t),a(t<0?0:0|h(t))}function u(t){for(var e=t.length<0?0:0|h(t.length),r=a(e),i=0;i<e;i+=1)r[i]=255&t[i];return r}function h(t){if(e<=t)throw new RangeError("Attempt to allocate Buffer larger than maximum size: 0x"+e.toString(16)+" bytes");return 0|t}function f(t,e){if(d.isBuffer(t))return t.length;if(ArrayBuffer.isView(t)||g(t,ArrayBuffer))return t.byteLength;if("string"!=typeof t)throw new TypeError('The "string" argument must be one of type string, Buffer, or ArrayBuffer. Received type '+typeof t);var r=t.length,i=2<arguments.length&&!0===arguments[2];if(!i&&0===r)return 0;for(var a=!1;;)switch(e){case"ascii":case"latin1":case"binary":return r;case"utf8":case"utf-8":return P(t).length;case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return 2*r;case"hex":return r>>>1;case"base64":return T(t).length;default:if(a)return i?-1:P(t).length;e=(""+e).toLowerCase(),a=!0}}function r(t,e,r){var i,a,n,s=!1;if((e=void 0===e||e<0?0:e)>this.length)return"";if((r=void 0===r||r>this.length?this.length:r)<=0)return"";if((r>>>=0)<=(e>>>=0))return"";for(t=t||"utf8";;)switch(t){case"hex":return function(t,e,r){var i=t.length;(!e||e<0)&&(e=0);(!r||r<0||i<r)&&(r=i);for(var a="",n=e;n<r;++n)a+=function(t){return t<16?"0"+t.toString(16):t.toString(16)}(t[n]);return a}(this,e,r);case"utf8":case"utf-8":return y(this,e,r);case"ascii":return function(t,e,r){var i="";r=Math.min(t.length,r);for(var a=e;a<r;++a)i+=String.fromCharCode(127&t[a]);return i}(this,e,r);case"latin1":case"binary":return function(t,e,r){var i="";r=Math.min(t.length,r);for(var a=e;a<r;++a)i+=String.fromCharCode(t[a]);return i}(this,e,r);case"base64":return i=this,n=r,0===(a=e)&&n===i.length?o.fromByteArray(i):o.fromByteArray(i.slice(a,n));case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return function(t,e,r){for(var i=t.slice(e,r),a="",n=0;n<i.length;n+=2)a+=String.fromCharCode(i[n]+256*i[n+1]);return a}(this,e,r);default:if(s)throw new TypeError("Unknown encoding: "+t);t=(t+"").toLowerCase(),s=!0}}function m(t,e,r){var i=t[e];t[e]=t[r],t[r]=i}function v(t,e,r,i,a){if(0===t.length)return-1;if("string"==typeof r?(i=r,r=0):2147483647<r?r=2147483647:r<-2147483648&&(r=-2147483648),(r=(r=w(r=+r)?a?0:t.length-1:r)<0?t.length+r:r)>=t.length){if(a)return-1;r=t.length-1}else if(r<0){if(!a)return-1;r=0}if("string"==typeof e&&(e=d.from(e,i)),d.isBuffer(e))return 0===e.length?-1:p(t,e,r,i,a);if("number"==typeof e)return e&=255,"function"==typeof Uint8Array.prototype.indexOf?(a?Uint8Array.prototype.indexOf:Uint8Array.prototype.lastIndexOf).call(t,e,r):p(t,[e],r,i,a);throw new TypeError("val must be string, number or Buffer")}function p(t,e,r,i,a){var n=1,s=t.length,o=e.length;if(void 0!==i&&("ucs2"===(i=String(i).toLowerCase())||"ucs-2"===i||"utf16le"===i||"utf-16le"===i)){if(t.length<2||e.length<2)return-1;s/=n=2,o/=2,r/=2}function l(t,e){return 1===n?t[e]:t.readUInt16BE(e*n)}if(a)for(var u=-1,h=r;h<s;h++)if(l(t,h)===l(e,-1===u?0:h-u)){if(h-(u=-1===u?h:u)+1===o)return u*n}else-1!==u&&(h-=h-u),u=-1;else for(h=r=s<r+o?s-o:r;0<=h;h--){for(var d=!0,f=0;f<o;f++)if(l(t,h+f)!==l(e,f)){d=!1;break}if(d)return h}return-1}function c(t,e,r,i){return S(function(t){for(var e=[],r=0;r<t.length;++r)e.push(255&t.charCodeAt(r));return e}(e),t,r,i)}function b(t,e,r,i){return S(function(t,e){for(var r,i,a=[],n=0;n<t.length&&!((e-=2)<0);++n)i=t.charCodeAt(n),r=i>>8,i=i%256,a.push(i),a.push(r);return a}(e,t.length-r),t,r,i)}function y(t,e,r){r=Math.min(t.length,r);for(var i=[],a=e;a<r;){var n,s,o,l,u=t[a],h=null,d=239<u?4:223<u?3:191<u?2:1;if(a+d<=r)switch(d){case 1:u<128&&(h=u);break;case 2:128==(192&(n=t[a+1]))&&127<(l=(31&u)<<6|63&n)&&(h=l);break;case 3:n=t[a+1],s=t[a+2],128==(192&n)&&128==(192&s)&&2047<(l=(15&u)<<12|(63&n)<<6|63&s)&&(l<55296||57343<l)&&(h=l);break;case 4:n=t[a+1],s=t[a+2],o=t[a+3],128==(192&n)&&128==(192&s)&&128==(192&o)&&65535<(l=(15&u)<<18|(63&n)<<12|(63&s)<<6|63&o)&&l<1114112&&(h=l)}null===h?(h=65533,d=1):65535<h&&(h-=65536,i.push(h>>>10&1023|55296),h=56320|1023&h),i.push(h),a+=d}return function(t){var e=t.length;if(e<=V)return String.fromCharCode.apply(String,t);var r="",i=0;for(;i<e;)r+=String.fromCharCode.apply(String,t.slice(i,i+=V));return r}(i)}F.kMaxLength=e,(d.TYPED_ARRAY_SUPPORT=function(){try{var t=new Uint8Array(1);return t.__proto__={__proto__:Uint8Array.prototype,foo:function(){return 42}},42===t.foo()}catch(t){return!1}}())||"undefined"==typeof console||"function"!=typeof console.error||console.error("This browser lacks typed array (Uint8Array) support which is required by `buffer` v5.x. Use `buffer` v4.x if you require old browser support."),Object.defineProperty(d.prototype,"parent",{enumerable:!0,get:function(){if(d.isBuffer(this))return this.buffer}}),Object.defineProperty(d.prototype,"offset",{enumerable:!0,get:function(){if(d.isBuffer(this))return this.byteOffset}}),"undefined"!=typeof Symbol&&null!=Symbol.species&&d[Symbol.species]===d&&Object.defineProperty(d,Symbol.species,{value:null,configurable:!0,enumerable:!1,writable:!1}),d.poolSize=8192,d.from=i,d.prototype.__proto__=Uint8Array.prototype,d.__proto__=Uint8Array,d.alloc=function(t,e,r){return e=e,r=r,s(t=t),!(t<=0)&&void 0!==e?"string"==typeof r?a(t).fill(e,r):a(t).fill(e):a(t)},d.allocUnsafe=l,d.allocUnsafeSlow=l,d.isBuffer=function(t){return null!=t&&!0===t._isBuffer&&t!==d.prototype},d.compare=function(t,e){if(g(t,Uint8Array)&&(t=d.from(t,t.offset,t.byteLength)),g(e,Uint8Array)&&(e=d.from(e,e.offset,e.byteLength)),!d.isBuffer(t)||!d.isBuffer(e))throw new TypeError('The "buf1", "buf2" arguments must be one of type Buffer or Uint8Array');if(t===e)return 0;for(var r=t.length,i=e.length,a=0,n=Math.min(r,i);a<n;++a)if(t[a]!==e[a]){r=t[a],i=e[a];break}return r<i?-1:i<r?1:0},d.isEncoding=function(t){switch(String(t).toLowerCase()){case"hex":case"utf8":case"utf-8":case"ascii":case"latin1":case"binary":case"base64":case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return!0;default:return!1}},d.concat=function(t,e){if(!Array.isArray(t))throw new TypeError('"list" argument must be an Array of Buffers');if(0===t.length)return d.alloc(0);if(void 0===e)for(a=e=0;a<t.length;++a)e+=t[a].length;for(var r=d.allocUnsafe(e),i=0,a=0;a<t.length;++a){var n=t[a];if(g(n,Uint8Array)&&(n=d.from(n)),!d.isBuffer(n))throw new TypeError('"list" argument must be an Array of Buffers');n.copy(r,i),i+=n.length}return r},d.byteLength=f,d.prototype._isBuffer=!0,d.prototype.swap16=function(){var t=this.length;if(t%2!=0)throw new RangeError("Buffer size must be a multiple of 16-bits");for(var e=0;e<t;e+=2)m(this,e,e+1);return this},d.prototype.swap32=function(){var t=this.length;if(t%4!=0)throw new RangeError("Buffer size must be a multiple of 32-bits");for(var e=0;e<t;e+=4)m(this,e,e+3),m(this,e+1,e+2);return this},d.prototype.swap64=function(){var t=this.length;if(t%8!=0)throw new RangeError("Buffer size must be a multiple of 64-bits");for(var e=0;e<t;e+=8)m(this,e,e+7),m(this,e+1,e+6),m(this,e+2,e+5),m(this,e+3,e+4);return this},d.prototype.toLocaleString=d.prototype.toString=function(){var t=this.length;return 0===t?"":0===arguments.length?y(this,0,t):r.apply(this,arguments)},d.prototype.equals=function(t){if(!d.isBuffer(t))throw new TypeError("Argument must be a Buffer");return this===t||0===d.compare(this,t)},d.prototype.inspect=function(){var t="",e=F.INSPECT_MAX_BYTES,t=this.toString("hex",0,e).replace(/(.{2})/g,"$1 ").trim();return this.length>e&&(t+=" ... "),"<Buffer "+t+">"},d.prototype.compare=function(t,e,r,i,a){if(g(t,Uint8Array)&&(t=d.from(t,t.offset,t.byteLength)),!d.isBuffer(t))throw new TypeError('The "target" argument must be one of type Buffer or Uint8Array. Received type '+typeof t);if(void 0===r&&(r=t?t.length:0),void 0===i&&(i=0),void 0===a&&(a=this.length),(e=void 0===e?0:e)<0||r>t.length||i<0||a>this.length)throw new RangeError("out of range index");if(a<=i&&r<=e)return 0;if(a<=i)return-1;if(r<=e)return 1;if(this===t)return 0;for(var n=(a>>>=0)-(i>>>=0),s=(r>>>=0)-(e>>>=0),o=Math.min(n,s),l=this.slice(i,a),u=t.slice(e,r),h=0;h<o;++h)if(l[h]!==u[h]){n=l[h],s=u[h];break}return n<s?-1:s<n?1:0},d.prototype.includes=function(t,e,r){return-1!==this.indexOf(t,e,r)},d.prototype.indexOf=function(t,e,r){return v(this,t,e,r,!0)},d.prototype.lastIndexOf=function(t,e,r){return v(this,t,e,r,!1)},d.prototype.write=function(t,e,r,i){if(void 0===e)i="utf8",r=this.length,e=0;else if(void 0===r&&"string"==typeof e)i=e,r=this.length,e=0;else{if(!isFinite(e))throw new Error("Buffer.write(string, encoding, offset[, length]) is no longer supported");e>>>=0,isFinite(r)?(r>>>=0,void 0===i&&(i="utf8")):(i=r,r=void 0)}var a=this.length-e;if((void 0===r||a<r)&&(r=a),0<t.length&&(r<0||e<0)||e>this.length)throw new RangeError("Attempt to write outside buffer bounds");i=i||"utf8";for(var n,s,o,l=!1;;)switch(i){case"hex":return function(t,e,r,i){r=Number(r)||0;var a=t.length-r;(!i||a<(i=Number(i)))&&(i=a),(a=e.length)/2<i&&(i=a/2);for(var n=0;n<i;++n){var s=parseInt(e.substr(2*n,2),16);if(w(s))return n;t[r+n]=s}return n}(this,t,e,r);case"utf8":case"utf-8":return s=e,o=r,S(P(t,(n=this).length-s),n,s,o);case"ascii":return c(this,t,e,r);case"latin1":case"binary":return c(this,t,e,r);case"base64":return n=this,s=e,o=r,S(T(t),n,s,o);case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return b(this,t,e,r);default:if(l)throw new TypeError("Unknown encoding: "+i);i=(""+i).toLowerCase(),l=!0}},d.prototype.toJSON=function(){return{type:"Buffer",data:Array.prototype.slice.call(this._arr||this,0)}};var V=4096;function q(t,e,r){if(t%1!=0||t<0)throw new RangeError("offset is not uint");if(r<t+e)throw new RangeError("Trying to access beyond buffer length")}function x(t,e,r,i,a,n){if(!d.isBuffer(t))throw new TypeError('"buffer" argument must be a Buffer instance');if(a<e||e<n)throw new RangeError('"value" argument is out of bounds');if(r+i>t.length)throw new RangeError("Index out of range")}function W(t,e,r,i){if(r+i>t.length)throw new RangeError("Index out of range");if(r<0)throw new RangeError("Index out of range")}function N(t,e,r,i,a){return e=+e,r>>>=0,a||W(t,0,r,4),n.write(t,e,r,i,23,4),r+4}function X(t,e,r,i,a){return e=+e,r>>>=0,a||W(t,0,r,8),n.write(t,e,r,i,52,8),r+8}d.prototype.slice=function(t,e){var r=this.length;(t=~~t)<0?(t+=r)<0&&(t=0):r<t&&(t=r),(e=void 0===e?r:~~e)<0?(e+=r)<0&&(e=0):r<e&&(e=r),e<t&&(e=t);e=this.subarray(t,e);return e.__proto__=d.prototype,e},d.prototype.readUIntLE=function(t,e,r){t>>>=0,e>>>=0,r||q(t,e,this.length);for(var i=this[t],a=1,n=0;++n<e&&(a*=256);)i+=this[t+n]*a;return i},d.prototype.readUIntBE=function(t,e,r){t>>>=0,e>>>=0,r||q(t,e,this.length);for(var i=this[t+--e],a=1;0<e&&(a*=256);)i+=this[t+--e]*a;return i},d.prototype.readUInt8=function(t,e){return t>>>=0,e||q(t,1,this.length),this[t]},d.prototype.readUInt16LE=function(t,e){return t>>>=0,e||q(t,2,this.length),this[t]|this[t+1]<<8},d.prototype.readUInt16BE=function(t,e){return t>>>=0,e||q(t,2,this.length),this[t]<<8|this[t+1]},d.prototype.readUInt32LE=function(t,e){return t>>>=0,e||q(t,4,this.length),(this[t]|this[t+1]<<8|this[t+2]<<16)+16777216*this[t+3]},d.prototype.readUInt32BE=function(t,e){return t>>>=0,e||q(t,4,this.length),16777216*this[t]+(this[t+1]<<16|this[t+2]<<8|this[t+3])},d.prototype.readIntLE=function(t,e,r){t>>>=0,e>>>=0,r||q(t,e,this.length);for(var i=this[t],a=1,n=0;++n<e&&(a*=256);)i+=this[t+n]*a;return(a*=128)<=i&&(i-=Math.pow(2,8*e)),i},d.prototype.readIntBE=function(t,e,r){t>>>=0,e>>>=0,r||q(t,e,this.length);for(var i=e,a=1,n=this[t+--i];0<i&&(a*=256);)n+=this[t+--i]*a;return(a*=128)<=n&&(n-=Math.pow(2,8*e)),n},d.prototype.readInt8=function(t,e){return t>>>=0,e||q(t,1,this.length),128&this[t]?-1*(255-this[t]+1):this[t]},d.prototype.readInt16LE=function(t,e){t>>>=0,e||q(t,2,this.length);t=this[t]|this[t+1]<<8;return 32768&t?4294901760|t:t},d.prototype.readInt16BE=function(t,e){t>>>=0,e||q(t,2,this.length);t=this[t+1]|this[t]<<8;return 32768&t?4294901760|t:t},d.prototype.readInt32LE=function(t,e){return t>>>=0,e||q(t,4,this.length),this[t]|this[t+1]<<8|this[t+2]<<16|this[t+3]<<24},d.prototype.readInt32BE=function(t,e){return t>>>=0,e||q(t,4,this.length),this[t]<<24|this[t+1]<<16|this[t+2]<<8|this[t+3]},d.prototype.readFloatLE=function(t,e){return t>>>=0,e||q(t,4,this.length),n.read(this,t,!0,23,4)},d.prototype.readFloatBE=function(t,e){return t>>>=0,e||q(t,4,this.length),n.read(this,t,!1,23,4)},d.prototype.readDoubleLE=function(t,e){return t>>>=0,e||q(t,8,this.length),n.read(this,t,!0,52,8)},d.prototype.readDoubleBE=function(t,e){return t>>>=0,e||q(t,8,this.length),n.read(this,t,!1,52,8)},d.prototype.writeUIntLE=function(t,e,r,i){t=+t,e>>>=0,r>>>=0,i||x(this,t,e,r,Math.pow(2,8*r)-1,0);var a=1,n=0;for(this[e]=255&t;++n<r&&(a*=256);)this[e+n]=t/a&255;return e+r},d.prototype.writeUIntBE=function(t,e,r,i){t=+t,e>>>=0,r>>>=0,i||x(this,t,e,r,Math.pow(2,8*r)-1,0);var a=r-1,n=1;for(this[e+a]=255&t;0<=--a&&(n*=256);)this[e+a]=t/n&255;return e+r},d.prototype.writeUInt8=function(t,e,r){return t=+t,e>>>=0,r||x(this,t,e,1,255,0),this[e]=255&t,e+1},d.prototype.writeUInt16LE=function(t,e,r){return t=+t,e>>>=0,r||x(this,t,e,2,65535,0),this[e]=255&t,this[e+1]=t>>>8,e+2},d.prototype.writeUInt16BE=function(t,e,r){return t=+t,e>>>=0,r||x(this,t,e,2,65535,0),this[e]=t>>>8,this[e+1]=255&t,e+2},d.prototype.writeUInt32LE=function(t,e,r){return t=+t,e>>>=0,r||x(this,t,e,4,4294967295,0),this[e+3]=t>>>24,this[e+2]=t>>>16,this[e+1]=t>>>8,this[e]=255&t,e+4},d.prototype.writeUInt32BE=function(t,e,r){return t=+t,e>>>=0,r||x(this,t,e,4,4294967295,0),this[e]=t>>>24,this[e+1]=t>>>16,this[e+2]=t>>>8,this[e+3]=255&t,e+4},d.prototype.writeIntLE=function(t,e,r,i){t=+t,e>>>=0,i||x(this,t,e,r,(i=Math.pow(2,8*r-1))-1,-i);var a=0,n=1,s=0;for(this[e]=255&t;++a<r&&(n*=256);)t<0&&0===s&&0!==this[e+a-1]&&(s=1),this[e+a]=(t/n>>0)-s&255;return e+r},d.prototype.writeIntBE=function(t,e,r,i){t=+t,e>>>=0,i||x(this,t,e,r,(i=Math.pow(2,8*r-1))-1,-i);var a=r-1,n=1,s=0;for(this[e+a]=255&t;0<=--a&&(n*=256);)t<0&&0===s&&0!==this[e+a+1]&&(s=1),this[e+a]=(t/n>>0)-s&255;return e+r},d.prototype.writeInt8=function(t,e,r){return t=+t,e>>>=0,r||x(this,t,e,1,127,-128),this[e]=255&(t=t<0?255+t+1:t),e+1},d.prototype.writeInt16LE=function(t,e,r){return t=+t,e>>>=0,r||x(this,t,e,2,32767,-32768),this[e]=255&t,this[e+1]=t>>>8,e+2},d.prototype.writeInt16BE=function(t,e,r){return t=+t,e>>>=0,r||x(this,t,e,2,32767,-32768),this[e]=t>>>8,this[e+1]=255&t,e+2},d.prototype.writeInt32LE=function(t,e,r){return t=+t,e>>>=0,r||x(this,t,e,4,2147483647,-2147483648),this[e]=255&t,this[e+1]=t>>>8,this[e+2]=t>>>16,this[e+3]=t>>>24,e+4},d.prototype.writeInt32BE=function(t,e,r){return t=+t,e>>>=0,r||x(this,t,e,4,2147483647,-2147483648),this[e]=(t=t<0?4294967295+t+1:t)>>>24,this[e+1]=t>>>16,this[e+2]=t>>>8,this[e+3]=255&t,e+4},d.prototype.writeFloatLE=function(t,e,r){return N(this,t,e,!0,r)},d.prototype.writeFloatBE=function(t,e,r){return N(this,t,e,!1,r)},d.prototype.writeDoubleLE=function(t,e,r){return X(this,t,e,!0,r)},d.prototype.writeDoubleBE=function(t,e,r){return X(this,t,e,!1,r)},d.prototype.copy=function(t,e,r,i){if(!d.isBuffer(t))throw new TypeError("argument should be a Buffer");if(r=r||0,i||0===i||(i=this.length),e>=t.length&&(e=t.length),(i=0<i&&i<r?r:i)===r)return 0;if(0===t.length||0===this.length)return 0;if((e=e||0)<0)throw new RangeError("targetStart out of bounds");if(r<0||r>=this.length)throw new RangeError("Index out of range");if(i<0)throw new RangeError("sourceEnd out of bounds");i>this.length&&(i=this.length);var a=(i=t.length-e<i-r?t.length-e+r:i)-r;if(this===t&&"function"==typeof Uint8Array.prototype.copyWithin)this.copyWithin(e,r,i);else if(this===t&&r<e&&e<i)for(var n=a-1;0<=n;--n)t[n+e]=this[n+r];else Uint8Array.prototype.set.call(t,this.subarray(r,i),e);return a},d.prototype.fill=function(t,e,r,i){if("string"==typeof t){if("string"==typeof e?(i=e,e=0,r=this.length):"string"==typeof r&&(i=r,r=this.length),void 0!==i&&"string"!=typeof i)throw new TypeError("encoding must be a string");if("string"==typeof i&&!d.isEncoding(i))throw new TypeError("Unknown encoding: "+i);var a;1===t.length&&(a=t.charCodeAt(0),("utf8"===i&&a<128||"latin1"===i)&&(t=a))}else"number"==typeof t&&(t&=255);if(e<0||this.length<e||this.length<r)throw new RangeError("Out of range index");if(r<=e)return this;var n;if(e>>>=0,r=void 0===r?this.length:r>>>0,"number"==typeof(t=t||0))for(n=e;n<r;++n)this[n]=t;else{var s=d.isBuffer(t)?t:d.from(t,i),o=s.length;if(0===o)throw new TypeError('The value "'+t+'" is invalid for argument "value"');for(n=0;n<r-e;++n)this[n+e]=s[n%o]}return this};var L=/[^+/0-9A-Za-z-_]/g;function P(t,e){var r;e=e||1/0;for(var i=t.length,a=null,n=[],s=0;s<i;++s){if(55295<(r=t.charCodeAt(s))&&r<57344){if(!a){if(56319<r){-1<(e-=3)&&n.push(239,191,189);continue}if(s+1===i){-1<(e-=3)&&n.push(239,191,189);continue}a=r;continue}if(r<56320){-1<(e-=3)&&n.push(239,191,189),a=r;continue}r=65536+(a-55296<<10|r-56320)}else a&&-1<(e-=3)&&n.push(239,191,189);if(a=null,r<128){if(--e<0)break;n.push(r)}else if(r<2048){if((e-=2)<0)break;n.push(r>>6|192,63&r|128)}else if(r<65536){if((e-=3)<0)break;n.push(r>>12|224,r>>6&63|128,63&r|128)}else{if(!(r<1114112))throw new Error("Invalid code point");if((e-=4)<0)break;n.push(r>>18|240,r>>12&63|128,r>>6&63|128,63&r|128)}}return n}function T(t){return o.toByteArray(function(t){if((t=(t=t.split("=")[0]).trim().replace(L,"")).length<2)return"";for(;t.length%4!=0;)t+="=";return t}(t))}function S(t,e,r,i){for(var a=0;a<i&&!(a+r>=e.length||a>=t.length);++a)e[a+r]=t[a];return a}function g(t,e){return t instanceof e||null!=t&&null!=t.constructor&&null!=t.constructor.name&&t.constructor.name===e.name}function w(t){return t!=t}}.call(this)}.call(this,z("buffer").Buffer)},{"base64-js":1,buffer:2,ieee754:3}],3:[function(t,e,r){r.read=function(t,e,r,i,a){var n,s,o=8*a-i-1,l=(1<<o)-1,u=l>>1,h=-7,d=r?a-1:0,f=r?-1:1,r=t[e+d];for(d+=f,n=r&(1<<-h)-1,r>>=-h,h+=o;0<h;n=256*n+t[e+d],d+=f,h-=8);for(s=n&(1<<-h)-1,n>>=-h,h+=i;0<h;s=256*s+t[e+d],d+=f,h-=8);if(0===n)n=1-u;else{if(n===l)return s?NaN:1/0*(r?-1:1);s+=Math.pow(2,i),n-=u}return(r?-1:1)*s*Math.pow(2,n-i)},r.write=function(t,e,r,i,a,n){var s,o,l=8*n-a-1,u=(1<<l)-1,h=u>>1,d=23===a?Math.pow(2,-24)-Math.pow(2,-77):0,f=i?0:n-1,m=i?1:-1,n=e<0||0===e&&1/e<0?1:0;for(e=Math.abs(e),isNaN(e)||e===1/0?(o=isNaN(e)?1:0,s=u):(s=Math.floor(Math.log(e)/Math.LN2),e*(i=Math.pow(2,-s))<1&&(s--,i*=2),2<=(e+=1<=s+h?d/i:d*Math.pow(2,1-h))*i&&(s++,i/=2),u<=s+h?(o=0,s=u):1<=s+h?(o=(e*i-1)*Math.pow(2,a),s+=h):(o=e*Math.pow(2,h-1)*Math.pow(2,a),s=0));8<=a;t[r+f]=255&o,f+=m,o/=256,a-=8);for(s=s<<a|o,l+=a;0<l;t[r+f]=255&s,f+=m,s/=256,l-=8);t[r+f-m]|=128*n}},{}],4:[function(t,e,r){var i,a,e=e.exports={};function n(){throw new Error("setTimeout has not been defined")}function s(){throw new Error("clearTimeout has not been defined")}function o(e){if(i===setTimeout)return setTimeout(e,0);if((i===n||!i)&&setTimeout)return i=setTimeout,setTimeout(e,0);try{return i(e,0)}catch(t){try{return i.call(null,e,0)}catch(t){return i.call(this,e,0)}}}!function(){try{i="function"==typeof setTimeout?setTimeout:n}catch(t){i=n}try{a="function"==typeof clearTimeout?clearTimeout:s}catch(t){a=s}}();var l,u=[],h=!1,d=-1;function f(){h&&l&&(h=!1,l.length?u=l.concat(u):d=-1,u.length&&m())}function m(){if(!h){var t=o(f);h=!0;for(var e=u.length;e;){for(l=u,u=[];++d<e;)l&&l[d].run();d=-1,e=u.length}l=null,h=!1,function(e){if(a===clearTimeout)return clearTimeout(e);if((a===s||!a)&&clearTimeout)return a=clearTimeout,clearTimeout(e);try{a(e)}catch(t){try{return a.call(null,e)}catch(t){return a.call(this,e)}}}(t)}}function v(t,e){this.fun=t,this.array=e}function p(){}e.nextTick=function(t){var e=new Array(arguments.length-1);if(1<arguments.length)for(var r=1;r<arguments.length;r++)e[r-1]=arguments[r];u.push(new v(t,e)),1!==u.length||h||o(m)},v.prototype.run=function(){this.fun.apply(null,this.array)},e.title="browser",e.browser=!0,e.env={},e.argv=[],e.version="",e.versions={},e.on=p,e.addListener=p,e.once=p,e.off=p,e.removeListener=p,e.removeAllListeners=p,e.emit=p,e.prependListener=p,e.prependOnceListener=p,e.listeners=function(t){return[]},e.binding=function(t){throw new Error("process.binding is not supported")},e.cwd=function(){return"/"},e.chdir=function(t){throw new Error("process.chdir is not supported")},e.umask=function(){return 0}},{}],5:[function(t,e,r){r.read=function(t,e,r,i,a){var n,s,o=8*a-i-1,l=(1<<o)-1,u=l>>1,h=-7,d=r?a-1:0,f=r?-1:1,r=t[e+d];for(d+=f,n=r&(1<<-h)-1,r>>=-h,h+=o;0<h;n=256*n+t[e+d],d+=f,h-=8);for(s=n&(1<<-h)-1,n>>=-h,h+=i;0<h;s=256*s+t[e+d],d+=f,h-=8);if(0===n)n=1-u;else{if(n===l)return s?NaN:1/0*(r?-1:1);s+=Math.pow(2,i),n-=u}return(r?-1:1)*s*Math.pow(2,n-i)},r.write=function(t,e,r,i,a,n){var s,o,l=8*n-a-1,u=(1<<l)-1,h=u>>1,d=23===a?Math.pow(2,-24)-Math.pow(2,-77):0,f=i?0:n-1,m=i?1:-1,n=e<0||0===e&&1/e<0?1:0;for(e=Math.abs(e),isNaN(e)||e===1/0?(o=isNaN(e)?1:0,s=u):(s=Math.floor(Math.log(e)/Math.LN2),e*(i=Math.pow(2,-s))<1&&(s--,i*=2),2<=(e+=1<=s+h?d/i:d*Math.pow(2,1-h))*i&&(s++,i/=2),u<=s+h?(o=0,s=u):1<=s+h?(o=(e*i-1)*Math.pow(2,a),s+=h):(o=e*Math.pow(2,h-1)*Math.pow(2,a),s=0));8<=a;t[r+f]=255&o,f+=m,o/=256,a-=8);for(s=s<<a|o,l+=a;0<l;t[r+f]=255&s,f+=m,s/=256,l-=8);t[r+f-m]|=128*n}},{}],6:[function(t,e,r){function d(t,e){var r=(65535&t)+(65535&e);return(t>>16)+(e>>16)+(r>>16)<<16|65535&r}function o(t,e,r,i,a,n){return d((n=d(d(e,t),d(i,n)))<<a|n>>>32-a,r)}function f(t,e,r,i,a,n,s){return o(e&r|~e&i,t,e,a,n,s)}function m(t,e,r,i,a,n,s){return o(e&i|r&~i,t,e,a,n,s)}function v(t,e,r,i,a,n,s){return o(e^r^i,t,e,a,n,s)}function p(t,e,r,i,a,n,s){return o(r^(e|~i),t,e,a,n,s)}function s(t,e){t[e>>5]|=128<<e%32,t[14+(e+64>>>9<<4)]=e;for(var r,i,a,n,s=1732584193,o=-271733879,l=-1732584194,u=271733878,h=0;h<t.length;h+=16)s=f(r=s,i=o,a=l,n=u,t[h],7,-680876936),u=f(u,s,o,l,t[h+1],12,-389564586),l=f(l,u,s,o,t[h+2],17,606105819),o=f(o,l,u,s,t[h+3],22,-1044525330),s=f(s,o,l,u,t[h+4],7,-176418897),u=f(u,s,o,l,t[h+5],12,1200080426),l=f(l,u,s,o,t[h+6],17,-1473231341),o=f(o,l,u,s,t[h+7],22,-45705983),s=f(s,o,l,u,t[h+8],7,1770035416),u=f(u,s,o,l,t[h+9],12,-1958414417),l=f(l,u,s,o,t[h+10],17,-42063),o=f(o,l,u,s,t[h+11],22,-1990404162),s=f(s,o,l,u,t[h+12],7,1804603682),u=f(u,s,o,l,t[h+13],12,-40341101),l=f(l,u,s,o,t[h+14],17,-1502002290),s=m(s,o=f(o,l,u,s,t[h+15],22,1236535329),l,u,t[h+1],5,-165796510),u=m(u,s,o,l,t[h+6],9,-1069501632),l=m(l,u,s,o,t[h+11],14,643717713),o=m(o,l,u,s,t[h],20,-373897302),s=m(s,o,l,u,t[h+5],5,-701558691),u=m(u,s,o,l,t[h+10],9,38016083),l=m(l,u,s,o,t[h+15],14,-660478335),o=m(o,l,u,s,t[h+4],20,-405537848),s=m(s,o,l,u,t[h+9],5,568446438),u=m(u,s,o,l,t[h+14],9,-1019803690),l=m(l,u,s,o,t[h+3],14,-187363961),o=m(o,l,u,s,t[h+8],20,1163531501),s=m(s,o,l,u,t[h+13],5,-1444681467),u=m(u,s,o,l,t[h+2],9,-51403784),l=m(l,u,s,o,t[h+7],14,1735328473),s=v(s,o=m(o,l,u,s,t[h+12],20,-1926607734),l,u,t[h+5],4,-378558),u=v(u,s,o,l,t[h+8],11,-2022574463),l=v(l,u,s,o,t[h+11],16,1839030562),o=v(o,l,u,s,t[h+14],23,-35309556),s=v(s,o,l,u,t[h+1],4,-1530992060),u=v(u,s,o,l,t[h+4],11,1272893353),l=v(l,u,s,o,t[h+7],16,-155497632),o=v(o,l,u,s,t[h+10],23,-1094730640),s=v(s,o,l,u,t[h+13],4,681279174),u=v(u,s,o,l,t[h],11,-358537222),l=v(l,u,s,o,t[h+3],16,-722521979),o=v(o,l,u,s,t[h+6],23,76029189),s=v(s,o,l,u,t[h+9],4,-640364487),u=v(u,s,o,l,t[h+12],11,-421815835),l=v(l,u,s,o,t[h+15],16,530742520),s=p(s,o=v(o,l,u,s,t[h+2],23,-995338651),l,u,t[h],6,-198630844),u=p(u,s,o,l,t[h+7],10,1126891415),l=p(l,u,s,o,t[h+14],15,-1416354905),o=p(o,l,u,s,t[h+5],21,-57434055),s=p(s,o,l,u,t[h+12],6,1700485571),u=p(u,s,o,l,t[h+3],10,-1894986606),l=p(l,u,s,o,t[h+10],15,-1051523),o=p(o,l,u,s,t[h+1],21,-2054922799),s=p(s,o,l,u,t[h+8],6,1873313359),u=p(u,s,o,l,t[h+15],10,-30611744),l=p(l,u,s,o,t[h+6],15,-1560198380),o=p(o,l,u,s,t[h+13],21,1309151649),s=p(s,o,l,u,t[h+4],6,-145523070),u=p(u,s,o,l,t[h+11],10,-1120210379),l=p(l,u,s,o,t[h+2],15,718787259),o=p(o,l,u,s,t[h+9],21,-343485551),s=d(s,r),o=d(o,i),l=d(l,a),u=d(u,n);return[s,o,l,u]}function l(t){for(var e="",r=0;r<32*t.length;r+=8)e+=String.fromCharCode(t[r>>5]>>>r%32&255);return e}function u(t){var e,r=[];for(r[(t.length>>2)-1]=void 0,e=0;e<r.length;e+=1)r[e]=0;for(e=0;e<8*t.length;e+=8)r[e>>5]|=(255&t.charCodeAt(e/8))<<e%32;return r}function i(t){for(var e,r="0123456789abcdef",i="",a=0;a<t.length;a+=1)e=t.charCodeAt(a),i+=r.charAt(e>>>4&15)+r.charAt(15&e);return i}function a(t){return unescape(encodeURIComponent(t))}function n(t){return l(s(u(t=a(t)),8*t.length))}function h(t,e){return function(t,e){var r,i=u(t),a=[],n=[];for(a[15]=n[15]=void 0,16<i.length&&(i=s(i,8*t.length)),r=0;r<16;r+=1)a[r]=909522486^i[r],n[r]=1549556828^i[r];return e=s(a.concat(u(e)),512+8*e.length),l(s(n.concat(e),640))}(a(t),a(e))}e.exports=function(t,e,r){return e?r?h(e,t):i(h(e,t)):r?n(t):i(n(t))}},{}],7:[function(t,e,r){"use strict";e.exports=a;var i=t("ieee754");function a(t){this.buf=ArrayBuffer.isView&&ArrayBuffer.isView(t)?t:new Uint8Array(t||0),this.pos=0,this.type=0,this.length=this.buf.length}a.Varint=0,a.Fixed64=1,a.Bytes=2,a.Fixed32=5;var n=4294967296,s=1/n,o="undefined"==typeof TextDecoder?null:new TextDecoder("utf8");function l(t){return t.type===a.Bytes?t.readVarint()+t.pos:t.pos+1}function u(t,e,r){return r?4294967296*e+(t>>>0):4294967296*(e>>>0)+(t>>>0)}function h(t,e,r){var i=e<=16383?1:e<=2097151?2:e<=268435455?3:Math.floor(Math.log(e)/(7*Math.LN2));r.realloc(i);for(var a=r.pos-1;t<=a;a--)r.buf[a+i]=r.buf[a]}function d(t,e){for(var r=0;r<t.length;r++)e.writeVarint(t[r])}function f(t,e){for(var r=0;r<t.length;r++)e.writeSVarint(t[r])}function m(t,e){for(var r=0;r<t.length;r++)e.writeFloat(t[r])}function v(t,e){for(var r=0;r<t.length;r++)e.writeDouble(t[r])}function p(t,e){for(var r=0;r<t.length;r++)e.writeBoolean(t[r])}function c(t,e){for(var r=0;r<t.length;r++)e.writeFixed32(t[r])}function b(t,e){for(var r=0;r<t.length;r++)e.writeSFixed32(t[r])}function y(t,e){for(var r=0;r<t.length;r++)e.writeFixed64(t[r])}function V(t,e){for(var r=0;r<t.length;r++)e.writeSFixed64(t[r])}function q(t,e){return(t[e]|t[e+1]<<8|t[e+2]<<16)+16777216*t[e+3]}function x(t,e,r){t[r]=e,t[r+1]=e>>>8,t[r+2]=e>>>16,t[r+3]=e>>>24}function W(t,e){return(t[e]|t[e+1]<<8|t[e+2]<<16)+(t[e+3]<<24)}a.prototype={destroy:function(){this.buf=null},readFields:function(t,e,r){for(r=r||this.length;this.pos<r;){var i=this.readVarint(),a=i>>3,n=this.pos;this.type=7&i,t(a,e,this),this.pos===n&&this.skip(i)}return e},readMessage:function(t,e){return this.readFields(t,e,this.readVarint()+this.pos)},readFixed32:function(){var t=q(this.buf,this.pos);return this.pos+=4,t},readSFixed32:function(){var t=W(this.buf,this.pos);return this.pos+=4,t},readFixed64:function(){var t=q(this.buf,this.pos)+q(this.buf,this.pos+4)*n;return this.pos+=8,t},readSFixed64:function(){var t=q(this.buf,this.pos)+W(this.buf,this.pos+4)*n;return this.pos+=8,t},readFloat:function(){var t=i.read(this.buf,this.pos,!0,23,4);return this.pos+=4,t},readDouble:function(){var t=i.read(this.buf,this.pos,!0,52,8);return this.pos+=8,t},readVarint:function(t){var e=this.buf,r=e[this.pos++],i=127&r;return r<128?i:(i|=(127&(r=e[this.pos++]))<<7,r<128?i:(i|=(127&(r=e[this.pos++]))<<14,r<128?i:(i|=(127&(r=e[this.pos++]))<<21,r<128?i:function(t,e,r){var i,a,n=r.buf;if(a=n[r.pos++],i=(112&a)>>4,a<128)return u(t,i,e);if(a=n[r.pos++],i|=(127&a)<<3,a<128)return u(t,i,e);if(a=n[r.pos++],i|=(127&a)<<10,a<128)return u(t,i,e);if(a=n[r.pos++],i|=(127&a)<<17,a<128)return u(t,i,e);if(a=n[r.pos++],i|=(127&a)<<24,a<128)return u(t,i,e);if(a=n[r.pos++],i|=(1&a)<<31,a<128)return u(t,i,e);throw new Error("Expected varint not more than 10 bytes")}(i|=(15&e[this.pos])<<28,t,this))))},readVarint64:function(){return this.readVarint(!0)},readSVarint:function(){var t=this.readVarint();return t%2==1?(t+1)/-2:t/2},readBoolean:function(){return Boolean(this.readVarint())},readString:function(){var t,e=this.readVarint()+this.pos,r=this.pos;return 12<=(this.pos=e)-r&&o?(t=this.buf,o.decode(t.subarray(r,e))):function(t,e,r){var i,a,n,s="",o=e;for(;o<r;){var l=t[o],u=null,h=239<l?4:223<l?3:191<l?2:1;if(r<o+h)break;1===h?l<128&&(u=l):2===h?128==(192&(i=t[o+1]))&&(u=(31&l)<<6|63&i)<=127&&(u=null):3===h?(i=t[o+1],a=t[o+2],128==(192&i)&&128==(192&a)&&((u=(15&l)<<12|(63&i)<<6|63&a)<=2047||55296<=u&&u<=57343)&&(u=null)):4===h&&(i=t[o+1],a=t[o+2],n=t[o+3],128==(192&i)&&128==(192&a)&&128==(192&n)&&((u=(15&l)<<18|(63&i)<<12|(63&a)<<6|63&n)<=65535||1114112<=u)&&(u=null)),null===u?(u=65533,h=1):65535<u&&(u-=65536,s+=String.fromCharCode(u>>>10&1023|55296),u=56320|1023&u),s+=String.fromCharCode(u),o+=h}return s}(this.buf,r,e)},readBytes:function(){var t=this.readVarint()+this.pos,e=this.buf.subarray(this.pos,t);return this.pos=t,e},readPackedVarint:function(t,e){if(this.type!==a.Bytes)return t.push(this.readVarint(e));var r=l(this);for(t=t||[];this.pos<r;)t.push(this.readVarint(e));return t},readPackedSVarint:function(t){if(this.type!==a.Bytes)return t.push(this.readSVarint());var e=l(this);for(t=t||[];this.pos<e;)t.push(this.readSVarint());return t},readPackedBoolean:function(t){if(this.type!==a.Bytes)return t.push(this.readBoolean());var e=l(this);for(t=t||[];this.pos<e;)t.push(this.readBoolean());return t},readPackedFloat:function(t){if(this.type!==a.Bytes)return t.push(this.readFloat());var e=l(this);for(t=t||[];this.pos<e;)t.push(this.readFloat());return t},readPackedDouble:function(t){if(this.type!==a.Bytes)return t.push(this.readDouble());var e=l(this);for(t=t||[];this.pos<e;)t.push(this.readDouble());return t},readPackedFixed32:function(t){if(this.type!==a.Bytes)return t.push(this.readFixed32());var e=l(this);for(t=t||[];this.pos<e;)t.push(this.readFixed32());return t},readPackedSFixed32:function(t){if(this.type!==a.Bytes)return t.push(this.readSFixed32());var e=l(this);for(t=t||[];this.pos<e;)t.push(this.readSFixed32());return t},readPackedFixed64:function(t){if(this.type!==a.Bytes)return t.push(this.readFixed64());var e=l(this);for(t=t||[];this.pos<e;)t.push(this.readFixed64());return t},readPackedSFixed64:function(t){if(this.type!==a.Bytes)return t.push(this.readSFixed64());var e=l(this);for(t=t||[];this.pos<e;)t.push(this.readSFixed64());return t},skip:function(t){t&=7;if(t===a.Varint)for(;127<this.buf[this.pos++];);else if(t===a.Bytes)this.pos=this.readVarint()+this.pos;else if(t===a.Fixed32)this.pos+=4;else{if(t!==a.Fixed64)throw new Error("Unimplemented type: "+t);this.pos+=8}},writeTag:function(t,e){this.writeVarint(t<<3|e)},realloc:function(t){for(var e,r=this.length||16;r<this.pos+t;)r*=2;r!==this.length&&((e=new Uint8Array(r)).set(this.buf),this.buf=e,this.length=r)},finish:function(){return this.length=this.pos,this.pos=0,this.buf.subarray(0,this.length)},writeFixed32:function(t){this.realloc(4),x(this.buf,t,this.pos),this.pos+=4},writeSFixed32:function(t){this.realloc(4),x(this.buf,t,this.pos),this.pos+=4},writeFixed64:function(t){this.realloc(8),x(this.buf,-1&t,this.pos),x(this.buf,Math.floor(t*s),this.pos+4),this.pos+=8},writeSFixed64:function(t){this.realloc(8),x(this.buf,-1&t,this.pos),x(this.buf,Math.floor(t*s),this.pos+4),this.pos+=8},writeVarint:function(t){268435455<(t=+t||0)||t<0?function(t,e){var r,i;0<=t?(r=t%4294967296|0,i=t/4294967296|0):(i=~(-t/4294967296),4294967295^(r=~(-t%4294967296))?r=r+1|0:i=i+1|(r=0));if(0x10000000000000000<=t||t<-0x10000000000000000)throw new Error("Given varint doesn't fit into 10 bytes");e.realloc(10),function(t,e){e.buf[e.pos++]=127&t|128,t>>>=7,e.buf[e.pos++]=127&t|128,t>>>=7,e.buf[e.pos++]=127&t|128,t>>>=7,e.buf[e.pos++]=127&t|128,t>>>=7,e.buf[e.pos]=127&t}(r,e),function(t,e){var r=(7&t)<<4;e.buf[e.pos++]|=r|((t>>>=3)?128:0),t&&(e.buf[e.pos++]=127&t|((t>>>=7)?128:0),t&&(e.buf[e.pos++]=127&t|((t>>>=7)?128:0),t&&(e.buf[e.pos++]=127&t|((t>>>=7)?128:0),t&&(e.buf[e.pos++]=127&t|((t>>>=7)?128:0),t&&(e.buf[e.pos++]=127&t)))))}(i,e)}(t,this):(this.realloc(4),this.buf[this.pos++]=127&t|(127<t?128:0),t<=127||(this.buf[this.pos++]=127&(t>>>=7)|(127<t?128:0),t<=127||(this.buf[this.pos++]=127&(t>>>=7)|(127<t?128:0),t<=127||(this.buf[this.pos++]=t>>>7&127))))},writeSVarint:function(t){this.writeVarint(t<0?2*-t-1:2*t)},writeBoolean:function(t){this.writeVarint(Boolean(t))},writeString:function(t){t=String(t),this.realloc(4*t.length),this.pos++;var e=this.pos;this.pos=function(t,e,r){for(var i,a,n=0;n<e.length;n++){if(55295<(i=e.charCodeAt(n))&&i<57344){if(!a){56319<i||n+1===e.length?(t[r++]=239,t[r++]=191,t[r++]=189):a=i;continue}if(i<56320){t[r++]=239,t[r++]=191,t[r++]=189,a=i;continue}i=a-55296<<10|i-56320|65536,a=null}else a&&(t[r++]=239,t[r++]=191,t[r++]=189,a=null);i<128?t[r++]=i:(i<2048?t[r++]=i>>6|192:(i<65536?t[r++]=i>>12|224:(t[r++]=i>>18|240,t[r++]=i>>12&63|128),t[r++]=i>>6&63|128),t[r++]=63&i|128)}return r}(this.buf,t,this.pos);t=this.pos-e;128<=t&&h(e,t,this),this.pos=e-1,this.writeVarint(t),this.pos+=t},writeFloat:function(t){this.realloc(4),i.write(this.buf,t,this.pos,!0,23,4),this.pos+=4},writeDouble:function(t){this.realloc(8),i.write(this.buf,t,this.pos,!0,52,8),this.pos+=8},writeBytes:function(t){var e=t.length;this.writeVarint(e),this.realloc(e);for(var r=0;r<e;r++)this.buf[this.pos++]=t[r]},writeRawMessage:function(t,e){this.pos++;var r=this.pos;t(e,this);e=this.pos-r;128<=e&&h(r,e,this),this.pos=r-1,this.writeVarint(e),this.pos+=e},writeMessage:function(t,e,r){this.writeTag(t,a.Bytes),this.writeRawMessage(e,r)},writePackedVarint:function(t,e){e.length&&this.writeMessage(t,d,e)},writePackedSVarint:function(t,e){e.length&&this.writeMessage(t,f,e)},writePackedBoolean:function(t,e){e.length&&this.writeMessage(t,p,e)},writePackedFloat:function(t,e){e.length&&this.writeMessage(t,m,e)},writePackedDouble:function(t,e){e.length&&this.writeMessage(t,v,e)},writePackedFixed32:function(t,e){e.length&&this.writeMessage(t,c,e)},writePackedSFixed32:function(t,e){e.length&&this.writeMessage(t,b,e)},writePackedFixed64:function(t,e){e.length&&this.writeMessage(t,y,e)},writePackedSFixed64:function(t,e){e.length&&this.writeMessage(t,V,e)},writeBytesField:function(t,e){this.writeTag(t,a.Bytes),this.writeBytes(e)},writeFixed32Field:function(t,e){this.writeTag(t,a.Fixed32),this.writeFixed32(e)},writeSFixed32Field:function(t,e){this.writeTag(t,a.Fixed32),this.writeSFixed32(e)},writeFixed64Field:function(t,e){this.writeTag(t,a.Fixed64),this.writeFixed64(e)},writeSFixed64Field:function(t,e){this.writeTag(t,a.Fixed64),this.writeSFixed64(e)},writeVarintField:function(t,e){this.writeTag(t,a.Varint),this.writeVarint(e)},writeSVarintField:function(t,e){this.writeTag(t,a.Varint),this.writeSVarint(e)},writeStringField:function(t,e){this.writeTag(t,a.Bytes),this.writeString(e)},writeFloatField:function(t,e){this.writeTag(t,a.Fixed32),this.writeFloat(e)},writeDoubleField:function(t,e){this.writeTag(t,a.Fixed64),this.writeDouble(e)},writeBooleanField:function(t,e){this.writeVarintField(t,Boolean(e))}}},{ieee754:5}],8:[function(t,e,r){t=t("../terrain/TerrainEditBase");class i extends t{constructor(t,e={}){super(t,e),this.colorScheme=e.colorScheme||{step:[0,.2,.4,.6,.8,.9,1],color:["#000000","#2747E0","#D33B7D","#D33038","#FF9742","#FF9742","#ffd700"]}}clear(){super.clear(),this._map.scene.globe.material=null,this.hasResetEnableLighting&&(this._map.scene.globe.enableLighting=!1,this._map.clock.currentTime=Cesium.JulianDate.now(),delete this.hasResetEnableLighting)}updateMaterial(){var t;let e;if(t=Cesium.Material.fromType("AspectRamp"),e=t.uniforms,e.image=this.getColorRamp(),!this._map.scene.globe.enableLighting){this._map.scene.globe.enableLighting=!0;let t=new Date;t.setHours(10),this._map.clock.currentTime=Cesium.JulianDate.fromDate(new Date(t)),this.hasResetEnableLighting=!0}this._map.scene.globe.material=t}addPolygon(t,e){e=super.addPolygon(t,e);return this.updateMaterial(),e}getColorRamp(){let t=document.createElement("canvas");t.width=100,t.height=1;let e=t.getContext("2d"),r=e.createLinearGradient(0,0,100,0);var i=this.colorScheme;if(0<i.step.length)for(let t=0,e=i.step.length;t<e;t++)r.addColorStop(i.step[t],i.color[t]);return e.fillStyle=r,e.fillRect(0,0,100,1),t}}e.exports=i},{"../terrain/TerrainEditBase":92}],9:[function(t,e,r){t=t("../terrain/TerrainEditBase");class i extends t{constructor(t,e={}){super(t,e),this.colorScheme=e.colorScheme||{step:[0,.045,.1,.15,.37,.54,1],color:["#000000","#2747E0","#D33B7D","#D33038","#FF9742","#FF9742","#ffd700"]},this.minHeight=Cesium.defaultValue(e.minHeight,-414),this.maxHeight=Cesium.defaultValue(e.maxHeight,8777)}clear(){super.clear(),this._map.scene.globe.material=null,this.hasResetEnableLighting&&(this._map.scene.globe.enableLighting=!1,this._map.clock.currentTime=Cesium.JulianDate.now(),delete this.hasResetEnableLighting)}updateMaterial(){var t;let e;if(t=Cesium.Material.fromType("ElevationRamp"),e=t.uniforms,e.minimumHeight=this.minHeight,e.maximumHeight=this.maxHeight,e.image=this.getColorRamp(),!this._map.scene.globe.enableLighting){this._map.scene.globe.enableLighting=!0;let t=new Date;t.setHours(10),this._map.clock.currentTime=Cesium.JulianDate.fromDate(new Date(t)),this.hasResetEnableLighting=!0}this._map.scene.globe.material=t}addPolygon(t,e){e=super.addPolygon(t,e);return this.updateMaterial(),e}getColorRamp(){let t=document.createElement("canvas");t.width=100,t.height=1;let e=t.getContext("2d"),r=e.createLinearGradient(0,0,100,0);var i=this.colorScheme;if(0<i.step.length)for(let t=0,e=i.step.length;t<e;t++)r.addColorStop(i.step[t],i.color[t]);return e.fillStyle=r,e.fillRect(0,0,100,1),t}}e.exports=i},{"../terrain/TerrainEditBase":92}],10:[function(t,e,r){t=t("../terrain/TerrainEditBase");class i extends t{constructor(t,e={}){super(t,e),this.colorScheme=e.colorScheme||{step:[0,.29,.5,Math.sqrt(2)/2,.87,.91,1],color:["#000000","#2747E0","#D33B7D","#D33038","#FF9742","#FF9742","#ffd700"]}}clear(){super.clear(),this._map.scene.globe.material=null,this.hasResetEnableLighting&&(this._map.scene.globe.enableLighting=!1,this._map.clock.currentTime=Cesium.JulianDate.now(),delete this.hasResetEnableLighting)}updateMaterial(){var t;let e;if(t=Cesium.Material.fromType("SlopeRamp"),e=t.uniforms,e.minimumHeight=this.minHeight,e.maximumHeight=this.maxHeight,e.image=this.getColorRamp(),!this._map.scene.globe.enableLighting){this._map.scene.globe.enableLighting=!0;let t=new Date;t.setHours(10),this._map.clock.currentTime=Cesium.JulianDate.fromDate(new Date(t)),this.hasResetEnableLighting=!0}this._map.scene.globe.material=t}addPolygon(t,e){e=super.addPolygon(t,e);return this.updateMaterial(),e}getColorRamp(){let t=document.createElement("canvas");t.width=100,t.height=1;let e=t.getContext("2d"),r=e.createLinearGradient(0,0,100,0);var i=this.colorScheme;if(0<i.step.length)for(let t=0,e=i.step.length;t<e;t++)r.addColorStop(i.step[t],i.color[t]);return e.fillStyle=r,e.fillRect(0,0,100,1),t}}e.exports=i},{"../terrain/TerrainEditBase":92}],11:[function(t,e,r){e.exports=class{constructor(t,e={}){this._map=t,this.options=e,this._horizontalAngle=Cesium.defaultValue(e.horizontalAngle,120),this._verticalAngle=Cesium.defaultValue(e.verticalAngle,90),this._visibleAreaColor=Cesium.defaultValue(e.visibleAreaColor,new Cesium.Color(0,1,0)),this._hiddenAreaColor=Cesium.defaultValue(e.hiddenAreaColor,new Cesium.Color(1,0,0)),this._alpha=Cesium.defaultValue(e.alpha,.5),this._offsetHeight=Cesium.defaultValue(e.offsetHeight,1.5),this._showFrustum=Cesium.defaultValue(e.showFrustum,!0),this._maximumDistance=Cesium.defaultValue(e.maximumDistance,5e3)}get horizontalAngle(){return this._horizontalAngle}set horizontalAngle(t){this._horizontalAngle=t,this._rectangularSensor&&(this._rectangularSensor.style={xHalfAngle:Cesium.Math.toRadians(t/2)})}get verticalAngle(){return this._verticalAngle}set verticalAngle(t){this._verticalAngle=t,this._rectangularSensor&&(this._rectangularSensor.style={yHalfAngle:Cesium.Math.toRadians(t/2)})}get distance(){return this._distance}set distance(t){this._distance=t,this._rectangularSensor&&(this._rectangularSensor.style={radius:t})}get visibleAreaColor(){return this._visibleAreaColor}set visibleAreaColor(t){this._visibleAreaColor=t}get hiddenAreaColor(){return this._hiddenAreaColor}set hiddenAreaColor(t){this._hiddenAreaColor=t}get alpha(){return this._alpha}set alpha(t){this._alpha=t}get showFrustum(){return this._showFrustum}set showFrustum(t){this._showFrustum=t,this._rectangularSensor&&(this._rectangularSensor.show=t)}get cameraPosition(){return this._cameraPosition}set cameraPosition(t){this._cameraPoint=LatLngPoint.parse(t),this._cameraPosition=this._cameraPoint?.toCartesian(),this._updateDraw()}get cameraPoint(){return this._cameraPoint}get position(){return this._position}set position(t){this._position=t,this._updateDraw()}add(){this._defaultColorTexture=new Cesium.Texture({context:this._map.scene.context,source:{width:1,height:1,arrayBufferView:new Uint8Array([0,0,0,0])},flipY:!1}),this._map.terrainShadows=Cesium.ShadowMode.ENABLED,this.options.cameraPosition&&(this.cameraPosition=this.options.cameraPosition),this.options.position&&(this.position=this.options.position),this.cameraPosition&&this.position?this._addToScene():this._bindMourseEvent()}remove(){this._map.terrainShadows=Cesium.ShadowMode.DISABLED,this._unbindMourseEvent(),this.postProcess&&(this._map.scene.postProcessStages.remove(this.postProcess),delete this.postProcess),this._rectangularSensor,this._map.scene.primitives.remove(this)}_bindMourseEvent(){this._map.on("click",this._onClickHandler,this),this._map.on("mouseMove",this._onMouseMoveHandler,this),this._map.setCursor(!0)}_unbindMourseEvent(){this._map.off("click",this._onClickHandler,this),this._map.off("mouseMove",this._onMouseMoveHandler,this),this._map.setCursor(!1)}_onClickHandler(t){let e=t.cartesian;e&&(this._cameraPosition?this._cameraPosition&&!this._position&&(5e3<Cesium.Cartesian3.distance(this._cameraPosition,e)&&(e=this.getOnLinePointByLen(this._cameraPosition,e,5e3)),this.position=e,this._addToScene(),this._unbindMourseEvent()):(e=this.addPositionsHeight(e,this._offsetHeight),this.cameraPosition=e))}_onMouseMoveHandler(e){let r=e.cartesian;if(r){e=this._cameraPosition;if(e){let t=Cesium.Cartesian3.distance(e,r);5e3<t&&(t=5e3,r=this.getOnLinePointByLen(e,r,5e3)),this.frustumQuaternion=this.getFrustumQuaternion(e,r),this.distance=Number(t.toFixed(1)),this._addRectangularSensor()}}}_updateDraw(){this._map}_addToScene(){var t=this._map.scene,e=this._cameraPosition,r=this._position;this.frustumQuaternion=this.getFrustumQuaternion(e,r),this.distance=Number(Cesium.Cartesian3.distance(e,r).toFixed(1));let i=new Cesium.Camera(t);i.position=e,i.direction=Cesium.Cartesian3.subtract(r,e,new Cesium.Cartesian3(0,0,0)),i.up=Cesium.Cartesian3.normalize(e,new Cesium.Cartesian3(0,0,0)),i.frustum=new Cesium.PerspectiveFrustum({fov:Cesium.Math.toRadians(120),aspectRatio:t.canvas.clientWidth/t.canvas.clientHeight,near:.1,far:5e3}),this.viewShadowMap=new Cesium.ShadowMap({lightCamera:i,enabled:!1,isPointLight:!1,isSpotLight:!0,cascadesEnabled:!1,context:t.context,pointLightRadius:this.distance,maximumDistance:this._maximumDistance}),this._addPostProcess(),this._addRectangularSensor(),this._map.scene.primitives.add(this)}_addRectangularSensor(){}_addPostProcess(){let e=this,r=this.viewShadowMap._isPointLight?this.viewShadowMap._pointBias:this.viewShadowMap._primitiveBias;this.postProcess=new Cesium.PostProcessStage({fragmentShader:`uniform float czzj;
uniform float dis;
uniform float spzj;
uniform vec3 visibleColor;
uniform vec3 disVisibleColor;
uniform float mixNum;
uniform sampler2D colorTexture;
uniform sampler2D marsShadow;
uniform sampler2D depthTexture;
uniform mat4 _shadowMap_matrix;
uniform vec4 shadowMap_lightPositionEC;
uniform vec3 shadowMap_lightPositionWC;
uniform vec4 shadowMap_lightDirectionEC;
uniform vec3 shadowMap_lightUp;
uniform vec3 shadowMap_lightDir;
uniform vec3 shadowMap_lightRight;
uniform vec4 shadowMap_normalOffsetScaleDistanceMaxDistanceAndDarkness;
uniform vec4 shadowMap_texelSizeDepthBiasAndNormalShadingSmooth;
varying vec2 v_textureCoordinates;
vec4 toEye(in vec2 uv, in float depth){
    vec2 xy = vec2((uv.x * 2.0 - 1.0),(uv.y * 2.0 - 1.0));
    vec4 posInCamera =czm_inverseProjection * vec4(xy, depth, 1.0);
    posInCamera =posInCamera / posInCamera.w;
    return posInCamera;
}
float getDepth(in vec4 depth){
    float z_window = czm_unpackDepth(depth);
    z_window = czm_reverseLogDepth(z_window);
    float n_range = czm_depthRange.near;
    float f_range = czm_depthRange.far;
    return (2.0 * z_window - n_range - f_range) / (f_range - n_range);
}
float _czm_sampleShadowMap(sampler2D shadowMap, vec2 uv){
    return texture2D(shadowMap, uv).r;
}
float _czm_shadowDepthCompare(sampler2D shadowMap, vec2 uv, float depth){
    return step(depth, _czm_sampleShadowMap(shadowMap, uv));
}
float _czm_shadowVisibility(sampler2D shadowMap, czm_shadowParameters shadowParameters){
    float depthBias = shadowParameters.depthBias;
    float depth = shadowParameters.depth;
    float nDotL = shadowParameters.nDotL;
    float normalShadingSmooth = shadowParameters.normalShadingSmooth;
    float darkness = shadowParameters.darkness;
    vec2 uv = shadowParameters.texCoords;
    depth -= depthBias;
    vec2 texelStepSize = shadowParameters.texelStepSize;
    float radius = 1.0;
    float dx0 = -texelStepSize.x * radius;
    float dy0 = -texelStepSize.y * radius;
    float dx1 = texelStepSize.x * radius;
    float dy1 = texelStepSize.y * radius;
    float visibility =
    (
    _czm_shadowDepthCompare(shadowMap, uv, depth)
    +_czm_shadowDepthCompare(shadowMap, uv + vec2(dx0, dy0), depth) +
    _czm_shadowDepthCompare(shadowMap, uv + vec2(0.0, dy0), depth) +
    _czm_shadowDepthCompare(shadowMap, uv + vec2(dx1, dy0), depth) +
    _czm_shadowDepthCompare(shadowMap, uv + vec2(dx0, 0.0), depth) +
    _czm_shadowDepthCompare(shadowMap, uv + vec2(dx1, 0.0), depth) +
    _czm_shadowDepthCompare(shadowMap, uv + vec2(dx0, dy1), depth) +
    _czm_shadowDepthCompare(shadowMap, uv + vec2(0.0, dy1), depth) +
    _czm_shadowDepthCompare(shadowMap, uv + vec2(dx1, dy1), depth)
    ) * (1.0 / 9.0)
    ;
    return visibility;
}
vec3 pointProjectOnPlane(in vec3 planeNormal, in vec3 planeOrigin, in vec3 point){
    vec3 v01 = point -planeOrigin;
    float d = dot(planeNormal, v01) ;
    return (point - planeNormal * d);
}
float ptm(vec3 pt){
    return sqrt(pt.x*pt.x + pt.y*pt.y + pt.z*pt.z);
}
void main()
{
    const float PI = 3.141592653589793;
    vec4 color = texture2D(colorTexture, v_textureCoordinates);
    vec4 currD = texture2D(depthTexture, v_textureCoordinates);

    // vec4 stcc = texture2D(marsShadow, v_textureCoordinates);
    // gl_FragColor = currD;
    // return;
    if(currD.r>=1.0){
        gl_FragColor = color;
        return;
    }

    float depth = getDepth(currD);
    // gl_FragColor = vec4(depth,0.0,0.0,1.0);
    // return;
    // float depth = czm_unpackDepth(texture2D(depthTexture, v_textureCoordinates));
    vec4 positionEC = toEye(v_textureCoordinates, depth);
    vec3 normalEC = vec3(1.0);
    czm_shadowParameters shadowParameters;
    shadowParameters.texelStepSize = shadowMap_texelSizeDepthBiasAndNormalShadingSmooth.xy;
    shadowParameters.depthBias = shadowMap_texelSizeDepthBiasAndNormalShadingSmooth.z;
    shadowParameters.normalShadingSmooth = shadowMap_texelSizeDepthBiasAndNormalShadingSmooth.w;
    shadowParameters.darkness = shadowMap_normalOffsetScaleDistanceMaxDistanceAndDarkness.w;
    shadowParameters.depthBias *= max(depth * 0.01, 1.0);
    vec3 directionEC = normalize(positionEC.xyz - shadowMap_lightPositionEC.xyz);
    float nDotL = clamp(dot(normalEC, -directionEC), 0.0, 1.0);
    vec4 shadowPosition = _shadowMap_matrix * positionEC;
    shadowPosition /= shadowPosition.w;
    if (any(lessThan(shadowPosition.xyz, vec3(0.0))) || any(greaterThan(shadowPosition.xyz, vec3(1.0))))
    {
        gl_FragColor = color;
        return;
    }

    //坐标与视点位置距离,大于最大距离则舍弃阴影效果
    vec4 lw = vec4(shadowMap_lightPositionWC,1.0);
    vec4 vw = czm_inverseView* vec4(positionEC.xyz, 1.0);
    if(distance(lw.xyz,vw.xyz)>dis){
        gl_FragColor = color;
        return;
    }


    //水平夹角限制
    vec3 ptOnSP = pointProjectOnPlane(shadowMap_lightUp,lw.xyz,vw.xyz);
    directionEC = ptOnSP - lw.xyz;
    float directionECMO = ptm(directionEC.xyz);
    float shadowMap_lightDirMO = ptm(shadowMap_lightDir.xyz);
    float cosJJ = dot(directionEC,shadowMap_lightDir)/(directionECMO*shadowMap_lightDirMO);
    float degJJ = acos(cosJJ)*(180.0 / PI);
    degJJ = abs(degJJ);
    if(degJJ>spzj/2.0){
        gl_FragColor = color;
        return;
    }

    //垂直夹角限制
    vec3 ptOnCZ = pointProjectOnPlane(shadowMap_lightRight,lw.xyz,vw.xyz);
    vec3 dirOnCZ = ptOnCZ - lw.xyz;
    float dirOnCZMO = ptm(dirOnCZ);
    float cosJJCZ = dot(dirOnCZ,shadowMap_lightDir)/(dirOnCZMO*shadowMap_lightDirMO);
    float degJJCZ = acos(cosJJCZ)*(180.0 / PI);
    degJJCZ = abs(degJJCZ);
    if(degJJCZ>czzj/2.0){
        gl_FragColor = color;
        return;
    }

    shadowParameters.texCoords = shadowPosition.xy;
    shadowParameters.depth = shadowPosition.z;
    shadowParameters.nDotL = nDotL;
    float visibility = _czm_shadowVisibility(marsShadow, shadowParameters);
    if(visibility==1.0){
        gl_FragColor = mix(color,vec4(visibleColor,1.0),mixNum);
    }else{
        // if(abs(shadowPosition.z-0.0)<0.01){
        //     return;
        // }
        gl_FragColor = mix(color,vec4(disVisibleColor,1.0),mixNum);
    }
}`,uniforms:{czzj:function(){return e.verticalAngle},dis:function(){return e.distance},spzj:function(){return e.horizontalAngle},visibleColor:function(){return e.visibleAreaColor},disVisibleColor:function(){return e.hiddenAreaColor},mixNum:function(){return e.alpha},marsShadow:function(){return e.viewShadowMap._shadowMapTexture||e._defaultColorTexture},_shadowMap_matrix:function(){return e.viewShadowMap._shadowMapMatrix},shadowMap_lightPositionEC:function(){return e.viewShadowMap._lightPositionEC},shadowMap_lightPositionWC:function(){return e.viewShadowMap._lightCamera.position},shadowMap_lightDirectionEC:function(){return e.viewShadowMap._lightDirectionEC},shadowMap_lightUp:function(){return e.viewShadowMap._lightCamera.up},shadowMap_lightDir:function(){return e.viewShadowMap._lightCamera.direction},shadowMap_lightRight:function(){return e.viewShadowMap._lightCamera.right},shadowMap_texelSizeDepthBiasAndNormalShadingSmooth:function(){let t=new Cesium.Cartesian2;return t.x=1/e.viewShadowMap._textureSize.x,t.y=1/e.viewShadowMap._textureSize.y,Cesium.Cartesian4.fromElements(t.x,t.y,r.depthBias,r.normalShadingSmooth,this.combinedUniforms1)},shadowMap_normalOffsetScaleDistanceMaxDistanceAndDarkness:function(){return Cesium.Cartesian4.fromElements(r.normalOffsetScale,e.viewShadowMap._distance,e.viewShadowMap.maximumDistance,e.viewShadowMap._darkness,this.combinedUniforms2)},depthTexture1:function(){return e.getSceneDepthTexture(e._map.scene)}}}),this._map.scene.postProcessStages.add(this.postProcess)}getSceneDepthTexture(t){var e=t._environmentState;let r=t._view;t=e.useGlobeDepthFramebuffer?r.globeDepth.framebuffer:void 0,e=r.sceneFramebuffer.getFramebuffer();return Cesium.defaultValue(t,e).depthStencilTexture}getFrustumQuaternion(t,e){var r=Cesium.Cartesian3.normalize(Cesium.Cartesian3.subtract(e,t,new Cesium.Cartesian3),new Cesium.Cartesian3),i=Cesium.Cartesian3.normalize(t,new Cesium.Cartesian3);let a=new Cesium.Camera(this._map.scene);a.position=t,a.direction=r,a.up=i;var r=a.directionWC,i=a.upWC,n=a.rightWC,s=new Cesium.Cartesian3,e=new Cesium.Matrix3,t=new Cesium.Quaternion,n=Cesium.Cartesian3.negate(n,s),e=e;return Cesium.Matrix3.setColumn(e,0,n,e),Cesium.Matrix3.setColumn(e,1,i,e),Cesium.Matrix3.setColumn(e,2,r,e),Cesium.Quaternion.fromRotationMatrix(e,t)}update(t){this.viewShadowMap&&t.shadowMaps.push(this.viewShadowMap)}getOnLinePointByLen(t,e,r,i){var a=Cesium.Transforms.eastNorthUpToFixedFrame(t),n=Cesium.Matrix4.inverse(a,new Cesium.Matrix4);t=Cesium.Matrix4.multiplyByPoint(n,t,new Cesium.Cartesian3),e=Cesium.Matrix4.multiplyByPoint(n,e,new Cesium.Cartesian3);var n=Cesium.Cartesian3.subtract(e,t,new Cesium.Cartesian3);let s=r/Cesium.Cartesian3.distance(t,e);i&&(s+=1);n=Cesium.Cartesian3.multiplyByScalar(n,s,new Cesium.Cartesian3);return n=Cesium.Matrix4.multiplyByPoint(a,n,new Cesium.Cartesian3)}addPositionsHeight(i,a=0){if(a=Number(a),isNaN(a)||0==a)return i;if(Array.isArray(i)){let r=[];for(let t=0,e=i.length;t<e;t++){var n=Cesium.Cartographic.fromCartesian(i[t]),n=Cesium.Cartesian3.fromRadians(n.longitude,n.latitude,n.height+a);r.push(n)}return r}var t=Cesium.Cartographic.fromCartesian(i);return Cesium.Cartesian3.fromRadians(t.longitude,t.latitude,t.height+a)}}},{}],12:[function(t,e,r){const y=Cesium.AttributeCompression,I=Cesium.BoundingSphere,i=Cesium.Cartesian2,v=Cesium.Cartesian3,m=Cesium.Color,u=Cesium.ComponentDatatype,p=Cesium.defaultValue,J=Cesium.defined,a=Cesium.destroyObject,V=Cesium.DeveloperError,d=Cesium.EncodedCartesian3,n=Cesium.IndexDatatype,q=Cesium.Math,E=Cesium.Matrix4,Y=Cesium.WebGLConstants,h=Cesium.Buffer,f=Cesium.BufferUsage,A=Cesium.ContextLimits,_=Cesium.DrawCommand,Q=Cesium.Pass,B=Cesium.RenderState,$=Cesium.ShaderProgram,tt=Cesium.ShaderSource,c=Cesium.VertexArrayFacade,et=Cesium._shadersBillboardCollectionFS,rt=Cesium._shadersBillboardCollectionVS,b=Cesium.Billboard,it=Cesium.BlendingState,at=Cesium.BlendOption,x=Cesium.HeightReference,W=Cesium.HorizontalOrigin,nt=Cesium.SceneMode,st=Cesium.SDFSettings,ot=Cesium.TextureAtlas,N=Cesium.VerticalOrigin;var lt,ut,ht=b.SHOW_INDEX,dt=b.POSITION_INDEX,ft=b.PIXEL_OFFSET_INDEX,mt=b.EYE_OFFSET_INDEX,vt=b.HORIZONTAL_ORIGIN_INDEX,pt=b.VERTICAL_ORIGIN_INDEX,ct=b.SCALE_INDEX,bt=b.IMAGE_INDEX_INDEX,yt=b.COLOR_INDEX,Vt=b.ROTATION_INDEX,qt=b.ALIGNED_AXIS_INDEX,xt=b.SCALE_BY_DISTANCE_INDEX,Wt=b.TRANSLUCENCY_BY_DISTANCE_INDEX,Nt=b.PIXEL_OFFSET_SCALE_BY_DISTANCE_INDEX,Xt=b.DISTANCE_DISPLAY_CONDITION,Lt=b.DISABLE_DEPTH_DISTANCE,X=b.TEXTURE_COORDINATE_BOUNDS,Pt=b.SDF_INDEX,Tt=b.NUMBER_OF_PROPERTIES,St={positionHighAndScale:0,positionLowAndRotation:1,compressedAttribute0:2,compressedAttribute1:3,compressedAttribute2:4,eyeOffset:5,scaleByDistance:6,pixelOffsetScaleByDistance:7,compressedAttribute3:8,textureCoordinateBoundsOrLabelTranslate:9,a_batchId:10,sdf:11},gt={direction:0,positionHighAndScale:1,positionLowAndRotation:2,compressedAttribute0:3,compressedAttribute1:4,compressedAttribute2:5,eyeOffset:6,scaleByDistance:7,pixelOffsetScaleByDistance:8,compressedAttribute3:9,textureCoordinateBoundsOrLabelTranslate:10,a_batchId:11,sdf:12};function s(t){t=p(t,p.EMPTY_OBJECT),this._scene=t.scene,this._batchTable=t.batchTable,this._textureAtlas=void 0,this._textureAtlasGUID=void 0,this._destroyTextureAtlas=!0,this._sp=void 0,this._spTranslucent=void 0,this._rsOpaque=void 0,this._rsTranslucent=void 0,this._vaf=void 0,this._billboards=[],this._billboardsToUpdate=[],this._billboardsToUpdateIndex=0,this._billboardsRemoved=!1,this._createVertexArray=!1,this._shaderRotation=!1,this._compiledShaderRotation=!1,this._shaderAlignedAxis=!1,this._compiledShaderAlignedAxis=!1,this._shaderScaleByDistance=!1,this._compiledShaderScaleByDistance=!1,this._shaderTranslucencyByDistance=!1,this._compiledShaderTranslucencyByDistance=!1,this._shaderPixelOffsetScaleByDistance=!1,this._compiledShaderPixelOffsetScaleByDistance=!1,this._shaderDistanceDisplayCondition=!1,this._compiledShaderDistanceDisplayCondition=!1,this._shaderDisableDepthDistance=!1,this._compiledShaderDisableDepthDistance=!1,this._shaderClampToGround=!1,this._compiledShaderClampToGround=!1,this._propertiesChanged=new Uint32Array(Tt),this._maxSize=0,this._maxEyeOffset=0,this._maxScale=1,this._maxPixelOffset=0,this._allHorizontalCenter=!0,this._allVerticalCenter=!0,this._allSizedInMeters=!0,this._baseVolume=new I,this._baseVolumeWC=new I,this._baseVolume2D=new I,this._boundingVolume=new I,this._boundingVolumeDirty=!1,this._colorCommands=[],this._ENUENABLED=p(t.enuEnabled,!1),this.modelMatrix=E.clone(p(t.modelMatrix,E.IDENTITY)),this._modelMatrix=E.clone(E.IDENTITY),this.debugShowBoundingVolume=p(t.debugShowBoundingVolume,!1),this.debugShowTextureAtlas=p(t.debugShowTextureAtlas,!1),this.blendOption=p(t.blendOption,at.OPAQUE_AND_TRANSLUCENT),this._blendOption=void 0,this._mode=nt.SCENE3D,this._buffersUsage=[f.STATIC_DRAW,f.STATIC_DRAW,f.STATIC_DRAW,f.STATIC_DRAW,f.STATIC_DRAW,f.STATIC_DRAW,f.STATIC_DRAW,f.STATIC_DRAW,f.STATIC_DRAW,f.STATIC_DRAW,f.STATIC_DRAW,f.STATIC_DRAW,f.STATIC_DRAW,f.STATIC_DRAW,f.STATIC_DRAW,f.STATIC_DRAW],this._highlightColor=m.clone(m.WHITE);var e=this;this._uniforms={u_atlas:function(){return e._textureAtlas.texture},u_highlightColor:function(){return e._highlightColor}};t=this._scene;J(t)&&J(t.terrainProviderChanged)&&(this._removeCallbackFunc=t.terrainProviderChanged.addEventListener(function(){for(var t=this._billboards,e=t.length,r=0;r<e;++r)t[r]._updateClamping()},this))}function o(t){for(var e=t.length,r=0;r<e;++r)t[r]&&t[r]._destroy()}function wt(t){if(t._billboardsRemoved){t._billboardsRemoved=!1;for(var e=[],r=t._billboards,i=r.length,a=0,n=0;a<i;++a){var s=r[a];s&&(s._index=n++,e.push(s))}t._billboards=e}}function zt(t){var e=t.cache.billboardCollection_indexBufferBatched;if(J(e))return e;for(var r=new Uint16Array(98298),i=0,a=0;i<98298;i+=6,a+=4)r[i]=a,r[i+1]=a+1,r[i+2]=a+2,r[i+3]=a+0,r[i+4]=a+2,r[i+5]=a+3;return(e=h.createIndexBuffer({context:t,typedArray:r,usage:f.STATIC_DRAW,indexDatatype:n.UNSIGNED_SHORT})).vertexArrayDestroyable=!1,t.cache.billboardCollection_indexBufferBatched=e}function Ft(t){var e=t.cache.billboardCollection_indexBufferInstanced;return J(e)?e:((e=h.createIndexBuffer({context:t,typedArray:new Uint16Array([0,1,2,0,2,3]),usage:f.STATIC_DRAW,indexDatatype:n.UNSIGNED_SHORT})).vertexArrayDestroyable=!1,t.cache.billboardCollection_indexBufferInstanced=e)}function jt(t,e,r,i,a,n){var s,o,l=[{index:lt.positionHighAndScale,componentsPerAttribute:4,componentDatatype:u.FLOAT,usage:r[dt]},{index:lt.positionLowAndRotation,componentsPerAttribute:4,componentDatatype:u.FLOAT,usage:r[dt]},{index:lt.compressedAttribute0,componentsPerAttribute:4,componentDatatype:u.FLOAT,usage:r[ft]},{index:lt.compressedAttribute1,componentsPerAttribute:4,componentDatatype:u.FLOAT,usage:r[Wt]},{index:lt.compressedAttribute2,componentsPerAttribute:4,componentDatatype:u.FLOAT,usage:r[yt]},{index:lt.eyeOffset,componentsPerAttribute:4,componentDatatype:u.FLOAT,usage:r[mt]},{index:lt.scaleByDistance,componentsPerAttribute:4,componentDatatype:u.FLOAT,usage:r[xt]},{index:lt.pixelOffsetScaleByDistance,componentsPerAttribute:4,componentDatatype:u.FLOAT,usage:r[Nt]},{index:lt.compressedAttribute3,componentsPerAttribute:4,componentDatatype:u.FLOAT,usage:r[Xt]},{index:lt.textureCoordinateBoundsOrLabelTranslate,componentsPerAttribute:4,componentDatatype:u.FLOAT,usage:r[X]}];i&&l.push({index:lt.direction,componentsPerAttribute:2,componentDatatype:u.FLOAT,vertexBuffer:(o=(s=t).cache.billboardCollection_vertexBufferInstanced,J(o)?o:((o=h.createVertexBuffer({context:s,typedArray:new Float32Array([0,0,1,0,1,1,0,1]),usage:f.STATIC_DRAW})).vertexArrayDestroyable=!1,s.cache.billboardCollection_vertexBufferInstanced=o))}),J(a)&&l.push({index:lt.a_batchId,componentsPerAttribute:1,componentDatatyps:u.FLOAT,bufferUsage:f.STATIC_DRAW}),n&&l.push({index:lt.sdf,componentsPerAttribute:2,componentDatatype:u.FLOAT,usage:r[Pt]});e=i?e:4*e;return new c(t,l,e,i)}Object.defineProperties(s.prototype,{length:{get:function(){return wt(this),this._billboards.length}},textureAtlas:{get:function(){return this._textureAtlas},set:function(t){this._textureAtlas!==t&&(this._textureAtlas=this._destroyTextureAtlas&&this._textureAtlas&&this._textureAtlas.destroy(),this._textureAtlas=t,this._createVertexArray=!0)}},destroyTextureAtlas:{get:function(){return this._destroyTextureAtlas},set:function(t){this._destroyTextureAtlas=t}}}),s.prototype.add=function(t){t=new b(t,this);return t._index=this._billboards.length,this._billboards.push(t),this._createVertexArray=!0,t},s.prototype.remove=function(t){return!!this.contains(t)&&(this._billboards[t._index]=null,this._billboardsRemoved=!0,this._createVertexArray=!0,t._destroy(),!0)},s.prototype.removeAll=function(){o(this._billboards),this._billboards=[],this._billboardsToUpdate=[],this._billboardsToUpdateIndex=0,this._billboardsRemoved=!1,this._createVertexArray=!0},s.prototype._updateBillboard=function(t,e){t._dirty||(this._billboardsToUpdate[this._billboardsToUpdateIndex++]=t),++this._propertiesChanged[e]},s.prototype.contains=function(t){return J(t)&&t._billboardCollection===this},s.prototype.get=function(t){if(!J(t))throw new V("index is required.");return wt(this),this._billboards[t]},s.prototype.computeNewBuffersUsage=function(){for(var t=this._buffersUsage,e=!1,r=this._propertiesChanged,i=0;i<Tt;++i){var a=0===r[i]?f.STATIC_DRAW:f.STREAM_DRAW,e=e||t[i]!==a;t[i]=a}return e};var L=new d;function Ut(t,e,r,i,a){var n,s=i[lt.positionHighAndScale],o=i[lt.positionLowAndRotation],l=a._getActualPosition();t._mode===nt.SCENE3D&&(I.expand(t._baseVolume,l,t._baseVolume),t._boundingVolumeDirty=!0),d.fromCartesian(l,L);var u=a.scale,h=a.rotation;0!==h&&(t._shaderRotation=!0),t._maxScale=Math.max(t._maxScale,u);i=L.high,l=L.low;t._instanced?(s(n=a._index,i.x,i.y,i.z,u),o(n,l.x,l.y,l.z,h)):(s((n=4*a._index)+0,i.x,i.y,i.z,u),s(n+1,i.x,i.y,i.z,u),s(n+2,i.x,i.y,i.z,u),s(n+3,i.x,i.y,i.z,u),o(n+0,l.x,l.y,l.z,h),o(n+1,l.x,l.y,l.z,h),o(n+2,l.x,l.y,l.z,h),o(n+3,l.x,l.y,l.z,h))}var P=new i,T=32768,S=65536,g=4096,w=256,z=128,F=32,j=8,U=4,R=1/256,Z=0,C=2,M=3,K=1;function Rt(t,e,r,i,a){var n,s=i[lt.compressedAttribute0],o=a.pixelOffset,l=o.x,u=o.y,h=a._translate,d=h.x,f=h.y;t._maxPixelOffset=Math.max(t._maxPixelOffset,Math.abs(l+d),Math.abs(-u+f));var m=a.horizontalOrigin,v=a._verticalOrigin,p=a.show&&a.clusterShow;0===a.color.alpha&&(p=!1),v===N.BASELINE&&(v=N.BOTTOM),t._allHorizontalCenter=t._allHorizontalCenter&&m===W.CENTER,t._allVerticalCenter=t._allVerticalCenter&&v===N.CENTER;var c=0,b=0,i=0,o=0,h=a._imageIndex;if(-1!==h){r=r[h];if(!J(r))throw new V("Invalid billboard image index: "+h);c=r.x,b=r.y,i=r.width,o=r.height}i=c+i,o=b+o,l=Math.floor(q.clamp(l,-T,T)+T)*z;l+=(m+1)*F,l+=(v+1)*j,l+=(p?1:0)*U;p=Math.floor(q.clamp(u,-T,T)+T)*w,u=Math.floor(q.clamp(d,-T,T)+T)*w,d=(q.clamp(f,-T,T)+T)*R,f=Math.floor(d);p+=f,u+=Math.floor((d-f)*w),P.x=c,P.y=b;b=y.compressTextureCoordinates(P);P.x=i;i=y.compressTextureCoordinates(P);P.y=o;o=y.compressTextureCoordinates(P);P.x=c;c=y.compressTextureCoordinates(P);t._instanced?s(n=a._index,l,p,u,b):(s((n=4*a._index)+0,l+Z,p,u,b),s(n+1,l+C,p,u,i),s(n+2,l+M,p,u,o),s(n+3,l+K,p,u,c))}function Zt(t,e,r,i,a){var n,s=i[lt.compressedAttribute1],o=a.alignedAxis;v.equals(o,v.ZERO)||(t._shaderAlignedAxis=!0);var l=0,u=1,h=1,d=1,f=a.translucencyByDistance;J(f)&&(l=f.near,u=f.nearValue,h=f.far,d=f.farValue,1===u&&1===d||(t._shaderTranslucencyByDistance=!0));i=0,f=a._imageIndex;if(-1!==f){var m=r[f];if(!J(m))throw new V("Invalid billboard image index: "+f);i=m.width}m=t._textureAtlas.texture.width,m=Math.round(p(a.width,m*i));t._maxSize=Math.max(t._maxSize,m);i=q.clamp(m,0,S),m=0;Math.abs(v.magnitudeSquared(o)-1)<q.EPSILON6&&(m=y.octEncodeFloat(o)),u=q.clamp(u,0,1),i=i*w+(u=1===u?255:255*u|0),d=q.clamp(d,0,1),m=m*w+(d=1===d?255:255*d|0),t._instanced?s(n=a._index,i,m,l,h):(s((n=4*a._index)+0,i,m,l,h),s(n+1,i,m,l,h),s(n+2,i,m,l,h),s(n+3,i,m,l,h))}function Ct(t,e,r,i,a){var n,s=i[lt.compressedAttribute2],o=a.color,l=J(t._batchTable)?m.WHITE:a.getPickId(e).color,u=a.sizeInMeters?1:0,h=Math.abs(v.magnitudeSquared(a.alignedAxis)-1)<q.EPSILON6?1:0;t._allSizedInMeters=t._allSizedInMeters&&1==u;var d=0,i=a._imageIndex;if(-1!==i){var f=r[i];if(!J(f))throw new V("Invalid billboard image index: "+i);d=f.height}e=t._textureAtlas.texture.dimensions,r=Math.round(p(a.height,e.y*d));t._maxSize=Math.max(t._maxSize,r);i=p(a._labelHorizontalOrigin,-2),f=r*U+(i+=2),e=m.floatToByte(o.red),d=m.floatToByte(o.green),r=m.floatToByte(o.blue),i=e*S+d*w+r,e=m.floatToByte(l.red),d=m.floatToByte(l.green),r=m.floatToByte(l.blue),r=e*S+d*w+r,l=m.floatToByte(o.alpha)*S+m.floatToByte(l.alpha)*w;l+=2*u+h,t._instanced?s(n=a._index,i,r,l,f):(s((n=4*a._index)+0,i,r,l,f),s(n+1,i,r,l,f),s(n+2,i,r,l,f),s(n+3,i,r,l,f))}function Mt(t,e,r,i,a){var n=i[lt.eyeOffset],s=a.eyeOffset,o=s.z;if(a._heightReference!==x.NONE&&(o*=1.005),t._maxEyeOffset=Math.max(t._maxEyeOffset,Math.abs(s.x),Math.abs(s.y),Math.abs(o)),t._instanced){var i=0,l=0,t=a._imageIndex;if(-1!==t){r=r[t];if(!J(r))throw new V("Invalid billboard image index: "+t);i=r.width,l=r.height}P.x=i,P.y=l;i=y.compressTextureCoordinates(P);n(l=a._index,s.x,s.y,o,i)}else n((l=4*a._index)+0,s.x,s.y,o,0),n(l+1,s.x,s.y,o,0),n(l+2,s.x,s.y,o,0),n(l+3,s.x,s.y,o,0)}function Kt(t,e,r,i,a){var n,s=i[lt.scaleByDistance],o=0,l=1,u=1,h=1,i=a.scaleByDistance;J(i)&&(o=i.near,l=i.nearValue,u=i.far,h=i.farValue,1===l&&1===h||(t._shaderScaleByDistance=!0)),t._instanced?s(n=a._index,o,l,u,h):(s((n=4*a._index)+0,o,l,u,h),s(n+1,o,l,u,h),s(n+2,o,l,u,h),s(n+3,o,l,u,h))}function kt(t,e,r,i,a){var n,s=i[lt.pixelOffsetScaleByDistance],o=0,l=1,u=1,h=1,i=a.pixelOffsetScaleByDistance;J(i)&&(o=i.near,l=i.nearValue,u=i.far,h=i.farValue,1===l&&1===h||(t._shaderPixelOffsetScaleByDistance=!0)),t._instanced?s(n=a._index,o,l,u,h):(s((n=4*a._index)+0,o,l,u,h),s(n+1,o,l,u,h),s(n+2,o,l,u,h),s(n+3,o,l,u,h))}function Dt(t,e,r,i,a){var n,s=i[lt.compressedAttribute3],o=0,l=Number.MAX_VALUE,u=a.distanceDisplayCondition;J(u)&&(o=u.near,l=u.far,o*=o,l*=l,t._shaderDistanceDisplayCondition=!0);var h=a.disableDepthTestDistance,d=a.heightReference===x.CLAMP_TO_GROUND&&t._scene.context.depthTexture;if(J(h)||(h=d?5e3:0),h*=h,(d||0<h)&&(t._shaderDisableDepthDistance=!0,h===Number.POSITIVE_INFINITY&&(h=-1)),J(a._labelDimensions))m=a._labelDimensions.x,f=a._labelDimensions.y;else{i=0,u=0,d=a._imageIndex;if(-1!==d){r=r[d];if(!J(r))throw new V("Invalid billboard image index: "+d);i=r.height,u=r.width}var f=Math.round(p(a.height,t._textureAtlas.texture.dimensions.y*i)),i=t._textureAtlas.texture.width,m=Math.round(p(a.width,i*u))}m=Math.floor(q.clamp(m,0,g)),f=Math.floor(q.clamp(f,0,g)),f=m*g+f;t._instanced?s(n=a._index,o,l,h,f):(s((n=4*a._index)+0,o,l,h,f),s(n+1,o,l,h,f),s(n+2,o,l,h,f),s(n+3,o,l,h,f))}function Gt(t,e,r,i,a){var n;a.heightReference===x.CLAMP_TO_GROUND&&(t._shaderClampToGround=t._scene.context.depthTexture);var s=i[lt.textureCoordinateBoundsOrLabelTranslate];if(0<A.maximumVertexTextureImageUnits){var o=0,l=0;return J(a._labelTranslate)&&(o=a._labelTranslate.x,l=a._labelTranslate.y),void(t._instanced?s(n=a._index,o,l,0,0):(s((n=4*a._index)+0,o,l,0,0),s(n+1,o,l,0,0),s(n+2,o,l,0,0),s(n+3,o,l,0,0)))}var u=0,h=0,i=0,o=0,l=a._imageIndex;if(-1!==l){r=r[l];if(!J(r))throw new V("Invalid billboard image index: "+l);u=r.x,h=r.y,i=r.width,o=r.height}i=u+i,o=h+o;t._instanced?s(n=a._index,u,h,i,o):(s((n=4*a._index)+0,u,h,i,o),s(n+1,u,h,i,o),s(n+2,u,h,i,o),s(n+3,u,h,i,o))}function Ht(t,e,r,i,a){var n,s,o,l,u,h;t._sdf&&(s=i[lt.sdf],o=a.outlineColor,h=a.outlineWidth,l=m.floatToByte(o.red),u=m.floatToByte(o.green),i=m.floatToByte(o.blue),i=l*S+u*w+i,h=h/st.RADIUS,h=m.floatToByte(o.alpha)*S+m.floatToByte(h)*w,t._instanced?s(n=a._index,i,h):(s((n=4*a._index)+0,i+Z,h),s(n+1,i+C,h),s(n+2,i+M,h),s(n+3,i+K,h)))}function Ot(t,e,r,i,a){var n,s,o;Ut(t,0,0,i,a),Rt(t,0,r,i,a),Zt(t,0,r,i,a),Ct(t,e,r,i,a),Mt(t,0,r,i,a),Kt(t,0,0,i,a),kt(t,0,0,i,a),Dt(t,0,r,i,a),Gt(t,0,r,i,a),n=t,s=i,e=a,J(n._batchTable)&&(r=s[lt.a_batchId],s=e._batchIndex,n._instanced?r(o=e._index,s):(r((o=4*e._index)+0,s),r(o+1,s),r(o+2,s),r(o+3,s))),Ht(t,0,0,i,a)}function It(t,e,r,i,a,n){var s;i.mode===nt.SCENE3D?(s=t._baseVolume,t._boundingVolumeDirty=!0):s=t._baseVolume2D;for(var o=[],l=0;l<r;++l){var u=e[l],h=u.position,h=b._computeActualPosition(u,h,i,a);J(h)&&(u._setActualPosition(h),n?o.push(h):I.expand(s,h,s))}n&&I.fromPoints(o,s)}var Jt=[];s.prototype.update=function(t){wt(this);var e=(l=this._billboards).length,r=t.context;this._instanced=r.instancedArrays,lt=this._instanced?gt:St,ut=this._instanced?Ft:zt;var i=this._textureAtlas;if(!J(i))for(var i=this._textureAtlas=new ot({context:r}),a=0;a<e;++a)l[a]._loadImage();var n,s,o=i.textureCoordinates;if(0!==o.length){m=this,n=(v=t).mode,s=m._billboards,f=m._billboardsToUpdate,p=m._modelMatrix,m._createVertexArray||m._mode!==n||n!==nt.SCENE3D&&!E.equals(p,m.modelMatrix)?(m._mode=n,E.clone(m.modelMatrix,p),m._createVertexArray=!0,n!==nt.SCENE3D&&n!==nt.SCENE2D&&n!==nt.COLUMBUS_VIEW||It(m,s,s.length,v,p,!0)):n===nt.MORPHING?It(m,s,s.length,v,p,!0):n!==nt.SCENE2D&&n!==nt.COLUMBUS_VIEW||It(m,f,m._billboardsToUpdateIndex,v,p,!1);var l,e=(l=this._billboards).length,u=this._billboardsToUpdate,h=this._billboardsToUpdateIndex,d=this._propertiesChanged,f=i.guid,m=this._createVertexArray||this._textureAtlasGUID!==f;this._textureAtlasGUID=f;var v=t.passes,p=v.pick;if(m||!p&&this.computeNewBuffersUsage()){this._createVertexArray=!1;for(var c=0;c<Tt;++c)d[c]=0;if(this._vaf=this._vaf&&this._vaf.destroy(),0<e){this._vaf=jt(r,e,this._buffersUsage,this._instanced,this._batchTable,this._sdf);for(var b=this._vaf.writers,y=0;y<e;++y){var V=this._billboards[y];V._dirty=!1,Ot(this,r,o,b,V)}this._vaf.commit(ut(r))}this._billboardsToUpdateIndex=0}else if(0<h){var q=Jt;q.length=0,(d[dt]||d[Vt]||d[ct])&&q.push(Ut),(d[bt]||d[ft]||d[vt]||d[pt]||d[ht])&&(q.push(Rt),this._instanced&&q.push(Mt)),(d[bt]||d[qt]||d[Wt])&&(q.push(Zt),q.push(Ct)),(d[bt]||d[yt])&&q.push(Ct),d[mt]&&q.push(Mt),d[xt]&&q.push(Kt),d[Nt]&&q.push(kt),(d[Xt]||d[Lt]||d[bt]||d[dt])&&q.push(Dt),(d[bt]||d[dt])&&q.push(Gt),d[Pt]&&q.push(Ht);var x=q.length;if(b=this._vaf.writers,.1<h/e){for(var W=0;W<h;++W){var N=u[W];N._dirty=!1;for(var X=0;X<x;++X)q[X](this,r,o,b,N)}this._vaf.commit(ut(r))}else{for(var L=0;L<h;++L){var P=u[L];P._dirty=!1;for(var T=0;T<x;++T)q[T](this,r,o,b,P);this._instanced?this._vaf.subCommit(P._index,1):this._vaf.subCommit(4*P._index,4)}this._vaf.endSubCommits()}this._billboardsToUpdateIndex=0}if(1.5*e<h&&(u.length=e),J(this._vaf)&&J(this._vaf.va)){this._boundingVolumeDirty&&(this._boundingVolumeDirty=!1,I.transform(this._baseVolume,this.modelMatrix,this._baseVolumeWC));var S=E.IDENTITY,g=t.mode===nt.SCENE3D?(S=this.modelMatrix,I.clone(this._baseVolumeWC,this._boundingVolume)):I.clone(this._baseVolume2D,this._boundingVolume);i=t,f=g,m=1,i=(m=!(p=this)._allSizedInMeters||0!==p._maxPixelOffset?i.camera.getPixelSize(f,i.context.drawingBufferWidth,i.context.drawingBufferHeight):m)*p._maxScale*p._maxSize*2,p._allHorizontalCenter&&p._allVerticalCenter&&(i*=.5),p=m*p._maxPixelOffset+p._maxEyeOffset,f.radius+=i+p;var w,m=this._blendOption!==this.blendOption;this._blendOption=this.blendOption,m&&(this._blendOption===at.OPAQUE||this._blendOption===at.OPAQUE_AND_TRANSLUCENT?this._rsOpaque=B.fromCache({depthTest:{enabled:!0,func:Y.LESS},depthMask:!0}):this._rsOpaque=void 0,z=this._blendOption===at.TRANSLUCENT,this._blendOption===at.TRANSLUCENT||this._blendOption===at.OPAQUE_AND_TRANSLUCENT?this._rsTranslucent=B.fromCache({depthTest:{enabled:!0,func:z?Y.LEQUAL:Y.LESS},depthMask:z,blending:it.ALPHA_BLEND}):this._rsTranslucent=void 0),this._shaderDisableDepthDistance=this._shaderDisableDepthDistance||0!==t.minimumDisableDepthTestDistance;var z,f=0<A.maximumVertexTextureImageUnits;!m&&this._shaderRotation===this._compiledShaderRotation&&this._shaderAlignedAxis===this._compiledShaderAlignedAxis&&this._shaderScaleByDistance===this._compiledShaderScaleByDistance&&this._shaderTranslucencyByDistance===this._compiledShaderTranslucencyByDistance&&this._shaderPixelOffsetScaleByDistance===this._compiledShaderPixelOffsetScaleByDistance&&this._shaderDistanceDisplayCondition===this._compiledShaderDistanceDisplayCondition&&this._shaderDisableDepthDistance===this._compiledShaderDisableDepthDistance&&this._shaderClampToGround===this._compiledShaderClampToGround&&this._sdf===this._compiledSDF||(i=rt,p=et,z=[],J(this._batchTable)&&(z.push("VECTOR_TILE"),i=this._batchTable.getVertexShaderCallback(!1,"a_batchId",void 0)(i),p=this._batchTable.getFragmentShaderCallback(!1,void 0)(p)),m=new tt({defines:z,sources:[i]}),this._ENUENABLED&&m.defines.push("ENU_ENABLED"),this._instanced&&m.defines.push("INSTANCED"),this._shaderRotation&&m.defines.push("ROTATION"),this._shaderAlignedAxis&&m.defines.push("ALIGNED_AXIS"),this._shaderScaleByDistance&&m.defines.push("EYE_DISTANCE_SCALING"),this._shaderTranslucencyByDistance&&m.defines.push("EYE_DISTANCE_TRANSLUCENCY"),this._shaderPixelOffsetScaleByDistance&&m.defines.push("EYE_DISTANCE_PIXEL_OFFSET"),this._shaderDistanceDisplayCondition&&m.defines.push("DISTANCE_DISPLAY_CONDITION"),this._shaderDisableDepthDistance&&m.defines.push("DISABLE_DEPTH_DISTANCE"),this._shaderClampToGround&&(f?m.defines.push("VERTEX_DEPTH_CHECK"):m.defines.push("FRAGMENT_DEPTH_CHECK")),z=1-st.CUTOFF,this._sdf&&m.defines.push("SDF"),i=J(this._batchTable)?"VECTOR_TILE":"",this._blendOption===at.OPAQUE_AND_TRANSLUCENT&&(w=new tt({defines:["OPAQUE",i],sources:[p]}),this._shaderClampToGround&&(f?w.defines.push("VERTEX_DEPTH_CHECK"):w.defines.push("FRAGMENT_DEPTH_CHECK")),this._sdf&&(w.defines.push("SDF"),w.defines.push("SDF_EDGE "+z)),this._sp=$.replaceCache({context:r,shaderProgram:this._sp,vertexShaderSource:m,fragmentShaderSource:w,attributeLocations:lt}),w=new tt({defines:["TRANSLUCENT",i],sources:[p]}),this._shaderClampToGround&&(f?w.defines.push("VERTEX_DEPTH_CHECK"):w.defines.push("FRAGMENT_DEPTH_CHECK")),this._sdf&&(w.defines.push("SDF"),w.defines.push("SDF_EDGE "+z)),this._spTranslucent=$.replaceCache({context:r,shaderProgram:this._spTranslucent,vertexShaderSource:m,fragmentShaderSource:w,attributeLocations:lt})),this._blendOption===at.OPAQUE&&(w=new tt({defines:[i],sources:[p]}),this._shaderClampToGround&&(f?w.defines.push("VERTEX_DEPTH_CHECK"):w.defines.push("FRAGMENT_DEPTH_CHECK")),this._sdf&&(w.defines.push("SDF"),w.defines.push("SDF_EDGE "+z)),this._sp=$.replaceCache({context:r,shaderProgram:this._sp,vertexShaderSource:m,fragmentShaderSource:w,attributeLocations:lt})),this._blendOption===at.TRANSLUCENT&&(w=new tt({defines:[i],sources:[p]}),this._shaderClampToGround&&(f?w.defines.push("VERTEX_DEPTH_CHECK"):w.defines.push("FRAGMENT_DEPTH_CHECK")),this._sdf&&(w.defines.push("SDF"),w.defines.push("SDF_EDGE "+z)),this._spTranslucent=$.replaceCache({context:r,shaderProgram:this._spTranslucent,vertexShaderSource:m,fragmentShaderSource:w,attributeLocations:lt})),this._compiledShaderRotation=this._shaderRotation,this._compiledShaderAlignedAxis=this._shaderAlignedAxis,this._compiledShaderScaleByDistance=this._shaderScaleByDistance,this._compiledShaderTranslucencyByDistance=this._shaderTranslucencyByDistance,this._compiledShaderPixelOffsetScaleByDistance=this._shaderPixelOffsetScaleByDistance,this._compiledShaderDistanceDisplayCondition=this._shaderDistanceDisplayCondition,this._compiledShaderDisableDepthDistance=this._shaderDisableDepthDistance,this._compiledShaderClampToGround=this._shaderClampToGround,this._compiledSDF=this._sdf);var F,j=t.commandList;if(v.render||v.pick){var U=this._colorCommands,R=this._blendOption===at.OPAQUE,Z=this._blendOption===at.OPAQUE_AND_TRANSLUCENT,C=this._vaf.va,v=C.length,M=this._uniforms,K=J(this._batchTable)?(M=this._batchTable.getUniformMapCallback()(M),this._batchTable.getPickId()):"v_pickColor";U.length=v;for(var k=Z?2*v:v,D=0;D<k;++D){var G=U[D],H=R||Z&&D%2==0;(G=!J(G)?U[D]=new _:G).pass=H||!Z?Q.OPAQUE:Q.TRANSLUCENT,G.owner=this;var O=Z?Math.floor(D/2):D;G.boundingVolume=g,G.modelMatrix=S,G.count=C[O].indicesCount,G.shaderProgram=H?this._sp:this._spTranslucent,G.uniformMap=M,G.vertexArray=C[O].va,G.renderState=H?this._rsOpaque:this._rsTranslucent,G.debugShowBoundingVolume=this.debugShowBoundingVolume,G.pickId=K,this._instanced&&(G.count=6,G.instanceCount=e),j.push(G)}this.debugShowTextureAtlas&&(J(this.debugCommand)||(this.debugCommand=(F=this,(t=(t=t.context).createViewportQuadCommand("uniform sampler2D billboard_texture; \nvarying vec2 v_textureCoordinates; \nvoid main() \n{ \n    gl_FragColor = texture2D(billboard_texture, v_textureCoordinates); \n} \n",{uniformMap:{billboard_texture:function(){return F._textureAtlas.texture}}})).pass=Q.OVERLAY,t)),j.push(this.debugCommand))}}}},s.prototype.isDestroyed=function(){return!1},s.prototype.destroy=function(){return J(this._removeCallbackFunc)&&(this._removeCallbackFunc(),this._removeCallbackFunc=void 0),this._textureAtlas=this._destroyTextureAtlas&&this._textureAtlas&&this._textureAtlas.destroy(),this._sp=this._sp&&this._sp.destroy(),this._spTranslucent=this._spTranslucent&&this._spTranslucent.destroy(),this._vaf=this._vaf&&this._vaf.destroy(),o(this._billboards),a(this)},e.exports=s},{}],13:[function(t,e,r){const w=Cesium.when,k=Cesium.AttributeCompression,D=Cesium.BoundingSphere,G=Cesium.Cartesian3,o=Cesium.Credit,n=Cesium.defaultValue,H=Cesium.defined,u=Cesium.DeveloperError,s=Cesium.Event,z=Cesium.GeographicTilingScheme,F=Cesium.WebMercatorTilingScheme,O=Cesium.getStringFromTypedArray,m=Cesium.HeightmapTerrainData,I=Cesium.IndexDatatype,J=Cesium.OrientedBoundingBox,E=Cesium.QuantizedMeshTerrainData,v=Cesium.Request,p=Cesium.RequestType,l=Cesium.Resource,c=Cesium.RuntimeError,j=Cesium.TerrainProvider,U=Cesium.TileAvailability,R=Cesium.TileProviderError;function Z(t){this.resource=t.resource,this.version=t.version,this.isHeightmap=t.isHeightmap,this.tileUrlTemplates=t.tileUrlTemplates,this.availability=t.availability,this.hasVertexNormals=t.hasVertexNormals,this.hasWaterMask=t.hasWaterMask,this.hasMetadata=t.hasMetadata,this.availabilityLevels=t.availabilityLevels,this.availabilityTilesLoaded=t.availabilityTilesLoaded,this.littleEndianExtensionSize=t.littleEndianExtensionSize,this.availabilityTilesLoaded=t.availabilityTilesLoaded,this.availabilityPromiseCache={}}function i(t){if(!H(t)||!H(t.url))throw new u("options.url is required.");this._heightmapWidth=65,this._heightmapStructure=void 0,this._hasWaterMask=!1,this._hasVertexNormals=!1,this._ellipsoid=t.ellipsoid,this._requestVertexNormals=n(t.requestVertexNormals,!1),this._requestWaterMask=n(t.requestWaterMask,!1),this._requestMetadata=n(t.requestMetadata,!0),this._errorEvent=new s;var e=t.credit;"string"==typeof e&&(e=new o(e)),this._credit=e,this._availability=void 0;var r=w.defer();this._ready=!1,this._readyPromise=r,this._tileCredits=void 0;var V,q,x,W=this,N=this._layers=[],X="",L=[],P=0;function T(t){if(!t.format)return u="The tile format is not specified in the layer.json file.",void(x=R.handleError(x,W,W._errorEvent,u,void 0,void 0,void 0,g));if(!t.tiles||0===t.tiles.length)return u="The layer.json file does not specify any tile URL templates.",void(x=R.handleError(x,W,W._errorEvent,u,void 0,void 0,void 0,g));var e=!1,r=!1,i=!1,a=!0,n=!1;if("heightmap-1.0"===t.format)n=!0,H(W._heightmapStructure)||(W._heightmapStructure={heightScale:.2,heightOffset:-1e3,elementsPerHeight:1,stride:1,elementMultiplier:256,isBigEndian:!1,lowestEncodedHeight:0,highestEncodedHeight:65535}),W._requestWaterMask=r=!0;else if(0!==t.format.indexOf("quantized-mesh-1."))return u='The tile format "'+t.format+'" is invalid or not supported.',void(x=R.handleError(x,W,W._errorEvent,u,void 0,void 0,void 0,g));var s,o=t.tiles,l=t.maxzoom;if(P=Math.max(P,l),t.projection&&"EPSG:4326"!==t.projection){if("EPSG:3857"!==t.projection)return u='The projection "'+t.projection+'" is invalid or not supported.',void(x=R.handleError(x,W,W._errorEvent,u,void 0,void 0,void 0,g));W._tilingScheme=new F({numberOfLevelZeroTilesX:1,numberOfLevelZeroTilesY:1,ellipsoid:W._ellipsoid})}else W._tilingScheme=new z({numberOfLevelZeroTilesX:2,numberOfLevelZeroTilesY:1,ellipsoid:W._ellipsoid});if(W._levelZeroMaximumGeometricError=j.getEstimatedLevelZeroGeometricErrorForAHeightmap(W._tilingScheme.ellipsoid,W._heightmapWidth,W._tilingScheme.getNumberOfXTilesAtLevel(0)),t.scheme&&"tms"!==t.scheme&&"slippyMap"!==t.scheme)return u='The scheme "'+t.scheme+'" is invalid or not supported.',void(x=R.handleError(x,W,W._errorEvent,u,void 0,void 0,void 0,g));W._scheme=t.scheme,H(t.extensions)&&-1!==t.extensions.indexOf("octvertexnormals")?e=!0:H(t.extensions)&&-1!==t.extensions.indexOf("vertexnormals")&&(a=!(e=!0)),H(t.extensions)&&-1!==t.extensions.indexOf("watermask")&&(r=!0),H(t.extensions)&&-1!==t.extensions.indexOf("metadata")&&(i=!0);var u=t.metadataAvailability,h=t.available;if(H(h)&&!H(u))for(var d=new U(W._tilingScheme,h.length),f=0;f<h.length;++f){var m=h[f],v=W._tilingScheme.getNumberOfYTilesAtLevel(f);H(L[f])||(L[f]=[]);for(var p=0;p<m.length;++p){var c=m[p],b=v-c.endY-1,y=v-c.startY-1;L[f].push([c.startX,b,c.endX,y]),d.addAvailableTileRange(f,c.startX,b,c.endX,y)}}else H(u)&&(s=new U(W._tilingScheme,l),d=new U(W._tilingScheme,l),L[0]=[[0,0,1,0]],d.addAvailableTileRange(0,0,0,1,0));W._hasWaterMask=W._hasWaterMask||r,W._hasVertexNormals=W._hasVertexNormals||e,W._hasMetadata=W._hasMetadata||i,H(t.attribution)&&(0<X.length&&(X+=" "),X+=t.attribution),N.push(new Z({resource:V,version:t.version,isHeightmap:n,tileUrlTemplates:o,availability:d,hasVertexNormals:e,hasWaterMask:r,hasMetadata:i,availabilityLevels:u,availabilityTilesLoaded:s,littleEndianExtensionSize:a}));t=t.parentUrl;if(H(t)){if(!H(d))return console.log("A layer.json can't have a parentUrl if it does't have an available array."),w.resolve();(V=V.getDerivedResource({url:t})).appendForwardSlash();t=(q=V.getDerivedResource({url:"layer.json"})).fetchJson();return w(t,T,S)}return w.resolve()}function S(t){var e="An error occurred while accessing "+q.url+".";x=R.handleError(x,W,W._errorEvent,e,void 0,void 0,void 0,g)}function i(t){T(t).then(function(){if(!H(x)){var t,e=L.length;if(0<e)for(var r=W._availability=new U(W._tilingScheme,P),i=0;i<e;++i)for(var a=L[i],n=0;n<a.length;++n){var s=a[n];r.addAvailableTileRange(i,s[0],s[1],s[2],s[3])}0<X.length&&(t=new o(X),H(W._tileCredits)?W._tileCredits.push(t):W._tileCredits=[t]),W._ready=!0,W._readyPromise.resolve(!0)}})}function a(t){H(t)&&404===t.statusCode?i({tilejson:"2.1.0",format:"heightmap-1.0",version:"1.0.0",scheme:"tms",tiles:["{z}/{x}/{y}.terrain?v={version}"]}):S()}function g(){w(q.fetchJson()).then(i).otherwise(a)}w(t.url).then(function(t){t=l.createIfNeeded(t);t.appendForwardSlash(),q=(V=t).getDerivedResource({url:"layer.json"}),W._tileCredits=t.credits,g()}).otherwise(function(t){r.reject(t)}),this.processor=new Cesium.TaskProcessor("RequestData",Number.POSITIVE_INFINITY)}var Y={OCT_VERTEX_NORMALS:1,WATER_MASK:2,METADATA:4};function b(t){return H(t)&&0!==t.length?{Accept:"application/vnd.quantized-mesh;extensions="+t.join("-")+",application/octet-stream;q=0.9,*/*;q=0.01"}:{Accept:"application/vnd.quantized-mesh,application/octet-stream;q=0.9,*/*;q=0.01"}}function y(a,n,s,o,l,e){if(!H(l))return w.reject(new c("Terrain tile doesn't exist"));var r,i=l.tileUrlTemplates;if(0!==i.length){r=a._scheme&&"tms"!==a._scheme?s:a._tilingScheme.getNumberOfYTilesAtLevel(o)-s-1;var u,h=[];a._requestVertexNormals&&l.hasVertexNormals&&h.push(l.littleEndianExtensionSize?"octvertexnormals":"vertexnormals"),a._requestWaterMask&&l.hasWaterMask&&h.push("watermask"),a._requestMetadata&&l.hasMetadata&&h.push("metadata");var d=i[(n+r+o)%i.length],i=l.resource,h=H(i._ionEndpoint)&&!H(i._ionEndpoint.externalType)?(0!==h.length&&(u={extensions:h.join("-")}),b(void 0)):b(h),e=i.getDerivedResource({url:d,templateValues:{version:l.version,z:o,x:n,y:r},queryParameters:u,headers:h,request:e}),f=w.defer();i._ionEndpoint&&(h.Authorization="Bearer "+i._ionEndpoint.accessToken);let t=a.processor.scheduleTask({url:e.url,headers:h,methodName:"fetchArrayBuffer"});return t.then(function(t){if(0==t)return f.reject();var e,r,i=t.result;return H(a._heightmapStructure)?f.resolve((e=a,r=i,t=new Uint16Array(r,0,e._heightmapWidth*e._heightmapWidth),new m({buffer:t,childTileMask:new Uint8Array(r,t.byteLength,1)[0],waterMask:new Uint8Array(r,t.byteLength+1,r.byteLength-t.byteLength-1),width:e._heightmapWidth,height:e._heightmapWidth,structure:e._heightmapStructure,credits:e._tileCredits}))):f.resolve(function(t,e,r,i,a,n){var s=n.littleEndianExtensionSize,o=0,l=3*Float64Array.BYTES_PER_ELEMENT,u=4*Float64Array.BYTES_PER_ELEMENT,h=3*Uint16Array.BYTES_PER_ELEMENT,d=Uint16Array.BYTES_PER_ELEMENT,f=3*d,m=new DataView(e),v=new G(m.getFloat64(o,!0),m.getFloat64(o+8,!0),m.getFloat64(o+16,!0)),p=m.getFloat32(o+=l,!0);o+=Float32Array.BYTES_PER_ELEMENT;var c=m.getFloat32(o,!0);o+=Float32Array.BYTES_PER_ELEMENT;var b=new D(new G(m.getFloat64(o,!0),m.getFloat64(o+8,!0),m.getFloat64(o+16,!0)),m.getFloat64(o+l,!0));o+=u;var y=new G(m.getFloat64(o,!0),m.getFloat64(o+8,!0),m.getFloat64(o+16,!0)),V=m.getUint32(o+=l,!0);o+=Uint32Array.BYTES_PER_ELEMENT;var q=new Uint16Array(e,o,3*V);o+=V*h,65536<V&&(f=3*(d=Uint32Array.BYTES_PER_ELEMENT));var x=q.subarray(0,V),u=q.subarray(V,2*V),l=q.subarray(2*V,3*V);k.zigZagDeltaDecode(x,u,l),o%d!=0&&(o+=d-o%d),h=m.getUint32(o,!0),o+=Uint32Array.BYTES_PER_ELEMENT;var W=I.createTypedArrayFromArrayBuffer(V,e,o,3*h);o+=h*f;for(var N=0,X=W.length,L=0;L<X;++L){var P=W[L];W[L]=N-P,0===P&&++N}x=m.getUint32(o,!0),o+=Uint32Array.BYTES_PER_ELEMENT,u=I.createTypedArrayFromArrayBuffer(V,e,o,x),l=m.getUint32(o+=x*d,!0),o+=Uint32Array.BYTES_PER_ELEMENT,h=I.createTypedArrayFromArrayBuffer(V,e,o,l),f=m.getUint32(o+=l*d,!0),o+=Uint32Array.BYTES_PER_ELEMENT,x=I.createTypedArrayFromArrayBuffer(V,e,o,f),l=m.getUint32(o+=f*d,!0),o+=Uint32Array.BYTES_PER_ELEMENT;var T,S,f=I.createTypedArrayFromArrayBuffer(V,e,o,l);for(o+=l*d;o<m.byteLength;){var g=m.getUint8(o,!0);o+=Uint8Array.BYTES_PER_ELEMENT;var w=m.getUint32(o,s);if(o+=Uint32Array.BYTES_PER_ELEMENT,g===Y.OCT_VERTEX_NORMALS&&t._requestVertexNormals)T=new Uint8Array(e,o,2*V);else if(g===Y.WATER_MASK&&t._requestWaterMask)S=new Uint8Array(e,o,w);else if(g===Y.METADATA&&t._requestMetadata){g=m.getUint32(o,!0);if(0<g){var g=O(new Uint8Array(e),o+Uint32Array.BYTES_PER_ELEMENT,g),z=JSON.parse(g).available;if(H(z))for(var F=0;F<z.length;++F)for(var j=r+F+1,U=z[F],R=t._tilingScheme.getNumberOfYTilesAtLevel(j),Z=0;Z<U.length;++Z){var C=U[Z],M=R-C.endY-1,K=R-C.startY-1;t.availability.addAvailableTileRange(j,C.startX,M,C.endX,K),n.availability.addAvailableTileRange(j,C.startX,M,C.endX,K)}}n.availabilityTilesLoaded.addAvailableTileRange(r,i,a,i,a)}o+=w}return l=5*t.getLevelMaximumGeometricError(r),d=t._tilingScheme.tileXYToRectangle(i,a,r),d=J.fromRectangle(d,p,c,t._tilingScheme.ellipsoid),new E({center:v,minimumHeight:p,maximumHeight:c,boundingSphere:b,orientedBoundingBox:d,horizonOcclusionPoint:y,quantizedVertices:q,encodedNormals:T,indices:W,westIndices:u,southIndices:h,eastIndices:x,northIndices:f,westSkirtHeight:l,southSkirtHeight:l,eastSkirtHeight:l,northSkirtHeight:l,childTileMask:t.availability.computeChildMaskForTile(r,i,a),waterMask:S,credits:t._tileCredits})}(a,i,o,n,s,l))}),f.promise}}function V(t,e,r,i){if(0!==i){t=t.availabilityLevels,t=i%t==0?i-t:(i/t|0)*t,i=1<<i-t;return{level:t,x:e/i|0,y:r/i|0}}}function h(t,e,r,i,a,n){if(!H(a.availabilityLevels))return{result:!1};function s(){delete a.availabilityPromiseCache[u]}for(var o,l,u,h=a.availabilityTilesLoaded,d=a.availability,f=V(a,e,r,i);H(f);){if(d.isTileAvailable(f.level,f.x,f.y)&&!h.isTileAvailable(f.level,f.x,f.y))return n||(u=f.level+"-"+f.x+"-"+f.y,l=a.availabilityPromiseCache[u],H(l)||(o=new v({throttle:!0,throttleByServer:!0,type:p.TERRAIN}),l=y(t,f.x,f.y,f.level,a,o),H(l)&&(a.availabilityPromiseCache[u]=l).then(s))),{result:!0,promise:l};f=V(a,f.x,f.y,f.level)}return{result:!1}}i.prototype.requestTileGeometry=function(t,e,r,i){if(!this._ready)throw new u("requestTileGeometry must not be called before the terrain provider is ready.");var a,n=this._layers,s=n.length;if(1===s)a=n[0];else for(var o=0;o<s;++o){var l=n[o];if(!H(l.availability)||l.availability.isTileAvailable(r,t,e)){a=l;break}}return y(this,t,e,r,a,i)},Object.defineProperties(i.prototype,{errorEvent:{get:function(){return this._errorEvent}},credit:{get:function(){if(!this._ready)throw new u("credit must not be called before the terrain provider is ready.");return this._credit}},tilingScheme:{get:function(){if(!this._ready)throw new u("tilingScheme must not be called before the terrain provider is ready.");return this._tilingScheme}},ready:{get:function(){return this._ready}},readyPromise:{get:function(){return this._readyPromise.promise}},hasWaterMask:{get:function(){if(!this._ready)throw new u("hasWaterMask must not be called before the terrain provider is ready.");return this._hasWaterMask&&this._requestWaterMask}},hasVertexNormals:{get:function(){if(!this._ready)throw new u("hasVertexNormals must not be called before the terrain provider is ready.");return this._hasVertexNormals&&this._requestVertexNormals}},hasMetadata:{get:function(){if(!this._ready)throw new u("hasMetadata must not be called before the terrain provider is ready.");return this._hasMetadata&&this._requestMetadata}},requestVertexNormals:{get:function(){return this._requestVertexNormals}},requestWaterMask:{get:function(){return this._requestWaterMask}},requestMetadata:{get:function(){return this._requestMetadata}},availability:{get:function(){if(!this._ready)throw new u("availability must not be called before the terrain provider is ready.");return this._availability}}}),i.prototype.getLevelMaximumGeometricError=function(t){return this._levelZeroMaximumGeometricError/(1<<t)},i.prototype.getTileDataAvailable=function(t,e,r){if(H(this._availability)){if(r>this._availability._maximumLevel)return!1;if(this._availability.isTileAvailable(r,t,e))return!0;if(!this._hasMetadata)return!1;for(var i=this._layers,a=i.length,n=0;n<a;++n)if(h(this,t,e,r,i[n],0===n).result)return;return!1}},i.prototype.loadTileDataAvailability=function(t,e,r){if(!(!H(this._availability)||r>this._availability._maximumLevel||this._availability.isTileAvailable(r,t,e))&&this._hasMetadata)for(var i=this._layers,a=i.length,n=0;n<a;++n){var s=h(this,t,e,r,i[n],0===n);if(H(s.promise))return s.promise}},i._getAvailabilityTile=V,e.exports=i},{}],14:[function(t,e,r){const i=Cesium.BoundingRectangle,g=Cesium.Cartesian2,b=Cesium.Color;Cesium.defaultValue;const w=Cesium.defined;Cesium.defineProperties;Cesium.destroyObject;Cesium.DeveloperError,Cesium.Matrix4,Cesium.writeTextToCanvas;const l=Cesium.BlendOption,z=Cesium.HeightReference,F=Cesium.HorizontalOrigin;Cesium.Label;const y=Cesium.LabelStyle,u=Cesium.TextureAtlas,j=Cesium.VerticalOrigin;var a=Cesium.LabelCollection;const n=t("../ext/BillboardCollection.js");var U=0;function V(){this.textureInfo=void 0,this.dimensions=void 0,this.billboard=void 0}function q(t,e,r){this.labelCollection=t,this.index=e,this.dimensions=r}var x="ID_WHITE_PIXEL",h=new g(4,4),W=new i(1,1,1,1);function N(t,e){e.textureInfo=void 0,e.dimensions=void 0;var r=e.billboard;w(r)&&(r.show=!1,r.image=void 0,w(r._removeCallbackFunc)&&(r._removeCallbackFunc(),r._removeCallbackFunc=void 0),t._spareBillboards.push(r),e.billboard=void 0)}function d(t,e,r){var i=e._renderedText;if(0!=i.length){var a,n=i.length,s=e._glyphs,o=s.length;if(e._relativeSize=e._fontSize/24,n<o)for(a=n;a<o;++a)N(t,s[a]);s.length=n;var l=e._showBackground&&0<i.split(" ").join("").length,u=e._backgroundBillboard,h=t._backgroundBillboardCollection;l?(w(u)||(u=h.add({collection:t,image:x,imageSubRegion:W}),e._backgroundBillboard=u),u.color=e._backgroundColor,u.show=e._show,u.position=e._position,u.eyeOffset=e._eyeOffset,u.pixelOffset=e._pixelOffset,u.horizontalOrigin=F.LEFT,u.verticalOrigin=e._verticalOrigin,u.heightReference=e._heightReference,u.scale=e.totalScale,u.pickPrimitive=e,u.id=e._id,u.translucencyByDistance=e._translucencyByDistance,u.pixelOffsetScaleByDistance=e._pixelOffsetScaleByDistance,u.scaleByDistance=e._scaleByDistance,u.distanceDisplayCondition=e._distanceDisplayCondition,u.disableDepthTestDistance=e._disableDepthTestDistance):w(u)&&(h.remove(u),e._backgroundBillboard=u=void 0);for(var d=t._glyphTextureCache,f=0;f<n;++f){var m,v=i[f],p=e._verticalOrigin,c=JSON.stringify([v,e._fontFamily,e._fontStyle,e._fontWeight,+p]),p=d[c];w(p)||(m=v.charCodeAt(0),(m=(m=r["微软雅黑"][m])||r["微软雅黑"][63]).hasOwnProperty("dimensions")||(m.dimensions={width:m.width-3,height:24,descent:0,bounds:{minx:0,miny:0,maxx:0,maxy:0}}),p=new q(t,-1,m.dimensions),d[c]=p,0<m.width&&0<m.height&&" "!==v&&function(t,e,r,i){t.addImage(e,r).then(function(t){i.index=t})}(t._textureAtlas,c,m,p)),v=s[f],w(v)?-1===p.index?N(t,v):w(v.textureInfo)&&(v.textureInfo=void 0):(v=new V,s[f]=v),v.textureInfo=p,v.dimensions=p.dimensions,-1!==p.index&&(m=v.billboard,p=t._spareBillboards,w(m)||(0<p.length?m=p.pop():((m=t._billboardCollection.add({collection:t}))._labelDimensions=new g,m._labelTranslate=new g),v.billboard=m),m.show=e._show,m.position=e._position,m.eyeOffset=e._eyeOffset,m.pixelOffset=e._pixelOffset,m.horizontalOrigin=F.LEFT,m.verticalOrigin=e._verticalOrigin,m.heightReference=e._heightReference,m.scale=e.totalScale,m.pickPrimitive=e,m.id=e._id,m.image=c,m.translucencyByDistance=e._translucencyByDistance,m.pixelOffsetScaleByDistance=e._pixelOffsetScaleByDistance,m.scaleByDistance=e._scaleByDistance,m.distanceDisplayCondition=e._distanceDisplayCondition,m.disableDepthTestDistance=e._disableDepthTestDistance,m._batchIndex=e._batchIndex,m.outlineColor=e.outlineColor,m.rotation=e._rotation,e.style===y.FILL_AND_OUTLINE?(m.color=e._fillColor,m.outlineWidth=e.outlineWidth):e.style===y.FILL?(m.color=e._fillColor,m.outlineWidth=0):e.style===y.OUTLINE&&(m.color=b.TRANSPARENT,m.outlineWidth=e.outlineWidth))}e._repositionAllGlyphs=!0}}function R(t,e,r){return e===F.CENTER?-t/2:e===F.RIGHT?-(t+r.x):r.x}var Z=new g,C=new g;class s extends a{constructor(t){super(t),this._backgroundBillboardCollection=new n({scene:this._scene}),this._backgroundBillboardCollection.destroyTextureAtlas=!1,this._billboardCollection=new n({scene:this._scene,batchTable:this._batchTable,enuEnabled:t.enuEnabled}),this._billboardCollection.destroyTextureAtlas=!1,this._billboardCollection._sdf=!0}setGlyphs(t){this.mapboxGlyphs=t}update(t){if(this.mapboxGlyphs){var e=this._billboardCollection,r=this._backgroundBillboardCollection;e.modelMatrix=this.modelMatrix,e.debugShowBoundingVolume=this.debugShowBoundingVolume,r.modelMatrix=this.modelMatrix,r.debugShowBoundingVolume=this.debugShowBoundingVolume;var i=t.context;w(this._textureAtlas)||(this._textureAtlas=new u({context:i}),e.textureAtlas=this._textureAtlas),w(this._backgroundTextureAtlas)||(this._backgroundTextureAtlas=new u({context:i,initialSize:h}),r.textureAtlas=this._backgroundTextureAtlas,function(t,e){var r=document.createElement("canvas");r.width=h.x,r.height=h.y;var i=r.getContext("2d");i.fillStyle="#fff",i.fillRect(0,0,r.width,r.height),t.addImage(x,r).then(function(t){e._whitePixelIndex=t})}(this._backgroundTextureAtlas,this));for(var a=this._labelsToUpdate.length,n=0;n<a;++n){var s,o=this._labelsToUpdate[n];o.isDestroyed()||(s=o._glyphs.length,o._rebindAllGlyphs&&(d(this,o,this.mapboxGlyphs),o._rebindAllGlyphs=!1),o._repositionAllGlyphs&&(function(t){var e=t._glyphs,r=t._renderedText,i=0,a=0,n=[],s=Number.NEGATIVE_INFINITY,o=0,l=1,u=e.length,h=t._backgroundBillboard,d=g.clone(w(h)?t._backgroundPadding:g.ZERO,C);for(d.x/=t._relativeSize,d.y/=t._relativeSize,T=0;T<u;++T)" "===r.charAt(T)?(n.push(i),++l,i=0):(X=(N=e[T]).dimensions,o=Math.max(o,X.height-X.descent),s=Math.max(s,X.descent),i+=X.width-X.bounds.minx,T<u-1&&(i+=e[T+1].dimensions.bounds.minx),a=Math.max(a,i));n.push(i);var f=o+s,m=t.totalScale,v=t._horizontalOrigin,p=t._verticalOrigin,c=0,b=R(n[c],v,d),y=1.2*f,V=y*(l-1),q=a,x=f+V;w(h)&&(q+=2*d.x,x+=2*d.y,h._labelHorizontalOrigin=v),Z.x=b*m;for(var W,N,X,L=!(Z.y=0),P=0,T=0;T<u;++T)" "===r.charAt(T)?(P+=y,b=R(n[++c],v,d),Z.x=b*m,L=!0):(X=(N=e[T]).dimensions,p===j.TOP?(Z.y=X.height-o-d.y,Z.y+=U):p===j.CENTER?Z.y=(V+X.height-o)/2:(p===j.BASELINE?Z.y=V:Z.y=V+s+d.y,Z.y-=U),Z.y=(Z.y-X.descent-P)*m,L&&(Z.x-=U*m,L=!1),w(N.billboard)&&(N.billboard._setTranslate(Z),N.billboard._labelDimensions.x=q,N.billboard._labelDimensions.y=x,N.billboard._labelHorizontalOrigin=v),T<u-1&&(W=e[T+1],Z.x+=(X.width-X.bounds.minx+W.dimensions.bounds.minx)*m));if(w(h)&&0<r.split(" ").join("").length&&(b=v===F.CENTER?-a/2-d.x:v===F.RIGHT?-(a+2*d.x):0,Z.x=b*m,p===j.TOP?Z.y=f-o-s:p===j.CENTER?Z.y=(f-o)/2-s:p===j.BASELINE?Z.y=-d.y-s:Z.y=0,Z.y=Z.y*m,h.width=q,h.height=x,h._setTranslate(Z),h._labelTranslate=g.clone(Z,h._labelTranslate)),t.totalWidth=q*m,t.totalHeight=x*m,t.heightReference===z.CLAMP_TO_GROUND)for(T=0;T<u;++T){var S=(N=e[T]).billboard;w(S)&&(S._labelTranslate=g.clone(Z,S._labelTranslate))}}(o),o._repositionAllGlyphs=!1),s=o._glyphs.length-s,this._totalGlyphCount+=s)}i=0<r.length?l.TRANSLUCENT:this.blendOption;e.blendOption=i,r.blendOption=i,e._highlightColor=this._highlightColor,r._highlightColor=this._highlightColor,this._labelsToUpdate.length=0,r.update(t),e.update(t)}}}e.exports=s},{"../ext/BillboardCollection.js":12}],15:[function(t,e,r){e.exports=function(){var t=Cesium.camera,e=t.positionCartographic,r=Cesium.Math.toDegrees(e.longitude),i=Cesium.Math.toDegrees(e.latitude);console.log("经纬度 : ["+r+","+i+"]"),console.log("地图高度 : "+e.height),console.log("heading :"+Cesium.Math.toDegrees(t.heading)),console.log("pitch :"+Cesium.Math.toDegrees(t.pitch)),console.log("roll :"+Cesium.Math.toDegrees(t.roll))}},{}],16:[function(t,e,r){var i="jssdk_bate@ cesium 2.0.2";e.exports=i,Cesium.setShowLevel=function(e){Cesium.showLevelMap={},Cesium.showLevelLength=e.length;for(let t=0;t<Cesium.showLevelLength;t++){var r=e[t];Cesium.showLevelMap[r]=t}},Cesium.tileSize=256,console.log(i)},{}],17:[function(t,e,r){const i=t("./CesiumTerrainProvider"),a=Cesium.defaultValue,n=Cesium.IonResource;e.exports=function(t){return t=a(t,a.EMPTY_OBJECT),new i({url:n.fromAssetId(1),requestVertexNormals:a(t.requestVertexNormals,!1),requestWaterMask:a(t.requestWaterMask,!1)})}},{"./CesiumTerrainProvider":13}],18:[function(t,e,r){e.exports=class{constructor(){this.otherDisplay=!0,this.layers=[],this.order=[]}addFilterLayer(t){this.layers.push(t)}removeFilterLayerById(t){for(var e=0;e<this.layers.length;e++)this.layers[e].id==t&&this.layers.splice(e,1)}}},{}],19:[function(t,e,r){e.exports=class{constructor(){this.id=null,this.filters={},this.idFilter=null,this.filterStr=null,this.display=!0,this.color=null}addFilterField(t,e){this.filters[t]=e}removeFilterField(t){delete this.filters[t]}}},{}],20:[function(t,e,r){e.exports=class{static createLines(t,e,r,i,a,n){let s=new Image;s.src="",e.glowImage=s;e=e,e=new Cesium.PolylineMaterialAppearance({material:new Cesium.Material({translucent:e.translucent||!1,fabric:{uniforms:{odColor:e.odColor||Cesium.Color.YELLOW,rate:e.rate||.05,t_rate:e.t_rate||120,glint:e.glint||!1,glowImage:e.glowImage},source:o[e.type]()}})});return new Cesium[r]({geometryInstances:t,appearance:e,asynchronous:i,modelMatrix:a,classificationType:n||0})}};let o={};o.TwinkleLineShader=function(){return"czm_material czm_getMaterial(czm_materialInput m){\n   czm_material dm = czm_getDefaultMaterial(m);\n   vec2 st = m.st;\n   vec4 color = odColor;\n   float f = fract(czm_frameNumber / t_rate);\n   color.a = (0.5 - abs(0.5 - st.t)) / 0.5;\n   if(glint){\n     color.rgb += color.rgb * sin( f * 3.1415926 * 2.) * rate;\n   }\n   dm.diffuse = color.rgb;\n   dm.alpha = color.a ;\n   return dm;\n}"},o.RunLineShader=function(){return"czm_material czm_getMaterial(czm_materialInput m){\n   float length = v_czm_batchTable_length;\n   czm_material dm = czm_getDefaultMaterial(m);\n   vec2 repeat= vec2(length * 0.001, 1.0);\n   vec2 st = repeat* m.st;\n   vec4 color = vec4(odColor.rgb,0.);\n   float time = fract(czm_frameNumber / t_rate) ;\n   vec4 tColor = texture2D(glowImage, vec2(fract(st.s -time),st.t));\n   dm.diffuse = tColor.a == 0.0 ?color.rgb : tColor.rgb * color.rgb;\n   dm.alpha = tColor.a == 0.0 ? odColor.a : tColor.a;\n   return dm;\n}"},o.RunLineShader2=function(){return"czm_material czm_getMaterial(czm_materialInput m){\n   float length = v_czm_batchTable_length;\n   czm_material dm = czm_getDefaultMaterial(m);\n   vec2 repeat= vec2(1.0, 1.0);\n   vec2 st = repeat* m.st;\n   vec4 color = vec4(odColor.rgb,0.);\n   float time = fract(czm_frameNumber / t_rate) ;\n   vec4 tColor = texture2D(glowImage, vec2(fract(st.s -time),st.t));\n   dm.diffuse = tColor.a == 0.0 ?color.rgb : tColor.rgb * color.rgb;\n   dm.alpha = tColor.a == 0.0 ? odColor.a : tColor.a;\n   return dm;\n}"},o.RunLineShader1=function(){return"czm_material czm_getMaterial(czm_materialInput m){\n   czm_material dm = czm_getDefaultMaterial(m);\n   vec2 st = m.st;\n   vec4 color = vec4(odColor.rgb,0.);\n   float time = fract(czm_frameNumber / t_rate) + rate;\n   float time1 = time + rate;\n   if(st.s > time && st.s < time1){\n     float ff = st.s - time;     color.a =  ff / rate ;\n     color.a *= ( .5 - abs(0.5 - st.t))/0.5;\n   }\n   if(time1 > 1.&& st.s < (time1 - 1.)){\n     color.a =  (st.s + 1. - time) / rate ;\n     color.a *= ( .5 - abs(0.5 - st.t))/0.5;\n   }\n   dm.diffuse = color.rgb;\n   dm.alpha = color.a ;\n   return dm;\n}"}},{}],21:[function(t,e,r){e.exports=class i{static createPolygonDiffuse(t){var e=new i(t);return t.viewer.scene.primitives.add(e),e}constructor(t){this.viewer=t.viewer||window.viewer,t.positions||console.log("输入控制点为空"),this.controlPoints=t.positions,this.radius=t.radius||1e3,this.center=t.center||this.computeCenter(this.controlPoints),0<this.radius&&!this.controlPoints&&(this.controlPoints=this.computeEllipsePosition_pd(this.center,this.radius,270,-90)),this.translucent=t.translucent||!1,this.height=t.extrudedHeight||500,this.direction=t.direction||-1,this.color=t.color||new Cesium.Color(.5,.8,1,1.3),this.startTime=2,this.angle_delta=Math.PI/180,this.stepCount=t.speed||1,this.xyScale=2,this.zScale=.01,this.mScale=Cesium.Matrix4.fromUniformScale(1),this.modelMatrix=Cesium.Matrix4.fromUniformScale(1),this.polyline=null,this.drawPolygon()}drawPolygon(){this.destroyPrimitive(),this.draw()}destroyPrimitive(){this.polyline&&this.viewer.scene.primitives.remove(this.polyline)}destroy(){for(var t in this.destroyPrimitive(),this.viewer.scene.primitives.remove(this),this)delete this[t]}createGeometry(t,e,r,i){return t=new Float64Array(t),e=new Float32Array(e),r=new Float32Array(r),i=new Uint16Array(i),new Cesium.Geometry({attributes:{position:new Cesium.GeometryAttribute({componentDatatype:Cesium.ComponentDatatype.DOUBLE,componentsPerAttribute:3,values:t}),normal:new Cesium.GeometryAttribute({componentDatatype:Cesium.ComponentDatatype.FLOAT,componentsPerAttribute:3,values:e}),st:new Cesium.GeometryAttribute({componentDatatype:Cesium.ComponentDatatype.FLOAT,componentsPerAttribute:2,values:r})},indices:i,primitiveType:Cesium.PrimitiveType.TRIANGLES,boundingSphere:Cesium.BoundingSphere.fromVertices(t)})}draw(){var t=this.computePositions_pd(this.controlPoints,this.height);this.positions=t.pos,this.normals=t.normals,this.sts=t.sts,this.indices=t.indices,t=new Cesium.GeometryInstance({geometry:this.createGeometry(this.positions,this.normals,this.sts,this.indices)}),this.polyline=new Cesium.Primitive({geometryInstances:t,appearance:new Cesium.MaterialAppearance({material:new Cesium.Material({translucent:this.translucent,fabric:{uniforms:{u_color:this.color},source:this.getFS(this.translucent)}}),vertexShaderSource:this.getVertexShaderSource1(),fragmentShaderSource:this.getFragmentShaderSource1()}),asynchronous:!1}),this.viewer.scene.primitives.add(this.polyline)}update(t){let e=(t=t.frameNumber/this.stepCount)-Math.floor(t);this.polyline&&(e=e<.01?.01:e,this.mScale[0]=this.mScale[5]=e*this.xyScale,this.mScale[10]=1.1-e,this.polyline.modelMatrix=this.scaleXYZ(this.center,this.mScale))}addHeight_pd(t,e){let r=Cesium.Cartographic.fromCartesian(t);return r.height+=e,Cesium.Cartographic.toCartesian(r)}computeCenter(t){let e=Number.MAX_VALUE,r=Number.MAX_VALUE,i=Number.MIN_VALUE,a=Number.MIN_VALUE;var n,s,o;for(o in t)n=(s=Cesium.Cartographic.fromCartesian(t[o])).longitude,s=s.latitude,n<e&&(e=n),n>i&&(i=n),s<r&&(r=s),s>a&&(a=s);return Cesium.Cartesian3.fromRadians(e+(i-e)/2,r+(a-r)/2)}computeEllipsePosition_pd(t,e,r,i,a){let n=[];var s=a||360,o=(i-r)*Math.PI/180/s,l=r*Math.PI/180,u=Cesium.Transforms.eastNorthUpToFixedFrame(t);for(let t=0;t<s;t++){var h=l+o*t,h=new Cesium.Cartesian3(Math.sin(h)*e,Math.cos(h)*e,0);n.push(Cesium.Matrix4.multiplyByPoint(u,h,new Cesium.Cartesian3))}return n}computePositions_pd(e,t){var r,i=e.length;let a=[];for(r in e)a.push(this.addHeight_pd(e[r],t));let n=[],s=[],o=[],l=[];for(let t=0;t<i;t++){var u=(t+1)%i;n.push(e[t].x,e[t].y,e[t].z),n.push(e[u].x,e[u].y,e[u].z),n.push(a[u].x,a[u].y,a[u].z),n.push(a[t].x,a[t].y,a[t].z),l.push(0,0,1),l.push(0,0,1),l.push(0,0,1),l.push(0,0,1),s.push(0,0,1,0,1,1,0,1);var h=4*t,u=2+h;o.push(u,3+h,h,h,1+h,u)}return{pos:n,normals:l,sts:s,indices:o}}scaleXYZ(t,e){var r=Cesium.Transforms.eastNorthUpToFixedFrame(t),t=Cesium.Matrix4.inverse(r,new Cesium.Matrix4),t=Cesium.Matrix4.multiply(e,t,new Cesium.Matrix4);return Cesium.Matrix4.multiply(r,t,new Cesium.Matrix4)}getVertexShaderSource1(){return"attribute vec3 position3DHigh;       attribute vec3 position3DLow;       attribute vec3 normal;       attribute vec2 st;       attribute float batchId;       varying vec2 v_st;       varying vec3 v_positionEC;       void main()       {          vec4 p = czm_translateRelativeToEye(position3DHigh,position3DLow);          v_positionEC = (czm_modelViewRelativeToEye * p).xyz;          v_st=st;          gl_Position = czm_modelViewProjectionRelativeToEye * p;       }       "}getFragmentShaderSource1(){return`
      varying vec3 v_positionEC;
      varying vec2 v_st;
      void main(){
        gl_FragColor = xh_getMaterial(v_st);
      }
      `}getFS(t){let e="";return e+="uniform vec4 u_color;\nvec4 xh_getMaterial(vec2 st){    float alpha = pow(1. - st.t, 4.);\n",e+=t?"    vec4 color = vec4(u_color.rgb * u_color.a, alpha);":"    vec4 color = vec4(u_color.rgb * u_color.a, 1.);",e+="    return color;\n}\n",e}}},{}],22:[function(t,e,r){e.exports=class i{static createRidingLantern(t){return new i(t)}constructor(t){this.viewer=t.viewer||window.viewer,this.positions=null,this.normals=null,this.sts=null,this.indices=null,this.controlPoints=t.positions,this.color=t.color,this.u_tcolor=t.u_tcolor||Cesium.Color.YELLOW,this.height=t.height||500,this.speed=t.speed||600,this.direction=t.direction||-1,this.translucent=t.translucent||!1,this.type=t.type||1,this.draw()}draw(){var t=this.computePositions_dws(this.controlPoints,this.height);this.positions=t.pos,this.normals=t.normals,this.sts=t.sts,this.indices=t.indices,t=this.createGeometry(this.positions,this.normals,this.sts,this.indices),t=new Cesium.GeometryInstance({geometry:t}),this.polyline=new Cesium.Primitive({geometryInstances:t,appearance:new Cesium.MaterialAppearance({material:new Cesium.Material({translucent:this.translucent,fabric:{uniforms:{u_color:this.color,speed:this.speed,direction:this.direction,u_tcolor:this.u_tcolor},source:this.createFS(this.translucent)}}),vertexShaderSource:this.getVertexShaderSource1(),fragmentShaderSource:this.getFragmentShaderSource1()}),asynchronous:!1}),this.viewer.scene.primitives.add(this.polyline)}createGeometry(t,e,r,i){return t=new Float64Array(t),e=new Float32Array(e),r=new Float32Array(r),i=new Uint16Array(i),new Cesium.Geometry({attributes:{position:new Cesium.GeometryAttribute({componentDatatype:Cesium.ComponentDatatype.DOUBLE,componentsPerAttribute:3,values:t}),normal:new Cesium.GeometryAttribute({componentDatatype:Cesium.ComponentDatatype.FLOAT,componentsPerAttribute:3,values:e}),st:new Cesium.GeometryAttribute({componentDatatype:Cesium.ComponentDatatype.FLOAT,componentsPerAttribute:2,values:r})},indices:i,primitiveType:Cesium.PrimitiveType.TRIANGLES,boundingSphere:Cesium.BoundingSphere.fromVertices(t)})}computePositions_dws(e,t){var r,i=e.length;let a=[];for(r in e)a.push(this.addHeight(e[r],t));let n=[],s=[],o=[],l=[];for(let t=0;t<i-1;t++){var u=t+1;n.push(e[t].x,e[t].y,e[t].z),n.push(e[u].x,e[u].y,e[u].z),n.push(a[u].x,a[u].y,a[u].z),n.push(a[t].x,a[t].y,a[t].z),l.push(0,0,1),l.push(0,0,1),l.push(0,0,1),l.push(0,0,1),s.push(0,0,1,0,1,1,0,1);var h=4*t,u=2+h;o.push(h,1+h,u,u,3+h,h)}return{pos:n,normals:l,sts:s,indices:o}}addHeight(e,r){if(r=r||0,e.hasOwnProperty("height"))return e.height+=r,e;{let t=Cesium.Cartographic.fromCartesian(e);return t.height+=r,Cesium.Cartographic.toCartesian(t)}}createFS(t){let e="";return 1===this.type?(e+="czm_material czm_getMaterial( czm_materialInput cmi )\n{\n   czm_material material = czm_getDefaultMaterial(cmi);\n   vec2 st = cmi.st;    float t = fract(czm_frameNumber/speed) * direction;\n    vec2 st1 = vec2(st.s,fract(st.t - t));\n    vec4 color = vec4(0.,0.,0.,0.);\n    float tt = st1.t;\n    float ss = st1.s ;\n",e+=t?"    float alpha = tt * 2.;\n    color = vec4(u_color.rgb, 1.0);\n   material.diffuse = color.rgb;\n   material.alpha = 1.0;\n    return material;\n}\n":"    color = vec4(u_color.rgb,1.0);   material.diffuse = color.rgb;\n   material.alpha = 1.0;\n    return material;\n}\n"):(e+="czm_material czm_getMaterial( czm_materialInput cmi )\n{\n   czm_material material = czm_getDefaultMaterial(cmi);\n   vec2 st = cmi.st;\n    float t = fract(czm_frameNumber/speed) * direction;\n    vec2 st1 = vec2(fract(st.s - t),st.t);\n    vec4 color = vec4(0.,0.,0.,0.);\n    float alpha = 1.-st.t;\n    float value = fract(st1.s/0.25);\n    alpha *= sin(value * 3.1415926);\n",e+=t?"    color = vec4(u_color.rgb, 1.0);   material.diffuse = color.rgb;\n   material.alpha = 1.0;\n    return material;\n}\n":"    color = vec4(u_color.rgb,1.0);\n   material.diffuse = color.rgb;\n   material.alpha = 1.0;\n    return material;\n}\n"),e}getVertexShaderSource1(){return"attribute vec3 position3DHigh;          attribute vec3 position3DLow;          attribute vec3 normal;          attribute vec2 st;          attribute float batchId;          varying vec2 v_st;          varying vec3 v_normalEC;          varying vec3 v_positionEC;          void main()          {              vec4 p = czm_translateRelativeToEye(position3DHigh,position3DLow);              v_positionEC = (czm_modelViewRelativeToEye * p).xyz;              v_normalEC = czm_normal * normal;              v_st=st;              gl_Position = czm_modelViewProjectionRelativeToEye * p;          }          "}getFragmentShaderSource1(){return"varying vec3 v_positionEC;\n    varying vec3 v_normalEC;\n    varying vec2 v_st;\n    void main()\n    {\n        vec3 positionToEyeEC = -v_positionEC;\n        vec3 normalEC = normalize(v_normalEC);\n    #ifdef FACE_FORWARD\n        normalEC = faceforward(normalEC, vec3(0.0, 0.0, 1.0), -normalEC);\n    #endif\n        czm_materialInput materialInput;\n        materialInput.normalEC = normalEC;\n        materialInput.positionToEyeEC = positionToEyeEC;\n        materialInput.st = v_st;\n        czm_material material = czm_getMaterial(materialInput);\n        gl_FragColor = vec4(material.diffuse + material.emission, material.alpha);\n    }"}}},{}],23:[function(t,e,r){e.exports=class i{static createRidingLantern(t){return new i(t).polyline}constructor(t){this.viewer=t.viewer||window.viewer,this.positions=null,this.normals=null,this.sts=null,this.indices=null,this.geometrys=t.positions,this.color=t.color,this.u_tcolor=t.u_tcolor||Cesium.Color.YELLOW,this.height=t.height||500,this.speed=t.speed||600,this.direction=t.direction||-1,this.translucent=t.translucent||!1,this.type=t.type||1,this.createPrimitive()}createPrimitive(){this.polyline=new Cesium.Primitive({geometryInstances:[],appearance:new Cesium.MaterialAppearance({material:new Cesium.Material({translucent:this.translucent,fabric:{uniforms:{u_color:this.color,speed:this.speed,direction:this.direction,u_tcolor:this.u_tcolor},source:this.createFS(this.translucent)}}),vertexShaderSource:this.getVertexShaderSource1(),fragmentShaderSource:this.getFragmentShaderSource1()}),asynchronous:!1})}createGeometryInstances(){let e=[];for(let t=0;t<this.geometrys.length;t++){var r=this.geometrys[t],r=this.computePositions_dws(r,this.height);this.positions=r.pos,this.normals=r.normals,this.sts=r.sts,this.indices=r.indices,r=this.createGeometry(this.positions,this.normals,this.sts,this.indices),r=new Cesium.GeometryInstance({geometry:r}),e.push(r)}return e}createGeometry(t,e,r,i){return t=new Float64Array(t),e=new Float32Array(e),r=new Float32Array(r),i=new Uint16Array(i),new Cesium.Geometry({attributes:{position:new Cesium.GeometryAttribute({componentDatatype:Cesium.ComponentDatatype.DOUBLE,componentsPerAttribute:3,values:t}),normal:new Cesium.GeometryAttribute({componentDatatype:Cesium.ComponentDatatype.FLOAT,componentsPerAttribute:3,values:e}),st:new Cesium.GeometryAttribute({componentDatatype:Cesium.ComponentDatatype.FLOAT,componentsPerAttribute:2,values:r})},indices:i,primitiveType:Cesium.PrimitiveType.TRIANGLES,boundingSphere:Cesium.BoundingSphere.fromVertices(t)})}computePositions_dws(e,t){var r,i=e.length;let a=[];for(r in e)a.push(this.addHeight(e[r],t));let n=[],s=[],o=[],l=[];for(let t=0;t<i-1;t++){var u=t+1;n.push(e[t].x,e[t].y,e[t].z),n.push(e[u].x,e[u].y,e[u].z),n.push(a[u].x,a[u].y,a[u].z),n.push(a[t].x,a[t].y,a[t].z),l.push(0,0,1),l.push(0,0,1),l.push(0,0,1),l.push(0,0,1),s.push(0,0,1,0,1,1,0,1);var h=4*t,u=2+h;o.push(h,1+h,u,u,3+h,h)}return{pos:n,normals:l,sts:s,indices:o}}addHeight(e,r){if(r=r||0,e.hasOwnProperty("height"))return e.height+=r,e;{let t=Cesium.Cartographic.fromCartesian(e);return t.height+=r,Cesium.Cartographic.toCartesian(t)}}createFS(t){let e="";return 1===this.type?(e+="czm_material czm_getMaterial( czm_materialInput cmi )\n{\n   czm_material material = czm_getDefaultMaterial(cmi);\n   vec2 st = cmi.st;    float t = fract(czm_frameNumber/speed) * direction;\n    vec2 st1 = vec2(st.s,fract(st.t - t));\n    vec4 color = vec4(0.,0.,0.,0.);\n    float tt = 0.5 - abs(0.5 - st1.t);\n    float ss = st1.s ;\n",e+=t?"    float alpha = tt * 2.;\n    color = vec4(u_color.rgb * u_color.a, alpha * 1.2);\n   material.diffuse = color.rgb;\n   material.alpha = color.a;\n    return material;\n}\n":"    color = vec4(u_color.rgb * u_color.a * pow(tt,0.25),1.);   material.diffuse = color.rgb;\n   material.alpha = color.a;\n    return material;\n}\n"):(e+="czm_material czm_getMaterial( czm_materialInput cmi )\n{\n   czm_material material = czm_getDefaultMaterial(cmi);\n   vec2 st = cmi.st;\n    float t = fract(czm_frameNumber/speed) * direction;\n    vec2 st1 = vec2(fract(st.s - t),st.t);\n    vec4 color = vec4(0.,0.,0.,0.);\n    float alpha = 1.-st.t;\n    float value = fract(st1.s/0.25);\n    alpha *= sin(value * 3.1415926);\n",e+=t?"    color = vec4(u_color.rgb * u_color.a, alpha * 1.2);   material.diffuse = color.rgb;\n   material.alpha = color.a;\n    return material;\n}\n":"    color = vec4(u_color.rgb * u_color.a,alpha);\n   material.diffuse = color.rgb;\n   material.alpha = color.a;\n    return material;\n}\n"),e}getVertexShaderSource1(){return"attribute vec3 position3DHigh;          attribute vec3 position3DLow;          attribute vec3 normal;          attribute vec2 st;          attribute float batchId;          varying vec2 v_st;          varying vec3 v_normalEC;          varying vec3 v_positionEC;          void main()          {              vec4 p = czm_translateRelativeToEye(position3DHigh,position3DLow);              v_positionEC = (czm_modelViewRelativeToEye * p).xyz;              v_normalEC = czm_normal * normal;              v_st=st;              gl_Position = czm_modelViewProjectionRelativeToEye * p;          }          "}getFragmentShaderSource1(){return"varying vec3 v_positionEC;\n    varying vec3 v_normalEC;\n    varying vec2 v_st;\n    void main()\n    {\n        vec3 positionToEyeEC = -v_positionEC;\n        vec3 normalEC = normalize(v_normalEC);\n    #ifdef FACE_FORWARD\n        normalEC = faceforward(normalEC, vec3(0.0, 0.0, 1.0), -normalEC);\n    #endif\n        czm_materialInput materialInput;\n        materialInput.normalEC = normalEC;\n        materialInput.positionToEyeEC = positionToEyeEC;\n        materialInput.st = v_st;\n        czm_material material = czm_getMaterial(materialInput);\n        gl_FragColor = vec4(material.diffuse + material.emission, material.alpha);\n    }"}}},{}],24:[function(t,e,r){e.exports=class n{static createTower(t,e,r,i,a){return new n(t,e,r,i,a)}constructor(t,e,r,i,a){this.viewer=t,this.center=e,this.extrudedHeight=i||100,this.topRadius=r/100,this.topRadius=1<this.topRadius?1:this.topRadius,this.u_color=a||new Cesium.Color(1,1,0,1),this.inner_controlPoints=this.computeEllipsePosition(e,.7*r,120),this.outer_controlPoints=this.computeEllipsePosition(e,r,120),this.circular_clone_topPoints=this.computeEllipsePosition(e,this.topRadius,120),this.circlePoints_2=this.computeEllipsePosition(e,2*r,120),this.polyline=null,this.polyline1=null,this.polyline2=null,this.polyline3=null,this.ringCanvas=this.drawRingCanvas(),this.gradientCircle=this.drawGradientCircle();let n=new Image;n.src="",n.onload=function(){this.image=this.drawCanvas(n),this.draw()}.bind(this)}draw(){this.addOuter(),this.addInner(),this.addCircle(),this.addRing()}destroy(){for(var t in this.polyline&&this.viewer.scene.primitives.remove(this.polyline),this.polyline1&&this.viewer.scene.primitives.remove(this.polyline1),this.polyline2&&this.viewer.scene.primitives.remove(this.polyline2),this.polyline3&&this.viewer.scene.primitives.remove(this.polyline3),this)delete this[t]}addOuter(){var t=this.createParticles_efa_cylinder(this.outer_controlPoints,this.extrudedHeight,this.circular_clone_topPoints);this.polyline=new Cesium.Primitive({geometryInstances:t,appearance:new Cesium.EllipsoidSurfaceAppearance({material:new Cesium.Material({fabric:{uniforms:{u_color:this.u_color,image:this.image},source:this.getSource()}})}),asynchronous:!1}),this.viewer.scene.primitives.add(this.polyline)}addInner(){var t=this.createParticles_efa_cylinder(this.inner_controlPoints,this.extrudedHeight,this.circular_clone_topPoints,this.v_color),e=new Cesium.EllipsoidSurfaceAppearance({material:new Cesium.Material({fabric:{uniforms:{u_color:this.u_color},source:this.cylinderGauss1_vtxf()}})});this.polyline1=new Cesium.Primitive({geometryInstances:t,appearance:e,asynchronous:!1}),this.viewer.scene.primitives.add(this.polyline1)}addCircle(){var t;Cesium.Cartographic.fromCartesian(this.center).height<1?(t=this.createCircleInstance(this.circlePoints_2,!1),this.polyline2=new Cesium.GroundPrimitive({geometryInstances:t,appearance:new Cesium.EllipsoidSurfaceAppearance({material:new Cesium.Material({fabric:{uniforms:{u_color:this.u_color,image:this.gradientCircle},source:this.particlesGradient()}})}),asynchronous:!1})):(t=this.createCircleInstance(this.circlePoints_2,!0),this.polyline2=new Cesium.Primitive({geometryInstances:t,appearance:new Cesium.EllipsoidSurfaceAppearance({material:new Cesium.Material({fabric:{uniforms:{u_color:this.u_color,image:this.gradientCircle},source:this.particlesGradient()}})}),asynchronous:!1})),this.viewer.scene.primitives.add(this.polyline2)}addRing(){var t;Cesium.Cartographic.fromCartesian(this.center).height<1?(t=this.createCircleInstance(this.circlePoints_2,!1),this.polyline3=new Cesium.GroundPrimitive({geometryInstances:t,appearance:new Cesium.EllipsoidSurfaceAppearance({material:new Cesium.Material({fabric:{uniforms:{u_color:this.u_color,image:this.ringCanvas},source:this.particlesRingScan()}})}),asynchronous:!1})):(t=this.createCircleInstance(this.circlePoints_2,!0),this.polyline3=new Cesium.Primitive({geometryInstances:t,appearance:new Cesium.EllipsoidSurfaceAppearance({material:new Cesium.Material({fabric:{uniforms:{u_color:this.u_color,image:this.ringCanvas},source:this.particlesRingScan()}})}),asynchronous:!1})),this.viewer.scene.primitives.add(this.polyline3)}drawCanvas(t){let e=document.createElement("canvas");e.width=64,e.height=256;let r=e.getContext("2d");return r.clearRect(0,0,64,256),r.drawImage(t,0,0),r.drawImage(t,33,0),e}drawRingCanvas(){let t=document.createElement("canvas");t.width=512,t.height=512;let e=t.getContext("2d");return e.fillStyle="rgba(255,255,255,0)",e.strokeStyle="rgba(255, 255, 255,255)",e.setLineDash([50,50]),e.lineWidth=30,e.beginPath(),e.arc(256,256,150,0,2*Math.PI,!0),e.stroke(),e.restore(),t}drawGradientCircle(){let t=document.createElement("canvas");t.width=512,t.height=512;let e=t.getContext("2d"),r=e.createRadialGradient(256,256,0,256,256,256);return r.addColorStop(.1,"rgba(255, 255, 255, 1.0)"),r.addColorStop(.2,"rgba(255, 255, 255, 0.0)"),r.addColorStop(.3,"rgba(255, 255, 255, 0.9)"),r.addColorStop(.5,"rgba(255, 255, 255, 0.0)"),r.addColorStop(.9,"rgba(255, 255, 255, 0.2)"),r.addColorStop(1,"rgba(255, 255, 255, 1.0)"),e.clearRect(0,0,512,512),e.beginPath(),e.arc(256,256,256,0,2*Math.PI,!0),e.fillStyle=r,e.fill(),e.restore(),t}cylinderGauss1_vtxf(){return"uniform vec4 u_color;\nczm_material czm_getMaterial(czm_materialInput materialInput){    czm_material material = czm_getDefaultMaterial(materialInput);\n    vec2 st = materialInput.st;\n    float powerRatio = 1./(fract(czm_frameNumber / 30.0) +  1.) ;\n    float alpha = pow(1. - st.t,powerRatio);\n    vec4 color = vec4(u_color.rgb, alpha*u_color.a);    material.diffuse = color.rgb;\n    material.alpha = color.a;\n    return material;\n}\n"}particlesRingScan(){return"czm_material czm_getMaterial(czm_materialInput materialInput){    czm_material material = czm_getDefaultMaterial(materialInput);\n    vec2 st = materialInput.st;\n    vec2 center = st - vec2(0.5,0.5);\n    float time = -czm_frameNumber * 3.1415926 / 180.;\n    float sin_t = sin(time);\n    float cos_t = cos(time);\n    vec2 center_rotate = vec2(center.s*cos_t-center.t*sin_t+0.5,center.s*sin_t+center.t*cos_t+0.5);\n    vec4 color = texture2D(image,center_rotate);\n    vec3 tColor = color.rgb * u_color.rgb;\n    tColor *= u_color.a;\n    material.diffuse = tColor;\n    float length = 2. - length(center)/0.5;\n    material.alpha = color.a * pow(length, 0.5);\n    return material;\n}\n"}particlesGradient(){return"czm_material czm_getMaterial(czm_materialInput materialInput){    czm_material material = czm_getDefaultMaterial(materialInput);\n    vec4 tColor = u_color;\n    vec2 st = materialInput.st;\n    vec2 center = st - vec2(0.5,0.5);\n    float length = length(center)/0.5;\n    float time = 1. - abs(czm_frameNumber / 360. - 0.5);\n    float param = 1. - step(length, 0.6);\n    float scale = param * length;\n    float alpha = param * (1.0 - abs(scale - 0.8) / 0.2);\n    float param1 = step(length, 0.7);\n    float scale1 = param1 * length;\n    alpha += param1 * (1.0 - abs(scale1 - 0.35) / 0.35);\n    material.diffuse = u_color.rgb * vec3(u_color.a);\n    material.alpha = pow(alpha, 4.0);\n    return material;\n}\n"}getSource(){return"uniform vec4 u_color;\nczm_material czm_getMaterial(czm_materialInput materialInput){    czm_material material = czm_getDefaultMaterial(materialInput);\n    vec2 st = materialInput.st;\n    float time = fract(czm_frameNumber / 90.) ;\n    vec2 new_st = fract(st-vec2(time,time));\n    vec4 color = texture2D(image,new_st);\n    vec3 diffuse = color.rgb;\n    float alpha = color.a;\n    diffuse *= u_color.rgb;\n    alpha *= u_color.a;\n    alpha *= u_color.a;\n    material.diffuse = diffuse;\n    material.alpha = alpha * pow(1. - st.t,u_color.a);\n    return material;\n}\n"}computeEllipsePosition(t,e,r){let i=[];var a=2*Math.PI/r,n=Cesium.Transforms.eastNorthUpToFixedFrame(t),s=2*Math.PI*270/360;for(let t=0;t<r;t++){var o=s-a*t,o=new Cesium.Cartesian3(Math.sin(o)*e,Math.cos(o)*e,0);i.push(Cesium.Matrix4.multiplyByPoint(n,o,new Cesium.Cartesian3))}return i.push(i[0]),i}createCircleInstance(t,e){return e=new Cesium.PolygonGeometry({polygonHierarchy:new Cesium.PolygonHierarchy(t),perPositionHeight:e}),new Cesium.GeometryInstance({geometry:e})}createParticles_efa_cylinder(t,e,r,i){i=i||new Cesium.Color(.5,.8,1,2);let a=t.slice();var n=t.length,s=2*n;let o=[];var l,u=1/(n-1);let h=[],d=[];for(let t=0;t<n;t++){d.push(this.addHeight(r[t],e)),o.push(t*u),o.push(0);var f=t+1,m=(t+1)%n,f=s-f;h.push(f-1,f,t),h.push(t,m,f-1)}for(l in d)a.push(d[n-l-1]),o.push(1-l*u),o.push(1);let v=new Cesium.PolygonGeometry({polygonHierarchy:new Cesium.PolygonHierarchy(a),perPositionHeight:!0});return v=Cesium.PolygonGeometry.createGeometry(v),v.indices=h,v.attributes.st.values=o,new Cesium.GeometryInstance({geometry:v,attributes:{color:Cesium.ColorGeometryInstanceAttribute.fromColor(i)}})}addHeight(t,e){e=e||0;let r=Cesium.Cartographic.fromCartesian(t);return r.height+=e,Cesium.Cartographic.toCartesian(r)}}},{}],25:[function(t,e,r){"use strict";const i=e.exports={};i.LabelCollectionExt=t("./ext/LabelCollectionExt"),i.BillboardCollection=t("./ext/BillboardCollection"),i.CesiumTerrainProvider=t("./ext/CesiumTerrainProvider"),i.createWorldTerrain=t("./ext/createWorldTerrain"),i.MapPosition=t("./ext/MapPosition"),i.LineGlow=t("./gloweffect/LineGlow"),i.TowerGlow=t("./gloweffect/TowerGlow"),i.RidingLanternGlow=t("./gloweffect/RidingLanternGlow"),i.PolygonDiffuseGlow=t("./gloweffect/PolygonDiffuseGlow"),i.RidingLanternGlowPrimitive=t("./gloweffect/RidingLanternGlowPrimitive"),i.PointLight=t("./lighteffect/PointLight"),i.RadarLight=t("./lighteffect/RadarLight"),i.WaveLight=t("./lighteffect/WaveLight"),i.UpDownScanLight=t("./lighteffect/UpDownScanLight"),i.Wave3dTileLight=t("./lighteffect/Wave3dTileLight"),i.Radar3dTileLight=t("./lighteffect/Radar3dTileLight"),i.ModelShaderFactory=t("./lighteffect/ModelShaderFactory"),i.ModelCollectionShaderFactory=t("./lighteffect/ModelCollectionShaderFactory"),i.LabelCollectionExt=t("./ext/LabelCollectionExt"),i.VectorTileServiceImageryProvider=t("./layer/vector/VectorTileServiceImageryProvider"),i.LabelTileServiceImageryProvider=t("./layer/label/LabelTileServiceImageryProvider"),i.HouseTileServiceImageryProvider=t("./layer/house/HouseTileServiceImageryProvider"),i.EnvelopeModelTileServiceImageryProvider=t("./layer/envelope/EnvelopeModelTileServiceImageryProvider"),i.ModelTileServiceImageryProvider=t("./layer/model/ModelTileServiceImageryProvider"),i.ImageTileProvider=t("./layer/image/ImageTileProvider"),i.HillShaderTileServiceImageryProvider=t("./layer/hillshader/HillShaderTileServiceImageryProvider"),i.WebMapTileServiceImageryProvider=t("./layer/wmts/WebMapTileServiceImageryProvider"),i.Quadtree3DTilesProvider=t("./layer/3dtiles/Quadtree3DTilesProvider"),i.DataSource=t("./layer/datasource/DataSource"),i.URLDataSource=t("./layer/datasource/URLDataSource"),i.LocalDataSource=t("./layer/datasource/LocalDataSource"),i.Filter=t("./filter/Filter"),i.FilterLayer=t("./filter/FilterLayer"),i.GlyphSource=t("./layer/label/glyph/GlyphSource"),i.Overlay=t("./overlay/Overlay"),i.BeziterLine=t("./utils/BeziterLine"),i.Wkt=t("./utils/Wkt"),i.Geojson=t("./utils/Geojson"),i.RGBWorldTerrainProvider=t("./layer/terrain/RGBWorldTerrainProvider"),i.Drag=t("./utils/Drag"),i.DragModel=t("./utils/DragModel"),i.TerrainClip=t("./terrain/TerrainClip"),i.ElevationAnalysis=t("./analysis/ElevationAnalysis"),i.AspectAnalysis=t("./analysis/AspectAnalysis"),i.SlopeAnalysis=t("./analysis/SlopeAnalysis"),i.ViewShedAnalysis=t("./analysis/ViewShedAnalysis"),i.TilesetClip=t("./tileset/TilesetClip"),i.TilesetFlat=t("./tileset/TilesetFlat")},{"./analysis/AspectAnalysis":8,"./analysis/ElevationAnalysis":9,"./analysis/SlopeAnalysis":10,"./analysis/ViewShedAnalysis":11,"./ext/BillboardCollection":12,"./ext/CesiumTerrainProvider":13,"./ext/LabelCollectionExt":14,"./ext/MapPosition":15,"./ext/createWorldTerrain":17,"./filter/Filter":18,"./filter/FilterLayer":19,"./gloweffect/LineGlow":20,"./gloweffect/PolygonDiffuseGlow":21,"./gloweffect/RidingLanternGlow":22,"./gloweffect/RidingLanternGlowPrimitive":23,"./gloweffect/TowerGlow":24,"./layer/3dtiles/Quadtree3DTilesProvider":26,"./layer/datasource/DataSource":29,"./layer/datasource/LocalDataSource":30,"./layer/datasource/URLDataSource":31,"./layer/envelope/EnvelopeModelTileServiceImageryProvider":33,"./layer/hillshader/HillShaderTileServiceImageryProvider":35,"./layer/house/HouseTileServiceImageryProvider":39,"./layer/image/ImageTileProvider":40,"./layer/label/LabelTileServiceImageryProvider":43,"./layer/label/glyph/GlyphSource":54,"./layer/model/ModelTileServiceImageryProvider":60,"./layer/terrain/RGBWorldTerrainProvider":63,"./layer/vector/VectorTileServiceImageryProvider":66,"./layer/wmts/WebMapTileServiceImageryProvider":72,"./lighteffect/ModelCollectionShaderFactory":74,"./lighteffect/ModelShaderFactory":75,"./lighteffect/PointLight":76,"./lighteffect/Radar3dTileLight":77,"./lighteffect/RadarLight":78,"./lighteffect/UpDownScanLight":79,"./lighteffect/Wave3dTileLight":80,"./lighteffect/WaveLight":81,"./overlay/Overlay":88,"./terrain/TerrainClip":91,"./tileset/TilesetClip":93,"./tileset/TilesetFlat":95,"./utils/BeziterLine":96,"./utils/Drag":99,"./utils/DragModel":100,"./utils/Geojson":102,"./utils/Wkt":110}],26:[function(t,e,r){const h=Cesium.combine,s=Cesium.Credit,o=Cesium.defaultValue,d=Cesium.defined,l=Cesium.DeveloperError,u=Cesium.Event,f=Array.isArray,m=Cesium.Rectangle,v=Cesium.Resource,p=Cesium.WebMercatorTilingScheme,c=Cesium.when,b=Cesium.TimeDynamicImagery,y=Cesium.Cesium3DTile,V=Cesium.Matrix4;var q={service:"WMTS",version:"1.0.0",request:"GetTile"};e.exports=class{constructor(t,e,r){if(this.viewer=t,e=o(e,o.EMPTY_OBJECT),this.id=Math.random(),!d(e.url))throw new l("options.url is required.");var i=v.createIfNeeded(e.url),a=e.style,t=e.tileMatrixSetID;0<=i.url.indexOf("{")?(i.setTemplateValues({style:a,Style:a,TileMatrixSet:t}),this._useKvp=!1):(i.setQueryParameters(q),this._useKvp=!0),this._resource=i,this._layer=e.layer,this._style=a,this._tileMatrixSetID=t,this._tileMatrixLabels=e.tileMatrixLabels,this._format=o(e.format,"image/jpeg"),this._tileDiscardPolicy=e.tileDiscardPolicy,this._tilingScheme=d(e.tilingScheme)?e.tilingScheme:new p({ellipsoid:e.ellipsoid}),this._tileWidth=o(e.tileWidth,256),this._tileHeight=o(e.tileHeight,256),this._minimumLevel=o(e.minimumLevel,0),this._maximumLevel=e.maximumLevel,this._rectangle=o(e.rectangle,this._tilingScheme.rectangle),this._dimensions=e.dimensions;var n=this;this._reload=void 0,d(e.times)&&(this._timeDynamicImagery=new b({clock:e.clock,times:e.times,requestImageFunction:function(t,e,r,i,a){return requestImage(n,t,e,r,i,a)},reloadFunction:function(){d(n._reload)&&n._reload()}})),this._readyPromise=c.defer();a=this._tilingScheme.positionToTileXY(m.southwest(this._rectangle),this._minimumLevel),t=this._tilingScheme.positionToTileXY(m.northeast(this._rectangle),this._minimumLevel),a=(Math.abs(t.x-a.x)+1)*(Math.abs(t.y-a.y)+1);if(4<a)throw new l("The imagery provider's rectangle and minimumLevel indicate that there are "+a+" tiles at the minimum level. Imagery providers with more than four tiles at the minimum level are not supported.");this._errorEvent=new u;a=e.credit;this._credit="string"==typeof a?new s(a):a,this._subdomains=e.subdomains,f(this._subdomains)?this._subdomains=this._subdomains.slice():d(this._subdomains)&&0<this._subdomains.length?this._subdomains=this._subdomains.split(""):this._subdomains=["a","b","c"];a=e.url.split("{z}")[0]+"tileset.json";this.loadRootJson(a).then(function(t){this.ready={value:!0},this._readyPromise.resolve(!0),this.tilesetJson=t;t=d(t.asset.gltfUpAxis)?Cesium.Axis.fromName(t.asset.gltfUpAxis):Cesium.Axis.Y;this._gltfUpAxis=t}.bind(this)),this.cache={},this.options=e,this.lightMap={},this.showLevel=e.showLevel||16,this.image=document.createElement("canvas"),this.clippingPlanes=e.clippingPlanes,this._modelMatrix=d(e.modelMatrix)?V.clone(e.modelMatrix):V.clone(V.IDENTITY),this._heatmap=new Cesium.Cesium3DTilesetHeatmap(e.debugHeatmapTilePropertyName),this._imageBasedLightingFactor=new Cesium.Cartesian2(1,1),Cesium.Cartesian2.clone(e.imageBasedLightingFactor,this._imageBasedLightingFactor),this._gltfUpAxis=void 0}get imageBasedLightingFactor(){return this._imageBasedLightingFactor}set imageBasedLightingFactor(t){Cesium.Cartesian2.clone(t,this._imageBasedLightingFactor)}loadRootJson(t){return v.createIfNeeded(t).fetchJson()}draw(t){var e,r={ignoreCommands:!1,isRender:!0,requestTiles:!0};for(e in this.getRenderTileMap(t)){let t=this.cache[e];t&&t.update(this,this.viewer.scene._frameState,r)}}getRenderTileMap(e){let r={};for(let t=0;t<e.length;t++){var i=e[t].data.imagery;for(let t=0;t<i.length;t++){var a=i[t].readyImagery;a&&a.imageryLayer._imageryProvider.id==this.id&&(a=a.x+"_"+a.y+"_"+a.level,r[a]=!0)}}return r}requestImageNow(t,e,r,i,a,n){var s,o=t._tileMatrixLabels,l=d(o)?o[i]:i.toString(),u=t._subdomains,o=t._dimensions,n=d(n)?n.data:void 0;t._useKvp?((s={}).tilematrix=l,s.layer=t._layer,s.style=t._style,s.tilerow=r,s.tilecol=e,s.tilematrixset=t._tileMatrixSetID,s.format=t._format,d(o)&&(s=h(s,o)),d(n)&&(s=h(s,n)),s=t._resource.getDerivedResource({queryParameters:s,request:a})):(u={z:l,y:r.toString(),x:e.toString(),s:u[(e+r+i)%u.length]},(s=t._resource.getDerivedResource({request:a})).setTemplateValues(u),d(o)&&s.setTemplateValues(o),d(n)&&s.setTemplateValues(n));n=c.defer(),i={x:e,y:r,z:i};return s._templateValues.z<this.showLevel?(n.reject(),n.promise):this.requestJsonData(n,t,s,i,a)?n.promise:void 0}requestJsonData(e,t,r,i,a){var n=i.x,s=i.y,o=i.z,l=r._templateValues.z;let u=n+"_"+s+"_"+o;if(this.cache[u])return e.resolve(this.image),e;this.tilesetJson.root.content={uri:s+".b3dm"};var h=new y(this,r,this.tilesetJson.root,null);return h._depth=1,h.requestContent()?(h._contentReadyToProcessPromise.then(function(t,e,r,i,a){this.cache[u]=h,t.resolve(this.image)}.bind(this,e,i,l,a),function(t){e.reject()}),!0):void 0}get url(){return this._resource.url}get proxy(){return this._resource.proxy}get tileWidth(){return this._tileWidth}get tileHeight(){return this._tileHeight}get maximumLevel(){return this._maximumLevel}get minimumLevel(){return this._minimumLevel}get tilingScheme(){return this._tilingScheme}get rectangle(){return this._rectangle}get tileDiscardPolicy(){return this._tileDiscardPolicy}get errorEvent(){return this._errorEvent}get format(){return this._format}get readyPromise(){return this._readyPromise}get credit(){return this._credit}get hasAlphaChannel(){return!0}get clock(){return this._timeDynamicImagery.clock}set clock(t){this._timeDynamicImagery.clock=t}get times(){return this._timeDynamicImagery.times}set times(t){this._timeDynamicImagery.times=t}get dimensions(){return this._dimensions}set dimensions(t){this._dimensions!==t&&(this._dimensions=t,d(this._reload)&&this._reload())}getTileCredits(t,e,r){}requestImage(t,e,r,i){var a,n,s=this._timeDynamicImagery;return d(s)&&(n=s.currentInterval,a=s.getFromCache(t,e,r,i)),d(a)||(a=this.requestImageNow(this,t,e,r,i,n)),d(a)&&d(s)&&s.checkApproachingInterval(t,e,r,i),a}pickFeatures(t,e,r,i,a){}destroy(){for(var e in this.cache){let t=this.cache[e];t.destroy()}this.cache={}}removeImageryFromCache(t,e,r){r=t+"_"+e+"_"+r;let i=this.cache[r];i&&(i.destroy(),delete this.cache[r])}get modelMatrix(){return this._modelMatrix}set modelMatrix(t){this._modelMatrix=V.clone(t,this._modelMatrix)}}},{}],27:[function(t,e,r){const i=t("md5-node");e.exports=class{constructor(t,e){this.viewer=t,this.indexDbName=i(e.url),this.viewer.imageryLayers.layerAdded.addEventListener(this.onLayerAdded,this),this.viewer.imageryLayers.layerRemoved.addEventListener(this.onLayerRemoved,this),this.viewer.imageryLayers.layerMoved.addEventListener(this.onLayerMoved,this),this.isElevation=!0}onLayerAdded(t,e){}onLayerRemoved(t,e){}onLayerMoved(t,e,r){}getTopProviders(){let e=this.viewer.imageryLayers.elevationProviders,r=0;for(let t=0;t<e.length;t++)if(e[t]==this){r=t;break}return r==e.length-1?[]:e.slice(r-1)}getBottomProviderIndexDbNames(){var e=this.viewer.imageryLayers.elevationProviders;let r=[];"RGBWorldTerrainProvider"==this.viewer.terrainProvider.name&&r.push(this.viewer.terrainProvider.indexDbName);for(let t=0;t<e.length;t++){var i=e[t];if(r.push(i.indexDbName),i==this)break}return r}getTopProvidersByIndex(t){return this.viewer.imageryLayers.elevationProviders.slice(t)}updateOtherProviderElevation(r){var i=this.getTopProviders();for(let e=0;e<i.length;e++){let t=i[e];if(!t.updateTileElevation(r))break}}updateTileElevation(t,e){}updateAllTileElevation(t){}}},{"md5-node":6}],28:[function(t,e,r){const l=t("../utils/es6-promise")["getJSON"],u=t("../filter/Filter"),h=t("../filter/FilterLayer"),d=t("../ext/Version");e.exports=class{constructor(){this.tileSize=256}setFilter(t,e){for(var r=0;r<t.layers.length;r++)t.layers[r].id||t.layers.splice(r,1);var i=JSON.stringify(t);this.isIE()?l({type:"post",url:this.host+"/mapserver/vmap/"+this.servername+"/setControl",data:"control= "+i,dataType:"json"}).then(function(t){t.isIE=!0,e(t)}.bind(this)):(i={isIE:!1,id:encodeURIComponent(i)},e(i))}parseUrl(t){var e=t.split("?"),t=e[0].split("/mapserver/");if(2==t.length&&(this.host=t[0],e[1])){this.servername=t[1].split("/")[1];for(var r=e[1].split("&"),i=0;i<r.length;i++){var a=r[i].split("=");if("styleId"==a[0])return void(this.styleId=a[1])}}}pickupFeatures(t,e,r,i,a,n,s,o){a=this.host+"/mapserver/pickup/"+this.servername+"/getData?x="+e+"&y="+t+"&l="+r+"&pixelX="+i+"&pixelY="+a+"&styleId="+this.styleId+"&tilesize="+this.tileSize+"&clientVersion="+d;n&&(a=a+"&control="+n),s&&(a=a+"&controlId="+s),l({url:a,dataType:"json"}).then(function(t){o(t)},function(){o([])})}CreateHighlightFilter(t,e){var r,i=new u;for(r in i.otherDisplay=!1,t){var a=t[r],n=new h;n.id=r,n.color=e;var s,o="";for(s in a)o=o+s+",";0<o.length&&(o=o.substr(0,o.length-1),n.idFilter=o),i.addFilterLayer(n)}return i}CreateEveryHighlightFilter(t){var e,r=new u;for(e in r.otherDisplay=!1,t){var i,a=t[e],n=a.style,s=!1;for(i in a){var o,l=a[i].style;(o=new h).id=e,o.idFilter=i,o.color=l,r.addFilterLayer(o),s=!0}!s&&n&&((o=new h).id=e,o.color=n,r.addFilterLayer(o))}return r}isIE(){return!0}}},{"../ext/Version":16,"../filter/Filter":18,"../filter/FilterLayer":19,"../utils/es6-promise":111}],29:[function(t,e,r){const i=t("../../utils/UUID");e.exports=class{constructor(){this.id=(new i).valueOf(),this.type="",this.textures={}}}},{"../../utils/UUID":108}],30:[function(t,e,r){var i=t("./DataSource");const n=t("./../../utils/es6-promise")["Deferred"];class a extends i{constructor(){super(),this.type="LocalDataSource",this.features=[],this.textureUrls={}}addFeature(t){this.features.push(t)}addTextureUrl(t,e){this.textureUrls[t]=e}removeTextureUrl(t){delete this.textureUrls[t]}loadTexture(){let i=new n,a=0;for(var t in this.textureUrls)a++;if(0!=a){let r=0;for(var e in this.textureUrls){let t=new Image;t.name=e,t.onload=function(t){r++;var e=t.target.name;this.textures[e]=t.target,r==a&&i.resolve()}.bind(this),t.src=this.textureUrls[e]}return i}i.resolve()}removeFeatureById(e){for(let t=0;t<this.features.length;t++)this.features[t].id==e&&this.features.splice(t,1)}}e.exports=a},{"./../../utils/es6-promise":111,"./DataSource":29}],31:[function(t,e,r){var i=t("./DataSource");const{Deferred:a,getJSON:n}=t("./../../utils/es6-promise"),o=t("../../ext/Version");class s extends i{constructor(){super(),this.urlArray=[],this.type="URLDataSource",this.url=null,this.styleUrl=null,this.styleId="style",this.filter=null,this.textures={},this.control=null,this.controlId=null,this.sourceUrl=null,this.host="",this.servername=""}loadStyle(t){let e=new a,r=new a,s=new a;this.parseUrl();var i=this.url.split("?")[1];if(this.sourceUrl||(this.sourceUrl=this.url+"&clientVersion="+o,this.url=this.url+"&clientVersion="+o),this.control&&this.isIE()?n({type:"post",url:this.host+"/mapserver/vmap/"+this.servername+"/setControl",data:"control="+this.control,dataType:"json"}).then(function(t){this.controlId=t.id,this.url=this.sourceUrl+"&controlId="+t.id,e.resolve()}.bind(this)):(this.control?this.url=this.sourceUrl+"&control="+encodeURIComponent(this.control):this.url=this.sourceUrl,e.resolve()),t=t||"label","_default__"!=this.styleId)return n({url:this.host+"/mapserver/styleInfo/"+this.servername+"/"+this.styleId+"/"+t+"/style.js?"+Math.random()+"&"+i,dataType:"text"}).then(function(t){this.styleFun=new Function("drawer","level",t),r.resolve()}.bind(this)),n({url:this.host+"/mapserver/styleInfo/"+this.servername+"/"+this.styleId+"/label/texture.js?"+Math.random()+"&"+i,dataType:"text"}).then(function(t){var e,i=JSON.parse(t);let a=0;for(e in i)a++;if(0!=a){let r=0;for(var n in i){let t=new Image;t.name=n,t.onload=function(t){r++;var e=t.target.name;this.textures[e]=t.target,r==a&&s.resolve()}.bind(this),t.src=i[n]}}else s.resolve()}.bind(this)),[e,r,s];return this.styleFun=new Function("drawer","level",'var layers = drawer.getAllLayer(); layers.setStyle(function(level , get){ return {"type":"_default__","show":true,"pointFillStyle":"#ff0000","radius":5,"lineFillStyle":"#00ff00","lineWidth":3 }})'),[e]}parseUrl(){let t=this.url.split("?"),e=t[0].split("/mapserver/");this.host=e[0],this.servername=e[1].split("/")[1];var r=t[1].split("&");for(let e=0;e<r.length;e++){let t=r[e];var i=t.split("=");if("styleId"==i[0])return void(this.styleId=i[1])}}setFilter(e){if(this.control=null,this.url&&e&&(0!=e.layers.length||0!=e.order.length)){for(let t=0;t<e.layers.length;t++)e.layers[t].id||e.layers.splice(t,1);this.control=JSON.stringify(e)}}getTexture(t){return this.textures[t]}addTexture(t,e){this.textures[t]=e}isIE(){if(window.ActiveXObject||"ActiveXObject"in window){var t=navigator.appVersion.split(";");if(t[1])if("MSIE9.0"==t[1].replace(/[ ]/g,""))return!1;return!0}return!1}}e.exports=s},{"../../ext/Version":16,"./../../utils/es6-promise":111,"./DataSource":29}],32:[function(t,e,r){Cesium.Cartesian3,Cesium.Color;const d=Cesium.defined;Cesium.CallbackProperty,Cesium.Math,Cesium.when;const i=Cesium.PrimitivePipeline,a=Cesium.Matrix4,n=Cesium.PrimitiveState,f=Cesium.BatchTable,m=Cesium.Cartesian4;e.exports=class{constructor(t,e,r,i,a,n){this.name=t,this.level=r,this.viewer=i,this.options=a,this.type="envelope",this.state=1,this.polygonPrimitive=new Cesium.ClassificationPrimitive({shadows:Cesium.ShadowMode.ENABLED,geometryInstances:[],undisplayable:!0,classificationType:Cesium.ClassificationType.CESIUM_3D_TILE,appearance:new Cesium.PerInstanceColorAppearance({flat:!1,translucent:this.translucent,closed:!0})}),this.load(e)}load(e){var r=e.polygon;if(r){let t=this.polygonPrimitive.getDrawFunctionOptions();t.shadows=Cesium.ShadowMode.ENABLED,t.appearance=new Cesium.PerInstanceColorAppearance({flat:!1,translucent:this.translucent,closed:!0}),t.undisplayable=!0,t.geometryInstances=[];e=new Cesium.Primitive(t);this.setPrimitive(e,r),this.state=2}}setPrimitive(t,e){var r=i.unpackCombineGeometryResults(e);t.isExt=!0,t._geometries=r.geometries,t._attributeLocations=r.attributeLocations,t.modelMatrix=a.clone(r.modelMatrix,t.modelMatrix),t._pickOffsets=r.pickOffsets,t._offsetInstanceExtend=r.offsetInstanceExtend,t._instanceBoundingSpheres=r.boundingSpheres,t._instanceBoundingSpheresCV=r.boundingSpheresCV,t.propertiesMapBuffer=e.propertiesMapBuffer,d(t._geometries)&&0<t._geometries.length&&(t._recomputeBoundingSpheres=!0,t._state=n.COMBINED),this.createBatchTable(t,e),t.appearance=this.polygonPrimitive.appearance,this.polygonPrimitive._primitive=t}createBatchTable(e,t){var r=t.attributes,i=(r.length,t.ids),a=t.batchValues,n=i.length;let s=t.pickId,o=this.viewer.scene.frameState.context,l=new f(o,r,n);l._batchValues=a;new m;if(e._allowPicking)for(let t=0;t<n;++t){var u={primitive:e},h=i[t];d(h)&&(u.id=h),s++,o._pickObjects[s]=u}e._instanceIds=i,e._batchTable=l,e._batchTableAttributeIndices=t.attributeIndices}remove(){this.polygonPrimitive&&this.viewer.scene.primitives.remove(this.polygonPrimitive),this.state=4}destroy(){this.remove(),this.polygonPrimitive&&!this.polygonPrimitive.isDestroyed()&&this.polygonPrimitive.destroy(),this.destroyed=!0}addToPrimitives(){this.polygonPrimitive&&this.polygonPrimitive._primitive&&this.viewer.scene.primitives.add(this.polygonPrimitive),this.state=3}showPrimitive(e){for(let t=0;t<e._instanceIds.length;t++)e._batchTable.setBatchedAttribute(t,1,1)}show(t){4!=this.state&&2!=this.state||this.addToPrimitives()}}},{}],33:[function(t,e,r){const h=Cesium.combine,a=Cesium.Credit,s=Cesium.defaultValue,d=Cesium.defined,o=Cesium.DeveloperError,l=Cesium.Event;Cesium.freezeObject;const u=Array.isArray,f=Cesium.Rectangle,m=Cesium.Resource,v=Cesium.WebMercatorTilingScheme,p=Cesium.when;Cesium.ImageryProvider;const c=Cesium.TimeDynamicImagery,b=Cesium.RequestState,n=t("./EnvelopeDataSource");t("../ElevationImageryProvider");var y={service:"WMTS",version:"1.0.0",request:"GetTile"};e.exports=class{constructor(t,e){if(this.viewer=t,e=s(e,s.EMPTY_OBJECT),this.id=Math.random(),this.needDecode=s(e.needDecode,!1),!d(e.url))throw new o("options.url is required.");var r=m.createIfNeeded(e.url),i=e.style,t=e.tileMatrixSetID;0<=r.url.indexOf("{")?(r.setTemplateValues({style:i,Style:i,TileMatrixSet:t}),this._useKvp=!1):(r.setQueryParameters(y),this._useKvp=!0),this._resource=r,this._layer=e.layer,this._style=i,this._tileMatrixSetID=t,this._tileMatrixLabels=e.tileMatrixLabels,this._format=s(e.format,"image/jpeg"),this._tileDiscardPolicy=e.tileDiscardPolicy,this._tilingScheme=d(e.tilingScheme)?e.tilingScheme:new v({ellipsoid:e.ellipsoid}),this._tileWidth=s(e.tileWidth,256),this._tileHeight=s(e.tileHeight,256),this._minimumLevel=s(e.minimumLevel,0),this._maximumLevel=e.maximumLevel,this._rectangle=s(e.rectangle,this._tilingScheme.rectangle),this._dimensions=e.dimensions;var n=this;this._reload=void 0,d(e.times)&&(this._timeDynamicImagery=new c({clock:e.clock,times:e.times,requestImageFunction:function(t,e,r,i,a){return requestImage(n,t,e,r,i,a)},reloadFunction:function(){d(n._reload)&&n._reload()}})),this._readyPromise=p.defer();i=this._tilingScheme.positionToTileXY(f.southwest(this._rectangle),this._minimumLevel),t=this._tilingScheme.positionToTileXY(f.northeast(this._rectangle),this._minimumLevel),i=(Math.abs(t.x-i.x)+1)*(Math.abs(t.y-i.y)+1);if(4<i)throw new o("The imagery provider's rectangle and minimumLevel indicate that there are "+i+" tiles at the minimum level. Imagery providers with more than four tiles at the minimum level are not supported.");this._errorEvent=new l;i=e.credit;this._credit="string"==typeof i?new a(i):i,this._subdomains=e.subdomains,u(this._subdomains)?this._subdomains=this._subdomains.slice():d(this._subdomains)&&0<this._subdomains.length?this._subdomains=this._subdomains.split(""):this._subdomains=["a","b","c"],this.dataType="binary",e.hasOwnProperty("dataType")?this.dataType=e.dataType:this.dataType="Json","binary"==this.dataType?this.processor=new Cesium.TaskProcessor("EnvelopeBinaryWorker",Number.POSITIVE_INFINITY):this.processor=new Cesium.TaskProcessor("HouseWorker",Number.POSITIVE_INFINITY),this.parseUrl(e.url),Promise.all(this.loadStyle()).then(function(){this.ready={value:!0},this._readyPromise.resolve(!0)}.bind(this)),this.cache={},this.options=e,this.lightMap={},this.showLevel=e.showLevel||16,this.image=document.createElement("canvas"),this.bufferDistance=s(this.options.bufferDistance,0)}draw(t){var e,r,i=this.getRenderTileMap(t);for(e in this.cache)if(!i[e]){let t=this.cache[e];t.remove()}for(r in i){let t=this.cache[r];t&&t.show(this.styleFun)}}getRenderTileMap(e){let r={};for(let t=0;t<e.length;t++){var i=e[t].data.imagery;for(let t=0;t<i.length;t++){var a=i[t].readyImagery;a&&a.imageryLayer._imageryProvider.id==this.id&&(a=a.x+"_"+a.y+"_"+a.level,r[a]=!0)}}return r}parseUrl(t){let e=t.split("?"),r=e[0].split("/mapserver/");this.host=r[0],0<this._subdomains.length&&(this.host=this.host.replace("{s}",this._subdomains[0])),this.servername=r[1].split("/")[1],this.queryParam=e[1];var i=this.queryParam.split("&");for(let e=0;e<i.length;e++){let t=i[e];var a=t.split("=");"styleId"==a[0]&&(this.styleId=a[1]),"return_type"==a[0]&&(this.return_type=a[1])}}loadStyle(){let e=[];var r=this.host+"/mapserver/styleInfo/"+this.servername+"/"+this.styleId+"/layer/style.js?"+Math.random();let t=m.createIfNeeded(r);r=t.fetchText();e.push(r);if("binary"==this.dataType){var r=this.host+"/mapserver/serverInfo/"+this.servername+".json?"+Math.random();let t=m.createIfNeeded(r);r=t.fetchJson(),e.push(r)}let n=p.defer();return p.all(e,function(t){var e=t[0],r=t[1];let i={init:!0,styleStr:e,tileSize:this._tileWidth,return_type:this.return_type};if(r&&r.layerMap){for(var a in this.serverInfo={},this.layerFieldMap={},r.layerMap)this.serverInfo[a]={geometryType:r.layerMap[a].geometryType,fieldsConfig:r.layerMap[a].fields},this.layerFieldMap[a]||(this.layerFieldMap[a]=r.layerMap[a].fields.length);i.serverInfo=this.serverInfo,i.layerFieldMap=this.layerFieldMap}this.options.hasOwnProperty("fillColor")&&(i.fillColor=this.options.fillColor),this.options.hasOwnProperty("opacity")&&(i.opacity=this.options.opacity),this.options.hasOwnProperty("heightProperty")&&(i.heightProperty=this.options.heightProperty),this.options.hasOwnProperty("heightValue")&&(i.heightValue=this.options.heightValue);e=this.processor.scheduleTask(i);p.all(e,function(){n.resolve()})}.bind(this)),[n.promise]}requestImageNow(t,e,r,i,a,n){var s,o=t._tileMatrixLabels,l=d(o)?o[i]:i.toString(),u=t._subdomains,o=t._dimensions,n=d(n)?n.data:void 0;t._useKvp?((s={}).tilematrix=l,s.layer=t._layer,s.style=t._style,s.tilerow=r,s.tilecol=e,s.tilematrixset=t._tileMatrixSetID,s.format=t._format,d(o)&&(s=h(s,o)),d(n)&&(s=h(s,n)),s=t._resource.getDerivedResource({queryParameters:s,request:a})):(u={z:l,y:r.toString(),x:e.toString(),s:u[(e+r+i)%u.length]},(s=t._resource.getDerivedResource({request:a})).setTemplateValues(u),d(o)&&s.setTemplateValues(o),d(n)&&s.setTemplateValues(n));n=p.defer(),i={x:e,y:r,z:i};return s._templateValues.z<this.showLevel?n.reject():this.requestJsonData(n,t,s,i,a),n.promise}requestJsonData(e,t,r,i,a){var n=i.x,s=i.y,o=i.z,l=r._templateValues.z;if(this.cache[n+"_"+s+"_"+o])return e.resolve(this.image),e;n=this._tilingScheme.tileXYToRectangle(i.x,i.y,i.z),s={west:n.west,north:n.north,width:n.width,height:n.height},o=Math.round(this.viewer.camera.getLevel()),n=i.x+"_"+i.y+"_"+i.z;let u=this.processor.scheduleTask({url:r.url,xyz:n,needDecode:this.options.needDecode,level:o,filterLayerId:this.options.filterLayerId,bufferDistance:this.bufferDistance,rectangle:s});return u.then(function(t,e,r,i,a){if(1==a)return i.state=b.CANCELLED,void t.reject();this.jsonPromiseResult(t,e,r,a),this.updateOtherProviderElevation(e)}.bind(this,e,i,l,a),function(t){e.reject()}),!0}jsonPromiseResult(t,e,r,i){e=e.x+"_"+e.y+"_"+e.z,r=new n(e,i,r,this.viewer,this.options,this.lightMap);this.cache[r.name]=r,t.resolve(this.image)}updateTileElevation(t,e){t=t.x+"_"+t.y+"_"+t.z;return!!this.cache[t]}get url(){return this._resource.url}get proxy(){return this._resource.proxy}get tileWidth(){return this._tileWidth}get tileHeight(){return this._tileHeight}get maximumLevel(){return this._maximumLevel}get minimumLevel(){return this._minimumLevel}get tilingScheme(){return this._tilingScheme}get rectangle(){return this._rectangle}get tileDiscardPolicy(){return this._tileDiscardPolicy}get errorEvent(){return this._errorEvent}get format(){return this._format}get readyPromise(){return this._readyPromise}get credit(){return this._credit}get hasAlphaChannel(){return!0}get clock(){return this._timeDynamicImagery.clock}set clock(t){this._timeDynamicImagery.clock=t}get times(){return this._timeDynamicImagery.times}set times(t){this._timeDynamicImagery.times=t}get dimensions(){return this._dimensions}set dimensions(t){this._dimensions!==t&&(this._dimensions=t,d(this._reload)&&this._reload())}getTileCredits(t,e,r){}requestImage(t,e,r,i){var a,n,s=this._timeDynamicImagery;return d(s)&&(n=s.currentInterval,a=s.getFromCache(t,e,r,i)),d(a)||(a=this.requestImageNow(this,t,e,r,i,n)),d(a)&&d(s)&&s.checkApproachingInterval(t,e,r,i),a}pickFeatures(t,e,r,i,a){}destroy(){for(var e in this.cache){let t=this.cache[e];t.destroy()}this.cache={}}removeImageryFromCache(t,e,r){r=t+"_"+e+"_"+r;let i=this.cache[r];i&&(i.destroy(),delete this.cache[r])}removeTile(t){let e=this.cache[t];e&&e.remove()}redraw(){var e=this.viewer.imageryLayers._layers;let r=null,i=-1;for(let t=0;t<e.length;t++){var a=e[t];a.imageryProvider==this&&(r=a,i=t)}r&&(this.viewer.imageryLayers.layerShownOrHidden.raiseEvent(r,i,!1),this.viewer.imageryLayers.layerShownOrHidden.raiseEvent(r,i,!0))}}},{"../ElevationImageryProvider":27,"./EnvelopeDataSource":32}],34:[function(t,e,r){e.exports=class{constructor(t,e,r,i,a,n){this.name=t,this.gl=e,this.dem=r,this.texture=i,this.latrange=a,this.level=n,this.needsHillshadePrepare=!0,this.renderTexture=null}destroy(){this.renderTexture&&this.gl.deleteTexture(this.renderTexture)}}},{}],35:[function(t,e,r){const h=Cesium.combine,o=Cesium.Credit,l=Cesium.defaultValue,d=Cesium.defined,u=Cesium.DeveloperError,f=Cesium.Event;Cesium.freezeObject;const m=Array.isArray,v=Cesium.Rectangle,p=Cesium.Resource,c=Cesium.WebMercatorTilingScheme,b=Cesium.when;Cesium.ImageryProvider;const y=Cesium.TimeDynamicImagery,V=Cesium.RequestState,i=t("../shaders/ProgramFactory"),q=t("../../utils/TextureQueue"),a=t("./draw/DrawFboHillShade"),x=t("./HillShaderTile"),W=Cesium.BufferUtil,N=t("../../mapbox/RasterBoundsArray"),X=t("../../mapbox/VertexArrayObject"),L=t("../../mapbox/Browser"),P=Cesium.Math;var T={service:"WMTS",version:"1.0.0",request:"GetTile"};e.exports=class{constructor(t,e,r){if(e=l(e,l.EMPTY_OBJECT),this.id=Math.random(),this.viewer=t,this.needDecode=l(e.needDecode,!1),!d(e.url))throw new u("options.url is required.");var i=p.createIfNeeded(e.url),a=e.style,t=e.tileMatrixSetID;0<=i.url.indexOf("{")?(i.setTemplateValues({style:a,Style:a,TileMatrixSet:t}),this._useKvp=!1):(i.setQueryParameters(T),this._useKvp=!0),this._resource=i,this._layer=e.layer,this._style=a,this._tileMatrixSetID=t,this._tileMatrixLabels=e.tileMatrixLabels,this._format=l(e.format,"image/jpeg"),this._tileDiscardPolicy=e.tileDiscardPolicy,this._tilingScheme=d(e.tilingScheme)?e.tilingScheme:new c({ellipsoid:e.ellipsoid}),this._tileWidth=l(e.tileWidth,256),this._tileHeight=l(e.tileHeight,256),this._minimumLevel=l(e.minimumLevel,0),this._maximumLevel=e.maximumLevel,this._rectangle=l(e.rectangle,this._tilingScheme.rectangle),this._dimensions=e.dimensions;var n=this;this._reload=void 0,d(e.times)&&(this._timeDynamicImagery=new y({clock:e.clock,times:e.times,requestImageFunction:function(t,e,r,i,a){return requestImage(n,t,e,r,i,a)},reloadFunction:function(){d(n._reload)&&n._reload()}})),this._readyPromise=b.defer();a=this._tilingScheme.positionToTileXY(v.southwest(this._rectangle),this._minimumLevel),t=this._tilingScheme.positionToTileXY(v.northeast(this._rectangle),this._minimumLevel),a=(Math.abs(t.x-a.x)+1)*(Math.abs(t.y-a.y)+1);if(4<a)throw new u("The imagery provider's rectangle and minimumLevel indicate that there are "+a+" tiles at the minimum level. Imagery providers with more than four tiles at the minimum level are not supported.");this._errorEvent=new f;a=e.credit;this._credit="string"==typeof a?new o(a):a,this._subdomains=e.subdomains,m(this._subdomains)?this._subdomains=this._subdomains.slice():d(this._subdomains)&&0<this._subdomains.length?this._subdomains=this._subdomains.split(""):this._subdomains=["a","b","c"],this.ready={value:!0},this._readyPromise.resolve(!0),this.cache={},this.options=e,this.lightMap={},this.showLevel=e.showLevel||16,this.processor=new Cesium.TaskProcessor("HillShaderWorker",Number.POSITIVE_INFINITY);a=document.createElement("canvas");this.image=a,this.ratio=1,e.hasOwnProperty("ratio")&&(this.ratio=e.ratio),this.textureQueue=new q(this.viewer.scene.context._gl),this.decimalLevel=10,this.getDecimalLevel(),this.viewer.scene.camera.moveEnd.addEventListener(this.getDecimalLevel.bind(this)),this.encoding="mapbox";const s=new N;s.emplaceBack(0,0,0,0,0,0),s.emplaceBack(8192,0,32767,0,0,0),s.emplaceBack(0,8192,0,32767,0,0),s.emplaceBack(8192,8192,32767,32767,0,0),this.rasterBoundsBuffer=W.fromStructArray(s,W.BufferType.VERTEX),this.rasterBoundsVAO=new X,this.options["hillshade-shadow-color"]?this.options["hillshade-shadow-color"]=this.formatColor(this.options["hillshade-shadow-color"],1):this.options["hillshade-shadow-color"]=this.formatColor("#000000",1),this.options["hillshade-highlight-color"]?this.options["hillshade-highlight-color"]=this.formatColor(this.options["hillshade-highlight-color"],1):this.options["hillshade-highlight-color"]=this.formatColor("#00FF00",1),this.options["hillshade-accent-color"]?this.options["hillshade-accent-color"]=this.formatColor(this.options["hillshade-accent-color"],1):this.options["hillshade-accent-color"]=this.formatColor("#000000",1),this.options["hillshade-illumination-direction"]||(this.options["hillshade-illumination-direction"]=335),this.options["hillshade-illumination-anchor"]||(this.options["hillshade-illumination-anchor"]="viewport"),this.options["hillshade-exaggeration"]||(this.options["hillshade-exaggeration"]=.5)}formatColor(t,e){t=this.fromHex(t);return[t[0]/255,t[1]/255,t[2]/255,e]}fromHex(t){t=t.toUpperCase();if(/^#[0-9a-fA-F]{3,6}$/.test(t)){for(var e=[],r=1,i=1;i<=3;i++)t.length-2*i>3-i?(e.push(Number("0x"+t.substring(r,r+2))),r+=2):(e.push(Number("0x"+t.charAt(r)+t.charAt(r))),r+=1);return e}}draw(t){}getRenderTileMap(e){let r={};for(let t=0;t<e.length;t++){var i=e[t].data.imagery;for(let t=0;t<i.length;t++){var a=i[t].readyImagery;a&&a.imageryLayer._imageryProvider.id==this.id&&(a=a.x+"_"+a.y+"_"+a.level,r[a]=!0)}}return r}requestImageNow(t,e,r,i,a,n){var s,o=t._tileMatrixLabels,l=d(o)?o[i]:i.toString(),u=t._subdomains,o=t._dimensions,n=d(n)?n.data:void 0;t._useKvp?((s={}).tilematrix=l,s.layer=t._layer,s.style=t._style,s.tilerow=r,s.tilecol=e,s.tilematrixset=t._tileMatrixSetID,s.format=t._format,d(o)&&(s=h(s,o)),d(n)&&(s=h(s,n)),s=t._resource.getDerivedResource({queryParameters:s,request:a})):(u={z:l,y:r.toString(),x:e.toString(),s:u[(e+r+i)%u.length]},(s=t._resource.getDerivedResource({request:a})).setTemplateValues(u),d(o)&&s.setTemplateValues(o),d(n)&&s.setTemplateValues(n));n=b.defer(),r={x:e,y:r,z:i},i=s._templateValues.z;this.viewer.camera.getLevel();return i<this.showLevel?(n.reject(),n.promise):this.requestJsonData(n,t,s,r,a)?n.promise:void 0}requestJsonData(t,e,r,i,a){var n=i.x,s=i.y,o=i.z,l=r._templateValues.z,o=this.cache[n+"_"+s+"_"+o];if(o)return t.resolve({isTexture:!0,texture:o.texture}),t;let u=r.fetchImage();return!!u&&(u.then(function(r,t,e,i,a){a=L.getImageData(a);let n=this.processor.scheduleTask({rawImageData:a});n.then(function(t,e,r,i,a){if(1==a)return i.state=V.CANCELLED,void t.reject();this.jsonPromiseResult(t,e,r,a)}.bind(this,r,t,e,i),function(t,e){r.reject()}.bind())}.bind(this,t,i,l,a),function(t){t.reject()}.bind(this,t)),!0)}jsonPromiseResult(t,e,r,i){var a=e.x+"_"+e.y+"_"+e.z,n=this._tilingScheme.tileXYToRectangle(e.x,e.y,e.z),e=this._tilingScheme.tileXYToRectangle(e.x,e.y+1,e.z),e=[P.toDegrees(n.north-n.height/2),P.toDegrees(e.north-e.height/2)];let s=new x(a,this.viewer.scene.context._gl,i,null,e,r);this.cache[a]=s;a={_target:3553,_texture:this.drawFbo(s,a),destroy:this.destroyTexture};s.texture=a,t.resolve({isTexture:!0,texture:a})}destroyTexture(){}drawFbo(t,e,r){return a(this,t,e)}get url(){return this._resource.url}get proxy(){return this._resource.proxy}get tileWidth(){return this._tileWidth}get tileHeight(){return this._tileHeight}get maximumLevel(){return this._maximumLevel}get minimumLevel(){return this._minimumLevel}get tilingScheme(){return this._tilingScheme}get rectangle(){return this._rectangle}get tileDiscardPolicy(){return this._tileDiscardPolicy}get errorEvent(){return this._errorEvent}get format(){return this._format}get readyPromise(){return this._readyPromise}get credit(){return this._credit}get hasAlphaChannel(){return!0}get clock(){return this._timeDynamicImagery.clock}set clock(t){this._timeDynamicImagery.clock=t}get times(){return this._timeDynamicImagery.times}set times(t){this._timeDynamicImagery.times=t}get dimensions(){return this._dimensions}set dimensions(t){this._dimensions!==t&&(this._dimensions=t,d(this._reload)&&this._reload())}getTileCredits(t,e,r){}requestImage(t,e,r,i){var a,n,s=this._timeDynamicImagery;return d(s)&&(n=s.currentInterval,a=s.getFromCache(t,e,r,i)),d(a)||(a=this.requestImageNow(this,t,e,r,i,n)),d(a)&&d(s)&&s.checkApproachingInterval(t,e,r,i),a}pickFeatures(t,e,r,i,a){}destroy(){for(var e in this.viewer.scene.camera.moveEnd.removeEventListener(this.getDecimalLevel.bind(this)),this.cache){let t=this.cache[e];t.destroy()}this.cache={}}removeImageryFromCache(t,e,r){r=t+"_"+e+"_"+r;let i=this.cache[r];i&&(i.destroy(),this.textureQueue.remove(i.name),delete this.cache[r])}useProgram(t){return i.createProgram(this.viewer.scene.context._gl,t)}getTexture(t){return null}getDecimalLevel(){let t=1;var e=this.decimalLevel;let r=this.viewer.camera.getLevel();var i=r.toString().split("."),a=i[0],i="0."+i[1];let n=a=Number(a);(i=Number(i))&&(e=Math.round(i*e)/e,n+=e,t+=e),this.zoom=a,this._zoom=n,this.scale=t}}},{"../../mapbox/Browser":82,"../../mapbox/RasterBoundsArray":85,"../../mapbox/VertexArrayObject":86,"../../utils/TextureQueue":107,"../shaders/ProgramFactory":61,"./HillShaderTile":34,"./draw/DrawFboHillShade":36}],36:[function(t,e,r){const n=t("./DrawHillshade"),a=t("../../../mapbox/gl-matrix")["mat4"];class s{static drawFboHillShade(t,e,r){const i=t.viewer.scene.context._gl;i.enable(i.BLEND),i.blendFunc(i.ONE,i.ONE_MINUS_SRC_ALPHA);let a=t.textureQueue.getOne(r,t._zoom);return a||(n.drawHillshade(t,e),a=s.initFramebufferObject(t,i,t.scale),t.textureQueue.add(r,t._zoom,a),s.drawRasterTile(t,e,i)),i.disable(i.BLEND),i.bindFramebuffer(i.FRAMEBUFFER,null),i.viewport(0,0,t.viewer._lastWidth,t.viewer._lastHeight),a}static drawRasterTile(t,e,r){var i=a.identity(new Float32Array(16));a.translate(i,i,[-1,-1,0]),a.scale(i,i,[2/8192,2/8192,1]),s.cleanViewPort(r,t._tileWidth*t.ratio*t.scale,t._tileWidth*t.ratio*t.scale),r.clearColor(1,1,1,1),r.clear(r.COLOR_BUFFER_BIT),n.renderHillshade(t,e,i)}static initFramebufferObject(t,e,r){var i=t.viewportFbo;i?e.bindFramebuffer(e.FRAMEBUFFER,i):(a=e.createFramebuffer(),e.bindFramebuffer(e.FRAMEBUFFER,a),t.viewportFbo=a),e.activeTexture(e.TEXTURE0);var a=e.createTexture();return e.bindTexture(e.TEXTURE_2D,a),e.texImage2D(e.TEXTURE_2D,0,e.RGBA,t._tileWidth*t.ratio*r,t._tileWidth*t.ratio*r,0,e.RGBA,e.UNSIGNED_BYTE,null),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MAG_FILTER,e.LINEAR),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MIN_FILTER,e.LINEAR),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_WRAP_S,e.CLAMP_TO_EDGE),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_WRAP_T,e.CLAMP_TO_EDGE),e.framebufferTexture2D(e.FRAMEBUFFER,e.COLOR_ATTACHMENT0,e.TEXTURE_2D,a,0),a}static cleanViewPort(t,e,r){t.viewport(0,0,e,r)}}e.exports=s.drawFboHillShade},{"../../../mapbox/gl-matrix":87,"./DrawHillshade":37}],37:[function(t,e,r){const u=8192,h=t("../../../mapbox/MapboxTexture"),d=t("../../../mapbox/RGBAImage"),f=t("../../../mapbox/gl-matrix")["mat4"];e.exports={drawHillshade:function(t,e){e.needsHillshadePrepare&&function(e,r){const i=e.viewer.scene.context._gl;if(r.dem&&r.dem.data){var a=r.dem.dim,n=(r.dem.stride,new d({width:r.dem.stride,height:r.dem.stride},new Uint8Array(r.dem.data.buffer)));if(i.activeTexture(i.TEXTURE1),i.pixelStorei(i.UNPACK_PREMULTIPLY_ALPHA_WEBGL,!1),r.demTexture){const o=r.demTexture;o.update(n,{premultiply:!1}),r.frambuffer=i.createFramebuffer(),o.bind(i.NEAREST,i.CLAMP_TO_EDGE)}else r.demTexture=new h(i,n,i.RGBA,{premultiply:!1}),r.demTexture.bind(i.NEAREST,i.CLAMP_TO_EDGE);i.activeTexture(i.TEXTURE2);let t=r.frambuffer;if(!t){const l=new h(i,{width:a,height:a,data:null},i.RGBA);l.bind(i.LINEAR,i.CLAMP_TO_EDGE),t=r.frambuffer=i.createFramebuffer(),r.renderTexture=l.texture,i.bindFramebuffer(i.FRAMEBUFFER,t),i.framebufferTexture2D(i.FRAMEBUFFER,i.COLOR_ATTACHMENT0,i.TEXTURE_2D,l.texture,0)}i.bindFramebuffer(i.FRAMEBUFFER,t),i.viewport(0,0,a,a);n=e.useProgram("hillshadePrepare"),a=e.rasterBoundsBuffer;const s=e.rasterBoundsVAO;!function(t,e,r){var i=r.dem.stride,a=f.create();f.ortho(a,0,u,-u,0,0,1),f.translate(a,a,[0,-u,0]),t.uniformMatrix4fv(e.u_matrix,!1,a),t.uniform1i(e.u_image,1),t.uniform2fv(e.u_dimension,[i,i]),t.uniform1f(e.u_zoom,r.level),t.uniform1f(e.u_maxzoom,22)}(i,n,r),s.bind(i,n,a),i.drawArrays(i.TRIANGLE_STRIP,0,a.length),r.needsHillshadePrepare=!1}}(t,e)},renderHillshade:function(t,e,r){const i=t.viewer.scene.context._gl,a=t.useProgram("hillshade");i.activeTexture(i.TEXTURE2),i.bindTexture(i.TEXTURE_2D,e.renderTexture),function(t,e,r,i,a){var n=r.options["hillshade-shadow-color"],s=r.options["hillshade-highlight-color"],o=r.options["hillshade-accent-color"];let l=r.options["hillshade-illumination-direction"]*(Math.PI/180);"viewport"===r.options["hillshade-illumination-anchor"]&&(l-=r.viewer.camera.heading);t.uniformMatrix4fv(e.u_matrix,!1,a),t.uniform1i(e.u_image,2),t.uniform2fv(e.u_latrange,i.latrange),t.uniform2f(e.u_light,r.options["hillshade-exaggeration"],l),t.uniform4f(e.u_shadow,n[0],n[1],n[2],n[3]),t.uniform4f(e.u_highlight,s[0],s[1],s[2],s[3]),t.uniform4f(e.u_accent,o[0],o[1],o[2],o[3])}(i,a,t,e,r);const n=t.rasterBoundsBuffer,s=t.rasterBoundsVAO;s.bind(i,a,n),i.drawArrays(i.TRIANGLE_STRIP,0,n.length)}}},{"../../../mapbox/MapboxTexture":83,"../../../mapbox/RGBAImage":84,"../../../mapbox/gl-matrix":87}],38:[function(t,e,r){Cesium.Cartesian3,Cesium.Color;const d=Cesium.defined;Cesium.CallbackProperty,Cesium.Math,Cesium.when,t("../../gloweffect/RidingLanternGlowPrimitive");const i=Cesium.PrimitivePipeline,a=Cesium.Matrix4,n=Cesium.PrimitiveState,f=Cesium.BatchTable,m=Cesium.Cartesian4,o=t("../../utils/LightTool"),s=new Cesium.Material.fromType("Image",{image:"",repeat:{x:-1,y:1}}),l=new Cesium.Material({fabric:{type:"Water",uniforms:{normalMap:"",frequency:1e3,animationSpeed:.1,amplitude:2}}});e.exports=class{constructor(t,e,r,i,a,n){this.name=t,this.level=r,this.viewer=i,this.options=a,this.type="house",this.state=1,this.translucent=!1,this.options.hasOwnProperty("translucent")&&(this.translucent=this.options.translucent),this.options.translucentMaterial?this.polygonPrimitive=new Cesium.Primitive({shadows:Cesium.ShadowMode.ENABLED,geometryInstances:[],undisplayable:!0,appearance:new Cesium.MaterialAppearance({material:s,transparent:this.translucent})}):this.polygonPrimitive=new Cesium.Primitive({shadows:Cesium.ShadowMode.ENABLED,geometryInstances:[],undisplayable:!0,appearance:new Cesium.PerInstanceColorAppearance({flat:!1,translucent:this.translucent,closed:!0})}),this.outlinePrimitive=new Cesium.Primitive({geometryInstances:[],undisplayable:!0,appearance:new Cesium.PerInstanceColorAppearance({flat:!0,translucent:this.translucent,closed:!0})}),this.waterPrimitive=new Cesium.Primitive({geometryInstances:[],undisplayable:!0,appearance:new Cesium.EllipsoidSurfaceAppearance({material:l})}),this.ridingLanternPrimitive=null,this.polygonSourceVs=this.polygonPrimitive.appearance.vertexShaderSource,this.polygonSourceFs=this.polygonPrimitive.appearance.fragmentShaderSource,this.setLightMap(n),this.load(e)}load(t){var e=t.polygon,r=t.water,i=t.outline,t=t.ridingLantern;e?this.setPrimitive(this.polygonPrimitive,e):this.polygonPrimitive=null,i?this.setPrimitive(this.outlinePrimitive,i):this.outlinePrimitive=null,r?this.setPrimitive(this.waterPrimitive,r):this.waterPrimitive=null,t&&(this.ridingLanternPrimitive=Custom.RidingLanternGlowPrimitive.createRidingLantern({viewer:this.viewer,height:200,speed:100,type:1,direction:1,color:new Cesium.Color(.3,.5,.8,2),translucent:!0}),this.setPrimitive(this.ridingLanternPrimitive,t)),this.state=2}setPrimitive(t,e){var r=i.unpackCombineGeometryResults(e);t.isExt=!0,t._geometries=r.geometries,t._attributeLocations=r.attributeLocations,t.modelMatrix=a.clone(r.modelMatrix,t.modelMatrix),t._pickOffsets=r.pickOffsets,t._offsetInstanceExtend=r.offsetInstanceExtend,t._instanceBoundingSpheres=r.boundingSpheres,t._instanceBoundingSpheresCV=r.boundingSpheresCV,t.propertiesMapBuffer=e.propertiesMapBuffer,d(t._geometries)&&0<t._geometries.length&&(t._recomputeBoundingSpheres=!0,t._state=n.COMBINED),this.createBatchTable(t,e)}createBatchTable(e,t){var r=t.attributes,i=(r.length,t.ids),a=t.batchValues,n=i.length;let s=t.pickId,o=this.viewer.scene.frameState.context,l=new f(o,r,n);l._batchValues=a;new m;if(e._allowPicking)for(let t=0;t<n;++t){var u={primitive:e},h=i[t];d(h)&&(u.id=h),s++,o._pickObjects[s]=u}e._instanceIds=i,e._batchTable=l,e._batchTableAttributeIndices=t.attributeIndices}remove(){this.polygonPrimitive&&this.viewer.scene.primitives.remove(this.polygonPrimitive),this.outlinePrimitive&&this.viewer.scene.primitives.remove(this.outlinePrimitive),this.waterPrimitive&&this.viewer.scene.primitives.remove(this.waterPrimitive),this.ridingLanternPrimitive&&this.viewer.scene.primitives.remove(this.ridingLanternPrimitive),this.state=4}destroy(){this.remove(),this.polygonPrimitive&&!this.polygonPrimitive.isDestroyed()&&this.polygonPrimitive.destroy(),this.outlinePrimitive&&!this.outlinePrimitive.isDestroyed()&&this.outlinePrimitive.destroy(),this.waterPrimitive&&!this.waterPrimitive.isDestroyed()&&this.waterPrimitive.destroy(),this.destroyed=!0}addToPrimitives(){this.polygonPrimitive&&this.viewer.scene.primitives.add(this.polygonPrimitive),this.outlinePrimitive&&this.viewer.scene.primitives.add(this.outlinePrimitive),this.waterPrimitive&&this.viewer.scene.primitives.add(this.waterPrimitive),this.ridingLanternPrimitive&&this.viewer.scene.primitives.add(this.ridingLanternPrimitive),this.state=3}showPrimitive(e){for(let t=0;t<e._instanceIds.length;t++)e._batchTable.setBatchedAttribute(t,1,1)}show(t){4!=this.state&&2!=this.state||this.addToPrimitives()}setLightMap(e){if(this.polygonPrimitive){let t=!1;for(var r in e)t=!0;t?(e=function(e,t,r){let i=[],a=[];for(var n in e){let t=e[n];var s=t.getPolygonColorPrimitiveShader(),n={name:t.type,shader:s.vertexShaderSource},s={name:t.type,shader:s.fragmentShaderSource};i.push(n),a.push(s)}return{vs:o.composeMainShader(t,i),fs:o.composeMainShader(r,a)}}(e,this.polygonSourceVs,this.polygonSourceFs),this.options.translucentMaterial?this.polygonPrimitive.appearance=new Cesium.MaterialAppearance({material:s,transparent:!0,vertexShaderSource:e.vs,fragmentShaderSource:e.fs}):this.polygonPrimitive.appearance=new Cesium.PerInstanceColorAppearance({flat:!1,translucent:this.translucent,closed:!0,vertexShaderSource:e.vs,fragmentShaderSource:e.fs})):this.options.translucentMaterial?this.polygonPrimitive.appearance=new Cesium.MaterialAppearance({material:s,transparent:!0}):this.polygonPrimitive.appearance=new Cesium.PerInstanceColorAppearance({flat:!1,translucent:this.translucent,closed:!0})}}}},{"../../gloweffect/RidingLanternGlowPrimitive":23,"../../utils/LightTool":105}],39:[function(t,e,r){const h=Cesium.combine,s=Cesium.Credit,o=Cesium.defaultValue,d=Cesium.defined,l=Cesium.DeveloperError,u=Cesium.Event;Cesium.freezeObject;const f=Array.isArray,m=Cesium.Rectangle,v=Cesium.Resource,p=Cesium.WebMercatorTilingScheme,c=Cesium.when;Cesium.ImageryProvider;const b=Cesium.TimeDynamicImagery,y=Cesium.RequestState,a=t("./HouseDataSource");var t=t("../ElevationImageryProvider"),V={service:"WMTS",version:"1.0.0",request:"GetTile"};class i extends t{constructor(t,e){if(super(t,e),this.indexDbName="house_"+this.indexDbName,e=o(e,o.EMPTY_OBJECT),this.id=Math.random(),this.needDecode=o(e.needDecode,!1),!d(e.url))throw new l("options.url is required.");var r=v.createIfNeeded(e.url),i=e.style,a=e.tileMatrixSetID;0<=r.url.indexOf("{")?(r.setTemplateValues({style:i,Style:i,TileMatrixSet:a}),this._useKvp=!1):(r.setQueryParameters(V),this._useKvp=!0),this._resource=r,this._layer=e.layer,this._style=i,this._tileMatrixSetID=a,this._tileMatrixLabels=e.tileMatrixLabels,this._format=o(e.format,"image/jpeg"),this._tileDiscardPolicy=e.tileDiscardPolicy,this._tilingScheme=d(e.tilingScheme)?e.tilingScheme:new p({ellipsoid:e.ellipsoid}),this._tileWidth=o(e.tileWidth,256),this._tileHeight=o(e.tileHeight,256),this._minimumLevel=o(e.minimumLevel,0),this._maximumLevel=e.maximumLevel,this._rectangle=o(e.rectangle,this._tilingScheme.rectangle),this._dimensions=e.dimensions;var n=this;this._reload=void 0,d(e.times)&&(this._timeDynamicImagery=new b({clock:e.clock,times:e.times,requestImageFunction:function(t,e,r,i,a){return requestImage(n,t,e,r,i,a)},reloadFunction:function(){d(n._reload)&&n._reload()}})),this._readyPromise=c.defer();i=this._tilingScheme.positionToTileXY(m.southwest(this._rectangle),this._minimumLevel),a=this._tilingScheme.positionToTileXY(m.northeast(this._rectangle),this._minimumLevel),i=(Math.abs(a.x-i.x)+1)*(Math.abs(a.y-i.y)+1);if(4<i)throw new l("The imagery provider's rectangle and minimumLevel indicate that there are "+i+" tiles at the minimum level. Imagery providers with more than four tiles at the minimum level are not supported.");this._errorEvent=new u;i=e.credit;this._credit="string"==typeof i?new s(i):i,this._subdomains=e.subdomains,f(this._subdomains)?this._subdomains=this._subdomains.slice():d(this._subdomains)&&0<this._subdomains.length?this._subdomains=this._subdomains.split(""):this._subdomains=["a","b","c"],this.dataType="binary",e.hasOwnProperty("dataType")?this.dataType=e.dataType:this.dataType="Json",this.hasTerrain=!1,"RGBWorldTerrainProvider"==t.terrainProvider.name&&(this.hasTerrain=!0),"binary"==this.dataType?this.processor=new Cesium.TaskProcessor("HouseBinaryWorker",Number.POSITIVE_INFINITY):this.processor=new Cesium.TaskProcessor("HouseWorker",Number.POSITIVE_INFINITY),this.parseUrl(e.url),Promise.all(this.loadStyle()).then(function(){this.ready={value:!0},this._readyPromise.resolve(!0)}.bind(this)),this.cache={},this.options=e,this.lightMap={},this.showLevel=e.showLevel||16,this.image=document.createElement("canvas"),this.ridingLanternHeight=o(e.ridingLanternHeight,200),this.ridingLanternColor=o(e.ridingLanternColor,"#4D80CD"),this.ridingLanternAlpha=o(e.ridingLanternAlpha,1),this.ridingLanternType=o(e.ridingLanternType,1),this.ridingLanternSpeed=o(e.ridingLanternSpeed,100)}draw(t){var e,r,i=this.getRenderTileMap(t);for(e in this.cache)if(!i[e]){let t=this.cache[e];t.remove()}for(r in i){let t=this.cache[r];t&&t.show(this.styleFun)}}getRenderTileMap(e){let r={};for(let t=0;t<e.length;t++){var i=e[t].data.imagery;for(let t=0;t<i.length;t++){var a=i[t].readyImagery;a&&a.imageryLayer._imageryProvider.id==this.id&&(a=a.x+"_"+a.y+"_"+a.level,r[a]=!0)}}return r}parseUrl(t){let e=t.split("?"),r=e[0].split("/mapserver/");this.host=r[0],0<this._subdomains.length&&(this.host=this.host.replace("{s}",this._subdomains[0])),this.servername=r[1].split("/")[1],this.queryParam=e[1];var i=this.queryParam.split("&");for(let e=0;e<i.length;e++){let t=i[e];var a=t.split("=");"styleId"==a[0]&&(this.styleId=a[1]),"return_type"==a[0]&&(this.return_type=a[1])}}loadStyle(){let e=[];var r=this.host+"/mapserver/styleInfo/"+this.servername+"/"+this.styleId+"/layer/style.js?"+Math.random();let t=v.createIfNeeded(r);r=t.fetchText();e.push(r);if("binary"==this.dataType){var r=this.host+"/mapserver/serverInfo/"+this.servername+".json?"+Math.random();let t=v.createIfNeeded(r);r=t.fetchJson(),e.push(r)}let n=c.defer();return c.all(e,function(t){var e=t[0],r=t[1];let i={init:!0,styleStr:e,tileSize:this._tileWidth,return_type:this.return_type,hasTerrain:this.hasTerrain};if(r&&r.layerMap){for(var a in this.serverInfo={},this.layerFieldMap={},r.layerMap)this.serverInfo[a]={geometryType:r.layerMap[a].geometryType,fieldsConfig:r.layerMap[a].fields},this.layerFieldMap[a]||(this.layerFieldMap[a]=r.layerMap[a].fields.length);i.serverInfo=this.serverInfo,i.layerFieldMap=this.layerFieldMap}this.options.hasOwnProperty("fillColor")&&(i.fillColor=this.options.fillColor),this.options.hasOwnProperty("opacity")&&(i.opacity=this.options.opacity),this.options.hasOwnProperty("heightProperty")&&(i.heightProperty=this.options.heightProperty),this.options.hasOwnProperty("heightScale")&&(i.heightScale=this.options.heightScale),this.options.hasOwnProperty("translucentMaterial")&&(i.translucentMaterial=this.options.translucentMaterial),this.options.hasOwnProperty("heightValue")&&(i.heightValue=this.options.heightValue),i.indexDbNames=this.getBottomProviderIndexDbNames(),i.indexDbName=this.indexDbName;e=this.processor.scheduleTask(i);c.all(e,function(){n.resolve()})}.bind(this)),[n.promise]}requestImageNow(t,e,r,i,a,n){var s,o=t._tileMatrixLabels,l=d(o)?o[i]:i.toString(),u=t._subdomains,o=t._dimensions,n=d(n)?n.data:void 0;t._useKvp?((s={}).tilematrix=l,s.layer=t._layer,s.style=t._style,s.tilerow=r,s.tilecol=e,s.tilematrixset=t._tileMatrixSetID,s.format=t._format,d(o)&&(s=h(s,o)),d(n)&&(s=h(s,n)),s=t._resource.getDerivedResource({queryParameters:s,request:a})):(u={z:l,y:r.toString(),x:e.toString(),s:u[(e+r+i)%u.length]},(s=t._resource.getDerivedResource({request:a})).setTemplateValues(u),d(o)&&s.setTemplateValues(o),d(n)&&s.setTemplateValues(n));n=c.defer(),i={x:e,y:r,z:i};return s._templateValues.z<this.showLevel?n.reject():this.requestJsonData(n,t,s,i,a),n.promise}requestJsonData(e,t,r,i,a){var n=i.x,s=i.y,o=i.z,l=r._templateValues.z;if(this.cache[n+"_"+s+"_"+o])return e.resolve(this.image),e;n=this._tilingScheme.tileXYToRectangle(i.x,i.y,i.z),s={west:n.west,north:n.north,width:n.width,height:n.height},o=Math.round(this.viewer.camera.getLevel()),n=i.x+"_"+i.y+"_"+i.z;let u=this.processor.scheduleTask({url:r.url,xyz:n,needDecode:this.options.needDecode,level:o,filterLayerId:this.options.filterLayerId,ridingLanternLayerId:this.options.ridingLanternLayerId,ridingLanternHeight:this.ridingLanternHeight,ridingLanternColor:this.ridingLanternColor,ridingLanternAlpha:this.ridingLanternAlpha,ridingLanternType:this.ridingLanternType,ridingLanternSpeed:this.ridingLanternSpeed,waterLayerId:this.options.waterLayerId,rectangle:s});return u.then(function(t,e,r,i,a){if(1==a)return i.state=y.CANCELLED,void t.reject();this.jsonPromiseResult(t,e,r,a),this.updateOtherProviderElevation(e)}.bind(this,e,i,l,a),function(t){e.reject()}),!0}jsonPromiseResult(t,e,r,i){e=e.x+"_"+e.y+"_"+e.z,r=new a(e,i,r,this.viewer,this.options,this.lightMap);this.cache[r.name]=r,t.resolve(this.image)}updateTileElevation(t,e){t=t.x+"_"+t.y+"_"+t.z;return!!this.cache[t]}get url(){return this._resource.url}get proxy(){return this._resource.proxy}get tileWidth(){return this._tileWidth}get tileHeight(){return this._tileHeight}get maximumLevel(){return this._maximumLevel}get minimumLevel(){return this._minimumLevel}get tilingScheme(){return this._tilingScheme}get rectangle(){return this._rectangle}get tileDiscardPolicy(){return this._tileDiscardPolicy}get errorEvent(){return this._errorEvent}get format(){return this._format}get readyPromise(){return this._readyPromise}get credit(){return this._credit}get hasAlphaChannel(){return!0}get clock(){return this._timeDynamicImagery.clock}set clock(t){this._timeDynamicImagery.clock=t}get times(){return this._timeDynamicImagery.times}set times(t){this._timeDynamicImagery.times=t}get dimensions(){return this._dimensions}set dimensions(t){this._dimensions!==t&&(this._dimensions=t,d(this._reload)&&this._reload())}getTileCredits(t,e,r){}requestImage(t,e,r,i){var a,n,s=this._timeDynamicImagery;return d(s)&&(n=s.currentInterval,a=s.getFromCache(t,e,r,i)),d(a)||(a=this.requestImageNow(this,t,e,r,i,n)),d(a)&&d(s)&&s.checkApproachingInterval(t,e,r,i),a}pickFeatures(t,e,r,i,a){}updateLightShader(t){this.lightMap[t.type]=t,this.updateLightMap()}removeLightShader(t){delete this.lightMap[t],this.updateLightMap()}updateLightMap(){for(var e in this.cache){let t=this.cache[e];t.setLightMap(this.lightMap)}}destroy(){for(var e in this.cache){let t=this.cache[e];t.destroy()}this.cache={}}removeImageryFromCache(t,e,r){r=t+"_"+e+"_"+r;let i=this.cache[r];i&&(i.destroy(),delete this.cache[r])}removeTile(t){let e=this.cache[t];e&&e.remove()}}e.exports=i},{"../ElevationImageryProvider":27,"./HouseDataSource":38}],40:[function(t,e,r){const i=Cesium.Color,a=Cesium.defaultValue,n=Cesium.defined,s=Cesium.Event,o=Cesium.GeographicTilingScheme,l=Cesium.when;function u(t){if(t=a(t,a.EMPTY_OBJECT),this._tilingScheme=n(t.tilingScheme)?t.tilingScheme:new o({ellipsoid:t.ellipsoid}),this._color=a(t.color,i.YELLOW),this._errorEvent=new s,this._tileWidth=a(t.tileWidth,256),this._tileHeight=a(t.tileHeight,256),this._readyPromise=l.resolve(!0),this.options=t,this.options.hasOwnProperty("showLevels")){this.showLevels=this.options.showLevels;for(let t=0;t<this.showLevels.length;t++)this.showLevels[t]=parseInt(this.showLevels[t])}else this.showLevels=[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26];this.defaultAlpha=void 0,this.defaultNightAlpha=void 0,this.defaultDayAlpha=void 0,this.defaultBrightness=void 0,this.defaultContrast=void 0,this.defaultHue=void 0,this.defaultSaturation=void 0,this.defaultGamma=void 0,this.defaultMinificationFilter=void 0,this.defaultMagnificationFilter=void 0}Object.defineProperties(u.prototype,{proxy:{get:function(){}},tileWidth:{get:function(){return this._tileWidth}},tileHeight:{get:function(){return this._tileHeight}},maximumLevel:{get:function(){}},minimumLevel:{get:function(){}},tilingScheme:{get:function(){return this._tilingScheme}},rectangle:{get:function(){return this._tilingScheme.rectangle}},tileDiscardPolicy:{get:function(){}},errorEvent:{get:function(){return this._errorEvent}},ready:{get:function(){return!0}},readyPromise:{get:function(){return this._readyPromise}},credit:{get:function(){}},hasAlphaChannel:{get:function(){return!0}}}),u.prototype.getTileCredits=function(t,e,r){},u.prototype.requestImage=function(t,e,r,i){return-1<this.showLevels.indexOf(r)?this.options.img:document.createElement("canvas")},u.prototype.pickFeatures=function(t,e,r,i,a){},e.exports=u},{}],41:[function(t,e,r){"use strict";const a=t("./avoid/GAnnoAvoid"),o=t("./avoid/GCutLine");let n=[],s=null,l=!0,u,h=!1,d,f;class m{static init(t,e,r,i){l=!1,u=r,n=t,f=i,h=!1;i=f.camera.getLevel();(!d||.1<Math.abs(i-d))&&(h=!0),d=i,s=new a(null,null,e)}static setTiles(t,e){l=!1,n=t,s=new a(null,null,e)}static avoidTile(){const e=(new Date).getTime();for(var r,i=f.camera.getLevel();0<n.length;){let t=n.shift();if(!t.isDestroy)if(h&&(r=Math.pow(2,t.level)/Math.pow(2,i)*.5,m.cutLine(t,t.features,r)),t.updateScreenPt(t.features),s.GLabelBox.setBox(t.features,t.styleMap,!0),s.defaultAvoid(t.features,t.styleMap,!0,!0,!1),m.updateLineLable(t.features),3<(new Date).getTime()-e)return}l=!0}static cutLine(a,e,r){for(let t=0;t<e.length;t++){let i=e[t];if("text"==i.lineType){var n=o.createLineTextFeatrue(i,u[i.styleId],0,r).feature;if(i.anglePositions=[],n)for(let r=0;r<n.sourceAngleData.length;r++){let t=[];var s=n.sourceAngleData[r],s=a.toLonLat([s[0][0],s[0][1]]);t.push(s),t.push(i.sourceAngleData[r][1]),i.anglePositions.push(t);let e=i.labels[r];i.anglePositions[r][0]?(e.show=!0,e.position=i.anglePositions[r][0]):e.show=!1}}}}static screenToposition(t,e){e=new Cesium.Cartesian2(t,e);return f.camera.pickEllipsoid(e,f.scene.globe.ellipsoid)}static updateLineLable(e){for(let t=0;t<e.length;t++){let r=e[t];if(!r.hidden&&"text"==r.lineType&&r.labels)for(let e=0;e<r.labels.length;e++){let t=r.labels[e];r.changeDirection?t.text=r.label.charAt(r.labels.length-1-e):t.text=r.label.charAt(e);var i=-r.textPoints[e][2];i!=t.angle&&(t.angle=i,t.rotation=Cesium.Math.toRadians(i))}}}static isFinished(){return l}}e.exports=m},{"./avoid/GAnnoAvoid":45,"./avoid/GCutLine":46}],42:[function(t,e,r){const i=t("./avoid/LabelDrawer"),a=t("./avoid/ParseLabelData"),n=t("./avoid/GridFilterLabel"),m=t("../../ext/LabelCollectionExt");e.exports=class{constructor(t,e,r,i,a,n,s,o,l,u,h,d,f){this.defaultHeight=t,this.name=e,this.xyz=r,this.tileSize=i,this.rectangle=a,this.sourceData=n,this.indexDbNames=s,this.styleFun=o,this.dataType=l,this.level=u,this.styleMap=h,this.textures=d,this.scene=f,this.labelCollection=new m({blendOption:Cesium.BlendOption.OPAQUE,enuEnabled:!1}),this.roadLabelCollection=new m({blendOption:Cesium.BlendOption.OPAQUE,enuEnabled:!0}),this.billboardCollection=new Cesium.BillboardCollection({blendOption:Cesium.BlendOption.OPAQUE}),this.ableAvoid=!0,this.ableWeight=!0,this.cellsize=4,this.maxPerCell=1,this.state=1,this.ready=!1,this.parse()}reset(){this.state=1,this.ready=!1,this.parse()}parse(){var t;"Binary"==this.dataType?(t=new i(this.sourceData,this.styleMap,this.level),this.styleFun.call({},t,this.level)):(r=new i(this.sourceData,this.styleMap,this.level),this.styleFun.call({},r,this.level));let e=a.parseLayerDatas(this.sourceData,this.styleMap,this.textures,this.xyz,!0);e.pointFeatures=n.removeTileOutPointFeatures(e.pointFeatures,this.tileSize);var r=n.fristFilter(e.pointFeatures,e.lineFeatures,this.styleMap,this.ableWeight,!0,this.tileSize,this.cellsize,.5*this.tileSize,this.maxPerCell);this.features=n.scendFilter(r.pointFeatures,r.lineFeatures,this.styleMap,this.ableWeight,!0,this.tileSize,this.cellsize,.5*this.tileSize),this.toLabelBillboards(this.features)}updateElevationData(t){this.elevationDataMap=t,this.toCartesian3(this.features),this.updateLabelPostion(this.features)}toCartesian3(e){for(let t=0;t<e.length;t++){let r=e[t];r.anglePositions=[];for(let e=0;e<r.sourceAngleData.length;e++){let t=[];var i=r.sourceAngleData[e],a=this.toLonLat([i[0][0],i[0][1]]);t.push(a),t.push(i[1]),r.anglePositions.push(t)}}}toLonLat(t){var e=t[0],r=t[1],i=Cesium.Math.toDegrees(this.rectangle.west+this.rectangle.width/this.tileSize*e),t=Cesium.Math.toDegrees(this.rectangle.north-this.rectangle.height/this.tileSize*r),r=this.getHeight(Math.round(e),Math.round(r));return Cesium.Cartesian3.fromDegrees(i,t,r)}getHeight(e,r){e=e==this.tileSize?this.tileSize-1:e,r=r==this.tileSize?this.tileSize-1:r;for(let t=this.indexDbNames.length-1;0<=t;t--){var i=this.indexDbNames[t],a=this.elevationDataMap[i];if(a){i=r*this.tileSize+e,i=a.data[i];if(0!=i)return i}}return this.defaultHeight}updateScreenPt(r){for(let t=0;t<r.length;t++){let e=r[t];e.datas=[];for(let t=0;t<e.anglePositions.length;t++){var i,a=e.anglePositions[t];a[0]?(i=Cesium.SceneTransforms.wgs84ToWindowCoordinates(this.scene,a[0]))?e.datas.push([[i.x,i.y],a[1]]):e.datas.push([[-50,-50],a[1]]):e.datas.push([[-50,-50],a[1]])}}}toLabelBillboards(e){for(let t=0;t<e.length;t++){var r=e[t];1==r.type&&this.toPointLabelOption(r),2==r.type&&this.toLineLabelOption(r)}}updateLabelPostion(e){for(let t=0;t<e.length;t++){let r=e[t];if(r.labelOptions)for(let e=0;e<r.labelOptions.length;e++){let t=r.labelOptions[e];t.position=r.anglePositions[e][0]}if(r.billboardOption&&(r.billboardOption.position=r.anglePositions[0][0]),r.labels)for(let e=0;e<r.labels.length;e++){let t=r.labels[e];t.position=r.anglePositions[e][0]}r.billboard&&(r.billboard.position=r.anglePositions[0][0])}}toPointLabelOption(t){t.labelOptions=[];var e=this.styleMap[t.styleId],r=t.iconImg?t.iconImg.width:0,r=e.graphicDistance+.5*r;let i={show:!1,disableDepthTestDistance:Number.POSITIVE_INFINITY,text:t.label+"",font:e.pointFillFont,style:Cesium.LabelStyle.FILL,verticalOrigin:Cesium.VerticalOrigin.CENTER,pixelOffset:new Cesium.Cartesian2(r,0),fillColor:Cesium.Color.fromCssColorString(e.pointFillStyle).withAlpha(e.pointFillAlpha)};1==e.pointHashBackground&&(i.showBackground=!0,i.backgroundColor=Cesium.Color.fromCssColorString(e.pointBackgroundColor).withAlpha(e.pointBackgroundAlpha),i.backgroundPadding=new Cesium.Cartesian2(e.pointBackgroundGap,e.pointBackgroundGap)),1==e.pointHashOutline&&(i.style=Cesium.LabelStyle.FILL_AND_OUTLINE,i.outlineColor=Cesium.Color.fromCssColorString(e.pointStrokeStyle).withAlpha(e.pointStrokeAlpha),i.outlineWidth=e.pointLineWidth+2),t.labelOptions.push(i),t.iconImg&&(e=this.toBillboardOption(t.iconImg,e),t.billboardOption=e)}toLineLabelOption(r){r.labelOptions=[];var i=this.styleMap[r.styleId];if("text"==r.lineType)if(1==i.lineHashBackground){Math.floor(r.sourceAngleData.length/2);let t={show:!1,disableDepthTestDistance:Number.POSITIVE_INFINITY,text:r.label+"",font:i.lineFillFont,style:Cesium.LabelStyle.FILL,verticalOrigin:Cesium.VerticalOrigin.CENTER,horizontalOrigin:Cesium.HorizontalOrigin.CENTER,fillColor:Cesium.Color.fromCssColorString(i.lineFillStyle).withAlpha(i.lineFillAlpha),showBackground:!0};t.backgroundColor=Cesium.Color.fromCssColorString(i.backgroundColor).withAlpha(i.backgroundAlpha),t.backgroundPadding=i.lineBackgroundGap,r.labelOptions.push(t)}else if(1==r.sourceAngleData.length){var e={show:!1,disableDepthTestDistance:Number.POSITIVE_INFINITY,text:r.label+"",font:i.lineFillFont,style:Cesium.LabelStyle.FILL,verticalOrigin:Cesium.VerticalOrigin.CENTER,horizontalOrigin:Cesium.HorizontalOrigin.CENTER,fillColor:Cesium.Color.fromCssColorString(i.lineFillStyle).withAlpha(i.lineFillAlpha)};r.labelOptions.push(e)}else for(let e=0;e<r.sourceAngleData.length;e++){var a=r.sourceAngleData[e];let t={show:!1,disableDepthTestDistance:Number.POSITIVE_INFINITY,text:(r.label+"").charAt(e),font:i.lineFillFont,style:Cesium.LabelStyle.FILL,verticalOrigin:Cesium.VerticalOrigin.CENTER,horizontalOrigin:Cesium.HorizontalOrigin.CENTER,rotation:Cesium.Math.toRadians(a[1]),fillColor:Cesium.Color.fromCssColorString(i.lineFillStyle).withAlpha(i.lineFillAlpha)};1==i.lineHashOutline&&(t.style=Cesium.LabelStyle.FILL_AND_OUTLINE,t.outlineColor=Cesium.Color.fromCssColorString(i.lineStrokeStyle).withAlpha(i.lineStrokeAlpha),t.outlineWidth=i.lineLineWidth),r.labelOptions.push(t)}if("code"==r.lineType){e=this.styleMap[r.styleId];let t={show:!1,disableDepthTestDistance:Number.POSITIVE_INFINITY,text:r.label+"",font:e.codeLineFillFont,style:Cesium.LabelStyle.FILL,verticalOrigin:Cesium.VerticalOrigin.CENTER,horizontalOrigin:Cesium.HorizontalOrigin.CENTER,fillColor:Cesium.Color.fromCssColorString(e.codeLineFillStyle).withAlpha(e.codeLineFillAlpha),showBackground:!0};t.backgroundColor=Cesium.Color.fromCssColorString(e.codeBackgroundColor).withAlpha(e.codeBackgroundAlpha),t.backgroundPadding=new Cesium.Cartesian2(e.codeLineBackgroundGap,e.codeLineBackgroundGap),1==e.codeLineHashOutline&&(t.style=Cesium.LabelStyle.FILL_AND_OUTLINE,t.outlineColor=Cesium.Color.fromCssColorString(e.codeLineStrokeStyle).withAlpha(e.codeLineStrokeAlpha),t.outlineWidth=e.codeLineLineWidth+2),r.labelOptions.push(t)}}toBillboardOption(t,e){let r=e.graphicWidth,i=e.graphicHeight;return r&&i||(r=t.width,i=t.height),{show:!1,disableDepthTestDistance:Number.POSITIVE_INFINITY,image:t,width:r,height:i}}addToMap(){1==this.state&&this.toDrawLabel(),0<this.labelCollection._labels.length&&this.scene.primitives.add(this.labelCollection),0<this.roadLabelCollection._labels.length&&this.scene.primitives.add(this.roadLabelCollection),0<this.billboardCollection._billboards.length&&this.scene.primitives.add(this.billboardCollection),this.updateNow(),this.state=2}toDrawLabel(){for(let t=0;t<this.features.length;t++){let e=this.features[t];if(e.labels=[],1==e.type){for(let t=0;t<e.labelOptions.length;t++)e.labels.push(this.labelCollection.add(e.labelOptions[t]));e.iconImg&&(e.billboard=this.billboardCollection.add(e.billboardOption))}if(2==e.type){if("text"==e.lineType)for(let t=0;t<e.labelOptions.length;t++)e.labels.push(this.roadLabelCollection.add(e.labelOptions[t]));if("code"==e.lineType)for(let t=0;t<e.labelOptions.length;t++)e.labels.push(this.labelCollection.add(e.labelOptions[t]))}}}updateNow(){0<this.labelCollection._labels.length&&this.labelCollection.update(this.scene._frameState),0<this.roadLabelCollection._labels.length&&this.roadLabelCollection.update(this.scene._frameState),0<this.billboardCollection._billboards.length&&this.billboardCollection.update(this.scene._frameState)}remove(){2==this.state&&(this.scene.primitives.remove(this.labelCollection),this.scene.primitives.remove(this.roadLabelCollection),this.scene.primitives.remove(this.billboardCollection),this.state=3)}show(){1!=this.state&&3!=this.state||this.addToMap()}destroy(){this.remove(),this.labelCollection.destroy(),this.roadLabelCollection.destroy(),this.billboardCollection.destroy(),this.isDestroy=!0}}},{"../../ext/LabelCollectionExt":14,"./avoid/GridFilterLabel":50,"./avoid/LabelDrawer":51,"./avoid/ParseLabelData":52}],43:[function(t,e,r){const h=Cesium.combine,l=Cesium.Credit,u=Cesium.defaultValue,d=Cesium.defined,f=Cesium.DeveloperError,m=Cesium.Event;Cesium.freezeObject;const v=Array.isArray,p=Cesium.Rectangle,c=Cesium.Resource,b=Cesium.WebMercatorTilingScheme,y=Cesium.when,V=Cesium.TimeDynamicImagery,q=t("./LabelTile"),x=t("./glyph/GlyphSource"),a=t("./AvoidTile"),i=t("../../utils/Buffer"),o=t("../../utils/VarintReader");var n=t("../ElevationImageryProvider");const W=t("../../utils/ElevationTool");let N={service:"WMTS",version:"1.0.0",request:"GetTile"};class s extends n{constructor(t,e){if(super(t,e),this.indexDbName="house_"+this.indexDbName,e=u(e,u.EMPTY_OBJECT),this.id=Math.random(),this.scene=t.scene,this.needDecode=u(e.needDecode,!1),this.defaultHeight=u(e.defaultHeight,0),!d(e.url))throw new f("options.url is required.");let r=c.createIfNeeded(e.url);var i=e.style,a=e.tileMatrixSetID;let n=r.url;0<=n.indexOf("{")?(r.setTemplateValues({style:i,Style:i,TileMatrixSet:a}),this._useKvp=!1):(r.setQueryParameters(N),this._useKvp=!0),this._resource=r,this._layer=e.layer,this._style=i,this._tileMatrixSetID=a,this._tileMatrixLabels=e.tileMatrixLabels,this._format=u(e.format,"image/jpeg"),this._tileDiscardPolicy=e.tileDiscardPolicy,this._tilingScheme=d(e.tilingScheme)?e.tilingScheme:new b({ellipsoid:e.ellipsoid}),this._tileWidth=u(e.tileWidth,256),this._tileHeight=u(e.tileHeight,256),this._minimumLevel=u(e.minimumLevel,0),this._maximumLevel=e.maximumLevel,this._rectangle=u(e.rectangle,this._tilingScheme.rectangle),this._dimensions=e.dimensions;let s=this;this._reload=void 0,d(e.times)&&(this._timeDynamicImagery=new V({clock:e.clock,times:e.times,requestImageFunction:function(t,e,r,i,a){return requestImage(s,t,e,r,i,a)},reloadFunction:function(){d(s._reload)&&s._reload()}})),this._readyPromise=y.defer();i=this._tilingScheme.positionToTileXY(p.southwest(this._rectangle),this._minimumLevel),a=this._tilingScheme.positionToTileXY(p.northeast(this._rectangle),this._minimumLevel),i=(Math.abs(a.x-i.x)+1)*(Math.abs(a.y-i.y)+1);if(4<i)throw new f("The imagery provider's rectangle and minimumLevel indicate that there are "+i+" tiles at the minimum level. Imagery providers with more than four tiles at the minimum level are not supported.");this._errorEvent=new m;i=e.credit;this._credit="string"==typeof i?new l(i):i,this._subdomains=e.subdomains,v(this._subdomains)?this._subdomains=this._subdomains.slice():d(this._subdomains)&&0<this._subdomains.length?this._subdomains=this._subdomains.split(""):this._subdomains=["a","b","c"],this.dataType="binary",e.hasOwnProperty("dataType")?this.dataType=e.dataType:this.dataType="Json",this.needDecode=e.needDecode,this.parseUrl(e.url);let o=this.loadStyle();if("binary"==this.dataType){i=this.host+"/mapserver/serverInfo/"+this.servername+".json?"+Math.random();let t=c.createIfNeeded(i);i=t.fetchJson();o.push(i)}this.hasTerrain=!1,"RGBWorldTerrainProvider"==t.terrainProvider.name&&(this.hasTerrain=!0),this.dbMap={},this.indexDbNames=this.getBottomProviderIndexDbNames();t=W.getDBMap(this.indexDbNames,this.dbMap).promise;o.push(t),Promise.all(o).then(function(t){var e=t[2];if(e&&e.layerMap)for(var r in this.serverInfo={},this.layerFieldMap={},e.layerMap)this.serverInfo[r]={geometryType:e.layerMap[r].geometryType,fieldsConfig:e.layerMap[r].fields},this.layerFieldMap[r]||(this.layerFieldMap[r]=e.layerMap[r].fields.length);this.ready={value:!0},this._readyPromise.resolve(!0)}.bind(this)),this.cache={},this.textures={},this.styleMap={},e.glyphUrl&&e.fontName&&(this.fontName=e.fontName,this.viewer.glyphSource||(this.viewer.glyphSource=new x(e.glyphUrl))),this.prevPosition=null,this.prevRenderTilesLength=-1,this.image=document.createElement("canvas")}updateStle(t){let e=c.createIfNeeded(t);var r=this._style,i=this.tileMatrixSetID;0<=(t=e.url).indexOf("{")?(e.setTemplateValues({style:r,Style:r,TileMatrixSet:i}),this._useKvp=!1):(e.setQueryParameters(N),this._useKvp=!0),this._resource=e,this.parseUrl(t),Promise.all(this.loadStyle()).then(function(){for(var e in this.cache){let t=this.cache[e];t.reset()}}.bind(this)),this.textures={},this.styleMap={}}draw(t){var e,r,i=this.getRenderTileMap(t);for(e in this.cache)if(!i[e]){let t=this.cache[e];t.remove()}let a=[];for(r in i){let t=this.cache[r];t&&t.ready&&(a.push(t),t.show(this.styleFun))}this.avoid(a)}avoid(t){var e=this.scene.camera.position;let r=100;this.prevPosition&&(r=Cesium.Cartesian3.distance(e,this.prevPosition));let i=Cesium.Math.toDegrees(this.viewer.camera.heading).toFixed(2);180<i&&(i-=360),10<r?(a.init(t,i,this.styleMap,this.viewer),this.prevPosition=new Cesium.Cartesian3(e.x,e.y,e.z)):((i!=this.prevHeading||this.prevRenderTilesLength!=t.length&&0<t.length)&&(a.setTiles(t,i),this.prevRenderTilesLength=t.length),this.prevHeading=i),a.isFinished()||a.avoidTile()}getRenderTileMap(e){let r={};for(let t=0;t<e.length;t++){var i=e[t].data.imagery;for(let t=0;t<i.length;t++){var a=i[t].readyImagery;a&&a.imageryLayer._imageryProvider.id==this.id&&(a=a.x+"_"+a.y+"_"+a.level,r[a]=!0)}}return r}parseUrl(t){let e=t.split("?"),r=e[0].split("/mapserver/");this.host=r[0],0<this._subdomains.length&&(this.host=this.host.replace("{s}",this._subdomains[0])),this.servername=r[1].split("/")[1],this.queryParam=e[1];var i=this.queryParam.split("&");for(let e=0;e<i.length;e++){let t=i[e];var a=t.split("=");if("styleId"==a[0])return void(this.styleId=a[1])}}loadStyle(){var t=this.host+"/mapserver/styleInfo/"+this.servername+"/"+this.styleId+"/label/style.js?"+Math.random();let e=c.createIfNeeded(t);var r=e.fetchText().then(function(t){"binary"==this.dataType?this.styleFun=new Function("render","level",t):this.styleFun=new Function("drawer","level",t)}.bind(this)),i=y.defer(),t=this.host+"/mapserver/styleInfo/"+this.servername+"/"+this.styleId+"/label/texture.js?"+Math.random();let a=c.createIfNeeded(t);return a.fetchText().then(function(i,t){var e,a=JSON.parse(t);let n=0;for(e in a)n++;if(0!=n){let r=0;for(var s in a){let t=new Image;t.name=s,t.onload=function(t){r++;var e=t.target.name;this.textures[e]=t.target,r==n&&i.resolve()}.bind(this),t.src=a[s]}}else i.resolve()}.bind(this,i)),[r,i.promise]}requestImageNow(e,r,i,t,a,n){var s=e._tileMatrixLabels,o=d(s)?s[t]:t.toString(),l=e._subdomains,s=e._dimensions,n=d(n)?n.data:void 0;let u;if(e._useKvp){let t={};t.tilematrix=o,t.layer=e._layer,t.style=e._style,t.tilerow=i,t.tilecol=r,t.tilematrixset=e._tileMatrixSetID,t.format=e._format,d(s)&&(t=h(t,s)),d(n)&&(t=h(t,n)),u=e._resource.getDerivedResource({queryParameters:t,request:a})}else{l={z:o,y:i.toString(),x:r.toString(),s:l[(r+i+t)%l.length]};u=e._resource.getDerivedResource({request:a}),u.setTemplateValues(l),d(s)&&u.setTemplateValues(s),d(n)&&u.setTemplateValues(n)}n=y.defer();if(this.requestJsonData(n,e,u,{x:r,y:i,z:t}))return n.promise}requestJsonData(t,e,r,i){let a=c.createIfNeeded(r),n=[],s=null;if(s="binary"==this.dataType?a.fetchArrayBuffer():a.fetchJson(),!s)return!1;n.push(s);r=r._templateValues.z;return y.all(n,function(t,e,r,i){i=i[0],i=this.jsonPromiseResult(e,r,i);let a=this.getStacks(i.features);e=e.x+"_"+e.y+"_"+e.z;let n=W.getElevation(this.dbMap,this.indexDbNames,e);n.then(function(t,e,r,i){e.updateElevationData(i),this.getGlyphs(a,function(t,e,r){e.labelCollection.setGlyphs(r),e.roadLabelCollection.setGlyphs(r),e.ready=!0,t.resolve(this.image)}.bind(this,t,e))}.bind(this,t,i,e))}.bind(this,t,i,r)),!0}jsonPromiseResult(e,r,i){"binary"==this.dataType&&(i=this.toBuffer(i),i=this.parseBinaryData(i));var a=i.label||i;if(i!={}){var n=e.x,s=e.y,o=e.z,i=this._tilingScheme.tileXYToRectangle(n,s,o),o=n+"_"+s+"_"+o;let t=this.cache[o];return t||(t=new q(this.defaultHeight,o,e,this.tileWidth,i,a,this.indexDbNames,this.styleFun,this.dataType,r,this.styleMap,this.textures,this.scene),this.cache[t.name]=t),t}}toBuffer(t){let e=new i(t.byteLength);var r=new Uint8Array(t);for(let t=0;t<e.length;++t)e[t]=r[t];return e}parseBinaryData(t){let i=new o(t,4,this.layerFieldMap);var e=i.getAllLayerNames();let a={};for(let t=0;t<e.length;t++){var n=e[t];a[n]={features:[],fieldsConfig:this.serverInfo[n]?this.serverInfo[n].fieldsConfig:{},type:1};let r=i.getGeometryType(n);var s=i.getLayerPro(n);if("point"==r.toLowerCase()?a[n].type=1:"line"!=r.toLowerCase()&&"linestring"!=r.toLowerCase()&&"multilinestring"!=r.toLowerCase()||(a[n].type=2),s&&0<s.length)for(let e=0;e<s.length;e++){let t=[];t.push(r),t.push(s[e]),t.push(i.getCoordinatesByIndex(n,e,10)),a[n].features.push(t)}}return a}getStacks(r){let i=[],t={};t[this.fontName]=i;let a=0;for(let t=0;t<r.length;t++){let e=r[t].label;if(e)for(let t=0;t<e.length;t++)i[a]=e.charCodeAt(t),a++}return i[a]="?".charCodeAt(0),t}getGlyphs(t,i){let a=Object.keys(t).length;const n={};for(const r in t)this.viewer.glyphSource.getSimpleGlyphs(r,t[r],e);function e(t,e,r){t&&console.error(t),n[r]=e,a--,0===a&&i(n)}}updateTileElevation(t,e){var r=t.x+"_"+t.y+"_"+t.z;let i=this.cache[r];if(!i)return!1;console.log("label图层重设高程:"+r);t=t.x+"_"+t.y+"_"+t.z;let a=W.getElevation(this.dbMap,this.indexDbNames,t);return a.then(function(t,e){i=this.cache[t],i&&i.updateElevationData(e)}.bind(this,r)),!0}get url(){return this._resource.url}get proxy(){return this._resource.proxy}get tileWidth(){return this._tileWidth}get tileHeight(){return this._tileHeight}get maximumLevel(){return this._maximumLevel}get minimumLevel(){return this._minimumLevel}get tilingScheme(){return this._tilingScheme}get rectangle(){return this._rectangle}get tileDiscardPolicy(){return this._tileDiscardPolicy}get errorEvent(){return this._errorEvent}get format(){return this._format}get readyPromise(){return this._readyPromise}get credit(){return this._credit}get hasAlphaChannel(){return!0}get clock(){return this._timeDynamicImagery.clock}set clock(t){this._timeDynamicImagery.clock=t}get times(){return this._timeDynamicImagery.times}set times(t){this._timeDynamicImagery.times=t}get dimensions(){return this._dimensions}set dimensions(t){this._dimensions!==t&&(this._dimensions=t,d(this._reload)&&this._reload())}getTileCredits(t,e,r){}requestImage(t,e,r,i){let a,n=this._timeDynamicImagery,s;return d(n)&&(s=n.currentInterval,a=n.getFromCache(t,e,r,i)),d(a)||(a=this.requestImageNow(this,t,e,r,i,s)),d(a)&&d(n)&&n.checkApproachingInterval(t,e,r,i),a}pickFeatures(t,e,r,i,a){}destroy(){for(var e in this.cache){let t=this.cache[e];t.destroy()}this.cache={}}removeImageryFromCache(t,e,r){r=t+"_"+e+"_"+r;let i=this.cache[r];i&&(i.destroy(),delete this.cache[r])}}e.exports=s},{"../../utils/Buffer":97,"../../utils/ElevationTool":101,"../../utils/VarintReader":109,"../ElevationImageryProvider":27,"./AvoidTile":41,"./LabelTile":42,"./glyph/GlyphSource":54}],44:[function(a,t,e){let n=null;t.exports=class{static getRealLength(t){for(var e=t.length,r=0,i=0;i<e;i++){var a=t.charCodeAt(i);r+=0<=a&&a<=128?.5:1}return r}static isNotNull(t){return!(!t&&0!=t)&&("string"!=typeof t||""!=(t=t.toLowerCase())&&"undefined"!=t&&"null"!=t)}static formatFont(t,i,e){var r=t;return e&&(null==n&&(n=a("./../../../../src/utils/font/Font")),(t=t.split(" ")).length-1!=0&&"italic"==t[0].toLowerCase()&&"simbei"!=t[arr.length-1]&&(t[t.length-1]=n.getDefaultFont()),t[t.length-1]="SimHei",r=t.join(" ")),r.replace(/(\d+\.?\d*)(px|em|rem|pt)/g,function(t,e,r){return(e=e<12?12*i:Math.round(e)*i)+r})}static formatLabel(t){return t=t&&(t=(t=(t+="").replace(/([\x00-\x1f\x7f])/g,"")).replace(/(\s*$)/g,"")).replace(/<br\/>/g,"")}static getAngle(t,e){if(e[0]-t[0]==0)return e[1]>t[0]?90:-90;t=(e[1]-t[1])/(e[0]-t[0]);return 360*Math.atan(t)/(2*Math.PI)}static getUpdateAngle(t,e){e=t-e;return 45<e&&e<=135?-90:135<e&&e<=225?-180:-225<=e&&e<-135?180:-135<=e&&e<-45?90:0}static updateAngle(t,e){e=t-e;return 45<e&&e<=135?t-90:135<e&&e<=225?t-180:-225<=e&&e<-135?t+180:-135<=e&&e<-45?t+90:t}static isChangeDirection(t,e,r,i){let a=!1;if(/.*[\u4e00-\u9fa5]+.*$/.test(t)){if(e[0]==r[0]&&e[1]>r[1])return a=!0,a;i<-45&&-90<i?e[0]<r[0]&&(a=!0):e[0]>r[0]&&(a=!0)}else e[0]>r[0]&&(a=!0);return a}static textToSameBearing(e){if(!(e.length<2))for(let t=1;t<e.length;t++){var r=e[t-1][1],i=e[t][1];45<Math.abs(i-r)&&(e[t][1]=0<i-r?i-90:i+90)}}}},{}],45:[function(t,e,r){const o=t("./GGridIndex"),i=t("./GLabelBox"),l=t("./Util");e.exports=class{constructor(t,e,r){this.ctx=t,this.grid=null,t||(this.grid=new o(4096,32,0)),this.GLabelBox=new i(t,e,r),this.featureMap={}}defaultAvoid(e,r,t,i,a){if(this.ctx&&(this.grid=t?new o(4096,32,0):new o(512,32,32)),null==e||e.length<1)return[];a&&l.sort(e,r,i);for(let t=0;t<e.length;t++){var n=e[t],s=r[n.styleId];this.avoidFeature(n,s),this.showOrHideFeature(n)}return e}avoidFeature(e,r){if(0!=r.show&&1!=e.hidden&&e.boxs){let t=!0;if(e.boxs)if(1==e.type)t=this.avoidPoint(e,r);else{if(e.isCollision)return void(e.hidden=!0);t=this.avoidLine(e,r)}e.hidden=!t}else e.hidden=!0}avoidPoint(t,e){return t.boxIndex=0,1==e.isImportant?(this.addBoxFeatureCells(t,e),!0):(e.isFourDirections||e.isEightDirections)&&e.texture?this.addFourCollisionFeatureToCells(t,e,0):!(t.boxIndexs&&!t.boxIndexs[0])&&(!this.isCollision(t.box)&&(this.addBoxFeatureCells(t,e),!0))}avoidLine(e,t){if(1==t.isImportant)return this.addBoxFeatureCells(e,t),!0;let r=!1;for(let t=0;t<e.boxs.length;t++){var i=e.boxs[t];if(this.isCollision(i)){r=!0;break}}return!r&&(this.addBoxFeatureCells(e,t),!0)}addFourCollisionFeatureToCells(t,e,r){let i=!0,a=[];return(!t.boxIndexs||t.boxIndexs&&t.boxIndexs[r])&&(a=t.boxs[r],i=this.isCollision(a)),i?(++r==t.boxs.length&&(r-=t.boxs.length),0!=r&&this.addFourCollisionFeatureToCells(t,e,r)):(t.boxIndex=r,t.box=a,this.addBoxFeatureCells(t,e),!0)}isCollision(t){var e=t[0],r=t[1],i=t[2],t=t[3];return 0<this.grid.query(e,r,i,t).length}getCollisionIds(t){var e=t[0],r=t[1],i=t[2],t=t[3];return this.grid.query(e,r,i,t)}getCollisionFeatureIds(r){if(1==r.type)return this.getCollisionIds(r.boxs[r.boxIndex]);if(2==r.type){let e=[];for(let t=0;t<r.boxs.length;t++){var i=this.getCollisionIds(r.boxs[t]);e=e.concat(i)}return e}}isShowCurrFeature(t,e,r){if(t.isImportant)return!0;var i=e.weight;for(let t=0;t<r.length;t++){var a=this.featureMap[r[t]];if(a){if(a.style.isImportant)return!1;if(a.feature.weight>=i)return!1}}return!0}hideCollisionFeatures(e,r){for(let t=0;t<r.length;t++){var i=this.featureMap[r[t]];if(i){let t=i.feature;i.style.isImportant&&t.objectId!=e.objectId||(t.hidden=!0,this.showOrHideFeature(t),this.removeBoxFeatureCells(t))}}}addBoxToCells(t,e,r){var i=r[0],a=r[1],n=r[2],r=r[3];this.grid.insert(e,i,a,n,r)}filterFeature(e){let r=[];for(let t=0;t<e.length;t++)e[t].hidden||(e[t].drawed=!0,r.push(e[t]));return r}addBoxFeatureCells(e,t){if(this.featureMap[e.primaryId]={feature:e,style:t},1==e.type&&this.addBoxToCells(e,e.primaryId,e.box),2==e.type)for(let t=0;t<e.boxs.length;t++){var r=e.boxs[t];this.addBoxToCells(e,e.primaryId,r)}}removeBoxFeatureCells(e){if(this.featureMap[e.primaryId]&&(delete this.featureMap[e.primaryId],1==e.type&&this.removeBoxToCells(e.primaryId,e.box),2==e.type))for(let t=0;t<e.boxs.length;t++){var r=e.boxs[t];this.removeBoxToCells(e.primaryId,r)}}removeBoxToCells(t,e){var r=e[0],i=e[1],a=e[2],e=e[3];this.grid.remove(t,r,i,a,e)}showOrHideFeature(r){var i=!r.hidden;if(r.labels)for(let e=0;e<r.labels.length;e++){let t=r.labels[e];t.show=i,1==r.type&&i&&(t.pixelOffset=r.offsetPostion[r.boxIndex])}r.iconImg&&(r.billboard.show=i)}}},{"./GGridIndex":48,"./GLabelBox":49,"./Util":53}],46:[function(t,e,r){const h=t("./GDistance"),d=t("./../../../utils/gistools/GisTools"),f=t("./AvoidUtil");e.exports=class{static cutLineFeature(t,e,r){let i=[];if(t.sourceData.length<4)return i;var a=this.createLineTextFeatrue(t,e,0,r),r=a.index;a.feature&&i.push(a.feature);a=this.createLineCodeFeatrue(t,e,r);r=a.index,a.feature&&i.push(a.feature);r=this.createLineArrowFeatrue(t,e,r);return r.feature&&i.push(r.feature),i}static createLineTextFeatrue(e,r,t,i,a){let n=e.sourceData;a&&(n=e[a]);let s=new h,o=[],l=null;if(i=i||1,f.isNotNull(e.label)){e.label=e.label+"";for(let t=0;t<e.label.length;t++)o.push((1.2*r.lineHeight+2+r.gap)*i);[].concat(o);var u=s.getNodePath(n,o),a=u.pointList;if(1<a.length){t=u.index;u=e.label.length-a.length;if(0<u){if(t=n.length,!(u<r.extendedNum))return{feature:null,index:t};this.delayTextPoint(n,a,e.label,(r.chinaLabelWidth+r.gap)*i)}f.textToSameBearing(a),l=this.cloneFeature(e),r.changeDirection,l.attributeId=e.attributeId+"_text",l.sourceAngleData=a,l.lineType="text"}l&&(r.lineOffset&&1<l.sourceAngleData.length&&(l.sourceAngleData=d.lineOffset(l.sourceAngleData,r.lineOffset)),l.textPoints=l.sourceAngleData,l.primaryId=l.attributeId+"_row_"+e.xyz.y+"_col_"+e.xyz.x+"_level_"+e.xyz.z+"_x_"+l.sourceAngleData[0][0][0]+"_y_"+l.sourceAngleData[0][0][1],l.id=l.attributeId+"_row_"+e.xyz.y+"_col_"+e.xyz.x+"_level_"+e.xyz.z+"_x_"+n[0]+"_y_"+n[1])}return{feature:l,index:t}}static createLineCodeFeatrue(t,e,r){let i=t.sourceData,a=new h,n=[],s=null;var o,l=t.roadCodeLabel;return e.showRoadCode&&f.isNotNull(l)&&r<i.length&&(o=i.slice(r,i.length-1),n.push(30),1==(o=(e=a.getNodePath(o,n)).pointList).length&&(r+=e.index,s=this.cloneFeature(t),s.attributeId=t.attributeId+"_code",s.sourceAngleData=o,s.lineType="code",s.label=l+""),0==o.length&&(s=this.cloneFeature(t),s.attributeId=t.attributeId+"_code",s.sourceAngleData=[[[i[0],i[1]],0]],s.lineType="code",s.label=l+"",r=2),s.textPoints=[s.sourceAngleData[0][0]],s.primaryId=s.attributeId+"_row_"+t.xyz.y+"_col_"+t.xyz.x+"_level_"+t.xyz.z+"_x_"+s.sourceAngleData[0][0][0]+"_y_"+s.sourceAngleData[0][0][1],s.id=s.attributeId+"_row_"+t.xyz.y+"_col_"+t.xyz.x+"_level_"+t.xyz.z+"_x_"+i[0]+"_y_"+i[1]),{feature:s,index:r}}static createLineArrowFeatrue(t,e,r){let i=t.sourceData,a=new h,n=[],s=null;return e.showArrow&&r<i.length&&(e=i.slice(r,i.length-1),n.push(16),n.push(16),2==(e=a.getNodePath(e,n).pointList).length&&(s=this.cloneFeature(t),s.attributeId=t.attributeId+"_arrow",s.sourceAngleData=e,s.textPoints=e,s.lineType="arrow",s.primaryId=s.attributeId+"_row_"+t.xyz.y+"_col_"+t.xyz.x+"_level_"+t.xyz.z+"_x_"+s.sourceAngleData[0][0][0]+"_y_"+s.sourceAngleData[0][0][1],s.id=s.attributeId+"_row_"+t.xyz.y+"_col_"+t.xyz.x+"_level_"+t.xyz.z+"_x_"+i[0]+"_y_"+i[1])),{feature:s,index:r}}static delayTextPoint(t,e,r,i){let a=null;a=1==e.length?[t[0],t[1]]:e[e.length-2][0];var n=e[e.length-1][0],s=e[e.length-1][1],o=e.length;for(let t=1;t<r.length-o+1;t++){var l=this.getPoint(a,n,i*t);e.push([l,s])}}static cloneFeature(t){return{type:t.type,datas:t.datas,centerPoint:t.centerPoint,sourceData:t.sourceData,label:t.label,roadCodeLabel:t.roadCodeLabel,attributes:t.attributes,attributeId:t.attributeId,styleId:t.styleId,textures:t.textures,xyz:t.xyz,lineType:t.lineType,weight:t.weight,layerName:t.layerName,objectId:t.objectId}}static getDistance(t,e){var r=e[0]-t[0],t=e[1]-t[1];return Math.pow(r*r+t*t,.5)}static getLineDistance(e){if(e.length<4)return 0;let r=0;for(let t=0;t<e.length/2-1;t++){var i=[e[2*t],e[2*t+1]],a=[e[2*(t+1)],e[2*(t+1)+1]];r+=this.getDistance(i,a)}return r}static getPoint(e,r,i){var a=r[0]-e[0],e=r[1]-e[1];let n=r[0],s=r[1];if(0==a)s=0<e?r[1]+i:r[1]-i;else{let t=Math.sqrt(i*i/(e/a*(e/a)+1));a<0&&(t=-t),n=r[0]+t,s=r[1]+e/a*t}return[n,s]}}},{"./../../../utils/gistools/GisTools":112,"./AvoidUtil":44,"./GDistance":47}],47:[function(t,e,r){e.exports=class{getLengthPoint(t,e,r,i,a,n){var s=r-t,o=i-e;let l,u;if(0==s)return l=r,u=0<o?e+a:e-a,null==n?[l,u]:[l,u,n];i=o/s,r=Math.sqrt(i*i+1),r=Math.abs(a/r),i=Math.abs(r*i);return l=0<s?t+r:t-r,u=0<o?e+i:e-i,null==n?[l,u]:[l,u,n]}getAngle(t,e){if(e[0]-t[0]==0)return e[1]>t[0]?90:-90;t=(e[1]-t[1])/(e[0]-t[0]);return 360*Math.atan(t)/(2*Math.PI)}length(t,e,r,i){t=r-t,e=i-e;return Math.sqrt(t*t+e*e)}getNodePath(t,e){let r=[],i={},a=[];function n(t){var e=t[0];return t.splice(0,1),e}var s=e.length;let o=n(e),l=0;for(;;){if(a.length==s)return i.index=l,i.pointList=a,i;if(l>=t.length)return i.index=l,i.pointList=a,i;var u=t[l],h=t[l+1];if(0!=r.length){var d=this.length(r[0],r[1],u,h);if(d>=o){var f=this.getLengthPoint(r[0],r[1],u,h,o,null);let t=this.getAngle(r,[u,h]);90==t&&(t=0),-90==t&&(t=0),0==t&&(t=.5),45<=t?t-=90:t<=-45&&(t+=90);var m=[f,t];a.push(m),r[0]=f[0],r[1]=f[1],o=n(e)}else o-=d,r[0]=u,r[1]=h,l+=2}else r[0]=u,r[1]=h}return i.index=l,i.pointList=a,i}}},{}],48:[function(t,e,r){e.exports=i;var d=3;function i(t,e,r){var i=this.cells=[];if(t instanceof ArrayBuffer){this.arrayBuffer=t;var a=new Int32Array(this.arrayBuffer);t=a[0],e=a[1],r=a[2],this.d=e+2*r;for(var n=0;n<this.d*this.d;n++){var s=a[d+n],o=a[d+n+1];i.push(s===o?null:a.subarray(s,o))}var l=a[d+i.length],u=a[d+i.length+1];this.keys=a.subarray(l,u),this.bboxes=a.subarray(u),this.insert=this._insertReadonly}else{this.d=e+2*r;for(var h=0;h<this.d*this.d;h++)i.push([]);this.keys=[],this.bboxes=[]}this.n=e,this.extent=t,this.padding=r,this.scale=e/t,this.uid=0;e=r/e*t;this.min=-e,this.max=t+e,this.keyUidMap={}}i.prototype.insert=function(t,e,r,i,a){this._forEachCell(e,r,i,a,this._insertCell,this.uid++),this.keyUidMap[t]=this.uid,this.keys.push(t),this.bboxes.push(e),this.bboxes.push(r),this.bboxes.push(i),this.bboxes.push(a)},i.prototype.remove=function(t,e,r,i,a){var e=this._convertToCellCoord(e),n=this._convertToCellCoord(r),s=this._convertToCellCoord(i),o=this._convertToCellCoord(a),l=this.keyUidMap[t];delete this.keyUidMap[t];for(var u=e;u<=s;u++)for(var h=n;h<=o;h++){var d=this.d*h+u;this.cells[d][l]=-1}},i.prototype._insertReadonly=function(){throw"Cannot insert into a GridIndex created from an ArrayBuffer."},i.prototype._insertCell=function(t,e,r,i,a,n){this.cells[a].push(n)},i.prototype.query=function(t,e,r,i){var a=this.min,n=this.max;if(t<=a&&e<=a&&n<=r&&n<=i)return Array.prototype.slice.call(this.keys);n=[];return this._forEachCell(t,e,r,i,this._queryCell,n,{}),n},i.prototype._queryCell=function(t,e,r,i,a,n,s){var o=this.cells[a];if(null!==o)for(var l=this.keys,u=this.bboxes,h=0;h<o.length;h++){var d,f=o[h];-1!=f&&void 0===s[f]&&(t<=u[2+(d=4*f)]&&e<=u[3+d]&&r>=u[0+d]&&i>=u[1+d]?(s[f]=!0,n.push(l[f])):s[f]=!1)}},i.prototype._forEachCell=function(t,e,r,i,a,n,s){for(var o=this._convertToCellCoord(t),l=this._convertToCellCoord(e),u=this._convertToCellCoord(r),h=this._convertToCellCoord(i),d=o;d<=u;d++)for(var f=l;f<=h;f++){var m=this.d*f+d;if(a.call(this,t,e,r,i,m,n,s))return}},i.prototype._convertToCellCoord=function(t){return Math.max(0,Math.min(this.d-1,Math.floor(t*this.scale)+this.padding))},i.prototype.toArrayBuffer=function(){if(this.arrayBuffer)return this.arrayBuffer;for(var t=this.cells,e=d+this.cells.length+1+1,r=0,i=0;i<this.cells.length;i++)r+=this.cells[i].length;var a=new Int32Array(e+r+this.keys.length+this.bboxes.length);a[0]=this.extent,a[1]=this.n,a[2]=this.padding;for(var n=e,s=0;s<t.length;s++){var o=t[s];a[d+s]=n,a.set(o,n),n+=o.length}return a[d+t.length]=n,a.set(this.keys,n),n+=this.keys.length,a[d+t.length+1]=n,a.set(this.bboxes,n),n+=this.bboxes.length,a.buffer}},{}],49:[function(t,e,r){const d=t("./AvoidUtil"),h=t("./Util");e.exports=class{constructor(t,e,r){this.boxDistance=0,this.ctx=t,this.formatFont=e,this.bearing=r}setBox(t,i,a){return t.forEach(function(t,e){t.hidden=!1;var r=i[t.styleId];0!=r.show?(1==t.type&&(a?this.setPointBox(t,t.datas,this.ctx,r):this.setPointBox(t,t.sourceAngleData,this.ctx,r)),2==t.type&&("text"==t.lineType&&(a?this.setTextLineBox(t,t.datas,this.ctx,r):this.setTextLineBox(t,t.sourceAngleData,this.ctx,r)),"code"==t.lineType&&(a?this.setCodeLineBox(t,t.datas,this.ctx,r):this.setCodeLineBox(t,t.sourceAngleData,this.ctx,r)),"arrow"==t.lineType&&(a?this.setArrowLineBox(t,t.datas,r):this.setArrowLineBox(t,t.sourceAngleData,r)))):t.hidden=!0}.bind(this)),t}setPointBox(a,r,n,s){if(s.isImportant=!1,s.labelFunction){let t=new Function("label",s.labelFunction);try{a.label=t.call({},a.attributes[s.labelfield])}catch(t){console.warn(a.label+": 调用labelFunction失败!")}}var o=d.isNotNull(a.label);if(o||a.iconImg){var l=this.getFontWidthHeight(n,a,s,o),u=l.graphicWidth,h=l.graphicHeight,n=l.fontWidth,o=l.fontHeight,l=l.maxFontheight;let t=s.pointOffsetX,e=s.pointOffsetY;t=t||0,e=e||0;let i=[r[0][0][0],r[0][0][1]];if(i[0]=i[0]+t,i[1]=i[1]+e,i[0]<0||i[1]<0)a.hidden=!0;else{s.pointBackgroundGap;s.pointHashBackground;let t=s.graphicDistance;0!=h&&0!=u||(t=0),s.hasOwnProperty("direction")||(s.direction=0);let e=[],r=[];r=s.texture?a.label?(e=this.getPointAvoidBox(i,s,t,u,h,n+2,l+2),this.getPointOffsetPosition(s,t,u,h,n,o)):(o=[i[0]-.5*u,i[1]-.5*o,i[0]+.5*u,i[1]+.5*o],o=this.boxScale(o,s.pointBoxDisance),e=[o],[new Cesium.Cartesian2(0,0)]):(l=[i[0]-.5*n,i[1]-.5*l,i[0]+.5*n,i[1]+.5*l],l=this.boxScale(l,s.pointBoxDisance),e=[l],[new Cesium.Cartesian2(.5*-n,0)]),a.boxs=e,a.offsetPostion=r,a.box=e[0]}}else a.hidden=!0}getFontWidthHeight(t,e,r,i){let a={},n=r.graphicWidth,s=r.graphicHeight;r=e.iconImg;return r?n&&s||(n=r.width,s=r.height):(n=0,s=0),a.graphicWidth=n,a.graphicHeight=s,a.fontWidth=n,a.fontHeight=s,i&&(e=e.labels[0],a.fontWidth=e.totalWidth,a.fontHeight=e.totalHeight,a.maxFontheight=a.fontHeight>s?a.fontHeight:s),a}getPointAvoidBox(t,e,r,i,a,n,s){var o=[t[0]-.5*i,t[1]-.5*s,t[0]+.5*i+r+n,t[1]+.5*s],l=[t[0]-.5*i-r-n,o[1],t[0]+.5*i,o[3]],i=[t[0]-.5*n,t[1]-.5*a,t[0]+.5*n,t[1]+.5*a+r+s],n=[i[0],t[1]-r-s-.5*a,i[2],t[1]+.5*a];let u=[o=this.boxScale(o,e.pointBoxDisance),l=this.boxScale(l,e.pointBoxDisance),i=this.boxScale(i,e.pointBoxDisance),n=this.boxScale(n,e.pointBoxDisance)];if(!e.isFourDirections&&!e.isEightDirections)return[u[e.direction]];if(e.isFourDirections)return 0<e.direction&&(h=u.splice(e.direction,1),u.unshift(h[0])),u;var r=[o[0],n[1],o[2],t[1]+.5*a],s=[o[0],t[1]-.5*a,o[2],i[3]],h=[l[0],n[1],l[2],t[1]+.5*a],a=[l[0],t[1]-.5*a,l[2],i[3]];return u=[o,l,i,n,r,s,h,a],0<e.direction&&(e=u.splice(e.direction,1),u.unshift(e[0])),u}getPointOffsetPosition(t,e,r,i,a,n){var s=new Cesium.Cartesian2(.5*r+e,0),o=new Cesium.Cartesian2(.5*-r-e-a,0),r=new Cesium.Cartesian2(.5*-a,e+.5*n+.5*i),a=new Cesium.Cartesian2(r.x,-e-.5*n-.5*i);let l=[s,o,r,a];if(!t.isFourDirections&&!t.isEightDirections)return[l[t.direction]];if(t.isFourDirections)return 0<t.direction&&(u=l.splice(t.direction,1),l.unshift(u[0])),l;var e=new Cesium.Cartesian2(s.x,a.y),n=new Cesium.Cartesian2(s.x,r.y),i=new Cesium.Cartesian2(o.x,a.y),u=new Cesium.Cartesian2(o.x,r.y);return l=[s,o,r,a,e,n,i,u],0<t.direction&&(t=l.splice(t.direction,1),l.unshift(t[0])),l}setTextLineBox(i,a,n,s){var o=i.label;let l=a;if(0!=l.length){i.textPoints=l;let r=[];if(1==s.lineHashBackground||1==l.length){let t=l[0][0];1<l.length&&(u=Math.floor(o.length/2),t=l[u][0]);let e=i.label.length*s.lineHeight;n&&(n.save(),this.formatFont?n.font=h.formatFont(s.lineFillFont,1,!0):n.font=s.lineFillFont,e=h.measureText(i.label,n.font,n),n.restore()),s.lineBackgroundGap||(s.lineBackgroundGap=0);var a=t[0]-e/2-s.lineBackgroundGap,u=t[0]+e/2+s.lineBackgroundGap,u=[a,t[1]-.5*s.lineHeight-s.lineBackgroundGap,u,t[1]+.5*s.lineHeight+s.lineBackgroundGap];this.boxScale(u,s.lineTextBoxDisance),r.push(u)}else{if(s.lineTextRotate||0==s.lineTextRotate)for(let t=0;t<l.length;t++)l[t][1]=s.lineTextRotate;else if(this.updateAngle(l),!s.isImportant&&this.isMessy(i,l,s,o))return void(i.hidden=!0);var t=this.getLineBoxs(o,l,s,n);if(!t)return void(i.hidden=!0);r=r.concat(t)}t=d.getAngle(l[0][0],l[l.length-1][0]),t=d.isChangeDirection(o,l[0][0],l[l.length-1][0],t);i.changeDirection=t,i.boxs=r}else i.hidden=!0}boxScale(t,e){return e||0==e||(e=this.boxDistance),t[0]=t[0]-.5*e,t[1]=t[1]-.5*e,t[2]=t[2]+.5*e,t[3]=t[3]+.5*e,t}setCodeLineBox(e,r,i,a){var n=r;if(0!=n.length){r=n[0][0];let t=e.label.length*a.codeLineHeight;i&&(i.save(),this.formatFont?i.font=h.formatFont(a.codeLineFillFont,1,!0):i.font=a.codeLineFillFont,t=h.measureText(e.label,i.font,i),i.restore());n=r[0]-t/2-a.codeLineBackgroundGap,i=r[0]+t/2+a.codeLineBackgroundGap,i=[n,r[1]-.5*a.codeLineHeight-a.codeLineBackgroundGap,i,r[1]+.5*a.codeLineHeight+a.codeLineBackgroundGap];this.boxScale(i,a.lineCodeBoxDisance),e.boxs=[i],e.codePoint=r}else e.hidden=!0}setArrowLineBox(t,e,r){var i,a,n,s=e;3==s.length?(i=s[0][0],n=s[1][0],a=(i[0]<n[0]?i:n)[0],e=(i[0]>n[0]?i:n)[0],n=[a,(i[1]<n[1]?i:n)[1],e,(i[1]>n[1]?i:n)[1]],this.boxScale(n,r.lineArrowBoxDisance),t.boxs=[n],t.arrowPoint=s):t.hiden=!0}isMessy(t,e,r,i){var a=e[0][0];let n=a[0],s=a[1],o=a[0],l=a[1],u=e[0][1],h=e[0][1];for(let t=0;t<i.length;t++){var d=e[t][0],f=e[t][1];d[0]>o&&(o=d[0]),d[0]<n&&(n=d[0]),d[1]>l&&(l=d[1]),d[1]<s&&(s=d[1]),f>h&&(h=f),f<u&&(u=f)}if(h-u>r.angle){if(0!=r.angleSwitch||!r.angleColor)return!0;t.lineFillStyle=r.angleColor}return!1}getLineBoxs(e,r,i,t){let a=[],n=[];for(let t=0;t<e.length;t++){var s=r[t][0];0==r[t][1]&&(r[t][1]=.5);var o=[s[0]-1.2*i.lineHeight*.5*1,s[1]-1.2*i.lineHeight*.5*1,s[0]+1.2*i.lineHeight*.5*1,s[1]+1.2*i.lineHeight*.5*1],s=[s[0]-.6*i.lineHeight*.25*1,s[1]-.6*i.lineHeight*.25*1,s[0]+.6*i.lineHeight*.25*1,s[1]+.6*i.lineHeight*.25*1];n.push(s),a.push(o)}if(!i.isImportant)for(let e=0;e<n.length-1;e++){var l=n[e];for(let t=e+1;t<n.length;t++){var u=n[t];if(this.crashBox(l,u))return null}}return a}crashBox(t,e){return t[0]<=e[2]&&t[2]>=e[0]&&t[1]<=e[3]&&t[3]>=e[1]}updateAngle(e){var r=d.getUpdateAngle(e[0][1],this.bearing);for(let t=0;t<e.length;t++)e[t][2]=e[t][1]+r}}},{"./AvoidUtil":44,"./Util":53}],50:[function(t,e,r){const l=t("./../../../utils/gistools/GridFilter"),h=t("./Util"),d=t("../../../utils/gistools/GisTools");class f{static fristFilter(t,e,r,i,a,n,s,o,l){return i&&a&&(h.sort(t),h.sort(e)),{pointFeatures:t=f.fristFilterStart(t,n,s,o,l),lineFeatures:e=f.fristFilterStart(e,n,s,o,l)}}static scendFilter(t,e,r,i,a,n,s,o,l){i&&a&&(h.sort(t),h.sort(e)),t=f.scendFilterStart(t,n,16,o),e=f.scendFilterStart(e,n,16,o);let u=[];return u=u.concat(t),u=u.concat(e),u}static removeTileOutPointFeatures(e,r){let i=[];for(let t=0;t<e.length;t++){var a=e[t],n=a.centerPoint;0<=n[0]&&n[0]<=r&&0<=n[1]&&n[1]<=r&&i.push(a)}return i}static removeTileOutLineFeatures(e,r){let i=[];for(let t=0;t<e.length;t++){var a=e[t];for(let t=0;t<a.datas.length;t++){var n=a.datas[t][0];if(0<=n[0]&&n[0]<=r&&0<=n[1]&&n[1]<=r){i.push(a);break}}}return i}static fristFilterStart(e,t,r,i,a){let n=new l(t,r,i,a),s=[];for(let t=0;t<e.length;t++){var o=e[t];n.filter(o.centerPoint[0],o.centerPoint[1])&&s.push(o)}return s}static scendFilterStart(e,t,r,i){let a=new l(t,r,i,1),n=[];for(let t=0;t<e.length;t++){var s=e[t];a.filterByBox(s.filterBox)&&n.push(s)}return n}static threeFilter(t,e,r){var t=f.getImportantOtherFeatures(t,e),i=h.groupByLabel(t.otherFeatures);let a=[];var n,s=[0,0,r,r];for(n in i){var o=i[n];if(1==o.length)a.push(o[0]);else{let r=[];for(let t=0;t<o.length;t++){var l=o[t];if(1==l.type&&(d.isInBox(l.box,s)?r:a).push(l),2==l.type){let e=!0;for(let t=0;t<l.boxs.length;t++){var u=l.boxs[t];if(!d.isInBox(u,s)){e=!1;break}}(e?r:a).push(l)}}0<r.length&&(r=h.sortPrimaryId(r),a=a.concat(f.distinctFeatures(r,e)))}}return a=a.concat(t.importantFeatures),a}static distinctFeatures(r,i){var t=r[0];let a="";1==t.type&&(a="distance"),2==t.type&&("text"==t.lineType&&(a="lineTextDistance"),"code"==t.lineType&&(a="lineCodeDistance"));let n=[];n.push(r[0]);for(let e=0;e<r.length-1;e++){var s=r[e];if(1!=s.hidden){let t=r[e+1];var o=f.getDistance(s.centerPoint,t.centerPoint),s=i[s.styleId];o<(s[a]||0)?t.hidden=!0:n.push(t)}}return n}static getDistance(t,e){var r=e[0]-t[0],t=e[1]-t[1];return Math.pow(r*r+t*t,.5)}static getImportantOtherFeatures(e,r){let i=[],a=[];for(let t=0;t<e.length;t++){var n=e[t];(r[n.styleId].isImportant?i:a).push(n)}return{otherFeatures:a,importantFeatures:i}}}e.exports=f},{"../../../utils/gistools/GisTools":112,"./../../../utils/gistools/GridFilter":113,"./Util":53}],51:[function(t,e,r){e.exports=class{constructor(t,e,r){this.layerDataMap=t,this.level=r,this.styleMap=e,this.propertyGetterMap={}}getLayer(t){this.layerDatas={};var e=this.layerDataMap[t];return null==e||null==e.features||(this.propertyGetterMap[t]=this.getProperty(e.fieldsConfig),this.layerDatas[t]=e),this}getAllLayer(){for(var t in this.layerDatas=this.layerDataMap,this.layerDataMap)this.propertyGetterMap[t]=this.getProperty(this.layerDataMap[t].fieldsConfig);return this}getGroupLayer(t,e){if(this.layerDatas={},0==e.split(",").length)return this;e=this.layerDataMap[t];return null==e||null==e.features||(this.propertyGetterMap[t]=this.getProperty(e.fieldsConfig),this.layerDatas[t]=e),this}getProperty(t){let e={},r=0;for(var i=0;i<t.length;i++)"true"!=t[i].id&&1!=t[i].id||(r=t[i].index),e[t[i].name]=parseInt(t[i].index);return{propertyConfig:e,idIndex:r}}setStyle(i){for(var t in this.layerDatas){var a=this.layerDatas[t];let r=this.propertyGetterMap[t];for(let t=0;t<a.features.length;t++){let e=a.features[t];var n=i.call({},this.level,function(t){return e[1][r.propertyConfig[t]]});n&&1==n.show&&(this.styleMap[n._id]||(this.styleMap[n._id]=n),e.avoidWeight=this.getWeight(n,e,r),e.styleId=n._id)}}}setGlobalStyle(t){this.globalStyle=t.call({})}getWeight(t,e,r){let i=e[1][r.propertyConfig[t.avoidField]];return i?(i=parseInt(i),isNaN(i)&&(i=0)):i=0,0==i&&t.avoidWeight?t.avoidWeight:i}draw(){}}},{}],52:[function(o,t,e){const l=o("./GCutLine"),h=o("./AvoidUtil");let u=null;class d{static parseLayerDatas(e,r,i,a,n){let s=[],o=[];for(var l in e)if("_layerAvoids"!=l){let t=e[l];t.xyz=a;var u,h=d.getProperty(t.fieldsConfig);1==t.type&&(u=d.parsePointLayer(t,l,h,r,i,n),s=s.concat(u)),2==t.type&&(h=d.parseLineLayer(t,l,h,r,n),o=o.concat(h))}return{pointFeatures:s,lineFeatures:o}}static parsePointLayer(r,i,a,n,s,o){let l=[];for(let e=0;e<r.features.length;e++){let t=r.features[e];var u=n[t.styleId];u&&(t.centerPoint=t[2],t.attributeId=i+"__"+t[1][a.idIndex],t.layerName=i,t.xyz=r.xyz,t.propertyGetter=a,t.type=r.type,t.weight=t.avoidWeight,null!=t.avoidWeight&&!isNaN(t.avoidWeight)||(t.avoidWeight=u.avoidWeight,t.weight=t.avoidWeight,null==t.weight&&(t.weight=0,t.avoidWeight=0)),u.isImportant&&(t.avoidWeight=99999999,t.weight=99999999),t=d.parsePoint(t,u,s,o),l.push(t))}return l}static parseLineLayer(r,i,a,n,s){let o=[];for(let e=0;e<r.features.length;e++){let t=r.features[e];var l=n[t.styleId];l&&(t.layerName=i,l=d.parseLine(t,l,r,a,s),o=o.concat(l))}return o}static parsePoint(e,r,t,i){if(i)e.iconImg=t[r.texture];else if(null==u&&(u=o("./../../../../src/process/texture/TextureManager")),r.texture){let t=u.getTexture(r.texture);null!=t&&(e.iconImg=t.toPattern(ratio))}e.attributes=d.getAttributes(e[1],e.propertyGetter);var a=e[2],n=[[a,0]],t=e.attributes[r.labelfield];e.primaryId=e.attributeId+"_row_"+e.xyz.y+"_col_"+e.xyz.x+"_level_"+e.xyz.z+"_x_"+n[0][0][0]+"_y_"+n[0][0][1],e.label=h.formatLabel(t),e.weight=e.avoidWeight;let s=0;return r.pointBoxDisance&&(s=.5*r.pointBoxDisance),e.filterBox=[e.centerPoint[0]-s,e.centerPoint[1]-s,e.centerPoint[0]+s,e.centerPoint[1]+s],e.sourceData=a,e.sourceAngleData=n,i&&(e.id=Math.round(256*Math.random()*256*256)),e}static parseLine(t,e,r,i,a){if(0==t[2].length)return[];var n=[];return d.processLineString(n,t[2],t,e,r,i,a),n}static processLineString(e,r,i,a,n,s,o){if(Array.isArray(r[0])){var l=r.length;for(let t=0;t<l;t++){var u=r[t];d.processLineString(e,u,i,a,n,s,o)}}else{var h=d.parseMultiLine(i,r,n,s,a,o);for(let t=0;t<h.length;t++)e.push(h[t])}}static parseMultiLine(t,e,r,i,a,n){var s=d.getAttributes(t[1],i);let o=[];var l=s[a.labelfield],u=s[a.roadCodeLabel],l=h.formatLabel(l),u=h.formatLabel(u),i=t[1][i.idIndex],i=t.layerName+"__"+i;t.avoidWeight;a.isImportant;t={type:r.type,sourceData:e,label:l,weight:t.avoidWeight,roadCodeLabel:u,attributes:s,attributeId:i,styleId:t.styleId,xyz:r.xyz,layerName:t.layerName};return o=o.concat(d.cutLineFeature(t,a,n,!1)),o}static cutLineFeature(r,i,a,t){if(a&&"_default__"==i.type)return r.sourceAngleData=d.lineToSourceAngleData(r.sourceData),[r];var n,s=l.cutLineFeature(r,i,1);let o=5;for(let e=0;e<s.length;e++){let t=s[e];t.primaryId=t.attributeId+"_row_"+r.xyz.y+"_col_"+r.xyz.x+"_level_"+r.xyz.z+"_x_"+t.sourceAngleData[0][0][0]+"_y_"+t.sourceAngleData[0][0][1],a&&(t.id=Math.round(256*Math.random()*256*256)),t.layerName=r.layerName,"text"==t.lineType&&(n=Math.floor(t.sourceAngleData.length/2),t.centerPoint=t.sourceAngleData[n][0],i.lineTextBoxDisance&&(o=.5*i.lineTextBoxDisance)),"code"==t.lineType&&(t.centerPoint=t.sourceAngleData[0][0],i.lineCodeBoxDisance&&(o=.5*i.lineCodeBoxDisance)),"arrow"==t.lineType&&(t.centerPoint=t.sourceAngleData[1][0]),t.filterBox=[t.centerPoint[0]-o,t.centerPoint[1]-o,t.centerPoint[0]+o,t.centerPoint[1]+o]}return s}static lineToSourceAngleData(e){let r=[];for(let t=0;t<e.length;t++){var i=e[t],a=e[t+1];r.push([[i,a],0]),t++}return r}static transformData(e,r,t,i,a,n){var s=i[0],i=i[3],o=(s-t[0])/a,l=(t[3]-i)/a;let u=[];for(let t=0;t<e.length;t++){var h=e[t][0],d=h[0]+r.x*n,h=h[1]+r.y*n;u.push([[d-o,h-l],e[t][1]])}return u}static toLonlat(t,e,r){return[CesiumMath.toDegrees(t.west+t.width/r*x),CesiumMath.toDegrees(t.north-t.height/r*y)]}static getProperty(t){let e={},r=0;for(var i=0;i<t.length;i++)"true"!=t[i].id&&1!=t[i].id||(r=t[i].index),e[t[i].name]=parseInt(t[i].index);return{propertyConfig:e,idIndex:r}}static getAttributes(t,e){let r={};var i,a=e.propertyConfig;for(i in a)r[i]=t[a[i]];return r}}t.exports=d},{"./AvoidUtil":44,"./GCutLine":46}],53:[function(t,e,r){e.exports=class{static measureText(t,e,r){return r.measureText(t).width}static sort(t,s,o){if(0<t.length)return t.sort(function(t,e){if(o){var r=s[t.styleId],i=s[e.styleId];if(r.isImportant&&!i.isImportant)return-1;if(i.isImportant&&!r.isImportant)return 1}let a=t.weight,n=e.weight;t=t.primaryId,e=e.primaryId;return a=a||-1,n=n||-1,a<n||a==n&&t<e?1:-1}.bind(this))}static sortPrimaryId(t){if(0<t.length)return t.sort(function(t,e){let r=t.weight,i=e.weight;t=t.primaryId,e=e.primaryId;return r=r||-1,i=i||-1,r<i||r==i&&t<e?1:-1}.bind(this))}static groupByLabel(e){let r={};for(let t=0;t<e.length;t++){var i=e[t];null==i.label&&null!=i.iconImg?(null==r[i.attributeId]&&(r[i.attributeId]=[]),r[i.attributeId].push(i)):(r[i.type+"_"+i.label]||(r[i.type+"_"+i.label]=[]),r[i.type+"_"+i.label].push(i))}return r}}},{}],54:[function(t,e,r){"use strict";const f=t("./verticalize_punctuation"),o=t("./glyphs"),l=t("pbf"),u=Cesium.Resource;e.exports=class{constructor(t){this.url=t,this.stacks={},this.loading={}}getSimpleGlyphs(s,e,o){void 0===this.stacks[s]&&(this.stacks[s]={});const l={},i=this.stacks[s];const u={};let h=0;var r=t=>{var e,r=Math.floor(t/256);i[r]?(e=i[r].glyphs[t])&&(l[t]=e):(void 0===u[r]&&(u[r]=[],h++),u[r].push(t))};for(let t=0;t<e.length;t++){var a=e[t],n=String.fromCharCode(a);r(a),f.lookup[n]&&r(f.lookup[n].charCodeAt(0))}h||o(void 0,l,s);var t=(t,e,r)=>{if(!t){var i=this.stacks[s][e]=r.stacks[0];for(let t=0;t<u[e].length;t++){var a=u[e][t],n=i.glyphs[a];n&&(l[a]=n)}}h--,h||o(void 0,l,s)};for(const d in u)this.loadRange(s,d,t)}loadRange(e,r,i){if(65535<256*r)return i("glyphs > 65535 not supported");void 0===this.loading[e]&&(this.loading[e]={});const a=this.loading[e];if(a[r])a[r].push(i);else{a[r]=[i];s=(n=e,s=256*r+"-"+(256*r+255),i=this.url,n=encodeURIComponent(e),i.replace("{fontstack}",n).replace("{range}",s));let t=new u({url:s});t.fetchArrayBuffer().then(function(t){var e=new o(new l(t));for(let t=0;t<a[r].length;t++)a[r][t](null,r,e);delete a[r]}.bind(this))}var n,s}}},{"./glyphs":55,"./verticalize_punctuation":58,pbf:7}],55:[function(t,e,r){"use strict";function n(t,e,r){1===t&&(r=r.readMessage(i,{glyphs:{}}),e.push(r))}function i(t,e,r){1===t?e.name=r.readString():2===t?e.range=r.readString():3===t&&(r=r.readMessage(a,{}),e.glyphs[r.id]=r)}function a(t,e,r){1===t?e.id=r.readVarint():2===t?e.bitmap=r.readBytes():3===t?e.width=r.readVarint():4===t?e.height=r.readVarint():5===t?e.left=r.readSVarint():6===t?e.top=r.readSVarint():7===t&&(e.advance=r.readVarint())}e.exports=function(t,e){this.stacks=t.readFields(n,[],e);for(var r=0;r<this.stacks.length;r++){var i,a=this.stacks[r].glyphs;for(i in a)!function(e){e.height=e.height+6,e.width=e.width+6;let r=new Uint8Array(4*e.bitmap.length);for(let t=0;t<e.bitmap.length;t++){var i=e.bitmap[t];0!=i&&(r[4*t+0]=i,r[4*t+1]=i,r[4*t+2]=i,r[4*t+3]=i)}e.arrayBufferView=r}(a[i])}}},{}],56:[function(t,e,r){"use strict";e.exports={"Latin-1 Supplement":t=>128<=t&&t<=255,Arabic:t=>1536<=t&&t<=1791,"Arabic Supplement":t=>1872<=t&&t<=1919,"Arabic Extended-A":t=>2208<=t&&t<=2303,"Hangul Jamo":t=>4352<=t&&t<=4607,"Unified Canadian Aboriginal Syllabics":t=>5120<=t&&t<=5759,"Unified Canadian Aboriginal Syllabics Extended":t=>6320<=t&&t<=6399,"General Punctuation":t=>8192<=t&&t<=8303,"Letterlike Symbols":t=>8448<=t&&t<=8527,"Number Forms":t=>8528<=t&&t<=8591,"Miscellaneous Technical":t=>8960<=t&&t<=9215,"Control Pictures":t=>9216<=t&&t<=9279,"Optical Character Recognition":t=>9280<=t&&t<=9311,"Enclosed Alphanumerics":t=>9312<=t&&t<=9471,"Geometric Shapes":t=>9632<=t&&t<=9727,"Miscellaneous Symbols":t=>9728<=t&&t<=9983,"Miscellaneous Symbols and Arrows":t=>11008<=t&&t<=11263,"CJK Radicals Supplement":t=>11904<=t&&t<=12031,"Kangxi Radicals":t=>12032<=t&&t<=12255,"Ideographic Description Characters":t=>12272<=t&&t<=12287,"CJK Symbols and Punctuation":t=>12288<=t&&t<=12351,Hiragana:t=>12352<=t&&t<=12447,Katakana:t=>12448<=t&&t<=12543,Bopomofo:t=>12544<=t&&t<=12591,"Hangul Compatibility Jamo":t=>12592<=t&&t<=12687,Kanbun:t=>12688<=t&&t<=12703,"Bopomofo Extended":t=>12704<=t&&t<=12735,"CJK Strokes":t=>12736<=t&&t<=12783,"Katakana Phonetic Extensions":t=>12784<=t&&t<=12799,"Enclosed CJK Letters and Months":t=>12800<=t&&t<=13055,"CJK Compatibility":t=>13056<=t&&t<=13311,"CJK Unified Ideographs Extension A":t=>13312<=t&&t<=19903,"Yijing Hexagram Symbols":t=>19904<=t&&t<=19967,"CJK Unified Ideographs":t=>19968<=t&&t<=40959,"Yi Syllables":t=>40960<=t&&t<=42127,"Yi Radicals":t=>42128<=t&&t<=42191,"Hangul Jamo Extended-A":t=>43360<=t&&t<=43391,"Hangul Syllables":t=>44032<=t&&t<=55215,"Hangul Jamo Extended-B":t=>55216<=t&&t<=55295,"Private Use Area":t=>57344<=t&&t<=63743,"CJK Compatibility Ideographs":t=>63744<=t&&t<=64255,"Arabic Presentation Forms-A":t=>64336<=t&&t<=65023,"Vertical Forms":t=>65040<=t&&t<=65055,"CJK Compatibility Forms":t=>65072<=t&&t<=65103,"Small Form Variants":t=>65104<=t&&t<=65135,"Arabic Presentation Forms-B":t=>65136<=t&&t<=65279,"Halfwidth and Fullwidth Forms":t=>65280<=t&&t<=65519}},{}],57:[function(t,e,r){"use strict";const i=t("./is_char_in_unicode_block");e.exports.allowsIdeographicBreaking=function(t){for(const e of t)if(!r.charAllowsIdeographicBreaking(e.charCodeAt(0)))return!1;return!0},e.exports.allowsVerticalWritingMode=function(t){for(const e of t)if(r.charHasUprightVerticalOrientation(e.charCodeAt(0)))return!0;return!1},e.exports.allowsLetterSpacing=function(t){for(const e of t)if(!r.charAllowsLetterSpacing(e.charCodeAt(0)))return!1;return!0},e.exports.charAllowsLetterSpacing=function(t){return!i.Arabic(t)&&(!i["Arabic Supplement"](t)&&(!i["Arabic Extended-A"](t)&&(!i["Arabic Presentation Forms-A"](t)&&!i["Arabic Presentation Forms-B"](t))))},e.exports.charAllowsIdeographicBreaking=function(t){return!(t<11904)&&(!!i["Bopomofo Extended"](t)||(!!i.Bopomofo(t)||(!!i["CJK Compatibility Forms"](t)||(!!i["CJK Compatibility Ideographs"](t)||(!!i["CJK Compatibility"](t)||(!!i["CJK Radicals Supplement"](t)||(!!i["CJK Strokes"](t)||(!!i["CJK Symbols and Punctuation"](t)||(!!i["CJK Unified Ideographs Extension A"](t)||(!!i["CJK Unified Ideographs"](t)||(!!i["Enclosed CJK Letters and Months"](t)||(!!i["Halfwidth and Fullwidth Forms"](t)||(!!i.Hiragana(t)||(!!i["Ideographic Description Characters"](t)||(!!i["Kangxi Radicals"](t)||(!!i["Katakana Phonetic Extensions"](t)||(!!i.Katakana(t)||(!!i["Vertical Forms"](t)||(!!i["Yi Radicals"](t)||!!i["Yi Syllables"](t))))))))))))))))))))},r.charHasUprightVerticalOrientation=function(t){return 746===t||747===t||!(t<4352)&&(!!i["Bopomofo Extended"](t)||(!!i.Bopomofo(t)||(!(!i["CJK Compatibility Forms"](t)||65097<=t&&t<=65103)||(!!i["CJK Compatibility Ideographs"](t)||(!!i["CJK Compatibility"](t)||(!!i["CJK Radicals Supplement"](t)||(!!i["CJK Strokes"](t)||(!(!i["CJK Symbols and Punctuation"](t)||12296<=t&&t<=12305||12308<=t&&t<=12319||12336===t)||(!!i["CJK Unified Ideographs Extension A"](t)||(!!i["CJK Unified Ideographs"](t)||(!!i["Enclosed CJK Letters and Months"](t)||(!!i["Hangul Compatibility Jamo"](t)||(!!i["Hangul Jamo Extended-A"](t)||(!!i["Hangul Jamo Extended-B"](t)||(!!i["Hangul Jamo"](t)||(!!i["Hangul Syllables"](t)||(!!i.Hiragana(t)||(!!i["Ideographic Description Characters"](t)||(!!i.Kanbun(t)||(!!i["Kangxi Radicals"](t)||(!!i["Katakana Phonetic Extensions"](t)||(!(!i.Katakana(t)||12540===t)||(!(!i["Halfwidth and Fullwidth Forms"](t)||65288===t||65289===t||65293===t||65306<=t&&t<=65310||65339===t||65341===t||65343===t||65371<=t&&t<=65503||65507===t||65512<=t&&t<=65519)||(!(!i["Small Form Variants"](t)||65112<=t&&t<=65118||65123<=t&&t<=65126)||(!!i["Unified Canadian Aboriginal Syllabics"](t)||(!!i["Unified Canadian Aboriginal Syllabics Extended"](t)||(!!i["Vertical Forms"](t)||(!!i["Yijing Hexagram Symbols"](t)||(!!i["Yi Syllables"](t)||!!i["Yi Radicals"](t))))))))))))))))))))))))))))))},r.charHasNeutralVerticalOrientation=function(t){return!(!i["Latin-1 Supplement"](t)||167!==t&&169!==t&&174!==t&&177!==t&&188!==t&&189!==t&&190!==t&&215!==t&&247!==t)||(!(!i["General Punctuation"](t)||8214!==t&&8224!==t&&8225!==t&&8240!==t&&8241!==t&&8251!==t&&8252!==t&&8258!==t&&8263!==t&&8264!==t&&8265!==t&&8273!==t)||(!!i["Letterlike Symbols"](t)||(!!i["Number Forms"](t)||(!(!i["Miscellaneous Technical"](t)||!(8960<=t&&t<=8967||8972<=t&&t<=8991||8996<=t&&t<=9e3||9003===t||9085<=t&&t<=9114||9150<=t&&t<=9165||9167===t||9169<=t&&t<=9179||9186<=t&&t<=9215))||(!(!i["Control Pictures"](t)||9251===t)||(!!i["Optical Character Recognition"](t)||(!!i["Enclosed Alphanumerics"](t)||(!!i["Geometric Shapes"](t)||(!(!i["Miscellaneous Symbols"](t)||9754<=t&&t<=9759)||(!(!i["Miscellaneous Symbols and Arrows"](t)||!(11026<=t&&t<=11055||11088<=t&&t<=11097||11192<=t&&t<=11243))||(!!i["CJK Symbols and Punctuation"](t)||(!!i.Katakana(t)||(!!i["Private Use Area"](t)||(!!i["CJK Compatibility Forms"](t)||(!!i["Small Form Variants"](t)||(!!i["Halfwidth and Fullwidth Forms"](t)||(8734===t||8756===t||8757===t||9984<=t&&t<=10087||10102<=t&&t<=10131||65532===t||65533===t)))))))))))))))))},r.charHasRotatedVerticalOrientation=function(t){return!(r.charHasUprightVerticalOrientation(t)||r.charHasNeutralVerticalOrientation(t))}},{"./is_char_in_unicode_block":56}],58:[function(t,n,e){"use strict";const s=t("./script_detection");n.exports=function(e){let r="";for(let t=0;t<e.length;t++){var i=e.charCodeAt(t+1)||null,a=e.charCodeAt(t-1)||null;(!i||!s.charHasRotatedVerticalOrientation(i)||n.exports.lookup[e[t+1]])&&(!a||!s.charHasRotatedVerticalOrientation(a)||n.exports.lookup[e[t-1]])&&n.exports.lookup[e[t]]?r+=n.exports.lookup[e[t]]:r+=e[t]}return r},n.exports.lookup={"!":"︕","#":"#",$:"$","%":"%","&":"&","(":"︵",")":"︶","*":"*","+":"+",",":"︐","-":"︲",".":"・","/":"/",":":"︓",";":"︔","<":"︿","=":"=",">":"﹀","?":"︖","@":"@","[":"﹇","\\":"\","]":"﹈","^":"^",_:"︳","`":"`","{":"︷","|":"―","}":"︸","~":"~","¢":"¢","£":"£","¥":"¥","¦":"¦","¬":"¬","¯":" ̄","–":"︲","—":"︱","‘":"﹃","’":"﹄","“":"﹁","”":"﹂","…":"︙","‧":"・","₩":"₩","、":"︑","。":"︒","〈":"︿","〉":"﹀","《":"︽","》":"︾","「":"﹁","」":"﹂","『":"﹃","』":"﹄","【":"︻","】":"︼","〔":"︹","〕":"︺","〖":"︗","〗":"︘","!":"︕","(":"︵",")":"︶",",":"︐","-":"︲",".":"・",":":"︓",";":"︔","<":"︿",">":"﹀","?":"︖","[":"﹇","]":"﹈","_":"︳","{":"︷","|":"―","}":"︸","⦅":"︵","⦆":"︶","。":"︒","「":"﹁","」":"﹂"}},{"./script_detection":57}],59:[function(t,e,r){Cesium.Cartesian3,Cesium.Color,Cesium.defined,Cesium.CallbackProperty,Cesium.Math;const c=Cesium.when;Cesium.Matrix4,Cesium.Cartesian4;e.exports=class{constructor(t,e,r,i,a,n){this.name=t,this.level=r,this.viewer=i,this.options=a,this.type="model",this.state=1,this.modelArray=[],this.urlMap=a.urlTypeLevelMap,this.readyPromise=c.defer(),this.ready=!1,this.load(e)}load(t){let r={};for(var e in t){var i=t[e];for(let e=0;e<i.length;e++){var a=i[e],n=a.properties[this.options.modelTypeField];r[n]||(r[n]=[]);var s=Number(a.properties[this.options.headingField]),o=Number(a.properties[this.options.scaleField]),l=Number(a.properties[this.options.lonField]),u=Number(a.properties[this.options.latField]),h=this.options.hasOwnProperty("addHeight")?Number(this.options.addHeight):0;let t=Number(a.properties[this.options.heightField]);t=t||0,t+=h;u=Cesium.Cartesian3.fromDegrees(l,u,t),s=Cesium.Transforms.headingPitchRollToFixedFrame(u,new Cesium.HeadingPitchRoll(Cesium.Math.toRadians(s),Cesium.Math.toRadians(0),Cesium.Math.toRadians(0)));Cesium.Matrix4.multiplyByUniformScale(s,o,s),r[n].push({modelMatrix:s})}}let d=[];for(var f in r){var m=r[f];if(this.urlMap[f]&&this.urlMap[f][this.level]){var v=this.urlMap[f][this.level];for(let e=0;e<m.length;e++){var p=m[e];let t=Cesium.ModelExperimental.fromGltf({asynchronous:!1,gltf:v,modelMatrix:p.modelMatrix});this.modelArray.push(t),t.update(this.viewer.scene.frameState),d.push(t.readyPromise)}}}c.all(d).always(function(t){this.state=2,this.readyPromise.resolve(),this.ready=!0}.bind(this))}remove(){for(let t=0;t<this.modelArray.length;t++)this.viewer.scene.primitives.remove(this.modelArray[t]);this.state=4}destroy(){this.remove();for(let e=0;e<this.modelArray.length;e++){let t=this.modelArray[e];t.finishedDestroy||(t.destroy(),t.finishedDestroy=!0)}this.modelArray=[],this.destroyed=!0}addToPrimitives(){for(let t=0;t<this.modelArray.length;t++)this.viewer.scene.primitives.add(this.modelArray[t]);this.state=3}showPrimitive(t){}show(t){2!=this.state&&4!=this.state||this.addToPrimitives()}}},{}],60:[function(t,e,r){const h=Cesium.combine,u=Cesium.Credit,d=Cesium.defaultValue,f=Cesium.defined,m=Cesium.DeveloperError,v=Cesium.Event;Cesium.freezeObject;const p=Array.isArray,c=Cesium.Rectangle,b=Cesium.Resource,y=Cesium.WebMercatorTilingScheme,V=Cesium.when;Cesium.ImageryProvider;const q=Cesium.TimeDynamicImagery,x=Cesium.RequestState,n=t("./ModelDataSource");var t=t("../ElevationImageryProvider"),W={service:"WMTS",version:"1.0.0",request:"GetTile"};class i extends t{constructor(e,t,r){if(super(e,t),this.options=t,this.indexDbName="house_"+this.indexDbName,t=d(t,d.EMPTY_OBJECT),this.id=Math.random(),this.needDecode=d(t.needDecode,!1),!f(t.url))throw new m("options.url is required.");var i=b.createIfNeeded(t.url),a=t.style,n=t.tileMatrixSetID;0<=i.url.indexOf("{")?(i.setTemplateValues({style:a,Style:a,TileMatrixSet:n}),this._useKvp=!1):(i.setQueryParameters(W),this._useKvp=!0),this._resource=i,this._layer=t.layer,this._style=a,this._tileMatrixSetID=n,this._tileMatrixLabels=t.tileMatrixLabels,this._format=d(t.format,"image/jpeg"),this._tileDiscardPolicy=t.tileDiscardPolicy,this._tilingScheme=f(t.tilingScheme)?t.tilingScheme:new y({ellipsoid:t.ellipsoid}),this._tileWidth=d(t.tileWidth,256),this._tileHeight=d(t.tileHeight,256),this._minimumLevel=d(t.minimumLevel,0),this._maximumLevel=t.maximumLevel,this._rectangle=d(t.rectangle,this._tilingScheme.rectangle),this._dimensions=t.dimensions;var s=this;this._reload=void 0,f(t.times)&&(this._timeDynamicImagery=new q({clock:t.clock,times:t.times,requestImageFunction:function(t,e,r,i,a){return requestImage(s,t,e,r,i,a)},reloadFunction:function(){f(s._reload)&&s._reload()}})),this._readyPromise=V.defer();a=this._tilingScheme.positionToTileXY(c.southwest(this._rectangle),this._minimumLevel),n=this._tilingScheme.positionToTileXY(c.northeast(this._rectangle),this._minimumLevel),a=(Math.abs(n.x-a.x)+1)*(Math.abs(n.y-a.y)+1);if(4<a)throw new m("The imagery provider's rectangle and minimumLevel indicate that there are "+a+" tiles at the minimum level. Imagery providers with more than four tiles at the minimum level are not supported.");this._errorEvent=new v;a=t.credit;this._credit="string"==typeof a?new u(a):a,this._subdomains=t.subdomains,p(this._subdomains)?this._subdomains=this._subdomains.slice():f(this._subdomains)&&0<this._subdomains.length?this._subdomains=this._subdomains.split(""):this._subdomains=["a","b","c"],this.dataType="binary",t.hasOwnProperty("dataType")?this.dataType=t.dataType:this.dataType="Json",this.hasTerrain=!1,"RGBWorldTerrainProvider"==e.terrainProvider.name&&(this.hasTerrain=!0),"binary"==this.dataType?this.processor=new Cesium.TaskProcessor("ModelPointBinaryWorker",Number.POSITIVE_INFINITY):this.processor=new Cesium.TaskProcessor("ModelPointWorker",Number.POSITIVE_INFINITY),Cesium.FeatureDetection.supportsWebP.initialize(),this.parseUrl(t.url);let o=this.parseModelUrlMap(),l=o.promiseArr;l.push(this.loadStyle()),V.all(l).always(function(){for(let t=0;t<o.modelArr.length;t++)e.scene.primitives.remove(o.modelArr[t]);this.ready={value:!0},this._readyPromise.resolve(!0)}.bind(this)),this.cache={},this.lightMap={},this.showLevel=t.showLevel||16,this.image=document.createElement("canvas"),this.showTilesMap={}}parseModelUrlMap(){let r=[];if(this.options.urlMap){let t={};for(var i in this.options.urlMap){var a,n=this.options.urlMap[i];let e={};for(a in n){var s=a.split("-"),o=s[0],l=s[1];for(let t=o;t<=l;t++)e[t]=n[a];r.push(n[a])}t[i]=e}this.options.urlTypeLevelMap=t}var e=Cesium.Transforms.headingPitchRollToFixedFrame(Cesium.Cartesian3.fromDegrees(0,0,0),new Cesium.HeadingPitchRoll(Cesium.Math.toRadians(0),Cesium.Math.toRadians(0),Cesium.Math.toRadians(0)));let u=[],h=[];for(let t=0;t<r.length;t++){var d=Cesium.ModelExperimental.fromGltf({asynchronous:!1,gltf:r[t],modelMatrix:e});u.push(d.readyPromise),h.push(d),viewer.scene.primitives.add(d)}return{promiseArr:u,modelArr:h}}draw(t){Cesium.cleanScreenTiles&&(this.showTilesMap={},Cesium.cleanScreenTiles=!1);var e,r,i=this.getRenderTileMap(t);for(e in this.cache)if(!i[e]){let t=this.cache[e];t.remove()}for(r in i){let t=this.cache[r];t&&(t.show(this.styleFun),this.showTilesMap[r]||(this.showTilesMap[r]=!0))}}getRenderTileMap(e){let r={};for(let t=0;t<e.length;t++){var i=e[t].data.imagery;for(let t=0;t<i.length;t++){var a=i[t].readyImagery;a&&a.imageryLayer._imageryProvider.id==this.id&&(a=a.x+"_"+a.y+"_"+a.level,r[a]=!0)}}return r}parseUrl(t){let e=t.split("?"),r=e[0].split("/mapserver/");this.host=r[0],0<this._subdomains.length&&(this.host=this.host.replace("{s}",this._subdomains[0])),this.servername=r[1].split("/")[1],this.queryParam=e[1];var i=this.queryParam.split("&");for(let e=0;e<i.length;e++){let t=i[e];var a=t.split("=");"styleId"==a[0]&&(this.styleId=a[1]),"return_type"==a[0]&&(this.return_type=a[1])}}loadStyle(){let e=[];var r=this.host+"/mapserver/styleInfo/"+this.servername+"/"+this.styleId+"/layer/style.js?"+Math.random();let t=b.createIfNeeded(r);r=t.fetchText();e.push(r);if("binary"==this.dataType){var r=this.host+"/mapserver/serverInfo/"+this.servername+".json?"+Math.random();let t=b.createIfNeeded(r);r=t.fetchJson(),e.push(r)}let n=V.defer();return V.all(e,function(t){var e=t[0],r=t[1];let i={init:!0,styleStr:e,tileSize:this._tileWidth,return_type:this.return_type,hasTerrain:this.hasTerrain};if(r&&r.layerMap){for(var a in this.serverInfo={},this.layerFieldMap={},r.layerMap)this.serverInfo[a]={geometryType:r.layerMap[a].geometryType,fieldsConfig:r.layerMap[a].fields},this.layerFieldMap[a]||(this.layerFieldMap[a]=r.layerMap[a].fields.length);i.serverInfo=this.serverInfo,i.layerFieldMap=this.layerFieldMap}i.indexDbNames=this.getBottomProviderIndexDbNames(),i.indexDbName=this.indexDbName;e=this.processor.scheduleTask(i);V.all(e,function(){n.resolve()})}.bind(this)),[n.promise]}requestImageNow(t,e,r,i,a,n){var s,o=t._tileMatrixLabels,l=f(o)?o[i]:i.toString(),u=t._subdomains,o=t._dimensions,n=f(n)?n.data:void 0;t._useKvp?((s={}).tilematrix=l,s.layer=t._layer,s.style=t._style,s.tilerow=r,s.tilecol=e,s.tilematrixset=t._tileMatrixSetID,s.format=t._format,f(o)&&(s=h(s,o)),f(n)&&(s=h(s,n)),s=t._resource.getDerivedResource({queryParameters:s,request:a})):(u={z:l,y:r.toString(),x:e.toString(),s:u[(e+r+i)%u.length]},(s=t._resource.getDerivedResource({request:a})).setTemplateValues(u),f(o)&&s.setTemplateValues(o),f(n)&&s.setTemplateValues(n));n=V.defer(),i={x:e,y:r,z:i};return s._templateValues.z<this.showLevel?n.reject():this.requestJsonData(n,t,s,i,a),n.promise}requestJsonData(e,t,r,i,a){var n=i.x,s=i.y,o=i.z,l=r._templateValues.z;if(this.cache[n+"_"+s+"_"+o]||0==o)return e.resolve(this.image),e;s=this._tilingScheme.tileXYToRectangle(i.x,i.y,i.z),o={west:s.west,north:s.north,width:s.width,height:s.height},s=i.x+"_"+i.y+"_"+i.z;let u=this.processor.scheduleTask({url:r.url,xyz:s,needDecode:this.options.needDecode,level:l,filterLayerId:this.options.filterLayerId,ridingLanternLayerId:this.options.ridingLanternLayerId,ridingLanternHeight:this.ridingLanternHeight,ridingLanternColor:this.ridingLanternColor,ridingLanternAlpha:this.ridingLanternAlpha,ridingLanternType:this.ridingLanternType,ridingLanternSpeed:this.ridingLanternSpeed,waterLayerId:this.options.waterLayerId,rectangle:o});return u.then(function(t,e,r,i,a){if(1==a)return i.state=x.CANCELLED,void t.reject();this.jsonPromiseResult(t,e,r,a),this.updateOtherProviderElevation(e)}.bind(this,e,i,l,a),function(t){e.reject()}),!0}jsonPromiseResult(t,e,r,i){e=e.x+"_"+e.y+"_"+e.z;let a=new n(e,i,r,this.viewer,this.options,this.lightMap);this.cache[a.name]=a,a.readyPromise.promise.then(function(){t.resolve(this.image)}.bind(this),function(){t.reject()})}updateTileElevation(t,e){t=t.x+"_"+t.y+"_"+t.z;return!!this.cache[t]}get url(){return this._resource.url}get proxy(){return this._resource.proxy}get tileWidth(){return this._tileWidth}get tileHeight(){return this._tileHeight}get maximumLevel(){return this._maximumLevel}get minimumLevel(){return this._minimumLevel}get tilingScheme(){return this._tilingScheme}get rectangle(){return this._rectangle}get tileDiscardPolicy(){return this._tileDiscardPolicy}get errorEvent(){return this._errorEvent}get format(){return this._format}get readyPromise(){return this._readyPromise}get credit(){return this._credit}get hasAlphaChannel(){return!0}get clock(){return this._timeDynamicImagery.clock}set clock(t){this._timeDynamicImagery.clock=t}get times(){return this._timeDynamicImagery.times}set times(t){this._timeDynamicImagery.times=t}get dimensions(){return this._dimensions}set dimensions(t){this._dimensions!==t&&(this._dimensions=t,f(this._reload)&&this._reload())}getTileCredits(t,e,r){}requestImage(t,e,r,i){var a,n,s=this._timeDynamicImagery;return f(s)&&(n=s.currentInterval,a=s.getFromCache(t,e,r,i)),f(a)||(a=this.requestImageNow(this,t,e,r,i,n)),f(a)&&f(s)&&s.checkApproachingInterval(t,e,r,i),a}pickFeatures(t,e,r,i,a){}updateLightShader(t){this.lightMap[t.type]=t,this.updateLightMap()}removeLightShader(t){delete this.lightMap[t],this.updateLightMap()}updateLightMap(){for(var e in this.cache){let t=this.cache[e];t.setLightMap(this.lightMap)}}destroy(){for(var e in this.cache){let t=this.cache[e];t.destroy()}this.cache={}}removeImageryFromCache(t,e,r){r=t+"_"+e+"_"+r;let i=this.cache[r];i&&(i.destroy(),delete this.cache[r])}removeTile(t){let e=this.cache[t];e&&e.remove()}}e.exports=i},{"../ElevationImageryProvider":27,"./ModelDataSource":59}],61:[function(t,e,r){const d=t("./Shaders"),f={};class m{static createProgram(e,r){let i=f[r];if(!i){var a=d[r];let t=`#define MAPBOX_GL_JS
#define DEVICE_PIXEL_RATIO ${window.devicePixelRatio.toFixed(1)}
`;a.definePragma&&(t+=a.definePragma);var n=m.makeShader(e,t+d.prelude.fragmentSource+a.fragmentSource,e.FRAGMENT_SHADER),a=m.makeShader(e,t+d.prelude.vertexSource+a.vertexSource,e.VERTEX_SHADER),s=e.createProgram();e.attachShader(s,n),e.attachShader(s,a),e.linkProgram(s);var o=e.getProgramParameter(s,e.ACTIVE_ATTRIBUTES);i={program:s,numAttributes:o};for(let t=0;t<o;t++){var l=e.getActiveAttrib(s,t);i[l.name]=e.getAttribLocation(s,l.name)}var u=e.getProgramParameter(s,e.ACTIVE_UNIFORMS);for(let t=0;t<u;t++){var h=e.getActiveUniform(s,t);i[h.name]=e.getUniformLocation(s,h.name)}f[r]=i}return e.useProgram(i.program),i}static compile(t,e){var r=/#pragma mapbox: ([\w]+) ([\w]+) ([\w]+) ([\w]+)/g,i=e.match(/attribute ([\w]+) ([\w]+)/g),a=t.match(/uniform ([\w]+) ([\w]+)([\s]*)([\w]*)/g);const n=e.match(/uniform ([\w]+) ([\w]+)([\s]*)([\w]*)/g);a=n?n.concat(a):a;const o={};return{fragmentSource:t=t.replace(r,(t,e,r,i,a)=>(o[a]=!0,"define"===e?`
#ifndef HAS_UNIFORM_u_${a}
varying ${r} ${i} ${a};
#else
uniform ${r} ${i} u_${a};
#endif
`:`
#ifdef HAS_UNIFORM_u_${a}
    ${r} ${i} ${a} = u_${a};
#endif
`)),vertexSource:e=e.replace(r,(t,e,r,i,a)=>{var n="float"===i?"vec2":"vec4",s=a.match(/color/)?"color":n;return o[a]?"define"===e?`
#ifndef HAS_UNIFORM_u_${a}
uniform lowp float u_${a}_t;
attribute ${r} ${n} a_${a};
varying ${r} ${i} ${a};
#else
uniform ${r} ${i} u_${a};
#endif
`:"vec4"==s?`
#ifndef HAS_UNIFORM_u_${a}
    ${a} = a_${a};
#else
    ${r} ${i} ${a} = u_${a};
#endif
`:`
#ifndef HAS_UNIFORM_u_${a}
    ${a} = unpack_mix_${s}(a_${a}, u_${a}_t);
#else
    ${r} ${i} ${a} = u_${a};
#endif
`:"define"===e?`
#ifndef HAS_UNIFORM_u_${a}
uniform lowp float u_${a}_t;
attribute ${r} ${n} a_${a};
#else
uniform ${r} ${i} u_${a};
#endif
`:"vec4"==s?`
#ifndef HAS_UNIFORM_u_${a}
    ${r} ${i} ${a} = a_${a};
#else
    ${r} ${i} ${a} = u_${a};
#endif
`:`
#ifndef HAS_UNIFORM_u_${a}
    ${r} ${i} ${a} = unpack_mix_${s}(a_${a}, u_${a}_t);
#else
    ${r} ${i} ${a} = u_${a};
#endif
`}),staticAttributes:i,staticUniforms:a}}static makeShader(t,e,r){r=t.createShader(r);return t.shaderSource(r,e),t.compileShader(r),t.getShaderParameter(r,t.COMPILE_STATUS)||alert("Error compiling shader: "+t.getShaderInfoLog(r)),r}}e.exports=m},{"./Shaders":62}],62:[function(t,e,r){"use strict";e.exports={prelude:{fragmentSource:"#ifdef GL_ES\nprecision mediump float;\n#else\n\n#if !defined(lowp)\n#define lowp\n#endif\n\n#if !defined(mediump)\n#define mediump\n#endif\n\n#if !defined(highp)\n#define highp\n#endif\n\n#endif\n",vertexSource:"#ifdef GL_ES\nprecision highp float;\n#else\n\n#if !defined(lowp)\n#define lowp\n#endif\n\n#if !defined(mediump)\n#define mediump\n#endif\n\n#if !defined(highp)\n#define highp\n#endif\n\n#endif\n\nfloat evaluate_zoom_function_1(const vec4 values, const float t) {\n    if (t < 1.0) {\n        return mix(values[0], values[1], t);\n    } else if (t < 2.0) {\n        return mix(values[1], values[2], t - 1.0);\n    } else {\n        return mix(values[2], values[3], t - 2.0);\n    }\n}\nvec4 evaluate_zoom_function_4(const vec4 value0, const vec4 value1, const vec4 value2, const vec4 value3, const float t) {\n    if (t < 1.0) {\n        return mix(value0, value1, t);\n    } else if (t < 2.0) {\n        return mix(value1, value2, t - 1.0);\n    } else {\n        return mix(value2, value3, t - 2.0);\n    }\n}\n\n// Unpack a pair of values that have been packed into a single float.\n// The packed values are assumed to be 8-bit unsigned integers, and are\n// packed like so:\n// packedValue = floor(input[0]) * 256 + input[1],\nvec2 unpack_float(const float packedValue) {\n    int packedIntValue = int(packedValue);\n    int v0 = packedIntValue / 256;\n    return vec2(v0, packedIntValue - v0 * 256);\n}\n\n\n// To minimize the number of attributes needed in the mapbox-gl-native shaders,\n// we encode a 4-component color into a pair of floats (i.e. a vec2) as follows:\n// [ floor(color.r * 255) * 256 + color.g * 255,\n//   floor(color.b * 255) * 256 + color.g * 255 ]\nvec4 decode_color(const vec2 encodedColor) {\n    return vec4(\n        unpack_float(encodedColor[0]) / 255.0,\n        unpack_float(encodedColor[1]) / 255.0\n    );\n}\n\n// Unpack a pair of paint values and interpolate between them.\nfloat unpack_mix_vec2(const vec2 packedValue, const float t) {\n    return mix(packedValue[0], packedValue[1], t);\n}\n\n// Unpack a pair of paint values and interpolate between them.\nvec4 unpack_mix_vec4(const vec4 packedColors, const float t) {\n    vec4 minColor = decode_color(vec2(packedColors[0], packedColors[1]));\n    vec4 maxColor = decode_color(vec2(packedColors[2], packedColors[3]));\n    return mix(minColor, maxColor, t);\n}\n\n// The offset depends on how many pixels are between the world origin and the edge of the tile:\n// vec2 offset = mod(pixel_coord, size)\n//\n// At high zoom levels there are a ton of pixels between the world origin and the edge of the tile.\n// The glsl spec only guarantees 16 bits of precision for highp floats. We need more than that.\n//\n// The pixel_coord is passed in as two 16 bit values:\n// pixel_coord_upper = floor(pixel_coord / 2^16)\n// pixel_coord_lower = mod(pixel_coord, 2^16)\n//\n// The offset is calculated in a series of steps that should preserve this precision:\nvec2 get_pattern_pos(const vec2 pixel_coord_upper, const vec2 pixel_coord_lower,\n    const vec2 pattern_size, const float tile_units_to_pixels, const vec2 pos) {\n\n    vec2 offset = mod(mod(mod(pixel_coord_upper, pattern_size) * 256.0, pattern_size) * 256.0 + pixel_coord_lower, pattern_size);\n    return (tile_units_to_pixels * pos + offset) / pattern_size;\n}\n"},circle:{fragmentSource:"\nvarying vec2 v_extrude;\nvarying lowp float v_antialiasblur;\n\nuniform highp vec4 color;\nuniform mediump float radius;\nuniform lowp float blur;\nuniform lowp float opacity;\nuniform vec4 stroke_color;\nuniform mediump float stroke_width;\nuniform lowp float stroke_opacity;\n\nvoid main() {\n\n    float extrude_length = length(v_extrude);\n    float antialiased_blur = -max(blur, v_antialiasblur);\n\n    float opacity_t = smoothstep(0.0, antialiased_blur, extrude_length - 1.0);\n\n    float color_t = stroke_width < 0.01 ? 0.0 : smoothstep(\n        antialiased_blur,\n        0.0,\n        extrude_length - radius / (radius + stroke_width)\n    );\n\n    gl_FragColor = opacity_t * mix(color * opacity, stroke_color * stroke_opacity, color_t);\n\n    //gl_FragColor = vec4(1.0,0.0,0.0,1.0);\n\n#ifdef OVERDRAW_INSPECTOR\n    gl_FragColor = vec4(1.0);\n#endif\n}\n",vertexSource:"uniform mat4 u_matrix;\nuniform bool u_pitch_with_map;\nuniform vec2 u_extrude_scale;\n\n\nuniform lowp float u_devicepixelratio;\n//uniform highp vec4 color;\nuniform mediump float radius;\n//uniform lowp float blur;\n//uniform lowp float opacity;\n//uniform vec4 stroke_color;\nuniform mediump float stroke_width;\n//uniform lowp float stroke_opacity;\n\nattribute vec2 a_pos;\n\nvarying vec2 v_extrude;\nvarying lowp float v_antialiasblur;\nvoid main(void) {\n\n    // unencode the extrusion vector that we snuck into the a_pos vector\n    v_extrude = vec2(mod(a_pos, 2.0) * 2.0 - 1.0);\n\n    vec2 extrude = v_extrude * (radius + stroke_width) * u_extrude_scale;\n    // multiply a_pos by 0.5, since we had it * 2 in order to sneak\n    // in extrusion data\n    \n\n    if (u_pitch_with_map) {\n        gl_Position = u_matrix * vec4(floor(a_pos * 0.5 + extrude), 0, 1);\n        //gl_Position.xy += extrude;\n    } else {\n        gl_Position = u_matrix * vec4(floor(a_pos * 0.5), 0, 1);\n        gl_Position.xy += extrude * gl_Position.w;\n        gl_Position.z = 0.0;\n    }\n    // This is a minimum blur distance that serves as a faux-antialiasing for\n    // the circle. since blur is a ratio of the circle's size and the intent is\n    // to keep the blur at roughly 1px, the two are inversely related.\n    v_antialiasblur = 1.0 / u_devicepixelratio / (radius + stroke_width);\n}\n\n\n\n\n\n\n\n\n\n"},fill:{fragmentSource:"uniform highp vec4 u_color;\nuniform lowp float u_opacity;\nvoid main() {\n    gl_FragColor = u_color * u_opacity;\n#ifdef OVERDRAW_INSPECTOR\n    gl_FragColor = vec4(1.0);\n#endif\n}\n",vertexSource:"attribute vec2 a_pos;\nuniform mat4 u_matrix;\nvoid main() {\n    gl_Position = u_matrix * vec4(a_pos, 0, 1);\n    gl_Position.y =  - gl_Position.y;\n}\n"},fillOutline:{fragmentSource:"uniform highp vec4 outline_color;\nuniform lowp float opacity;\n\nvarying vec2 v_pos;\n\nvoid main() {\n    float dist = length(v_pos - gl_FragCoord.xy);\n    float alpha = 1.0 - smoothstep(0.0, 1.0, dist);\n    gl_FragColor = outline_color * (alpha * opacity);\n\n#ifdef OVERDRAW_INSPECTOR\n    gl_FragColor = vec4(1.0);\n#endif\n}\n",vertexSource:"attribute vec2 a_pos;\nuniform mat4 u_matrix;\nuniform vec2 u_world;\n\nvarying vec2 v_pos;\n\nvoid main() {\n    gl_Position = u_matrix * vec4(a_pos, 0, 1);\n    gl_Position.y =  - gl_Position.y;\n    v_pos = (gl_Position.xy / gl_Position.w + 1.0) / 2.0 * u_world;\n}\n"},fillOutlinePattern:{fragmentSource:"uniform vec2 u_pattern_tl_a;\nuniform vec2 u_pattern_br_a;\nuniform vec2 u_pattern_tl_b;\nuniform vec2 u_pattern_br_b;\nuniform vec2 u_texsize;\nuniform float u_mix;\n\nuniform sampler2D u_image;\n\nvarying vec2 v_pos_a;\nvarying vec2 v_pos_b;\nvarying vec2 v_pos;\n\n#pragma mapbox: define lowp float opacity\n\nvoid main() {\n    #pragma mapbox: initialize lowp float opacity\n\n    vec2 imagecoord = mod(v_pos_a, 1.0);\n    vec2 pos = mix(u_pattern_tl_a / u_texsize, u_pattern_br_a / u_texsize, imagecoord);\n    vec4 color1 = texture2D(u_image, pos);\n\n    vec2 imagecoord_b = mod(v_pos_b, 1.0);\n    vec2 pos2 = mix(u_pattern_tl_b / u_texsize, u_pattern_br_b / u_texsize, imagecoord_b);\n    vec4 color2 = texture2D(u_image, pos2);\n\n    // find distance to outline for alpha interpolation\n\n    float dist = length(v_pos - gl_FragCoord.xy);\n    float alpha = 1.0 - smoothstep(0.0, 1.0, dist);\n\n\n    gl_FragColor = mix(color1, color2, u_mix) * alpha * opacity;\n\n#ifdef OVERDRAW_INSPECTOR\n    gl_FragColor = vec4(1.0);\n#endif\n}\n",vertexSource:"uniform mat4 u_matrix;\nuniform vec2 u_world;\nuniform vec2 u_pattern_size_a;\nuniform vec2 u_pattern_size_b;\nuniform vec2 u_pixel_coord_upper;\nuniform vec2 u_pixel_coord_lower;\nuniform float u_scale_a;\nuniform float u_scale_b;\nuniform float u_tile_units_to_pixels;\n\nattribute vec2 a_pos;\n\nvarying vec2 v_pos_a;\nvarying vec2 v_pos_b;\nvarying vec2 v_pos;\n\n#pragma mapbox: define lowp float opacity\n\nvoid main() {\n    #pragma mapbox: initialize lowp float opacity\n\n    gl_Position = u_matrix * vec4(a_pos, 0, 1);\n    gl_Position.y =  - gl_Position.y;\n\n    v_pos_a = get_pattern_pos(u_pixel_coord_upper, u_pixel_coord_lower, u_scale_a * u_pattern_size_a, u_tile_units_to_pixels, a_pos);\n    v_pos_b = get_pattern_pos(u_pixel_coord_upper, u_pixel_coord_lower, u_scale_b * u_pattern_size_b, u_tile_units_to_pixels, a_pos);\n\n    v_pos = (gl_Position.xy / gl_Position.w + 1.0) / 2.0 * u_world;\n}\n"},fillPattern:{fragmentSource:"uniform vec2 u_pattern_tl_a;\nuniform vec2 u_pattern_br_a;\nuniform vec2 u_pattern_tl_b;\nuniform vec2 u_pattern_br_b;\nuniform vec2 u_texsize;\nuniform float u_mix;\n\nuniform sampler2D u_image;\n\nvarying vec2 v_pos_a;\nvarying vec2 v_pos_b;\n\n#pragma mapbox: define lowp float opacity\n\nvoid main() {\n    #pragma mapbox: initialize lowp float opacity\n\n    vec2 imagecoord = mod(v_pos_a, 1.0);\n    vec2 pos = mix(u_pattern_tl_a / u_texsize, u_pattern_br_a / u_texsize, imagecoord);\n    vec4 color1 = texture2D(u_image, pos);\n\n    vec2 imagecoord_b = mod(v_pos_b, 1.0);\n    vec2 pos2 = mix(u_pattern_tl_b / u_texsize, u_pattern_br_b / u_texsize, imagecoord_b);\n    vec4 color2 = texture2D(u_image, pos2);\n\n    gl_FragColor = mix(color1, color2, u_mix) * opacity;\n\n#ifdef OVERDRAW_INSPECTOR\n    gl_FragColor = vec4(1.0);\n#endif\n}\n",vertexSource:"uniform mat4 u_matrix;\nuniform vec2 u_pattern_size_a;\nuniform vec2 u_pattern_size_b;\nuniform vec2 u_pixel_coord_upper;\nuniform vec2 u_pixel_coord_lower;\nuniform float u_scale_a;\nuniform float u_scale_b;\nuniform float u_tile_units_to_pixels;\n\nattribute vec2 a_pos;\n\nvarying vec2 v_pos_a;\nvarying vec2 v_pos_b;\n\n#pragma mapbox: define lowp float opacity\n\nvoid main() {\n    #pragma mapbox: initialize lowp float opacity\n\n    gl_Position = u_matrix * vec4(a_pos, 0, 1);\n    gl_Position.y =  - gl_Position.y;\n\n    v_pos_a = get_pattern_pos(u_pixel_coord_upper, u_pixel_coord_lower, u_scale_a * u_pattern_size_a, u_tile_units_to_pixels, a_pos);\n    v_pos_b = get_pattern_pos(u_pixel_coord_upper, u_pixel_coord_lower, u_scale_b * u_pattern_size_b, u_tile_units_to_pixels, a_pos);\n}\n"},line:{fragmentSource:"\n\nvarying vec2 v_width2;\nvarying vec2 v_normal;\nvarying float v_gamma_scale;\nuniform highp vec4 color;\nuniform lowp float blur;\nuniform lowp float opacity;\nvoid main() {\n\n    // Calculate the distance of the pixel from the line in pixels.\n    float dist = length(v_normal) * v_width2.s;\n\n    // Calculate the antialiasing fade factor. This is either when fading in\n    // the line in case of an offset line (v_width2.t) or when fading out\n    // (v_width2.s)\n    float blur2 = (blur + 1.0 / DEVICE_PIXEL_RATIO) * v_gamma_scale;\n    float alpha = clamp(min(dist - (v_width2.t - blur2), v_width2.s - dist) / blur2, 0.0, 1.0);\n\n    gl_FragColor = color * (alpha * opacity);\n\n#ifdef OVERDRAW_INSPECTOR\n    gl_FragColor = vec4(1.0);\n#endif\n}\n",vertexSource:"\n\n// the distance over which the line edge fades out.\n// Retina devices need a smaller distance to avoid aliasing.\n#define ANTIALIASING 1.0 / DEVICE_PIXEL_RATIO / 2.0\n\n// floor(127 / 2) == 63.0\n// the maximum allowed miter limit is 2.0 at the moment. the extrude normal is\n// stored in a byte (-128..127). we scale regular normals up to length 63, but\n// there are also \"special\" normals that have a bigger length (of up to 126 in\n// this case).\n// #define scale 63.0\n#define scale 0.015873016\n\nattribute vec2 a_pos;\nattribute vec4 a_data;\nattribute vec2 a_txy;\n\nuniform mat4 u_matrix;\nuniform mediump float u_ratio;\nuniform mediump float u_width;\nuniform vec2 u_gl_units_to_pixels;\n\nvarying vec2 v_normal;\nvarying vec2 v_width2;\nvarying float v_gamma_scale;\n\n uniform mediump float a_gapwidth;\n uniform float a_offset;\nmediump  float gapwidth;\nlowp float offset;\n\n\nvoid main() {\n\n    vec2 a_extrude = a_data.xy - 128.0;\n    float a_direction = mod(a_data.z, 4.0) - 1.0;\n\n    // We store the texture normals in the most insignificant bit\n    // transform y so that 0 => -1 and 1 => 1\n    // In the texture normal, x is 0 if the normal points straight up/down and 1 if it's a round cap\n    // y is 1 if the normal points up, and -1 if it points down\n    mediump vec2 normal = a_txy;\n    normal.y = sign(normal.y - 0.5);\n    v_normal = normal;\n\n\n    // these transformations used to be applied in the JS and native code bases.\n    // moved them into the shader for clarity and simplicity.\n    gapwidth = a_gapwidth / 2.0;\n    float width = u_width / 2.0;\n    offset = -1.0 * a_offset;\n\n    float inset = gapwidth + (gapwidth > 0.0 ? ANTIALIASING : 0.0);\n    float outset = gapwidth + width * (gapwidth > 0.0 ? 2.0 : 1.0) + ANTIALIASING;\n\n    // Scale the extrusion vector down to a normal and then up by the line width\n    // of this vertex.\n    mediump vec2 dist = outset * a_extrude * scale;\n\n    // Calculate the offset when drawing a line that is to the side of the actual line.\n    // We do this by creating a vector that points towards the extrude, but rotate\n    // it when we're drawing round end points (a_direction = -1 or 1) since their\n    // extrude vector points in another direction.\n    mediump float u = 0.5 * a_direction;\n    mediump float t = 1.0 - abs(u);\n    mediump vec2 offset2 = offset * a_extrude * scale * normal.y * mat2(t, -u, u, t);\n\n    // Remove the texture normal bit to get the position\n//    vec2 pos = a_pos;\n\n    vec4 projected_extrude = u_matrix * vec4(dist / u_ratio, 0.0, 0.0);\n\n    gl_Position = u_matrix * vec4(a_pos + offset2 / u_ratio, 0.0, 1.0) + projected_extrude;\n    gl_Position.y =  - gl_Position.y;\n\n    // calculate how much the perspective view squishes or stretches the extrude\n    float extrude_length_without_perspective = length(dist);\n    float extrude_length_with_perspective = length(projected_extrude.xy / gl_Position.w * u_gl_units_to_pixels);\n    v_gamma_scale = extrude_length_without_perspective / extrude_length_with_perspective;\n\n    v_width2 = vec2(outset, inset);\n}\n"},linePattern:{fragmentSource:"uniform vec2 u_pattern_size_a;\nuniform vec2 u_pattern_size_b;\nuniform vec2 u_pattern_tl_a;\nuniform vec2 u_pattern_br_a;\nuniform vec2 u_pattern_tl_b;\nuniform vec2 u_pattern_br_b;\nuniform vec2 u_texsize;\nuniform float u_fade;\n\nuniform sampler2D u_image;\n\nvarying vec2 v_normal;\nvarying vec2 v_width2;\nvarying float v_linesofar;\nvarying float v_gamma_scale;\n\n#pragma mapbox: define lowp float blur\n#pragma mapbox: define lowp float opacity\n\nvoid main() {\n    #pragma mapbox: initialize lowp float blur\n    #pragma mapbox: initialize lowp float opacity\n\n    // Calculate the distance of the pixel from the line in pixels.\n    float dist = length(v_normal) * v_width2.s;\n\n    // Calculate the antialiasing fade factor. This is either when fading in\n    // the line in case of an offset line (v_width2.t) or when fading out\n    // (v_width2.s)\n    float blur2 = (blur + 1.0 / DEVICE_PIXEL_RATIO) * v_gamma_scale;\n    float alpha = clamp(min(dist - (v_width2.t - blur2), v_width2.s - dist) / blur2, 0.0, 1.0);\n\n    float x_a = mod(v_linesofar / u_pattern_size_a.x, 1.0);\n    float x_b = mod(v_linesofar / u_pattern_size_b.x, 1.0);\n    float y_a = 0.5 + (v_normal.y * v_width2.s / u_pattern_size_a.y);\n    float y_b = 0.5 + (v_normal.y * v_width2.s / u_pattern_size_b.y);\n    vec2 pos_a = mix(u_pattern_tl_a / u_texsize, u_pattern_br_a / u_texsize, vec2(x_a, y_a));\n    vec2 pos_b = mix(u_pattern_tl_b / u_texsize, u_pattern_br_b / u_texsize, vec2(x_b, y_b));\n\n    vec4 color = mix(texture2D(u_image, pos_a), texture2D(u_image, pos_b), u_fade);\n\n    gl_FragColor = color * alpha * opacity;\n\n#ifdef OVERDRAW_INSPECTOR\n    gl_FragColor = vec4(1.0);\n#endif\n}\n",vertexSource:"// floor(127 / 2) == 63.0\n// the maximum allowed miter limit is 2.0 at the moment. the extrude normal is\n// stored in a byte (-128..127). we scale regular normals up to length 63, but\n// there are also \"special\" normals that have a bigger length (of up to 126 in\n// this case).\n// #define scale 63.0\n#define scale 0.015873016\n\n// We scale the distance before adding it to the buffers so that we can store\n// long distances for long segments. Use this value to unscale the distance.\n#define LINE_DISTANCE_SCALE 2.0\n\n// the distance over which the line edge fades out.\n// Retina devices need a smaller distance to avoid aliasing.\n#define ANTIALIASING 1.0 / DEVICE_PIXEL_RATIO / 2.0\n\nattribute vec2 a_pos;\nattribute vec4 a_data;\n\nuniform mat4 u_matrix;\nuniform mediump float u_ratio;\nuniform mediump float u_width;\nuniform vec2 u_gl_units_to_pixels;\n\nvarying vec2 v_normal;\nvarying vec2 v_width2;\nvarying float v_linesofar;\nvarying float v_gamma_scale;\n\n#pragma mapbox: define lowp float blur\n#pragma mapbox: define lowp float opacity\n#pragma mapbox: define lowp float offset\n#pragma mapbox: define mediump float gapwidth\n\nvoid main() {\n    #pragma mapbox: initialize lowp float blur\n    #pragma mapbox: initialize lowp float opacity\n    #pragma mapbox: initialize lowp float offset\n    #pragma mapbox: initialize mediump float gapwidth\n\n    vec2 a_extrude = a_data.xy - 128.0;\n    float a_direction = mod(a_data.z, 4.0) - 1.0;\n    float a_linesofar = (floor(a_data.z / 4.0) + a_data.w * 64.0) * LINE_DISTANCE_SCALE;\n\n    // We store the texture normals in the most insignificant bit\n    // transform y so that 0 => -1 and 1 => 1\n    // In the texture normal, x is 0 if the normal points straight up/down and 1 if it's a round cap\n    // y is 1 if the normal points up, and -1 if it points down\n    mediump vec2 normal = mod(a_pos, 2.0);\n    normal.y = sign(normal.y - 0.5);\n    v_normal = normal;\n\n    // these transformations used to be applied in the JS and native code bases. \n    // moved them into the shader for clarity and simplicity. \n    gapwidth = gapwidth / 2.0;\n    float width = u_width / 2.0;\n    offset = -1.0 * offset; \n\n    float inset = gapwidth + (gapwidth > 0.0 ? ANTIALIASING : 0.0);\n    float outset = gapwidth + width * (gapwidth > 0.0 ? 2.0 : 1.0) + ANTIALIASING;\n\n    // Scale the extrusion vector down to a normal and then up by the line width\n    // of this vertex.\n    mediump vec2 dist = outset * a_extrude * scale;\n\n    // Calculate the offset when drawing a line that is to the side of the actual line.\n    // We do this by creating a vector that points towards the extrude, but rotate\n    // it when we're drawing round end points (a_direction = -1 or 1) since their\n    // extrude vector points in another direction.\n    mediump float u = 0.5 * a_direction;\n    mediump float t = 1.0 - abs(u);\n    mediump vec2 offset2 = offset * a_extrude * scale * normal.y * mat2(t, -u, u, t);\n\n    // Remove the texture normal bit to get the position\n    vec2 pos = floor(a_pos * 0.5);\n\n    vec4 projected_extrude = u_matrix * vec4(dist / u_ratio, 0.0, 0.0);\n    gl_Position = u_matrix * vec4(pos + offset2 / u_ratio, 0.0, 1.0) + projected_extrude;\n    gl_Position.y =  - gl_Position.y;\n\n    // calculate how much the perspective view squishes or stretches the extrude\n    float extrude_length_without_perspective = length(dist);\n    float extrude_length_with_perspective = length(projected_extrude.xy / gl_Position.w * u_gl_units_to_pixels);\n    v_gamma_scale = extrude_length_without_perspective / extrude_length_with_perspective;\n\n    v_linesofar = a_linesofar;\n    v_width2 = vec2(outset, inset);\n}\n"},lineSDF:{fragmentSource:"\nuniform sampler2D u_image;\nuniform float u_sdfgamma;\nuniform float u_mix;\n\nvarying vec2 v_normal;\nvarying vec2 v_width2;\nvarying vec2 v_tex_a;\nvarying vec2 v_tex_b;\nvarying float v_gamma_scale;\n\n\nuniform highp vec4 color;\nuniform lowp float blur;\nuniform lowp float opacity;\n\n\nvoid main() {\n       // Calculate the distance of the pixel from the line in pixels.\n    float dist = length(v_normal) * v_width2.s;\n\n    // Calculate the antialiasing fade factor. This is either when fading in\n    // the line in case of an offset line (v_width2.t) or when fading out\n    // (v_width2.s)\n    float blur2 = (blur + 1.0 / DEVICE_PIXEL_RATIO) * v_gamma_scale;\n    float alpha = clamp(min(dist - (v_width2.t - blur2), v_width2.s - dist) / blur2, 0.0, 1.0);\n\n    float sdfdist_a = texture2D(u_image, -v_tex_a).a;\n    float sdfdist_b = texture2D(u_image, -v_tex_b).a;\n    float sdfdist = mix(sdfdist_a, sdfdist_b, u_mix);\n    alpha *= smoothstep(0.5 - u_sdfgamma, 0.5 + u_sdfgamma, sdfdist);\n\n    gl_FragColor = color * (alpha * opacity);\n\n#ifdef OVERDRAW_INSPECTOR\n    gl_FragColor = vec4(1.0);\n#endif\n}\n",vertexSource:"// floor(127 / 2) == 63.0\n// the maximum allowed miter limit is 2.0 at the moment. the extrude normal is\n// stored in a byte (-128..127). we scale regular normals up to length 63, but\n// there are also \"special\" normals that have a bigger length (of up to 126 in\n// this case).\n// #define scale 63.0\n#define scale 0.015873016\n\n// We scale the distance before adding it to the buffers so that we can store\n// long distances for long segments. Use this value to unscale the distance.\n#define LINE_DISTANCE_SCALE 2.0\n\n// the distance over which the line edge fades out.\n// Retina devices need a smaller distance to avoid aliasing.\n#define ANTIALIASING 1.0 / DEVICE_PIXEL_RATIO / 2.0\n\nattribute vec2 a_pos;\nattribute vec4 a_data;\nattribute vec2 a_txy;\n\nuniform mat4 u_matrix;\nuniform mediump float u_ratio;\nuniform vec2 u_patternscale_a;\nuniform float u_tex_y_a;\nuniform vec2 u_patternscale_b;\nuniform float u_tex_y_b;\nuniform vec2 u_gl_units_to_pixels;\nuniform mediump float u_width;\n\nvarying vec2 v_normal;\nvarying vec2 v_width2;\nvarying vec2 v_tex_a;\nvarying vec2 v_tex_b;\nvarying float v_gamma_scale;\n\n\nuniform mediump float a_gapwidth;\nuniform lowp float a_offset;\nmediump float gapwidth;\nlowp float offset;\n\nvoid main() {\n    vec2 a_extrude = a_data.xy - 128.0;\n    float a_direction = mod(a_data.z, 4.0) - 1.0;\n    float a_linesofar = (floor(a_data.z / 4.0) + a_data.w * 64.0) * LINE_DISTANCE_SCALE;\n\n    // We store the texture normals in the most insignificant bit\n    // transform y so that 0 => -1 and 1 => 1\n    // In the texture normal, x is 0 if the normal points straight up/down and 1 if it's a round cap\n    // y is 1 if the normal points up, and -1 if it points down\n    mediump vec2 normal = a_txy;\n    normal.y = sign(normal.y - 0.5);\n    v_normal = normal;\n\n    // these transformations used to be applied in the JS and native code bases. \n    // moved them into the shader for clarity and simplicity. \n    gapwidth = a_gapwidth / 2.0;\n    float width = u_width / 2.0;\n    offset = -1.0 * a_offset;\n\n    float inset = gapwidth + (gapwidth > 0.0 ? ANTIALIASING : 0.0);\n    float outset = gapwidth + width * (gapwidth > 0.0 ? 2.0 : 1.0) + ANTIALIASING;\n\n    // Scale the extrusion vector down to a normal and then up by the line width\n    // of this vertex.\n    mediump vec2 dist =outset * a_extrude * scale;\n\n    // Calculate the offset when drawing a line that is to the side of the actual line.\n    // We do this by creating a vector that points towards the extrude, but rotate\n    // it when we're drawing round end points (a_direction = -1 or 1) since their\n    // extrude vector points in another direction.\n    mediump float u = 0.5 * a_direction;\n    mediump float t = 1.0 - abs(u);\n    mediump vec2 offset2 = offset * a_extrude * scale * normal.y * mat2(t, -u, u, t);\n\n    // Remove the texture normal bit to get the position\n    vec2 pos = a_pos;\n\n    vec4 projected_extrude = u_matrix * vec4(dist / u_ratio, 0.0, 0.0);\n    gl_Position = u_matrix * vec4(pos + offset2 / u_ratio, 0.0, 1.0) + projected_extrude;\n    gl_Position.y =  - gl_Position.y;\n    // calculate how much the perspective view squishes or stretches the extrude\n    float extrude_length_without_perspective = length(dist);\n    float extrude_length_with_perspective = length(projected_extrude.xy / gl_Position.w * u_gl_units_to_pixels);\n    v_gamma_scale = extrude_length_without_perspective / extrude_length_with_perspective;\n\n    v_tex_a = vec2(a_linesofar * u_patternscale_a.x, normal.y * u_patternscale_a.y + u_tex_y_a);\n    v_tex_b = vec2(a_linesofar * u_patternscale_b.x, normal.y * u_patternscale_b.y + u_tex_y_b);\n\n    v_width2 = vec2(outset, inset);\n}\n"},hillshade:{fragmentSource:"uniform sampler2D u_image;\nvarying vec2 v_pos;\n\nuniform vec2 u_latrange;\nuniform vec2 u_light;\nuniform vec4 u_shadow;\nuniform vec4 u_highlight;\nuniform vec4 u_accent;\n\n#define PI 3.141592653589793\n\nvoid main() {\n    vec4 pixel = texture2D(u_image, v_pos);\n\n    vec2 deriv = ((pixel.rg * 2.0) - 1.0);\n\n    // We divide the slope by a scale factor based on the cosin of the pixel's approximate latitude\n    // to account for mercator projection distortion. see #4807 for details\n    float scaleFactor = cos(radians((u_latrange[0] - u_latrange[1]) * (1.0 - v_pos.y) + u_latrange[1]));\n    // We also multiply the slope by an arbitrary z-factor of 1.25\n    float slope = atan(1.25 * length(deriv) / scaleFactor);\n    float aspect = deriv.x != 0.0 ? atan(deriv.y, -deriv.x) : PI / 2.0 * (deriv.y > 0.0 ? 1.0 : -1.0);\n\n    float intensity = u_light.x;\n    // We add PI to make this property match the global light object, which adds PI/2 to the light's azimuthal\n    // position property to account for 0deg corresponding to north/the top of the viewport in the style spec\n    // and the original shader was written to accept (-illuminationDirection - 90) as the azimuthal.\n    float azimuth = u_light.y + PI;\n\n    // We scale the slope exponentially based on intensity, using a calculation similar to\n    // the exponential interpolation function in the style spec:\n    // https://github.com/mapbox/mapbox-gl-js/blob/master/src/style-spec/expression/definitions/interpolate.js#L217-L228\n    // so that higher intensity values create more opaque hillshading.\n    float base = 1.875 - intensity * 1.75;\n    float maxValue = 0.5 * PI;\n    float scaledSlope = intensity != 0.5 ? ((pow(base, slope) - 1.0) / (pow(base, maxValue) - 1.0)) * maxValue : slope;\n\n    // The accent color is calculated with the cosine of the slope while the shade color is calculated with the sine\n    // so that the accent color's rate of change eases in while the shade color's eases out.\n    float accent = cos(scaledSlope);\n    // We multiply both the accent and shade color by a clamped intensity value\n    // so that intensities >= 0.5 do not additionally affect the color values\n    // while intensity values < 0.5 make the overall color more transparent.\n    vec4 accent_color = (1.0 - accent) * u_accent * clamp(intensity * 2.0, 0.0, 1.0);\n    float shade = abs(mod((aspect + azimuth) / PI + 0.5, 2.0) - 1.0);\n    vec4 shade_color = mix(u_shadow, u_highlight, shade) * sin(scaledSlope) * clamp(intensity * 2.0, 0.0, 1.0);\n    gl_FragColor = accent_color * (1.0 - shade_color.a) + shade_color;\n\n#ifdef OVERDRAW_INSPECTOR\n    gl_FragColor = vec4(1.0);\n#endif\n}\n",vertexSource:"uniform mat4 u_matrix;\n\nattribute vec2 a_pos;\nattribute vec2 a_texture_pos;\n\nvarying vec2 v_pos;\n\nvoid main() {\n    gl_Position = u_matrix * vec4(a_pos, 0, 1);\n    gl_Position.y =  - gl_Position.y;\n    v_pos = a_texture_pos / 32768.0;\n}\n"},hillshadePrepare:{fragmentSource:"#ifdef GL_ES\nprecision highp float;\n#endif\n\nuniform sampler2D u_image;\nvarying vec2 v_pos;\nuniform vec2 u_dimension;\nuniform float u_zoom;\nuniform float u_maxzoom;\n\nfloat getElevation(vec2 coord, float bias) {\n    // Convert encoded elevation value to meters\n    vec4 data = texture2D(u_image, coord) * 255.0;\n    return (data.r + data.g * 256.0 + data.b * 256.0 * 256.0) / 4.0;\n}\n\nvoid main() {\n    vec2 epsilon = 1.0 / u_dimension;\n\n    // queried pixels:\n    // +-----------+\n    // |   |   |   |\n    // | a | b | c |\n    // |   |   |   |\n    // +-----------+\n    // |   |   |   |\n    // | d | e | f |\n    // |   |   |   |\n    // +-----------+\n    // |   |   |   |\n    // | g | h | i |\n    // |   |   |   |\n    // +-----------+\n\n    float a = getElevation(v_pos + vec2(-epsilon.x, -epsilon.y), 0.0);\n    float b = getElevation(v_pos + vec2(0, -epsilon.y), 0.0);\n    float c = getElevation(v_pos + vec2(epsilon.x, -epsilon.y), 0.0);\n    float d = getElevation(v_pos + vec2(-epsilon.x, 0), 0.0);\n    float e = getElevation(v_pos, 0.0);\n    float f = getElevation(v_pos + vec2(epsilon.x, 0), 0.0);\n    float g = getElevation(v_pos + vec2(-epsilon.x, epsilon.y), 0.0);\n    float h = getElevation(v_pos + vec2(0, epsilon.y), 0.0);\n    float i = getElevation(v_pos + vec2(epsilon.x, epsilon.y), 0.0);\n\n    // here we divide the x and y slopes by 8 * pixel size\n    // where pixel size (aka meters/pixel) is:\n    // circumference of the world / (pixels per tile * number of tiles)\n    // which is equivalent to: 8 * 40075016.6855785 / (512 * pow(2, u_zoom))\n    // which can be reduced to: pow(2, 19.25619978527 - u_zoom)\n    // we want to vertically exaggerate the hillshading though, because otherwise\n    // it is barely noticeable at low zooms. to do this, we multiply this by some\n    // scale factor pow(2, (u_zoom - u_maxzoom) * a) where a is an arbitrary value\n    // Here we use a=0.3 which works out to the expression below. see \n    // nickidlugash's awesome breakdown for more info\n    // https://github.com/mapbox/mapbox-gl-js/pull/5286#discussion_r148419556\n    float exaggeration = u_zoom < 2.0 ? 0.4 : u_zoom < 4.5 ? 0.35 : 0.3;\n\n    vec2 deriv = vec2(\n        (c + f + f + i) - (a + d + d + g),\n        (g + h + h + i) - (a + b + b + c)\n    ) /  pow(2.0, (u_zoom - u_maxzoom) * exaggeration + 19.2562 - u_zoom);\n\n    gl_FragColor = clamp(vec4(\n        deriv.x / 2.0 + 0.5,\n        deriv.y / 2.0 + 0.5,\n        1.0,\n        1.0), 0.0, 1.0);\n\n#ifdef OVERDRAW_INSPECTOR\n    gl_FragColor = vec4(1.0);\n#endif\n}\n",vertexSource:"uniform mat4 u_matrix;\nuniform vec2 u_dimension;\n\nattribute vec2 a_pos;\nattribute vec2 a_texture_pos;\n\nvarying vec2 v_pos;\n\nvoid main() {\n    gl_Position = u_matrix * vec4(a_pos, 0, 1);\n\n    highp vec2 epsilon = 1.0 / u_dimension;\n    float scale = (u_dimension.x - 2.0) / u_dimension.x;\n    v_pos = (a_texture_pos / 32768.0) * scale + epsilon;\n}\n"}}},{}],63:[function(t,e,r){const l=Cesium.when,i=Cesium.Credit,a=Cesium.defaultValue,u=Cesium.defined,h=Cesium.DeveloperError,n=Cesium.Ellipsoid,s=Cesium.Event,o=Cesium.GeographicTilingScheme,d=Cesium.HeightmapTerrainData,f=Cesium.Resource,m=Cesium.TerrainProvider,v=Cesium.RequestState,p=t("md5-node");function c(t){if(t=a(t,a.EMPTY_OBJECT),this.name="RGBWorldTerrainProvider",this._tileMatrixLabels=t.tileMatrixLabels,!u(t.url))throw new h("options.url is required.");var e=f.createIfNeeded(t.url);this._resource=e,this._errorEvent=new s,this._ready=!1,this._readyPromise=l.defer();e=t.credit;"string"==typeof e&&(e=new i(e)),this._credit=e,this._tilingScheme=void 0,this._rectangles=[];e=a(t.ellipsoid,n.WGS84);this._maxLevel=a(t.maxLevel,15),this._tilingScheme=a(t.tilingScheme,new o({ellipsoid:e})),this._width=parseInt(a(t.width,65)),this.tileSize=Cesium.tileSize,this._levelZeroMaximumGeometricError=m.getEstimatedLevelZeroGeometricErrorForAHeightmap(e,65,this._tilingScheme.getNumberOfXTilesAtLevel(0)),this.processor=new Cesium.TaskProcessor("TerrainWorker",Number.POSITIVE_INFINITY),t.url&&(this.url=t.url,this.indexDbName="terrain_"+p(t.url));t=this._tilingScheme instanceof o?"GeographicTilingScheme":"WebMercatorTilingScheme";let r=this.processor.scheduleTask({init:!0,w:this._width,indexDbName:this.indexDbName,tilingSchemeName:t,maxLevel:this._maxLevel,tileSize:this.tileSize});r.then(function(){this._ready=!0,this._readyPromise.resolve(!0)}.bind(this))}Object.defineProperties(c.prototype,{errorEvent:{get:function(){return this._errorEvent}},credit:{get:function(){return this._credit}},tilingScheme:{get:function(){return this._tilingScheme}},ready:{get:function(){return this._ready}},readyPromise:{get:function(){return this._readyPromise.promise}},hasWaterMask:{get:function(){return!1}},hasVertexNormals:{get:function(){return!1}}}),c.prototype.requestTileGeometry=function(t,e,r,i){if(!this.ready)throw new h("requestTileGeometry must not be called before ready returns true.");var a=this._tileMatrixLabels,n=u(a)?a[0]:0,a=r+parseInt(n),n=this._resource.getDerivedResource({request:i}),t={z:a,y:e,x:t};n.setTemplateValues(t);t={url:n.url,xyz:{x:t.x,y:t.y,z:r}};r>this._maxLevel&&(t.resourceUrl=this.url);let s=this.processor.scheduleTask(t);var o=l.defer();return s.then(function(t,e,r){if(!r)return e.state=v.CANCELLED,void t.reject();r=new d({buffer:r.sData,_minimumHeight:r._minimumHeight,_maximumHeight:r._maximumHeight,width:this._width,height:this._width});t.resolve(r)}.bind(this,o,i),function(t){i.state=v.CANCELLED,o.reject()}.bind(this,o,i)),o.promise},c.prototype.getLevelMaximumGeometricError=function(t){if(!this.ready)throw new h("requestTileGeometry must not be called before ready returns true.");return this._levelZeroMaximumGeometricError/(1<<t)},c.prototype.getTileDataAvailable=function(t,e,r){},c.prototype.loadTileDataAvailability=function(t,e,r){},e.exports=c},{"md5-node":6}],64:[function(t,e,r){"use strict";Cesium.PixelFormat;e.exports=class{constructor(t,e){this.width=t,this.height=e,this.nextRow=0,this.bytes=4,this.data=new Uint8Array(this.width*this.height*this.bytes),this.positions={}}setSprite(t){this.sprite=t}getDash(t,e){var r=t.join(",")+e;return this.positions[r]||(this.positions[r]=this.addDash(t,e)),this.positions[r]}addDash(s,o){var l=o?7:0,t=2*l+1;if(this.nextRow+t>this.height)return console.log("LineAtlas out of space"),null;let e=0;for(let t=0;t<s.length;t++)e+=s[t];var u=this.width/e,h=u/2,d=s.length%2==1;for(let n=-l;n<=l;n++){var f=this.nextRow+l+n,m=this.width*f;let r=d?-s[s.length-1]:0,i=s[0],a=1;for(let e=0;e<this.width;e++){for(;i<e/u;)r=i,i+=s[a],d&&a===s.length-1&&(i+=s[0]),a++;var v=Math.abs(e-r*u),p=Math.abs(e-i*u),c=Math.min(v,p),b=a%2==1;let t;t=o?(v=l?n/l*(1+h):0,b?(p=h-Math.abs(v),Math.sqrt(c*c+p*p)):h-Math.sqrt(c*c+v*v)):(b?1:-1)*c,this.data[3+4*(m+e)]=Math.max(0,Math.min(255,t+128))}}var r={y:(this.nextRow+l+.5)/this.height,height:2*l/this.height,width:e};return this.nextRow+=t,this.dirty=!0,r}bind(t){this.texture?(t.bindTexture(t.TEXTURE_2D,this.texture),this.dirty&&(this.dirty=!1,t.texSubImage2D(t.TEXTURE_2D,0,0,0,this.width,this.height,t.RGBA,t.UNSIGNED_BYTE,this.data))):(this.texture=t.createTexture(),t.bindTexture(t.TEXTURE_2D,this.texture),t.texParameteri(t.TEXTURE_2D,t.TEXTURE_WRAP_S,t.REPEAT),t.texParameteri(t.TEXTURE_2D,t.TEXTURE_WRAP_T,t.REPEAT),t.texParameteri(t.TEXTURE_2D,t.TEXTURE_MIN_FILTER,t.LINEAR),t.texParameteri(t.TEXTURE_2D,t.TEXTURE_MAG_FILTER,t.LINEAR),t.texImage2D(t.TEXTURE_2D,0,t.RGBA,this.width,this.height,0,t.RGBA,t.UNSIGNED_BYTE,this.data))}}},{}],65:[function(t,e,r){e.exports=class{constructor(t,e,r,i,a){this.name=t,this.level=e,this.tileData=r,this.buckets=i,this.texture=a}destroy(){for(let t=0;t<this.buckets.length;t++){let e=this.buckets[t];e.layoutVertexBuffer.destroy(),e.layoutVertexBuffer2&&e.layoutVertexBuffer2.destroy(),e.indexBuffer.destroy(),e.indexBuffer2&&e.indexBuffer2.destroy();for(let t=0;t<e.segments.segments.length;t++){const r=e.segments.segments[t];r.vao&&(r.vao.destroy(),r.vao=null)}if(e.segments2)for(let t=0;t<e.segments2.segments.length;t++){const i=e.segments2.segments[t];i.vao&&(i.vao.destroy(),i.vao=null)}}}}},{}],66:[function(t,e,r){const h=Cesium.combine,s=Cesium.Credit,o=Cesium.defaultValue,d=Cesium.defined,l=Cesium.DeveloperError,u=Cesium.Event;Cesium.freezeObject;const f=Array.isArray,m=Cesium.Rectangle,v=Cesium.Resource,p=Cesium.WebMercatorTilingScheme,c=Cesium.when;Cesium.ImageryProvider;const b=Cesium.TimeDynamicImagery,y=Cesium.RequestState,i=t("../shaders/ProgramFactory"),V=t("../../utils/TextureQueue"),q=t("./LineAtlas"),a=t("./draw/DrawFboVector"),n=t("./draw/DrawTilesFboVector"),x=t("./VectorTile"),W=Cesium.FillBucket,N=Cesium.LineBucket;var X={service:"WMTS",version:"1.0.0",request:"GetTile"};e.exports=class{constructor(t,e,r){if(e=o(e,o.EMPTY_OBJECT),this.id=Math.random(),this.viewer=t,this.needDecode=o(e.needDecode,!1),!d(e.url))throw new l("options.url is required.");var i=v.createIfNeeded(e.url),a=e.style,t=e.tileMatrixSetID;0<=i.url.indexOf("{")?(i.setTemplateValues({style:a,Style:a,TileMatrixSet:t}),this._useKvp=!1):(i.setQueryParameters(X),this._useKvp=!0),this._resource=i,this._layer=e.layer,this._style=a,this._tileMatrixSetID=t,this._tileMatrixLabels=e.tileMatrixLabels,this._format=o(e.format,"image/jpeg"),this._tileDiscardPolicy=e.tileDiscardPolicy,this._tilingScheme=d(e.tilingScheme)?e.tilingScheme:new p({ellipsoid:e.ellipsoid}),this._tileWidth=o(e.tileWidth,256),this._tileHeight=o(e.tileHeight,256),this._minimumLevel=o(e.minimumLevel,0),this._maximumLevel=e.maximumLevel,this._rectangle=o(e.rectangle,this._tilingScheme.rectangle),this._dimensions=e.dimensions;var n=this;this._reload=void 0,d(e.times)&&(this._timeDynamicImagery=new b({clock:e.clock,times:e.times,requestImageFunction:function(t,e,r,i,a){return requestImage(n,t,e,r,i,a)},reloadFunction:function(){d(n._reload)&&n._reload()}})),this._readyPromise=c.defer();a=this._tilingScheme.positionToTileXY(m.southwest(this._rectangle),this._minimumLevel),t=this._tilingScheme.positionToTileXY(m.northeast(this._rectangle),this._minimumLevel),a=(Math.abs(t.x-a.x)+1)*(Math.abs(t.y-a.y)+1);if(4<a)throw new l("The imagery provider's rectangle and minimumLevel indicate that there are "+a+" tiles at the minimum level. Imagery providers with more than four tiles at the minimum level are not supported.");this._errorEvent=new u;a=e.credit;this._credit="string"==typeof a?new s(a):a,this._subdomains=e.subdomains,f(this._subdomains)?this._subdomains=this._subdomains.slice():d(this._subdomains)&&0<this._subdomains.length?this._subdomains=this._subdomains.split(""):this._subdomains=["a","b","c"],this.parseUrl(e.url),this.cache={},this.options=e,this.lightMap={},this.showLevel=e.showLevel||16,this.dataType="binary",e.hasOwnProperty("dataType")?this.dataType=e.dataType:this.dataType="Json","binary"==this.dataType?this.processor=new Cesium.TaskProcessor("VectorBinaryWorker",Number.POSITIVE_INFINITY):this.processor=new Cesium.TaskProcessor("VectorWorker",Number.POSITIVE_INFINITY);a=document.createElement("canvas");this.image=a,this.ratio=1,e.hasOwnProperty("ratio")&&(this.ratio=e.ratio),this.textureQueue=new V(this.viewer.scene.context._gl),this.lineAtlas=new q(256,512),this.decimalLevel=10,this.getDecimalLevel(),this.viewer.scene.camera.moveEnd.addEventListener(this.getDecimalLevel.bind(this)),this.changeStyleTilesMap={},this.needDrawTilesMap={},this.needDrawTiles=[],Promise.all(this.loadStyle()).then(function(){this.ready={value:!0},this._readyPromise.resolve(!0)}.bind(this))}draw(t){var e,t=this.getRenderTileMap(t),r=this.getStyleLevel();for(e in t){var i,a=this.cache[e];a&&(this.textureQueue.getOne(a.name,this._zoom,r)||(i=a.name+"_"+this._zoom+"_"+r,this.needDrawTilesMap[i]||(this.needDrawTilesMap[i]=!0,r!=a.level?this.changeStyle(a,r,i):this.needDrawTiles.push(a))))}n(this,this.needDrawTiles,this.needDrawTilesMap,r)}getStyleLevel(){let t=Math.round(this.viewer.camera.getLevel())-1;var e=this._tileMatrixLabels;return d(e)?e[t]:t.toString()}changeStyle(e,r,i){if(!this.changeStyleTilesMap[i]){this.changeStyleTilesMap[i]=!0;let t=this.processor.scheduleTask({changeStyle:!0,needDecode:this.options.needDecode,level:r,tileData:e.tileData,filterLayerId:this.options.filterLayerId,dataType:this.dataType});t.then(function(t,e,r){this.createBuffer(r),t.buckets=r,this.needDrawTiles.push(t),delete this.changeStyleTilesMap[e]}.bind(this,e,i),function(t,e){delete this.changeStyleTilesMap[t]}.bind(this,i))}}getRenderTileMap(e){let r={};var i=this._tileMatrixLabels;for(let t=0;t<e.length;t++){var a=e[t].data.imagery;for(let t=0;t<a.length;t++){var n,s=a[t].readyImagery;s&&s.imageryLayer._imageryProvider.id==this.id&&(n=d(i)?i[s.level]:s.level,n=s.x+"_"+s.y+"_"+n,r[n]=!0)}}return r}parseUrl(t){let e=t.split("?"),r=e[0].split("/mapserver/");this.host=r[0],0<this._subdomains.length&&(this.host=this.host.replace("{s}",this._subdomains[0])),this.servername=r[1].split("/")[1],this.queryParam=e[1];var i=this.queryParam.split("&");for(let e=0;e<i.length;e++){let t=i[e];var a=t.split("=");"styleId"==a[0]&&(this.styleId=a[1]),"return_type"==a[0]&&(this.return_type=a[1])}}loadStyle(){let e=[];var r=this.host+"/mapserver/styleInfo/"+this.servername+"/"+this.styleId+"/layer/style.js?"+Math.random();let t=v.createIfNeeded(r);r=t.fetchText();e.push(r);if("binary"==this.dataType){var r=this.host+"/mapserver/serverInfo/"+this.servername+".json?"+Math.random();let t=v.createIfNeeded(r);r=t.fetchJson(),e.push(r)}let n=c.defer();return c.all(e,function(t){var e=t[0],r=t[1];let i={init:!0,styleStr:e,tileSize:this._tileWidth,return_type:this.return_type};if(r&&r.layerMap){for(var a in this.serverInfo={},this.layerFieldMap={},r.layerMap)this.serverInfo[a]={geometryType:r.layerMap[a].geometryType,fieldsConfig:r.layerMap[a].fields},this.layerFieldMap[a]||(this.layerFieldMap[a]=r.layerMap[a].fields.length);i.serverInfo=this.serverInfo,i.layerFieldMap=this.layerFieldMap}e=this.processor.scheduleTask(i);c.all(e,function(){n.resolve()})}.bind(this)),[n.promise]}requestImageNow(t,e,r,i,a,n){var s,o=t._tileMatrixLabels,l=d(o)?o[i]:i.toString(),u=t._subdomains,o=t._dimensions,n=d(n)?n.data:void 0;t._useKvp?((s={}).tilematrix=l,s.layer=t._layer,s.style=t._style,s.tilerow=r,s.tilecol=e,s.tilematrixset=t._tileMatrixSetID,s.format=t._format,d(o)&&(s=h(s,o)),d(n)&&(s=h(s,n)),s=t._resource.getDerivedResource({queryParameters:s,request:a})):(u={z:l,y:r.toString(),x:e.toString(),s:u[(e+r+i)%u.length]},(s=t._resource.getDerivedResource({request:a})).setTemplateValues(u),d(o)&&s.setTemplateValues(o),d(n)&&s.setTemplateValues(n));n=c.defer(),r={x:e,y:r,z:i},i=s._templateValues.z;this.viewer.camera.getLevel();return i<this.showLevel?(n.reject(),n.promise):this.requestJsonData(n,t,s,r,a)?n.promise:void 0}requestJsonData(t,e,r,i,a){var n=i.x,s=i.y,o=(i.z,r._templateValues.z),s=this.cache[n+"_"+s+"_"+o];if(s)return t.resolve({isTexture:!0,texture:s.texture}),t;let l=this.processor.scheduleTask({url:r.url,needDecode:this.options.needDecode,level:o,filterLayerId:this.options.filterLayerId});return l.then(function(t,e,r,i,a,n){if(1==n)return i.state=y.CANCELLED,void t.reject();this.jsonPromiseResult(t,e,r,n)}.bind(this,t,i,o,a,r.url),function(t,e){t.reject()}.bind(this,t)),!0}jsonPromiseResult(t,e,r,i){var a=e.x,n=e.y,e=i.buckets,i=i.tileData,a=a+"_"+n+"_"+r;this.createBuffer(e);n={_target:3553,_texture:this.drawFbo(e,a,r),destroy:this.destroyTexture},e=new x(a,r,i,e,n);this.cache[a]=e,t.resolve({isTexture:!0,texture:n})}destroyTexture(){}drawFbo(t,e,r){return a(this,t,e,r)}createBuffer(e){for(let t=0;t<e.length;t++){var r=e[t];"fill"==r.type&&W.createBuffer(r),"line"==r.type&&N.createBuffer(r)}}get url(){return this._resource.url}get proxy(){return this._resource.proxy}get tileWidth(){return this._tileWidth}get tileHeight(){return this._tileHeight}get maximumLevel(){return this._maximumLevel}get minimumLevel(){return this._minimumLevel}get tilingScheme(){return this._tilingScheme}get rectangle(){return this._rectangle}get tileDiscardPolicy(){return this._tileDiscardPolicy}get errorEvent(){return this._errorEvent}get format(){return this._format}get readyPromise(){return this._readyPromise}get credit(){return this._credit}get hasAlphaChannel(){return!0}get clock(){return this._timeDynamicImagery.clock}set clock(t){this._timeDynamicImagery.clock=t}get times(){return this._timeDynamicImagery.times}set times(t){this._timeDynamicImagery.times=t}get dimensions(){return this._dimensions}set dimensions(t){this._dimensions!==t&&(this._dimensions=t,d(this._reload)&&this._reload())}getTileCredits(t,e,r){}requestImage(t,e,r,i){var a,n,s=this._timeDynamicImagery;return d(s)&&(n=s.currentInterval,a=s.getFromCache(t,e,r,i)),d(a)||(a=this.requestImageNow(this,t,e,r,i,n)),d(a)&&d(s)&&s.checkApproachingInterval(t,e,r,i),a}pickFeatures(t,e,r,i,a){}destroy(){for(var e in this.viewer.scene.camera.moveEnd.removeEventListener(this.getDecimalLevel.bind(this)),this.cache){let t=this.cache[e];t.destroy()}this.cache={}}removeImageryFromCache(t,e,r){var i=this._tileMatrixLabels,r=t+"_"+e+"_"+(d(i)?i[r]:r);let a=this.cache[r];a&&(a.destroy(),this.textureQueue.remove(a.name),delete this.cache[r])}useProgram(t){return i.createProgram(this.viewer.scene.context._gl,t)}getTexture(t){let e=t.level;var r=this._tileMatrixLabels,r=d(r)?r[e]:e.toString(),t=t.x+"_"+t.y+"_"+r,r=this.getStyleLevel(),r=this.textureQueue.get(t,this._zoom,r);return r?{_target:3553,_texture:r,destroy:this.destroyTexture}:null}getDecimalLevel(){let t=1;var e=this.decimalLevel;let r=this.viewer.camera.getLevel();var i=r.toString().split("."),a=i[0],i="0."+i[1];let n=a=Number(a);(i=Number(i))&&(e=Math.round(i*e)/e,n+=e,t+=e),this.zoom=a,this._zoom=n,this.scale=t}}},{"../../utils/TextureQueue":107,"../shaders/ProgramFactory":61,"./LineAtlas":64,"./VectorTile":65,"./draw/DrawFboVector":67,"./draw/DrawTilesFboVector":70}],67:[function(t,e,r){const n=t("./DrawVector"),s=t("../../../mapbox/gl-matrix")["mat4"];class l{static drawFboVector(t,e,r,i){const a=t.viewer.scene.context._gl;var n=t.viewer.scene._view.passState;let s=null;n.framebuffer&&(s=n.framebuffer._framebuffer);n=n.viewport;a.enable(a.BLEND),a.blendFunc(a.ONE,a.ONE_MINUS_SRC_ALPHA);let o=t.textureQueue.getOne(r,t._zoom,i);return o||(o=l.initFramebufferObject(t,a,t.scale,1),t.textureQueue.add(r,t._zoom,i,o),l.drawRasterTile(t,e,a,1)),a.bindFramebuffer(a.FRAMEBUFFER,s),a.viewport(0,0,n.width,n.height),a.viewport(0,0,t.viewer._lastWidth,t.viewer._lastHeight),o}static drawRasterTile(t,e,r,i){var a=s.identity(new Float32Array(16));s.translate(a,a,[-1,-1,0]),s.scale(a,a,[2/8192,2/8192,1]),l.cleanViewPort(r,t._tileWidth*t.ratio*t.scale*i,t._tileWidth*t.ratio*t.scale*i),r.clearColor(1,1,1,0),r.clear(r.COLOR_BUFFER_BIT),n(t,e,a,!0)}static initFramebufferObject(t,e,r,i){var a=t.viewportFbo;a?e.bindFramebuffer(e.FRAMEBUFFER,a):(n=e.createFramebuffer(),e.bindFramebuffer(e.FRAMEBUFFER,n),t.viewportFbo=n);var n=e.createTexture();return e.bindTexture(e.TEXTURE_2D,n),e.texImage2D(e.TEXTURE_2D,0,e.RGBA,t._tileWidth*t.ratio*r*i,t._tileWidth*t.ratio*r*i,0,e.RGBA,e.UNSIGNED_BYTE,null),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MAG_FILTER,e.LINEAR),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MIN_FILTER,e.LINEAR),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_WRAP_S,e.CLAMP_TO_EDGE),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_WRAP_T,e.CLAMP_TO_EDGE),e.framebufferTexture2D(e.FRAMEBUFFER,e.COLOR_ATTACHMENT0,e.TEXTURE_2D,n,0),n}static cleanViewPort(t,e,r){t.viewport(0,0,e,r)}}e.exports=l.drawFboVector},{"../../../mapbox/gl-matrix":87,"./DrawVector":71}],68:[function(t,e,r){const p=t("../../../mapbox/VertexArrayObject");e.exports=function(t,e,r,i){e.style.fill&&function(t,e,r,i,a){const n=t.viewer.scene.context._gl;let s,o,l,u,h,d;s=i?(o="fillOutline",n.LINES):(o="fill",n.TRIANGLES);var f=t.useProgram(o);null;i?(u=e.layoutVertexBuffer2,h=e.indexBuffer2,d=e.segments2,n.drawingBufferWidth,n.drawingBufferHeight,l=(o,function(t,e,r,i,a){e.uniformMatrix4fv(t.u_matrix,!1,r);i=i._tileWidth*i.ratio*i.scale;e.uniform2f(t.u_world,i,i),e.uniform4fv(t.outline_color,a.strokeColor),e.uniform1f(t.opacity,a.strokeOpacity)}(f,n,r,t,e.style))):(u=e.layoutVertexBuffer,h=e.indexBuffer,d=e.segments,l=n.uniformMatrix4fv(f.u_matrix,!1,r),function(t,e,r){t.uniform4fv(e.u_color,r.fillColor),t.uniform1f(e.u_opacity,r.fillOpacity)}(n,f,e.style));var m={[n.LINES]:2,[n.TRIANGLES]:3,[n.LINE_STRIP]:1}[s];for(let t=0;t<d.segments.length;t++){const v=d.segments[t];v.vao||(v.vao=new p),v.vao.bind(n,f,u,h,null,v.vertexOffset),n.drawElements(s,v.primitiveLength*m,n.UNSIGNED_SHORT,v.primitiveOffset*m*2),a&&v.vao.destroy()}}(t,e,r,!1,i)}},{"../../../mapbox/VertexArrayObject":86}],69:[function(t,e,r){const d=t("../../../mapbox/VertexArrayObject");e.exports=function(t,e,r,i,a){var n=e.style,s=n.strokeWidth;if(0!=n.strokeOpacity&&0!=s){var o=n.dash;const u=t.viewer.scene.context._gl;var l=t.useProgram(o?"lineSDF":"line");o?function(t,e,r,i,a,n){t.uniformMatrix4fv(e.u_matrix,!1,r),t.uniform1f(e.u_ratio,i._tileWidth/8192),t.uniform2f(e.u_gl_units_to_pixels,1/(2/t.drawingBufferWidth),1/(-2/t.drawingBufferHeight));var s;var o=i._tileWidth/8192;s=i.lineAtlas.getDash(a,"round"===n.lineCap),r=i.lineAtlas.getDash(a,"round"===n.lineJoin);a=2*s.width,n=+r.width;t.uniform2f(e.u_patternscale_a,o/a,-s.height/2),t.uniform2f(e.u_patternscale_b,o/n,-r.height/2),t.uniform1f(e.u_sdfgamma,i.lineAtlas.width/(256*Math.min(a,n)*1.25)/2),t.uniform1i(e.u_image,0),t.activeTexture(t.TEXTURE0),i.lineAtlas.bind(t),t.uniform1f(e.u_tex_y_a,s.y),t.uniform1f(e.u_tex_y_b,r.y),t.uniform1f(e.u_mix,1)}(u,l,r,t,o,n):(s=u,o=l,t=t._tileWidth,s.uniformMatrix4fv(o.u_matrix,!1,r),s.uniform1f(o.u_ratio,t/8192),s.uniform2f(o.u_gl_units_to_pixels,1/(2/s.drawingBufferWidth),1/(-2/s.drawingBufferHeight)));null,function(t,e,r,i){let a=r.strokeWidth;i&&(a/=i);t.uniform1f(e.u_width,a),t.uniform4fv(e.color,r.strokeColor),t.uniform1f(e.opacity,r.strokeOpacity),t.uniform1f(e.blur,0),t.uniform1f(e.a_gapwidth,0),t.uniform1f(e.a_offset,0)}(u,l,n,a);for(let t=0;t<e.segments.segments.length;t++){const h=e.segments.segments[t];h.vao||(h.vao=new d),h.vao.bind(u,l,e.layoutVertexBuffer,e.indexBuffer,null,h.vertexOffset),u.drawElements(u.TRIANGLES,3*h.primitiveLength,u.UNSIGNED_SHORT,3*h.primitiveOffset*2),i&&h.vao.destroy()}}}},{"../../../mapbox/VertexArrayObject":86}],70:[function(t,e,r){const s=t("./DrawVector"),o=t("../../../mapbox/gl-matrix")["mat4"],m=t("../../../mapbox/Browser");class v{static drawFboVector(r,i,a,n){if(0!=i.length){const d=m.now();var t=r.viewer.scene._view.passState;let e=null;t.framebuffer&&(e=t.framebuffer._framebuffer);var s=t.viewport;const f=r.viewer.scene.context._gl;for(f.enable(f.BLEND),f.blendFunc(f.ONE,f.ONE_MINUS_SRC_ALPHA);0<i.length;){var o=i.shift();delete a[o.name+"_"+r._zoom+"_"+n];var l=o.name,u=o.buckets;let t=1;n-o.level==1&&(t=2);var h=v.initFramebufferObject(r,f,r.scale,t);r.textureQueue.add(l,r._zoom,n,h);o=Math.pow(2,n)/Math.pow(2,o.level);if(v.drawRasterTile(r,u,f,t,o),3<m.now()-d)return f.disable(f.BLEND),f.bindFramebuffer(f.FRAMEBUFFER,e),f.viewport(0,0,s.width,s.height),!0}return f.disable(f.BLEND),f.bindFramebuffer(f.FRAMEBUFFER,e),f.viewport(0,0,s.width,s.height),!0}}static drawRasterTile(t,e,r,i,a){var n=o.identity(new Float32Array(16));o.translate(n,n,[-1,-1,0]),o.scale(n,n,[2/8192,2/8192,1]),v.cleanViewPort(r,t._tileWidth*t.ratio*t.scale*i,t._tileWidth*t.ratio*t.scale*i),r.clearColor(1,1,1,0),r.clear(r.COLOR_BUFFER_BIT),s(t,e,n,!1,a)}static initFramebufferObject(t,e,r,i){var a=t.viewportFbo;a?e.bindFramebuffer(e.FRAMEBUFFER,a):(n=e.createFramebuffer(),e.bindFramebuffer(e.FRAMEBUFFER,n),t.viewportFbo=n);var n=e.createTexture();return e.bindTexture(e.TEXTURE_2D,n),e.texImage2D(e.TEXTURE_2D,0,e.RGBA,t._tileWidth*t.ratio*r*i,t._tileWidth*t.ratio*r*i,0,e.RGBA,e.UNSIGNED_BYTE,null),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MAG_FILTER,e.LINEAR),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MIN_FILTER,e.LINEAR),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_WRAP_S,e.CLAMP_TO_EDGE),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_WRAP_T,e.CLAMP_TO_EDGE),e.framebufferTexture2D(e.FRAMEBUFFER,e.COLOR_ATTACHMENT0,e.TEXTURE_2D,n,0),n}static cleanViewPort(t,e,r){t.viewport(0,0,e,r)}}e.exports=v.drawFboVector},{"../../../mapbox/Browser":82,"../../../mapbox/gl-matrix":87,"./DrawVector":71}],71:[function(t,e,r){const o={fill:t("./DrawFill"),line:t("./DrawLine")};e.exports=function(e,r,i,a,n){const t=e.viewer.scene.context._gl;t.disable(t.DEPTH_TEST);for(let t=0;t<r.length;t++){var s=r[t];o[s.type](e,s,i,a,n)}t.enable(t.DEPTH_TEST)}},{"./DrawFill":68,"./DrawLine":69}],72:[function(t,e,r){const h=Cesium.combine,a=Cesium.Credit,s=Cesium.defaultValue,d=Cesium.defined,o=Cesium.DeveloperError,l=Cesium.Event,u=Cesium.Rectangle,f=Cesium.Resource,m=Cesium.WebMercatorTilingScheme,v=Cesium.when,p=Cesium.ImageryProvider,c=Cesium.TimeDynamicImagery,b=t("../GXYZUtil");var y=Object.freeze({service:"WMTS",version:"1.0.0",request:"GetTile"});function V(t,e){if(this.viewer=t,e=s(e,s.EMPTY_OBJECT),!d(e.url))throw new o("options.url is required.");if(!d(e.layer))throw new o("options.layer is required.");if(!d(e.style))throw new o("options.style is required.");if(!d(e.tileMatrixSetID))throw new o("options.tileMatrixSetID is required.");if(d(e.times)&&!d(e.clock))throw new o("options.times was specified, so options.clock is required.");!e.hasOwnProperty("hostUrl")||2==(i=e.url.split("mapserver")).length&&(e.url=e.hostUrl+"/"+i[1]);var r=f.createIfNeeded(e.url),t=e.style,i=e.tileMatrixSetID;0<=r.url.indexOf("{")?(r.setTemplateValues({style:t,Style:t,TileMatrixSet:i}),this._useKvp=!1):(r.setQueryParameters(y),this._useKvp=!0),this._resource=r,this._layer=e.layer,this._style=t,this._tileMatrixSetID=i,this._tileMatrixLabels=e.tileMatrixLabels,this._format=s(e.format,"image/jpeg"),this._tileDiscardPolicy=e.tileDiscardPolicy,this._tilingScheme=d(e.tilingScheme)?e.tilingScheme:new m({ellipsoid:e.ellipsoid}),this._tileWidth=s(e.tileWidth,256),this._tileHeight=s(e.tileHeight,256),this._minimumLevel=s(e.minimumLevel,0),this._maximumLevel=e.maximumLevel,this._rectangle=s(e.rectangle,this._tilingScheme.rectangle),this._dimensions=e.dimensions;var n=this;this._reload=void 0,d(e.times)&&(this._timeDynamicImagery=new c({clock:e.clock,times:e.times,requestImageFunction:function(t,e,r,i,a){return q(n,t,e,r,i,a)},reloadFunction:function(){d(n._reload)&&n._reload()}})),this._readyPromise=v.resolve(!0);t=this._tilingScheme.positionToTileXY(u.southwest(this._rectangle),this._minimumLevel),i=this._tilingScheme.positionToTileXY(u.northeast(this._rectangle),this._minimumLevel),t=(Math.abs(i.x-t.x)+1)*(Math.abs(i.y-t.y)+1);if(4<t)throw new o("The imagery provider's rectangle and minimumLevel indicate that there are "+t+" tiles at the minimum level. Imagery providers with more than four tiles at the minimum level are not supported.");this._errorEvent=new l;t=e.credit;this._credit="string"==typeof t?new a(t):t,this._subdomains=e.subdomains,Array.isArray(this._subdomains)?this._subdomains=this._subdomains.slice():d(this._subdomains)&&0<this._subdomains.length?this._subdomains=this._subdomains.split(""):this._subdomains=["a","b","c"],e.highlightLayer||(this.viewer.imageryLayers.layerAdded.addEventListener(V.prototype._onLayerAdded,this),this.viewer.imageryLayers.layerRemoved.addEventListener(V.prototype._onLayerRemoved,this),this.viewer.imageryLayers.layerMoved.addEventListener(V.prototype._onLayerMoved,this)),this.options=e,this.sourceUrl=e.url.split("&control")[0],this.gxyzUtil=new b,this.gxyzUtil.tileSize=this.tilesize,this.gxyzUtil.parseUrl(e.url)}function q(t,e,r,i,a,n){var s,o=t._tileMatrixLabels,l=d(o)?o[i]:i.toString(),u=t._subdomains,o=t._dimensions,n=d(n)?n.data:void 0;t._useKvp?((s={}).tilematrix=l,s.layer=t._layer,s.style=t._style,s.tilerow=r,s.tilecol=e,s.tilematrixset=t._tileMatrixSetID,s.format=t._format,d(o)&&(s=h(s,o)),d(n)&&(s=h(s,n)),s=t._resource.getDerivedResource({queryParameters:s,request:a})):(u={TileMatrix:l,TileRow:r.toString(),TileCol:e.toString(),s:u[(e+r+i)%u.length]},(s=t._resource.getDerivedResource({request:a})).setTemplateValues(u),d(o)&&s.setTemplateValues(o),d(n)&&s.setTemplateValues(n));s.templateValues;return p.loadImage(t,s)}Object.defineProperties(V.prototype,{url:{get:function(){return this._resource.url}},proxy:{get:function(){return this._resource.proxy}},tileWidth:{get:function(){return this._tileWidth}},tileHeight:{get:function(){return this._tileHeight}},maximumLevel:{get:function(){return this._maximumLevel}},minimumLevel:{get:function(){return this._minimumLevel}},tilingScheme:{get:function(){return this._tilingScheme}},rectangle:{get:function(){return this._rectangle}},tileDiscardPolicy:{get:function(){return this._tileDiscardPolicy}},errorEvent:{get:function(){return this._errorEvent}},format:{get:function(){return this._format}},ready:{value:!0},readyPromise:{get:function(){return this._readyPromise}},credit:{get:function(){return this._credit}},hasAlphaChannel:{get:function(){return!0}},clock:{get:function(){return this._timeDynamicImagery.clock},set:function(t){this._timeDynamicImagery.clock=t}},times:{get:function(){return this._timeDynamicImagery.times},set:function(t){this._timeDynamicImagery.times=t}},dimensions:{get:function(){return this._dimensions},set:function(t){this._dimensions!==t&&(this._dimensions=t,d(this._reload)&&this._reload())}}}),V.prototype.getTileCredits=function(t,e,r){},V.prototype.requestImage=function(t,e,r,i){var a,n,s=this._timeDynamicImagery;return d(s)&&(n=s.currentInterval,a=s.getFromCache(t,e,r,i)),d(a)||(a=q(this,t,e,r,i,n)),d(a)&&d(s)&&s.checkApproachingInterval(t,e,r,i),a},V.prototype.pickFeatures=function(t,e,r,i,a){},V.prototype._onLayerAdded=function(t,e){t.imageryProvider==this&&(this.index=e)},V.prototype._onLayerRemoved=function(t,e){t.imageryProvider==this&&this.cancelHighlight()},V.prototype._onLayerMoved=function(t,e,r){t.imageryProvider==this&&(this.index=e)},V.prototype.setFilter=function(t){if(this.isSetIngFilter=!0,!t||0==t.layers.length&&0==t.order.length)return this.isSetIngFilter=!1,this.controlId=null,this.control=null,this.UpdateUrl(this.sourceUrl),void this.redraw();this.gxyzUtil.setFilter(t,function(t){var e;this.isSetIngFilter=!1,t.isIE?(this.controlId=t.id,e=this.sourceUrl+"&controlId="+t.id,this.UpdateUrl(e)):(this.control=t.id,t=this.sourceUrl+"&control="+t.id,this.UpdateUrl(t)),this.redraw()}.bind(this))},V.prototype.UpdateUrl=function(t){this.options.url=t;var e=f.createIfNeeded(this.options.url),r=this.options.style,i=this.options.tileMatrixSetID;0<=(t=e.url).indexOf("{")?(e.setTemplateValues({style:r,Style:r,TileMatrixSet:i}),this._useKvp=!1):(e.setQueryParameters(y),this._useKvp=!0),this._resource=e},V.prototype.redraw=function(){var e=this.viewer.imageryLayers._layers;let r=null,i=-1;for(let t=0;t<e.length;t++){var a=e[t];a.imageryProvider==this&&(r=a,i=t)}r&&(this.viewer.imageryLayers.layerShownOrHidden.raiseEvent(r,i,!1),this.viewer.imageryLayers.layerShownOrHidden.raiseEvent(r,i,!0))},V.prototype.highlightByFilter=function(t){var e;0!=t.layers.length&&(this.highlightLayer||(e=Object.assign({highlightLayer:!0},this.options),this.highlightProvider=new V(this.viewer,e),this.highlightLayer=new Cesium.ImageryLayer(this.highlightProvider),this.viewer.imageryLayers.add(this.highlightLayer,this.index+1)),this.highlightProvider.setFilter(t))},V.prototype.cancelHighlight=function(){this.highlightLayer&&(this.viewer.imageryLayers.remove(this.highlightLayer),this.highlightLayer=null)},V.prototype.highlightFeatures=function(t,e){t=this.gxyzUtil.CreateHighlightFilter(t,e);0!=t.layers.length&&(this.highlightLayer||(e=Object.assign({highlightLayer:!0},this.options),this.highlightProvider=new V(this.viewer,e),this.highlightLayer=new Cesium.ImageryLayer(this.highlightProvider),this.viewer.imageryLayers.add(this.highlightLayer,this.index+1)),this.highlightProvider.setFilter(t))},e.exports=V},{"../GXYZUtil":28}],73:[function(t,e,r){e.exports=class{constructor(){this.type="",this.positionArray=[],this.colorArray=[],this.lightCount=0,this.lightMap={},this.films=[]}addFilm(t){this.films.push(t),0<this.positionArray.length&&t.updateLightShader(this)}removeFilm(t){var e=this.films.indexOf(t);this.films.splice(e,1),0<this.positionArray.length&&t.removeLightShader(this.type)}addLight(t,e){for(var r in this.lightMap[t]||this.lightCount++,this.lightMap[t]=e,this.updateLightArray(),this.films){let t=this.films[r];t.updateLightShader(this)}}removeLight(t){if(this.lightMap[t]){this.lightMap[t];if(this.lightCount--,delete this.lightMap[t],this.updateLightArray(),0==this.lightCount)for(var e in this.films){let t=this.films[e];t.removeLightShader(this.type)}else for(var r in this.films){let t=this.films[r];t.updateLightShader(this)}}}removeAllLight(){for(var e in this.lightCount=0,this.lightMap={},this.films){let t=this.films[e];t.removeLightShader(this.type)}}updateLightArray(){}getGlobeSurfaceShader(){}getPolygonColorPrimitiveShader(){}getLineColorPrimitiveShader(){}}},{}],74:[function(t,e,r){function v(t){let e=t.toString();return e.indexOf(".")<0&&(e+="."),e}e.exports=class{static createLightOptions(t){var e=this.createVertexShader(t),r=this.createFragmentShader(t);let i=[];var a=t.pointLightOptions;if(a)for(var n in a)i.push(a[n].pointLightPosition);return{vertexShader:e,fragmentShader:r,plp:i}}static createVertexShader(t){let e="void main(){\n xh_vertexShader();\n",r="";t.b2tScanOptions&&(r+=this.createTop2BottomVertexShader(t.b2tScanOptions),e+="  xh_b2tScanShader();\n");let i="";t.pointLightOptions&&(i+=this.createPointLightVertexShader(),e+="  xh_pointLightShader();\n");return r+i+e+"}\n"}static createFragmentShader(t){let e="void main(){\n xh_fragmentShader();\n",r="";t.b2tScanOptions&&(r+=this.createTop2BottomFragmentShader(t.b2tScanOptions),e+="  xh_b2tScanShader();\n");let i="";t.pointLightOptions&&(i+=this.createPointLightFragmentShader(t.pointLightOptions),e+="  xh_pointLightShader();\n");return r+i+e+"}\n"}static createTop2BottomVertexShader(t){var e=t.axisName||"z";let r=t.correctHeight||0;return"varying float v_height_b2t;\nvarying vec3 v_positionEC_b2t;\nvoid xh_b2tScanShader(){\n   v_height_b2t = a_position."+e+" + "+r.toFixed(2)+";\n   vec4 tp = czm_instanced_modelView * vec4(a_position,1.);\n   //tp = czm_inverseView * tp;\n   v_positionEC_b2t = tp.xyz/tp.w;\n}\n"}static createTop2BottomFragmentShader(t){var e=t.maxHeight||1e3,r=t.scanHeight||2500,i=(t.scanWidth||50)/r,a=t.speed||600,n=t.color||Cesium.Color.YELLOW;let s=t.correctHeight||0;var o=t.minimumlight||.8,l=t.maximumlight||1,u=t.blackAndWhite||.1;console.log(o,l,u);t="void xh_b2tScanShader(){\n";return t+="  float minl = "+v(o)+";\n",t+="  float maxl = "+v(l)+";\n",t+="  float baw = "+v(u)+";\n",t+="  float speed = "+v(a)+";\n",t+="  float rate = "+v(i)+";\n",t+="  float mHeight = "+v(e)+";\n",t+="  float sHeight =  "+v(r)+";\n",t+="  vec3 color =  vec3("+v(n.red)+","+v(n.green)+","+v(n.blue)+");\n","varying float v_height_b2t;\nvarying vec3 v_positionEC_b2t;\nuniform mat4 u_ienu_view;\nvoid b2tScan(float ch,float mh,float sh,float speed,float sRate,vec3 color,float minl,float maxl,float baw){\n   float a11 = fract(czm_frameNumber / speed) * 3.14159265 * 2.;\n   float f = ch /mh;\n   \n   float ff = clamp(f,minl,maxl);\n   float a12 = ff + sin(a11) * baw;\n   gl_FragColor.rgb *= a12;\n   float a13 = fract(czm_frameNumber / speed);\n   float ah = clamp(ch / sh, 0.0, 1.0);\n   a13 = abs(a13 - 0.5) * 2.0;\n   float a_diff = step(sRate, abs(ah - a13));\n   if(a_diff < 0.5)\n     gl_FragColor.rgb = color.rgb;\n}\n"+(t+="   float ch = v_height_b2t;\n   vec4 tp = u_ienu_view * vec4(v_positionEC_b2t , 1.);\n   tp /= tp.w;\n   b2tScan(tp.z + "+s.toFixed(4)+",mHeight,sHeight,speed,rate,color,minl,maxl,baw);}\n")}static createPointLightVertexShader(){return"varying vec3 xh_pointLightCoord;\nvoid xh_pointLightShader(){\n   vec4 tp = czm_instanced_modelView * vec4(a_position ,1.);\n   xh_pointLightCoord = tp.xyz;\n}\n"}static createPointLightFragmentShader(t){let e="varying vec3 xh_pointLightCoord;\n";for(var r in t)e+="uniform vec3 xh_pointLightPosition"+r+";\n";let i="void xh_pointLightShader(){\n";for(var a in t){var n=t[a],s=n.pointLightPosition,o=n.pointLightColor||Cesium.Color.WHITE,l=n.pointLightRadius||100,u=n.pointLightStrength||1,h=v(l),d=v(s.x),f=v(s.y),m=v(s.z),n=v(o.red),l=v(o.green),s=v(o.blue),o=v(o.alpha);i+="float xh_pointLightRadius"+a+" = "+v(h)+";\nfloat xh_pointLightStrength"+a+" = "+v(u)+";\nvec3 xh_pointLightCoord"+a+" = vec3("+v(d)+","+v(f)+","+v(m)+");\nvec4 xh_pointLightColor"+a+" = vec4("+v(n)+","+v(l)+","+v(s)+","+v(o)+");\n",i+=this.pointLightShader(a,"xh_pointLightCoord")}return e+i+"}\n"}static pointLightShader(t,e){return"vec4 xh_pl"+t+" =  czm_inverseView3D * vec4(xh_pointLightPosition"+t+".xyz ,1.);\n xh_pl"+t+" /=  xh_pl"+t+".w ;\n float xh_dis"+t+" = length( "+e+" - xh_pointLightPosition"+t+".xyz);\n if(xh_dis"+t+" <= xh_pointLightRadius"+t+"){\n   float f = (1. - xh_dis"+t+"/ xh_pointLightRadius"+t+");\n   gl_FragColor.rgb += xh_pointLightStrength"+t+"* xh_pointLightColor"+t+".rgb * f ;\n }\n"}}},{}],75:[function(t,e,r){function v(t){let e=t.toString();return e.indexOf(".")<0&&(e+="."),e}class p{static createLightOptions(t){var e=p.createVertexShader(t),r=p.createFragmentShader(t);let i=[];var a=t.pointLightOptions;if(a)for(var n in a)i.push(a[n].pointLightPosition);return{vertexShader:e,fragmentShader:r,plp:i}}static createVertexShader(t){let e="void main(){\n xh_vertexShader();\n",r="";t.b2tScanOptions&&(r+=p.createTop2BottomVertexShader(t.b2tScanOptions),e+="  xh_b2tScanShader();\n");let i="";t.pointLightOptions&&(i+=p.createPointLightVertexShader(),e+="  xh_pointLightShader();\n");return r+i+e+"}\n"}static createFragmentShader(t){let e="void main(){\n xh_fragmentShader();\n",r="";t.b2tScanOptions&&(r+=p.createTop2BottomFragmentShader(t.b2tScanOptions),e+="  xh_b2tScanShader();\n");let i="";t.pointLightOptions&&(i+=p.createPointLightFragmentShader(t.pointLightOptions),e+="  xh_pointLightShader();\n");return r+i+e+"}\n"}static createTop2BottomVertexShader(t){var e=t.axisName||"z";let r=t.correctHeight||0;return"varying float v_height_b2t;\nvarying vec3 v_positionEC_b2t;\nvoid xh_b2tScanShader(){\n   v_height_b2t = a_position."+e+" + "+r.toFixed(2)+";\n   vec4 tp = u_modelViewMatrix * vec4(a_position,1.);\n   //tp = czm_inverseView * tp;\n   v_positionEC_b2t = tp.xyz/tp.w;\n}\n"}static createTop2BottomFragmentShader(t){var e=t.maxHeight||1e3,r=t.scanHeight||2500,i=(t.scanWidth||50)/r,a=t.speed||600,n=t.color||Cesium.Color.YELLOW;let s=t.correctHeight||0;var o=t.minimumlight||.8,l=t.maximumlight||1,u=t.blackAndWhite||.1;console.log(o,l,u);t="void xh_b2tScanShader(){\n";return t+="  float minl = "+v(o)+";\n",t+="  float maxl = "+v(l)+";\n",t+="  float baw = "+v(u)+";\n",t+="  float speed = "+v(a)+";\n",t+="  float rate = "+v(i)+";\n",t+="  float mHeight = "+v(e)+";\n",t+="  float sHeight =  "+v(r)+";\n",t+="  vec3 color =  vec3("+v(n.red)+","+v(n.green)+","+v(n.blue)+");\n","varying float v_height_b2t;\nvarying vec3 v_positionEC_b2t;\nuniform mat4 u_ienu_view;\nvoid b2tScan(float ch,float mh,float sh,float speed,float sRate,vec3 color,float minl,float maxl,float baw){\n   float a11 = fract(czm_frameNumber / speed) * 3.14159265 * 2.;\n   float f = ch /mh;\n   \n   float ff = clamp(f,minl,maxl);\n   float a12 = ff + sin(a11) * baw;\n   gl_FragColor.rgb *= a12;\n   float a13 = fract(czm_frameNumber / speed);\n   float ah = clamp(ch / sh, 0.0, 1.0);\n   a13 = abs(a13 - 0.5) * 2.0;\n   float a_diff = step(sRate, abs(ah - a13));\n   if(a_diff < 0.5)\n     gl_FragColor.rgb = color.rgb;\n}\n"+(t+="   float ch = v_height_b2t;\n   vec4 tp = u_ienu_view * vec4(v_positionEC_b2t , 1.);\n   tp /= tp.w;\n   b2tScan(tp.z + "+s.toFixed(4)+",mHeight,sHeight,speed,rate,color,minl,maxl,baw);}\n")}static createPointLightVertexShader(){return"varying vec3 xh_pointLightCoord;\nvoid xh_pointLightShader(){\n   vec4 tp = u_modelViewMatrix * vec4(a_position ,1.);\n   xh_pointLightCoord = tp.xyz;\n}\n"}static createPointLightFragmentShader(t){let e="varying vec3 xh_pointLightCoord;\n";for(var r in t)e+="uniform vec3 xh_pointLightPosition"+r+";\n";let i="void xh_pointLightShader(){\n";for(var a in t){var n=t[a],s=n.pointLightPosition,o=n.pointLightColor||Cesium.Color.WHITE,l=n.pointLightRadius||100,u=n.pointLightStrength||1,h=v(l),d=v(s.x),f=v(s.y),m=v(s.z),n=v(o.red),l=v(o.green),s=v(o.blue),o=v(o.alpha);i+="float xh_pointLightRadius"+a+" = "+v(h)+";\nfloat xh_pointLightStrength"+a+" = "+v(u)+";\nvec3 xh_pointLightCoord"+a+" = vec3("+v(d)+","+v(f)+","+v(m)+");\nvec4 xh_pointLightColor"+a+" = vec4("+v(n)+","+v(l)+","+v(s)+","+v(o)+");\n",i+=p.pointLightShader(a,"xh_pointLightCoord")}return e+i+"}\n"}static pointLightShader(t,e){return"vec4 xh_pl"+t+" =  czm_inverseView3D * vec4(xh_pointLightPosition"+t+".xyz ,1.);\n xh_pl"+t+" /=  xh_pl"+t+".w ;\n float xh_dis"+t+" = length( "+e+" - xh_pointLightPosition"+t+".xyz);\n if(xh_dis"+t+" <= xh_pointLightRadius"+t+"){\n   float f = (1. - xh_dis"+t+"/ xh_pointLightRadius"+t+");\n   gl_FragColor.rgb += xh_pointLightStrength"+t+"* xh_pointLightColor"+t+".rgb * f ;\n }\n"}}e.exports=p},{}],76:[function(t,e,r){t=t("./Light.js");class i extends t{constructor(){super(),this.type="PointLight",this.radiusArray=[]}updateLightArray(){for(var t in this.positionArray=[],this.colorArray=[],this.radiusArray=[],this.lightMap){t=this.lightMap[t];this.positionArray.push(t.position),this.colorArray.push(t.color),this.radiusArray.push(t.radius)}}getGlobeSurfaceShader(){return{vertexShaderSource:Cesium.ShaderSource.replaceMain(this.getGlobeSurfaceVS(),this.type),fragmentShaderSource:Cesium.ShaderSource.replaceMain(this.getFS(),this.type)}}getPolygonColorPrimitiveShader(){return{vertexShaderSource:Cesium.ShaderSource.replaceMain(this.getPolygonColorPrimitiveVs(),this.type),fragmentShaderSource:Cesium.ShaderSource.replaceMain(this.getFS(),this.type)}}getGlobeSurfaceVS(){return`
          varying vec3 v_xh_position;
          void main(){
            #ifdef QUANTIZATION_BITS12
                vec2 xy = czm_decompressTextureCoordinates(compressed0.x);
                vec2 zh = czm_decompressTextureCoordinates(compressed0.y);
                vec3 position = vec3(xy, zh.x);
                float height = zh.y;
                vec2 textureCoordinates = czm_decompressTextureCoordinates(compressed0.z);
            
                height = height * (u_minMaxHeight.y - u_minMaxHeight.x) + u_minMaxHeight.x;
                position = (u_scaleAndBias * vec4(position, 1.0)).xyz;
            #else
                // A single float per element
                vec3 position = position3DAndHeight.xyz;
            #endif
                v_xh_position = position + u_center3D;
          }
          `}getPolygonColorPrimitiveVs(){return"varying vec3 v_xh_position;\nvoid main(){\n v_xh_position = position3DHigh + position3DLow;\n}\n"}getFS(){let t="vec3 calPointLightColor(vec3 wp,vec3 pos,vec4 color,float radius){\n   vec3 color1 = vec3(0.,0.,0.);\n   float dis = length(wp - pos);\n   if(dis < radius){\n     color1 = color.rgb * (1. - dis / radius);\n   }\n   return color1;\n}\nvoid main(){\n";for(var e in this.positionArray)t+="vec3 lightPos"+e+" = vec3("+this.positionArray[e].x.toFixed(5)+","+this.positionArray[e].y.toFixed(5)+","+this.positionArray[e].z.toFixed(5)+");\nvec4 lightColor"+e+" = vec4("+this.colorArray[e].red.toFixed(5)+","+this.colorArray[e].green.toFixed(5)+","+this.colorArray[e].blue.toFixed(5)+","+this.colorArray[e].alpha.toFixed(5)+");\nfloat lightRadius"+e+" = "+this.radiusArray[e].toFixed(5)+";\ngl_FragColor.rgb += calPointLightColor( v_xh_position, lightPos"+e+", lightColor"+e+", lightRadius"+e+");\n";return t+="}\n","varying vec3 v_xh_position;\n"+t}}e.exports=i},{"./Light.js":73}],77:[function(t,e,r){e.exports=class i{static createRadar3dTileLigh(t){return new i(t)}constructor(t){this.viewer=t.viewer||window.viewer,this.positions=t.positions,this.center=t.center,this.radius=t.radius||0,this.center&&0<this.radius&&(this.positions=this.computeEllipsePosition_pls(this.center,this.radius,270,-90)),this.color=t.color||Cesium.Color.YELLOW,this.direction=t.direction||-1,this.speed=t.speed||600,this.scale=t.scale||.5,this.showLine=t.showLine||!1,this.lineWidth=t.lineWidth||4,this.lineColor=t.lineColor||new Cesium.Color(1,1,0,.5),this.scanCenter=t.scanCenter,Cesium.defined(t.scanCenter)?this.scanCenter=this.computeScanTextureCoordAndRate(t.scanCenter,this.positions).tc:this.scanCenter=new Cesium.Cartesian2(.5,.5),this.update()}draw(){var t=new Cesium.PolygonGeometry({polygonHierarchy:new Cesium.PolygonHierarchy(this.positions)}),t=new Cesium.GeometryInstance({geometry:t});this.primitive=new Cesium.GroundPrimitive({geometryInstances:[t],appearance:new Cesium.EllipsoidSurfaceAppearance({material:new Cesium.Material({fabric:{uniforms:{speed:this.speed,color:this.color,direction:this.direction},source:this.createPolygonScanShader1()}})}),asynchronous:!0}),this.viewer.scene.primitives.add(this.primitive)}drawLine(){var t=new Cesium.GroundPolylineGeometry({positions:this.positions,width:this.lineWidth,loop:!0}),t=new Cesium.GeometryInstance({geometry:t});this.primitive1=new Cesium.GroundPolylinePrimitive({geometryInstances:[t],appearance:new Cesium.EllipsoidSurfaceAppearance({material:new Cesium.Material({fabric:{type:"Color",uniforms:{color:this.lineColor}}})}),asynchronous:!0}),this.viewer.scene.primitives.add(this.primitive1)}update(){this.destroyPrimitive(),this.draw(),this.showLine&&this.drawLine()}destroyPrimitive(){this.primitive&&this.viewer.scene.primitives.remove(this.primitive),this.primitive1&&this.viewer.scene.primitives.remove(this.primitive1)}destroy(){for(var t in this.destroyPrimitive(),this)delete this[t]}createPolygonScanShader1(){return"czm_material czm_getMaterial(czm_materialInput materialInput){   czm_material material = czm_getDefaultMaterial(materialInput);\n   vec2 st = normalize(materialInput.st -vec2(0.5,0.5));\n   vec4 color1 = vec4(color.rgb,0.);\n   float time = fract(czm_frameNumber / speed) * direction;\n   float angle = 3.1415926535898 * 2.0 * time;\n   vec2 normal = vec2(sin(angle),cos(angle));\n   float ff = normal.x * st.t - normal.y * st.s;\n   if(ff < 0.0 ){\n     float fff = dot(normal,st);\n     if(fff > 0.70710678){\n         color1.a =  pow(fff,4.);\n     }\n   }\n    material.diffuse = color.rgb;\n    material.alpha = color1.a ;\n    return material;\n}\n"}createPolygonScanShader(){return"czm_material czm_getMaterial(czm_materialInput materialInput){    czm_material material = czm_getDefaultMaterial(materialInput);\n    vec2 st = materialInput.st;\n    vec2 center = (st - scanCenter)*scale;\n    float time = direction * czm_frameNumber * 3.1415926 / 180.;\n    float sin_t = sin(time);\n    float cos_t = cos(time);\n    vec2 center_rotate = vec2(center.s*cos_t-center.t*sin_t+0.5,center.s*sin_t+center.t*cos_t+0.5);\n    vec4 color = texture2D(image,center_rotate);\n    vec3 tColor = czm_gammaCorrect(color.rgb * highlightColor.rgb);\n    tColor *= vec3(1.2,1.2,1.2);\n    if(length(center)>0.48){\n      tColor = highlightColor.rgb * 1.2;\n    }\n    material.diffuse = tColor;\n    material.alpha = color.a * 2.;\n    return material;\n}\n"}computeScanTextureCoordAndRate(t,e){e=this.computeMinMaxCoords(e),t=this.carte2carto(t);let r=new Cesium.Cartesian2;return r.x=(t.longitude-e[0])/(e[2]-e[0]),r.y=(t.latitude-e[1])/(e[3]-e[1]),e=(e[2]-e[0])/(e[3]-e[1]),{tc:r,rate:e}}computeMinMaxCoords(t){let e=Number.MAX_VALUE,r=Number.MAX_VALUE,i=Number.MIN_VALUE,a=Number.MIN_VALUE;var n,s,o;for(o in t)n=(s=this.carte2carto(t[o])).longitude,s=s.latitude,n<e&&(e=n),n>i&&(i=n),s<r&&(r=s),s>a&&(a=s);return[e,r,i,a]}carte2carto(t){return Cesium.Cartographic.fromCartesian(t)}computeEllipsePosition_pls(t,e,r,i,a){let n=[];var s=a||360,o=(i-r)*Math.PI/180/s,l=r*Math.PI/180,u=Cesium.Transforms.eastNorthUpToFixedFrame(t);for(let t=0;t<s;t++){var h=l+o*t,h=new Cesium.Cartesian3(Math.sin(h)*e,Math.cos(h)*e,0);n.push(Cesium.Matrix4.multiplyByPoint(u,h,new Cesium.Cartesian3))}return n}}},{}],78:[function(t,e,r){t=t("./Light.js");class i extends t{constructor(){super(),this.type="RadarLight"}updateLightArray(){}getGlobeSurfaceShader(){return{vertexShaderSource:Cesium.ShaderSource.replaceMain(this.getGlobeSurfaceVS(),this.type),fragmentShaderSource:Cesium.ShaderSource.replaceMain(this.getFS(),this.type)}}getPolygonColorPrimitiveShader(){return{vertexShaderSource:Cesium.ShaderSource.replaceMain(this.getPolygonColorPrimitiveVs(),this.type),fragmentShaderSource:Cesium.ShaderSource.replaceMain(this.getFS(),this.type)}}getGlobeSurfaceVS(){return`
          varying vec3 v_xh_position2;
          void main(){
            #ifdef QUANTIZATION_BITS12
                vec2 xy = czm_decompressTextureCoordinates(compressed0.x);
                vec2 zh = czm_decompressTextureCoordinates(compressed0.y);
                vec3 position = vec3(xy, zh.x);
                float height = zh.y;
                vec2 textureCoordinates = czm_decompressTextureCoordinates(compressed0.z);
            
                height = height * (u_minMaxHeight.y - u_minMaxHeight.x) + u_minMaxHeight.x;
                position = (u_scaleAndBias * vec4(position, 1.0)).xyz;
            #else
                // A single float per element
                vec3 position = position3DAndHeight.xyz;
            #endif
                v_xh_position2 = position + u_center3D;
          }
          `}getPolygonColorPrimitiveVs(){return"varying vec3 v_xh_position2;\nvoid main(){\n v_xh_position2 = position3DHigh + position3DLow;\n}\n"}getFS(){var o,t;let l="";for(o in this.lightMap){var u=this.lightMap[o].polygon||[new Cesium.Cartesian3],h=this.lightMap[o].position;let t=this.lightMap[o].speed||600,e=this.lightMap[o].count||3,r=this.lightMap[o].direction||-1,i=this.lightMap[o].color||new Cesium.Color(.3,.5,.8,1),a=this.lightMap[o].isCircle||1,n=this.lightMap[o].radius||0;this.lightMap[o].polygon&&(a=-1),l+="int isInPolygon"+o+"(vec2 checkPoint, vec2 polygonPoints["+u.length+"]) {\n    int counter = 0;\n    float xinters;\n    vec2 p1;\n    vec2 p2;\n    const int pointCount = "+u.length+";\n    p1 = polygonPoints[0];\n\t\n    for (int i = 1; i < pointCount; i++) {\n        p2 = polygonPoints[i ];\n        if (checkPoint.x > min(p1.x, p2.x) && checkPoint.x <= max(p1.x, p2.x)) {\n            if (checkPoint.y <= max(p1.y, p2.y)) {\n                if (p1.x != p2.x) {\n                    xinters = (checkPoint.x - p1.x) * (p2.y - p1.y) / (p2.x - p1.x) + p1.y;\n                    if (p1.y == p2.y || checkPoint.y <= xinters) {\n                        counter++;\n                    }\n                }\n            }\n        }\n        p1 = p2;\n    }\n    float f = float(counter) / 2.;\n    float ff = f - floor(f);\n    if(ff > 0.000001)\n       return 1;\n    else\n       return 0;\n}\n",l+="void lidarScan"+o+"(){\n";h=Cesium.Transforms.eastNorthUpToFixedFrame(h);let s=Cesium.Matrix4.inverse(h,new Cesium.Matrix4);var d,h="mat4 ienu_mat1 = mat4("+s[0].toFixed(15)+","+s[1].toFixed(15)+","+s[2].toFixed(15)+","+s[3].toFixed(15)+","+s[4].toFixed(15)+","+s[5].toFixed(15)+","+s[6].toFixed(15)+","+s[7].toFixed(15)+","+s[8].toFixed(15)+","+s[9].toFixed(15)+","+s[10].toFixed(15)+","+s[11].toFixed(15)+","+s[12].toFixed(15)+","+s[13].toFixed(15)+","+s[14].toFixed(15)+","+s[15].toFixed(15)+");\n";for(d in l+=h,l+="vec2 scan_polygon["+u.length+"];\n",u){let t=Cesium.Matrix4.multiplyByPoint(s,u[d],new Cesium.Cartesian3);l+="scan_polygon["+d+"] = vec2("+t.x.toFixed(5)+","+t.y.toFixed(5)+");\n"}l+="int isCircle = "+a+";\n",l+="float speed = "+t.toFixed(5)+";\n",l+="float rate = 1. / "+e.toFixed(5)+";\n",l+="float radius = "+n.toFixed(5)+";\n",l+="float direction =  "+r.toFixed(5)+";\n",l+="vec3 color =  vec3("+i.red.toFixed(5)+","+i.green.toFixed(5)+","+i.blue.toFixed(5)+");\n",l+=" vec4 tpoint = ienu_mat1 * vec4(v_xh_position2 ,1.);\n tpoint /= tpoint.w;\n vec2 txy = tpoint.xy;\n int f = 0;\n if(isCircle == 1)\n   f = 1;\n else\n   f = isInPolygon"+o+"( txy, scan_polygon );\n if(f == 1){\n   vec2 st = normalize(txy / radius);\n   float time = fract(czm_frameNumber / speed) * direction;\n   float angle = 3.1415926535898 * 2.0 * time;\n   vec2 normal = vec2(sin(angle),cos(angle));\n   float ff = normal.x * st.t - normal.y * st.s;\n   float distance = length(txy);\n   if(ff < 0.0 && distance < radius){\n     float fff = dot(normal,st);\n     if(fff > 0.70710678){\n         gl_FragColor.rgb = mix(gl_FragColor.rgb, color.rgb, pow(fff,4.));\n     }\n   }\n }\n}\n"}let e="void main(){\n";for(t in this.lightMap)e+="  lidarScan"+t+"();\n";return e+="}\n","varying vec3 v_xh_position2;\n"+l+e}}e.exports=i},{"./Light.js":73}],79:[function(t,e,r){t=t("./Light.js");class i extends t{constructor(){super(),this.type="UpDownScanLight"}updateLightArray(){}getGlobeSurfaceShader(){}getPolygonColorPrimitiveShader(){return{vertexShaderSource:Cesium.ShaderSource.replaceMain(this.getPolygonColorPrimitiveVs(),this.type),fragmentShaderSource:Cesium.ShaderSource.replaceMain(this.getFs(),this.type)}}getPolygonColorPrimitiveVs(){return"varying vec3 v_xh_position3;\n void main(){\n   vec4 p = czm_computePosition();\n   v_xh_position3 = (czm_modelViewRelativeToEye * p).xyz;\n}\n"}getFs(){let t=null;for(var e in this.lightMap)t=this.lightMap[e];var r=t.position,i=t.maxHeight||10,a=t.scanHeight||50,n=(t.scanWidth||2)/a,s=t.speed||600,o=t.color||new Cesium.Color(.1,.3,.5,1),l=r,u=Cesium.Cartographic.fromCartesian(l),h=Cesium.Cartesian3.fromRadians(u.longitude,u.latitude,u.height+2e5),d=new window.Cesium.Cartesian3(Math.floor(l.x),Math.floor(l.y),Math.floor(l.z)),r=new window.Cesium.Cartesian3(l.x-Math.floor(l.x),l.y-Math.floor(l.y),l.z-Math.floor(l.z)),u=new window.Cesium.Cartesian3(Math.floor(h.x),Math.floor(h.y),Math.floor(h.z)),l=new window.Cesium.Cartesian3(h.x-Math.floor(h.x),h.y-Math.floor(h.y),h.z-Math.floor(h.z)),h="void main(){\n";return h+="float speed = "+this.isContainPoint(s)+";\n",h+="float rate = "+this.isContainPoint(n)+";\n",h+="float mHeight = "+this.isContainPoint(i)+";\n",h+="float sHeight =  "+this.isContainPoint(a)+";\n",h+="vec3 color =  vec3("+this.isContainPoint(o.red)+","+this.isContainPoint(o.green)+","+this.isContainPoint(o.blue)+");\n",h+="vec3 high1 =  vec3("+this.isContainPoint(d.x)+","+this.isContainPoint(d.y)+","+this.isContainPoint(d.z)+");\n",h+="vec3 low1 =  vec3("+this.isContainPoint(r.x)+","+this.isContainPoint(r.y)+","+this.isContainPoint(r.z)+");\n",h+="vec3 high2 =  vec3("+this.isContainPoint(u.x)+","+this.isContainPoint(u.y)+","+this.isContainPoint(u.z)+");\n",h+="vec3 low2 =  vec3("+this.isContainPoint(l.x)+","+this.isContainPoint(l.y)+","+this.isContainPoint(l.z)+");\n","varying vec3 v_xh_position3;\nvec3 calPoint(vec3 high,vec3 low){\n     vec4 tPoint = czm_translateRelativeToEye(high,low);\n     return (czm_modelViewRelativeToEye *tPoint).xyz;\n}\nvec3 pointProjectOnPlane(vec3 planeNormal,vec3 planeOrigin,vec3 point)\n{\n   vec3 dd = point - planeOrigin;\n   float d = dot(planeNormal,dd);\n   return (point - planeNormal * d);\n}\nfloat calHeight(vec3 o,vec3 up,vec3 p)\n{\n   vec3 normal = up - o;\n   normal = normalize(normal);\n   vec3 op = p - o;\n   return dot(normal,op);\n}\nvoid b2tScan(float ch,float mh,float sh,float speed,float sRate,vec3 color){\n   float a11 = fract(czm_frameNumber / speed) * 3.14159265 * 2.;\n   float a12 = ch / mh + sin(a11) * 0.2 + 0.5;\n   gl_FragColor.rgb *= a12;\n   float a13 = fract(czm_frameNumber / speed);\n   float ah = clamp(ch / sh, 0.0, 1.0);\n   a13 = abs(a13 - 0.5) * 2.0;\n   float a_diff = step(sRate, abs(ah - a13));\n   if(a_diff < 0.5)\n     gl_FragColor.rgb = color.rgb;\n}\n"+(h+="   vec3 origin = calPoint(high1,low1);\n   vec3 originAbove = calPoint(high2,low2);\n   float ch = calHeight(origin, originAbove, v_xh_position3);\n   b2tScan(ch,mHeight,sHeight,speed,rate,color);\n}\n")}isContainPoint(t){let e=t.toString();return e.indexOf(".")<0&&(e+="."),e}}e.exports=i},{"./Light.js":73}],80:[function(t,e,r){e.exports=class i{static createWave3dTileLight(t){return new i(t)}constructor(t){this.viewer=t.viewer||window.viewer,this.positions=t.positions,this.center=t.center,this.radius=t.radius,this.center&&0<this.radius&&(this.positions=this.computeEllipsePosition_prs(this.center,this.radius,270,-90)),this.color=t.color||Cesium.Color.RED,this.direction=t.direction||-1,this.speed=t.speed||1e3,this.repeat=t.count||3,this.scanCenter=t.scanCenter,Cesium.defined(t.scanCenter)?this.scanCenter=computeScanTextureCoordAndRate(t.scanCenter,this.positions).tc:this.scanCenter=new Cesium.Cartesian2(.5,.5),this.showLine=t.showLine||!1,this.lineWidth=t.lineWidth||4,this.lineColor=t.lineColor||new Cesium.Color(1,1,0,.5),this.offset=0,this.update()}draw(){var t=new Cesium.PolygonGeometry({polygonHierarchy:new Cesium.PolygonHierarchy(this.positions)}),t=new Cesium.GeometryInstance({geometry:t});this.primitive=new Cesium.GroundPrimitive({geometryInstances:[t],appearance:new Cesium.EllipsoidSurfaceAppearance({material:new Cesium.Material({fabric:{uniforms:{color:this.color,repeat:2*this.repeat,u_radius:this.radius,speed:this.speed,scanCenter:this.scanCenter,direction:this.direction},source:this.createPolygonScanShader()}})}),asynchronous:!1}),this.viewer.scene.primitives.add(this.primitive)}drawLine(){var t=new Cesium.GroundPolylineGeometry({positions:this.positions,width:this.lineWidth,loop:!0}),t=new Cesium.GeometryInstance({geometry:t});this.primitive1=new Cesium.GroundPolylinePrimitive({geometryInstances:[t],appearance:new Cesium.EllipsoidSurfaceAppearance({material:new Cesium.Material({fabric:{type:"Color",uniforms:{color:this.lineColor}}})}),asynchronous:!1}),this.viewer.scene.primitives.add(this.primitive1)}update(){this.destroyPrimitive(),this.draw(),this.showLine&&this.drawLine()}destroyPrimitive(){this.primitive&&this.viewer.scene.primitives.remove(this.primitive),this.primitive1&&this.viewer.scene.primitives.remove(this.primitive1)}destroy(){for(var t in this.destroyPrimitive(),this)delete this[t]}createPolygonScanShader(){return`
              uniform vec4 color;
              uniform float repeat;
              //uniform float offset;
              uniform float u_radius;
              //uniform float thickness;
              uniform float speed;
              uniform vec2 scanCenter;
               uniform float direction;
              czm_material czm_getMaterial(czm_materialInput materialInput)
              {
                  czm_material material = czm_getDefaultMaterial(materialInput);
                  vec4 color1 = vec4(color.rgb,0.);
                  vec2 st = materialInput.st - vec2(0.5,0.5);
                  float tf = sqrt(2.);
                  float radius = u_radius;
                  float rate = 1. * tf / repeat;
                  float time = fract(czm_frameNumber / speed) * direction;
                  
                  float rr =   radius * time  ;
                  float ring = rate * radius;
                  float dis = length(st) * radius * tf;
                  float f = (dis - rr /tf ) / ring;//由于dis只有0-0.5,而白膜dis为0-1,所以time必须除以2.
                  float ff = fract(f);
                  if( ff < rate ){
                    color1.a = 1. - ff / rate;
                  }
                  material.diffuse = color1.rgb;
                  material.alpha = color1.a;
                  return material;
              }
          `}computeScanTextureCoordAndRate(t,e){e=this.computeMinMaxCoords(e),t=this.carte2carto_prs(t);let r=new Cesium.Cartesian2;return r.x=(t.longitude-e[0])/(e[2]-e[0]),r.y=(t.latitude-e[1])/(e[3]-e[1]),e=(e[2]-e[0])/(e[3]-e[1]),{tc:r,rate:e}}computeEllipsePosition_prs(t,e,r,i,a){let n=[];var s=a||360,o=(i-r)*Math.PI/180/s,l=r*Math.PI/180,u=Cesium.Transforms.eastNorthUpToFixedFrame(t);for(let t=0;t<s;t++){var h=l+o*t,h=new Cesium.Cartesian3(Math.sin(h)*e,Math.cos(h)*e,0);n.push(Cesium.Matrix4.multiplyByPoint(u,h,new Cesium.Cartesian3))}return n}computeMinMaxCoords(t){let e=Number.MAX_VALUE,r=Number.MAX_VALUE,i=Number.MIN_VALUE,a=Number.MIN_VALUE;var n,s,o;for(o in t)n=(s=this.carte2carto_prs(t[o])).longitude,s=s.latitude,n<e&&(e=n),n>i&&(i=n),s<r&&(r=s),s>a&&(a=s);return[e,r,i,a]}carte2carto_prs(t){return Cesium.Cartographic.fromCartesian(t)}}},{}],81:[function(t,e,r){t=t("./Light.js");class i extends t{constructor(){super(),this.type="WaveLight"}updateLightArray(){}getGlobeSurfaceShader(){return{vertexShaderSource:Cesium.ShaderSource.replaceMain(this.getGlobeSurfaceVS(),this.type),fragmentShaderSource:Cesium.ShaderSource.replaceMain(this.getFs(),this.type)}}getPolygonColorPrimitiveShader(){return{vertexShaderSource:Cesium.ShaderSource.replaceMain(this.getPolygonColorPrimitiveVs(),this.type),fragmentShaderSource:Cesium.ShaderSource.replaceMain(this.getFs(),this.type)}}getGlobeSurfaceVS(){return`
          varying vec3 v_xh_position1;
          void main(){
            #ifdef QUANTIZATION_BITS12
                vec2 xy = czm_decompressTextureCoordinates(compressed0.x);
                vec2 zh = czm_decompressTextureCoordinates(compressed0.y);
                vec3 position = vec3(xy, zh.x);
                float height = zh.y;
                vec2 textureCoordinates = czm_decompressTextureCoordinates(compressed0.z);
            
                height = height * (u_minMaxHeight.y - u_minMaxHeight.x) + u_minMaxHeight.x;
                position = (u_scaleAndBias * vec4(position, 1.0)).xyz;
            #else
                // A single float per element
                vec3 position = position3DAndHeight.xyz;
            #endif
                v_xh_position1 = position + u_center3D;
          }
          `}getPolygonColorPrimitiveVs(){return"varying vec3 v_xh_position1;\nvoid main(){\n v_xh_position1 = position3DHigh + position3DLow;\n}\n"}getFs(){var o,t;let l="";for(o in this.lightMap){var u=this.lightMap[o].polygon||[new Cesium.Cartesian3],h=this.lightMap[o].position;let t=this.lightMap[o].speed||600,e=this.lightMap[o].count||3,r=this.lightMap[o].direction||-1,i=this.lightMap[o].color||new Cesium.Color(.3,.5,.8,1),a=this.lightMap[o].isCircle||1,n=this.lightMap[o].radius||0;this.lightMap[o].polygon&&(a=-1);h=Cesium.Transforms.eastNorthUpToFixedFrame(h);let s=Cesium.Matrix4.inverse(h,new Cesium.Matrix4);var d,h="mat4 ienu_mat = mat4("+s[0].toFixed(15)+","+s[1].toFixed(15)+","+s[2].toFixed(15)+","+s[3].toFixed(15)+","+s[4].toFixed(15)+","+s[5].toFixed(15)+","+s[6].toFixed(15)+","+s[7].toFixed(15)+","+s[8].toFixed(15)+","+s[9].toFixed(15)+","+s[10].toFixed(15)+","+s[11].toFixed(15)+","+s[12].toFixed(15)+","+s[13].toFixed(15)+","+s[14].toFixed(15)+","+s[15].toFixed(15)+");\n";for(d in l+="int isInPolygonCircle"+o+"(vec2 checkPoint, vec2 polygonPoints["+u.length+"]) {\n    int counter = 0;\n    float xinters;\n    vec2 p1;\n    vec2 p2;\n    const int pointCount = "+u.length+";\n    p1 = polygonPoints[0];\n\t\n    for (int i = 1; i < pointCount; i++) {\n        p2 = polygonPoints[i ];\n        if (checkPoint.x > min(p1.x, p2.x) && checkPoint.x <= max(p1.x, p2.x)) {\n            if (checkPoint.y <= max(p1.y, p2.y)) {\n                if (p1.x != p2.x) {\n                    xinters = (checkPoint.x - p1.x) * (p2.y - p1.y) / (p2.x - p1.x) + p1.y;\n                    if (p1.y == p2.y || checkPoint.y <= xinters) {\n                        counter++;\n                    }\n                }\n            }\n        }\n        p1 = p2;\n    }\n    float f = float(counter) / 2.;\n    float ff = f - floor(f);\n    if(ff > 0.000001)\n       return 1;\n    else\n       return 0;\n}\n",l+="void circleScan"+o+"(){\n",l+=h,l+="vec2 scan_polygon["+u.length+"];\n",u){let t=Cesium.Matrix4.multiplyByPoint(s,u[d],new Cesium.Cartesian3);l+="scan_polygon["+d+"] = vec2("+t.x.toFixed(5)+","+t.y.toFixed(5)+");\n"}l+="int isCircle = "+a+";\n",l+="float speed = "+t.toFixed(5)+";\n",l+="float rate = 1. / "+e.toFixed(5)+";\n",l+="float radius = "+n.toFixed(5)+";\n",l+="float direction =  "+r.toFixed(5)+";\n",l+="vec3 color =  vec3("+i.red.toFixed(5)+","+i.green.toFixed(5)+","+i.blue.toFixed(5)+");\n",l+=" vec4 tpoint = ienu_mat * vec4(v_xh_position1 ,1.);\n tpoint /= tpoint.w;\n vec2 txy = tpoint.xy;\n int f = 0;\n if(isCircle == 1)\n   f = 1;\n else   f = isInPolygonCircle"+o+"( txy, scan_polygon );\n if(f == 1){\n   float time = fract(czm_frameNumber / speed) * direction;\n   float rr = radius * time;\n   float ring = rate * radius;\n   float dis = length(txy);\n   float f = abs(dis - rr) /ring;\n   float ff = fract(f);\n   if(dis < radius  &&ff < rate){\n     float ta = ff / rate ;\n     gl_FragColor.rgb = mix(color,gl_FragColor.rgb,ta);\n   }\n }\n}\n"}let e="void main(){\n";for(t in this.lightMap)e+="  circleScan"+t+"();\n";return e+="}\n","varying vec3 v_xh_position1;\n"+l+e}}e.exports=i},{"./Light.js":73}],82:[function(t,o,l){"use strict";o.exports.now=window.performance&&window.performance.now?window.performance.now.bind(window.performance):Date.now.bind(Date);const e=window.requestAnimationFrame||window.mozRequestAnimationFrame||window.webkitRequestAnimationFrame||window.msRequestAnimationFrame;l.frame=function(t){return e(t)};const r=window.cancelAnimationFrame||window.mozCancelAnimationFrame||window.webkitCancelAnimationFrame||window.msCancelAnimationFrame;function i(t){return 0==(t&t-1)}function a(t){--t;for(var e=1;e<32;e<<=1)t|=t>>e;return t+1}l.cancelFrame=function(t){r(t)},l.timed=function(r,i,a){if(!i)return r.call(a,1),null;let n=!1;const s=o.exports.now();return l.frame(function t(e){n||((e=o.exports.now())>=s+i?r.call(a,1):(r.call(a,(e-s)/i),l.frame(t)))}),function(){n=!0}},l.getImageData=function(t){const e=window.document.createElement("canvas"),r=e.getContext("2d");return e.width=t.width,e.height=t.height,r.drawImage(t,0,0,t.width,t.height),r.getImageData(0,0,t.width,t.height)},l.createPowerOfTwoImageFromImage=function(t){var e;return i(t.width)&&i(t.height)||((e=window.document.createElement("canvas")).width=a(t.width),e.height=a(t.height),e.getContext("2d").drawImage(t,0,0,t.width,t.height),t=e),t},l.hardwareConcurrency=window.navigator.hardwareConcurrency||4,Object.defineProperty(l,"devicePixelRatio",{get:function(){return window.devicePixelRatio}}),l.supportsWebp=!1;const n=window.document.createElement("img");n.onload=function(){l.supportsWebp=!0},n.src=""},{}],83:[function(t,e,r){const{HTMLImageElement:o,HTMLCanvasElement:l,HTMLVideoElement:u,ImageData:h}=window;e.exports=class{constructor(t,e,r,i){this.gl=t,this.format=r,this.texture=t.createTexture(),this.update(e,i)}update(t,e,r){var{width:i,height:a}=t,n=!(this.size&&this.size[0]===i&&this.size[1]===a||r);const s=this.gl;this.useMipmap=Boolean(e&&e.useMipmap),s.bindTexture(s.TEXTURE_2D,this.texture),s.pixelStorei(s.UNPACK_FLIP_Y_WEBGL,!1),s.pixelStorei(s.UNPACK_ALIGNMENT,1),s.pixelStorei(s.UNPACK_PREMULTIPLY_ALPHA_WEBGL,this.format===s.RGBA&&(!e||!1!==e.premultiply)),n?(this.size=[i,a],t instanceof o||t instanceof l||t instanceof u||t instanceof h?s.texImage2D(s.TEXTURE_2D,0,this.format,this.format,s.UNSIGNED_BYTE,t):s.texImage2D(s.TEXTURE_2D,0,this.format,i,a,0,this.format,s.UNSIGNED_BYTE,t.data)):({x:n,y:r}=r||{x:0,y:0},t instanceof o||t instanceof l||t instanceof u||t instanceof h?s.texSubImage2D(s.TEXTURE_2D,0,n,r,s.RGBA,s.UNSIGNED_BYTE,t):s.texSubImage2D(s.TEXTURE_2D,0,n,r,i,a,s.RGBA,s.UNSIGNED_BYTE,t.data)),this.useMipmap&&this.isSizePowerOfTwo()&&s.generateMipmap(s.TEXTURE_2D)}bind(t,e,r){const i=this.gl;i.bindTexture(i.TEXTURE_2D,this.texture),r!==i.LINEAR_MIPMAP_NEAREST||this.isSizePowerOfTwo()||(r=i.LINEAR),t!==this.filter&&(i.texParameteri(i.TEXTURE_2D,i.TEXTURE_MAG_FILTER,t),i.texParameteri(i.TEXTURE_2D,i.TEXTURE_MIN_FILTER,r||t),this.filter=t),e!==this.wrap&&(i.texParameteri(i.TEXTURE_2D,i.TEXTURE_WRAP_S,e),i.texParameteri(i.TEXTURE_2D,i.TEXTURE_WRAP_T,e),this.wrap=e)}isSizePowerOfTwo(){return this.size[0]===this.size[1]&&Math.log(this.size[0])/Math.LN2%1==0}destroy(){this.gl.deleteTexture(this.texture),this.texture=null}}},{}],84:[function(t,e,r){function n(t,{width:e,height:r},i,a){if(a){if(a.length!==e*r*i)throw new RangeError("mismatched image size")}else a=new Uint8Array(e*r*i);return t.width=e,t.height=r,t.data=a,t}function s(e,r,i,a,n,s){if(0===n.width||0===n.height)return r;if(n.width>e.width||n.height>e.height||i.x>e.width-n.width||i.y>e.height-n.height)throw new RangeError("out of range source coordinates for image copy");if(n.width>r.width||n.height>r.height||a.x>r.width-n.width||a.y>r.height-n.height)throw new RangeError("out of range destination coordinates for image copy");var o=e.data;const l=r.data;for(let t=0;t<n.height;t++){var u=((i.y+t)*e.width+i.x)*s,h=((a.y+t)*r.width+a.x)*s;for(let t=0;t<n.width*s;t++)l[h+t]=o[u+t]}return r}e.exports=class i{constructor(t,e){n(this,t,4,e)}resize(t){var e,r,i,a;[e,{width:r,height:i},a]=[this,t,4],r===e.width&&i===e.height||(s(e,t=n({},{width:r,height:i},a),{x:0,y:0},{x:0,y:0},{width:Math.min(e.width,r),height:Math.min(e.height,i)},a),e.width=r,e.height=i,e.data=t.data)}clone(){return new i({width:this.width,height:this.height},new Uint8Array(this.data))}static copy(t,e,r,i,a){s(t,e,r,i,a,4)}serialize(t){if(this.data)return t.push(this.data.buffer),{data:this.data,width:this.width,height:this.height}}}},{}],85:[function(t,e,r){"use strict";const i=Cesium.StructArray;var a=i({members:[{name:"a_pos",type:"Float32",components:2},{name:"a_texture_pos",type:"Int16",components:2},{name:"a_data",components:2,type:"Int16"}]});e.exports=a},{}],86:[function(t,e,r){e.exports=class{constructor(){this.boundProgram=null,this.boundVertexBuffer=null,this.boundVertexBuffer2=null,this.boundElementBuffer=null,this.boundVertexOffset=null,this.vao=null}bind(t,e,r,i,a,n){void 0===t.extVertexArrayObject&&(t.extVertexArrayObject=t.getExtension("OES_vertex_array_object"));var s=!this.vao||this.boundProgram!==e||this.boundVertexBuffer!==r||this.boundVertexBuffer2!==a||this.boundElementBuffer!==i||this.boundVertexOffset!==n;!t.extVertexArrayObject||s?(this.freshBind(t,e,r,i,a,n),this.gl=t):t.extVertexArrayObject.bindVertexArrayOES(this.vao)}freshBind(e,t,r,i,a,n){let s;var o=t.numAttributes;if(e.extVertexArrayObject)this.vao&&this.destroy(),this.vao=e.extVertexArrayObject.createVertexArrayOES(),e.extVertexArrayObject.bindVertexArrayOES(this.vao),s=0,this.boundProgram=t,this.boundVertexBuffer=r,this.boundVertexBuffer2=a,this.boundElementBuffer=i,this.boundVertexOffset=n;else{s=e.currentNumAttributes||0;for(let t=o;t<s;t++)e.disableVertexAttribArray(t)}r.enableAttributes(e,t),a&&a.enableAttributes(e,t),r.bind(e),r.setVertexAttribPointers(e,t,n),a&&(a.bind(e),a.setVertexAttribPointers(e,t,n)),i&&i.bind(e),r.isenableAttributes=!0,e.currentNumAttributes=o}destroy(){this.vao&&(this.gl.extVertexArrayObject.deleteVertexArrayOES(this.vao),this.vao=null)}}},{}],87:[function(t,e,r){var i,a;i=this,a=function(){"use strict";(t=new Float32Array(3))[0]=0,t[1]=0,t[2]=0;var t;(t=new Float32Array(4))[0]=0,t[1]=0,t[2]=0,t[3]=0;return{vec3:{transformMat3:function(t,e,r){var i=e[0],a=e[1],e=e[2];return t[0]=i*r[0]+a*r[3]+e*r[6],t[1]=i*r[1]+a*r[4]+e*r[7],t[2]=i*r[2]+a*r[5]+e*r[8],t}},vec4:{transformMat4:function(t,e,r){var i=e[0],a=e[1],n=e[2],e=e[3];return t[0]=r[0]*i+r[4]*a+r[8]*n+r[12]*e,t[1]=r[1]*i+r[5]*a+r[9]*n+r[13]*e,t[2]=r[2]*i+r[6]*a+r[10]*n+r[14]*e,t[3]=r[3]*i+r[7]*a+r[11]*n+r[15]*e,t}},mat2:{create:function(){var t=new Float32Array(4);return t[0]=1,t[1]=0,t[2]=0,t[3]=1,t},rotate:function(t,e,r){var i=e[0],a=e[1],n=e[2],s=e[3],e=Math.sin(r),r=Math.cos(r);return t[0]=i*r+n*e,t[1]=a*r+s*e,t[2]=i*-e+n*r,t[3]=a*-e+s*r,t},scale:function(t,e,r){var i=e[0],a=e[1],n=e[2],s=e[3],e=r[0],r=r[1];return t[0]=i*e,t[1]=a*e,t[2]=n*r,t[3]=s*r,t}},mat3:{create:function(){var t=new Float32Array(9);return t[0]=1,t[1]=0,t[2]=0,t[3]=0,t[4]=1,t[5]=0,t[6]=0,t[7]=0,t[8]=1,t},fromRotation:function(t,e){var r=Math.sin(e),e=Math.cos(e);return t[0]=e,t[1]=r,t[2]=0,t[3]=-r,t[4]=e,t[5]=0,t[6]=0,t[7]=0,t[8]=1,t},fromMat4:function(t,e){return t[0]=e[0],t[1]=e[1],t[2]=e[2],t[3]=e[4],t[4]=e[5],t[5]=e[6],t[6]=e[8],t[7]=e[9],t[8]=e[10],t},transpose:function(t,e){var r,i,a;return t===e?(r=e[1],i=e[2],a=e[5],t[1]=e[3],t[2]=e[6],t[3]=r,t[5]=e[7],t[6]=i,t[7]=a):(t[0]=e[0],t[1]=e[3],t[2]=e[6],t[3]=e[1],t[4]=e[4],t[5]=e[7],t[6]=e[2],t[7]=e[5],t[8]=e[8]),t},invert:function(t,e){var r=e[0],i=e[1],a=e[2],n=e[3],s=e[4],o=e[5],l=e[6],u=e[7],h=e[8],d=h*s-o*u,f=-h*n+o*l,m=u*n-s*l;return(e=r*d+i*f+a*m)?(t[0]=d*(e=1/e),t[1]=(-h*i+a*u)*e,t[2]=(o*i-a*s)*e,t[3]=f*e,t[4]=(h*r-a*l)*e,t[5]=(-o*r+a*n)*e,t[6]=m*e,t[7]=(-u*r+i*l)*e,t[8]=(s*r-i*n)*e,t):null}},mat4:{create:function(){var t=new Float32Array(16);return t[0]=1,t[1]=0,t[2]=0,t[3]=0,t[4]=0,t[5]=1,t[6]=0,t[7]=0,t[8]=0,t[9]=0,t[10]=1,t[11]=0,t[12]=0,t[13]=0,t[14]=0,t[15]=1,t},identity:function(t){return t[0]=1,t[1]=0,t[2]=0,t[3]=0,t[4]=0,t[5]=1,t[6]=0,t[7]=0,t[8]=0,t[9]=0,t[10]=1,t[11]=0,t[12]=0,t[13]=0,t[14]=0,t[15]=1,t},translate:function(t,e,r){var i,a,n,s,o,l,u,h,d,f,m,v=r[0],p=r[1],c=r[2];return e===t?(t[12]=e[0]*v+e[4]*p+e[8]*c+e[12],t[13]=e[1]*v+e[5]*p+e[9]*c+e[13],t[14]=e[2]*v+e[6]*p+e[10]*c+e[14],t[15]=e[3]*v+e[7]*p+e[11]*c+e[15]):(i=e[0],a=e[1],n=e[2],s=e[3],o=e[4],l=e[5],u=e[6],h=e[7],d=e[8],f=e[9],m=e[10],r=e[11],t[0]=i,t[1]=a,t[2]=n,t[3]=s,t[4]=o,t[5]=l,t[6]=u,t[7]=h,t[8]=d,t[9]=f,t[10]=m,t[11]=r,t[12]=i*v+o*p+d*c+e[12],t[13]=a*v+l*p+f*c+e[13],t[14]=n*v+u*p+m*c+e[14],t[15]=s*v+h*p+r*c+e[15]),t},scale:function(t,e,r){var i=r[0],a=r[1],r=r[2];return t[0]=e[0]*i,t[1]=e[1]*i,t[2]=e[2]*i,t[3]=e[3]*i,t[4]=e[4]*a,t[5]=e[5]*a,t[6]=e[6]*a,t[7]=e[7]*a,t[8]=e[8]*r,t[9]=e[9]*r,t[10]=e[10]*r,t[11]=e[11]*r,t[12]=e[12],t[13]=e[13],t[14]=e[14],t[15]=e[15],t},multiply:function(t,e,r){var i=e[0],a=e[1],n=e[2],s=e[3],o=e[4],l=e[5],u=e[6],h=e[7],d=e[8],f=e[9],m=e[10],v=e[11],p=e[12],c=e[13],b=e[14],y=e[15],V=r[0],q=r[1],x=r[2],e=r[3];return t[0]=V*i+q*o+x*d+e*p,t[1]=V*a+q*l+x*f+e*c,t[2]=V*n+q*u+x*m+e*b,t[3]=V*s+q*h+x*v+e*y,V=r[4],q=r[5],x=r[6],e=r[7],t[4]=V*i+q*o+x*d+e*p,t[5]=V*a+q*l+x*f+e*c,t[6]=V*n+q*u+x*m+e*b,t[7]=V*s+q*h+x*v+e*y,V=r[8],q=r[9],x=r[10],e=r[11],t[8]=V*i+q*o+x*d+e*p,t[9]=V*a+q*l+x*f+e*c,t[10]=V*n+q*u+x*m+e*b,t[11]=V*s+q*h+x*v+e*y,V=r[12],q=r[13],x=r[14],e=r[15],t[12]=V*i+q*o+x*d+e*p,t[13]=V*a+q*l+x*f+e*c,t[14]=V*n+q*u+x*m+e*b,t[15]=V*s+q*h+x*v+e*y,t},perspective:function(t,e,r,i,a){var n=1/Math.tan(e/2),e=1/(i-a);return t[0]=n/r,t[1]=0,t[2]=0,t[3]=0,t[4]=0,t[5]=n,t[6]=0,t[7]=0,t[8]=0,t[9]=0,t[10]=(a+i)*e,t[11]=-1,t[12]=0,t[13]=0,t[14]=2*a*i*e,t[15]=0,t},rotateX:function(t,e,r){var i=Math.sin(r),a=Math.cos(r),n=e[4],s=e[5],o=e[6],l=e[7],u=e[8],h=e[9],d=e[10],r=e[11];return e!==t&&(t[0]=e[0],t[1]=e[1],t[2]=e[2],t[3]=e[3],t[12]=e[12],t[13]=e[13],t[14]=e[14],t[15]=e[15]),t[4]=n*a+u*i,t[5]=s*a+h*i,t[6]=o*a+d*i,t[7]=l*a+r*i,t[8]=u*a-n*i,t[9]=h*a-s*i,t[10]=d*a-o*i,t[11]=r*a-l*i,t},rotateY:function(t,e,r){var i=Math.sin(r),a=Math.cos(r),n=e[0],s=e[1],o=e[2],l=e[3],u=e[8],h=e[9],d=e[10],r=e[11];return e!==t&&(t[4]=e[4],t[5]=e[5],t[6]=e[6],t[7]=e[7],t[12]=e[12],t[13]=e[13],t[14]=e[14],t[15]=e[15]),t[0]=n*a-u*i,t[1]=s*a-h*i,t[2]=o*a-d*i,t[3]=l*a-r*i,t[8]=n*i+u*a,t[9]=s*i+h*a,t[10]=o*i+d*a,t[11]=l*i+r*a,t},rotateZ:function(t,e,r){var i=Math.sin(r),a=Math.cos(r),n=e[0],s=e[1],o=e[2],l=e[3],u=e[4],h=e[5],d=e[6],r=e[7];return e!==t&&(t[8]=e[8],t[9]=e[9],t[10]=e[10],t[11]=e[11],t[12]=e[12],t[13]=e[13],t[14]=e[14],t[15]=e[15]),t[0]=n*a+u*i,t[1]=s*a+h*i,t[2]=o*a+d*i,t[3]=l*a+r*i,t[4]=u*a-n*i,t[5]=h*a-s*i,t[6]=d*a-o*i,t[7]=r*a-l*i,t},invert:function(t,e){var r=e[0],i=e[1],a=e[2],n=e[3],s=e[4],o=e[5],l=e[6],u=e[7],h=e[8],d=e[9],f=e[10],m=e[11],v=e[12],p=e[13],c=e[14],b=e[15],y=r*o-i*s,V=r*l-a*s,q=r*u-n*s,x=i*l-a*o,W=i*u-n*o,N=a*u-n*l,X=h*p-d*v,L=h*c-f*v,P=h*b-m*v,T=d*c-f*p,S=d*b-m*p,g=f*b-m*c;return(e=y*g-V*S+q*T+x*P-W*L+N*X)?(t[0]=(o*g-l*S+u*T)*(e=1/e),t[1]=(a*S-i*g-n*T)*e,t[2]=(p*N-c*W+b*x)*e,t[3]=(f*W-d*N-m*x)*e,t[4]=(l*P-s*g-u*L)*e,t[5]=(r*g-a*P+n*L)*e,t[6]=(c*q-v*N-b*V)*e,t[7]=(h*N-f*q+m*V)*e,t[8]=(s*S-o*P+u*X)*e,t[9]=(i*P-r*S-n*X)*e,t[10]=(v*W-p*q+b*y)*e,t[11]=(d*q-h*W-m*y)*e,t[12]=(o*L-s*T-l*X)*e,t[13]=(r*T-i*L+a*X)*e,t[14]=(p*V-v*x-c*y)*e,t[15]=(h*x-d*V+f*y)*e,t):null},ortho:function(t,e,r,i,a,n,s){var o=1/(e-r),l=1/(i-a),u=1/(n-s);return t[0]=-2*o,t[1]=0,t[2]=0,t[3]=0,t[4]=0,t[5]=-2*l,t[6]=0,t[7]=0,t[8]=0,t[9]=0,t[10]=2*u,t[11]=0,t[12]=(e+r)*o,t[13]=(a+i)*l,t[14]=(s+n)*u,t[15]=1,t},lookAt:function(t,e,r,i){var a,n=e[0],s=e[1],o=e[2],l=i[0],u=i[1],h=i[2],d=r[0],f=r[1],m=r[2];return 0===Math.abs(n-d)&&0===Math.abs(s-f)&&0===Math.abs(o-m)?identity(t):(a=n-d,e=s-f,i=o-m,d=u*(i*=r=1/Math.sqrt(a*a+e*e+i*i))-h*(e*=r),f=h*(a*=r)-l*i,m=l*e-u*a,(r=Math.sqrt(d*d+f*f+m*m))?(d*=r=1/r,f*=r,m*=r):m=f=d=0,h=e*m-i*f,l=i*d-a*m,u=a*f-e*d,(r=Math.sqrt(h*h+l*l+u*u))?(h*=r=1/r,l*=r,u*=r):u=l=h=0,t[0]=d,t[1]=h,t[2]=a,t[3]=0,t[4]=f,t[5]=l,t[6]=e,t[7]=0,t[8]=m,t[9]=u,t[10]=i,t[11]=0,t[12]=-(d*n+f*s+m*o),t[13]=-(h*n+l*s+u*o),t[14]=-(a*n+e*s+i*o),t[15]=1,t)},fromRotationTranslationScale:function(t,e,r,i){var a=e[0],n=e[1],s=e[2],o=e[3],l=a*(d=a+a),u=a*(f=n+n),h=a*(m=s+s),e=n*f,a=n*m,n=s*m,s=o*d,d=o*f,f=o*m,o=i[0],m=i[1],i=i[2];return t[0]=(1-(e+n))*o,t[1]=(u+f)*o,t[2]=(h-d)*o,t[3]=0,t[4]=(u-f)*m,t[5]=(1-(l+n))*m,t[6]=(a+s)*m,t[7]=0,t[8]=(h+d)*i,t[9]=(a-s)*i,t[10]=(1-(l+e))*i,t[11]=0,t[12]=r[0],t[13]=r[1],t[14]=r[2],t[15]=1,t},clone:function(t){var e=new Float32Array(16);return e[0]=t[0],e[1]=t[1],e[2]=t[2],e[3]=t[3],e[4]=t[4],e[5]=t[5],e[6]=t[6],e[7]=t[7],e[8]=t[8],e[9]=t[9],e[10]=t[10],e[11]=t[11],e[12]=t[12],e[13]=t[13],e[14]=t[14],e[15]=t[15],e}}}},"object"==typeof r&&void 0!==e?e.exports=a():i.glMatrix=a()},{}],88:[function(t,e,r){window.Cesium.Viewer.prototype.addOverlay=function(t){t.setViewer(this),this._container.appendChild(t.element)};e.exports=function(t){var e=this;this.id=(t=t||{}).id,this.element=t.element,this.position=t.position,this.offset=t.offset,this.scratch=new Cesium.Cartesian2,this._viewer=null,this.setViewer=function(t){this._viewer=t,e._viewer.scene.preRender.addEventListener(e.update)},this.getViewer=function(){return e._viewer},this.updatePosition=function(){var t;e.position?e.getViewer()&&(t=Cesium.SceneTransforms.wgs84ToWindowCoordinates(e.getViewer().scene,e.position),Cesium.defined(t)&&(e.offset?(e.element.style.top=t.y+e.offset.y+"px",e.element.style.left=t.x+e.offset.x+"px"):(e.element.style.top=t.y+"px",e.element.style.left=t.x+"px"),e.show())):e.close()},this.update=function(){"none"!==e.element.style.display&&e.updatePosition()},this.getPosition=function(){},this.close=function(){e.element.style.display="none"},this.show=function(){e.element.style.display="block"},this.destroy=function(){e._viewer.scene.preRender.removeEventListener(e.update),e.element.parentNode&&(e._viewer._container.removeChild(e.element),e.close())},this.setPosition=function(t){e.position=t}}},{}],89:[function(t,e,r){const a=t("./PitWallGeometry"),l=t("../utils/PointUtil")["getSurfaceHeight"];e.exports=class{constructor(t,e={}){this._map=t,this.style=e.style,this.style.diffHeight=Cesium.defaultValue(this.style.diffHeight,10),this.style.splitNum=Cesium.defaultValue(this.style.splitNum,50),e.positions&&(this.positions=e.positions);e=this._getWellData();this.wellData=e,this._createPit(e)}get czmObjectEx(){let t=[];return this._bottomPrimitive&&t.push(this._bottomPrimitive),this._primitive_label&&t.push(this._primitive_label),t}get center(){return this.centerOfMass}get diffHeight(){return this.style.diffHeight}set diffHeight(t){this.style.diffHeight=t;let r=[];var i=this._minHeight-t,a=this.wellData.cartoList;for(let t=0,e=a.length;t<e;t++){var n=a[t];r.push(Cesium.Cartesian3.fromRadians(n.longitude,n.latitude,i))}this.wellData.bottomPositions=r,this._removePit(),this._createPit(this.wellData)}_getWellData(){if(0!=this.positions.length){this._minHeight=this.getMinHeight(this.positions);var n=this._minHeight-this.diffHeight;let r=[],i=[],a=[];var s=this.interPolyline({scene:this._map.scene,positions:this.positions.concat(this.positions[0]),splitNum:this.style.splitNum});for(let t=0,e=s.length;t<e;t++){var o=Cesium.Cartographic.fromCartesian(s[t]);a.push(new Cesium.Cartographic(o.longitude,o.latitude)),i.push(Cesium.Cartesian3.fromRadians(o.longitude,o.latitude,n)),r.push(Cesium.Cartesian3.fromRadians(o.longitude,o.latitude,0))}return{cartoList:a,bottomPositions:i,wallTopPositions:r}}}_removePit(){this._primitive&&(this._map.scene.primitives.remove(this._primitive),delete this._primitive),this._bottomPrimitive&&(this._map.scene.primitives.remove(this._bottomPrimitive),delete this._bottomPrimitive)}_createPit(t){var e;this._createBottomSurface(t.bottomPositions),Boolean(this._map.terrainProvider._layers)?(e=Cesium.sampleTerrainMostDetailed(this._map.terrainProvider,t.cartoList),Cesium.when(e,r=>{let i=[],a=-9999,n=[];for(let t=0,e=r.length;t<e;t++){var s=r[t];i.push(s.height),a=Math.max(s.height,a),n.push(Cesium.Cartesian3.fromRadians(s.longitude,s.latitude,s.height))}this._maxHeight=a,this._topHeights=i,this._createWellWall(t.bottomPositions,n)})):this._createWellWall(t.bottomPositions,t.wallTopPositions)}_createWellWall(t,e){var r=this._minHeight-this.diffHeight;let i=new a({minimumArr:t,maximumArr:e});i=i.createGeometry(i,this._topHeights,r,this._maxHeight),this._primitive=new Cesium.Primitive({geometryInstances:new Cesium.GeometryInstance({geometry:i,attributes:{color:Cesium.ColorGeometryInstanceAttribute.fromColor(Cesium.Color.GREY)},id:this.uuid}),appearance:new Cesium.MaterialAppearance({translucent:!1,flat:!0,material:new Cesium.Material({fabric:{type:"Image",uniforms:{image:this.style.image,color:Cesium.Color.WHITE.withAlpha(this.style.opacity||1)}}})}),asynchronous:!1}),this._map.scene.primitives.add(this._primitive)}_createBottomSurface(t){t.length&&(this._bottomPrimitive=new Cesium.Primitive({geometryInstances:new Cesium.GeometryInstance({geometry:Cesium.PolygonGeometry.fromPositions({vertexFormat:Cesium.VertexFormat.ALL,positions:t,perPositionHeight:!0})}),appearance:new Cesium.MaterialAppearance({material:Cesium.Material.fromType(Cesium.Material.ImageType,{image:this.style.imageBottom,color:Cesium.Color.WHITE.withAlpha(this.style.opacity||1)})})}),this._map.scene.primitives.add(this._bottomPrimitive))}getMinHeight(e,t=0){if(null==e||0==e.length)return t;let r=t;for(let t=0;t<e.length;t++){var i=Cesium.Cartographic.fromCartesian(e[t]);0==t&&(r=i.height),i.height<r&&(r=i.height)}return r.toFixed(3)}interPolyline(r){var t=r.positions,i=r.scene;let e=this.getGranularity(t,r.splitNum||100);e<=0&&(e=null);var a,n,s=Cesium.PolylinePipeline.generateArc({positions:t,height:r.height,minDistance:r.minDistance,granularity:e});let o=[];for(let e=0;e<s.length;e+=3){let t=Cesium.Cartesian3.unpack(s,e);i&&Cesium.defaultValue(r.surfaceHeight,!0)&&(delete r.callback,a=l(i,t,r),n=Cesium.Cartographic.fromCartesian(t),t=Cesium.Cartesian3.fromRadians(n.longitude,n.latitude,a)),o.push(t)}return o}getGranularity(t,e=10){t=Cesium.Rectangle.fromCartesianArray(t),t=Math.max(t.height,t.width);return t/=e}}},{"../utils/PointUtil":106,"./PitWallGeometry":90}],90:[function(t,e,r){e.exports=class{constructor(t={}){var e=(t=Cesium.defaultValue(t,Cesium.defaultValue.EMPTY_OBJECT)).minimumArr,r=t.maximumArr;Cesium.Check.defined("dingmian",r),Cesium.Check.defined("dimianmian",e),Cesium.Check.typeOf.number.greaterThanOrEquals("dingmian.length",r.length,3),Cesium.Check.typeOf.number.greaterThanOrEquals("dimian.length",e.length,3);t=new Cesium.VertexFormat({st:!0,position:!0,bitangent:!1,normal:!1,color:!1,tangent:!1});this._minimumArr=Cesium.clone(e),this._maximumArr=Cesium.clone(r),this._vertexFormat=t,this._workerName=""}createGeometry(t,r,i,a=0){var e=t._minimumArr,n=t._maximumArr,t=t._vertexFormat;let s=new Cesium.GeometryAttributes,o,l,u,h;if(Cesium.defined(t.position)&&Cesium.defined(t.st)){if(Cesium.defined(t.position)){l=new Float64Array(4*n.length*3);for(let t=0;t<n.length;t++)t==n.length-1?(l[12*t+0]=n[t].x,l[12*t+1]=n[t].y,l[12*t+2]=n[t].z,l[12*t+3]=e[t].x,l[12*t+4]=e[t].y,l[12*t+5]=e[t].z,l[12*t+9]=e[0].x,l[12*t+10]=e[0].y,l[12*t+11]=e[0].z,l[12*t+6]=n[0].x,l[12*t+7]=n[0].y,l[12*t+8]=n[0].z):(l[12*t+0]=n[t].x,l[12*t+1]=n[t].y,l[12*t+2]=n[t].z,l[12*t+3]=e[t].x,l[12*t+4]=e[t].y,l[12*t+5]=e[t].z,l[12*t+9]=e[t+1].x,l[12*t+10]=e[t+1].y,l[12*t+11]=e[t+1].z,l[12*t+6]=n[t+1].x,l[12*t+7]=n[t+1].y,l[12*t+8]=n[t+1].z);s.position=new Cesium.GeometryAttribute({componentDatatype:Cesium.ComponentDatatype.DOUBLE,componentsPerAttribute:3,values:l})}if(Cesium.defined(t.st)){let e=new Float32Array(4*n.length*2);var d=n.length;for(let t=0;t<n.length;t++){var f=t/d,m=((r&&r[t]||0)-i)/(a-i),v=t+1,p=v/d,v=((r&&r[v]||0)-i)/(a-i);e[8*t+0]=f,e[8*t+1]=m,e[8*t+2]=f,e[8*t+3]=m-m,e[8*t+4]=p,e[8*t+5]=v,e[8*t+6]=p,e[8*t+7]=v-v}s.st=new Cesium.GeometryAttribute({componentDatatype:Cesium.ComponentDatatype.FLOAT,componentsPerAttribute:2,values:e})}o=new Uint16Array(2*n.length*3),u=new Cesium.Cartesian3(9999999999999,9999999999999,9999999999999),h=new Cesium.Cartesian3(-9999999999999,-9999999999999,-9999999999999);for(let t=0;t<n.length;t++)o[6*t+0]=4*t+0,o[6*t+1]=4*t+1,o[6*t+2]=4*t+2,o[6*t+3]=4*t+1,o[6*t+4]=4*t+2,o[6*t+5]=4*t+3,n[t].x>=h.x&&n[t].y>=h.y&&n[t].z>=h.z&&(h=n[t]),e[t].x<=u.x&&e[t].y<=u.y&&e[t].z<=u.z&&(u=e[t])}t=Cesium.Cartesian3.subtract(h,u,new Cesium.Cartesian3),t=.5*Cesium.Cartesian3.magnitude(t);return new Cesium.Geometry({attributes:s,indices:o,primitiveType:Cesium.PrimitiveType.TRIANGLES,boundingSphere:new Cesium.BoundingSphere(Cesium.Cartesian3.ZERO,t)})}}},{}],91:[function(t,e,r){var i=t("./TerrainEditBase");const a=t("./Pit");class n extends i{constructor(t,e={}){super(t,e),this._clipOutSide=Cesium.defaultValue(e.clipOutSide,!1)}get terrainEditCtl(){return this._map.scene.globe._surface.tileProvider._excavateAnalysis}get clipOutSide(){return this.terrainEditCtl.showTailorOnly}set clipOutSide(t){this.terrainEditCtl.showTailorOnly=t}get diffHeight(){return this.options.diffHeight}set diffHeight(t){this.options.diffHeight=t}clear(){for(let e=0;e<this._areaList.length;e++){let t=this._areaList[e];t.pitPrimitive._removePit()}super.clear(),this.yanmoFbo=null,this._map.scene.globe._surface.tileProvider.applyTailor=!1,this.terrainEditCtl.enableTailor=!1,this.terrainEditCtl.inverTailorCenterMat=Cesium.Matrix4.IDENTITY,this.terrainEditCtl.tailorArea=void 0,this._hasChangeHighDynamicRange&&(this._map.scene.highDynamicRange=!1,this._hasChangeHighDynamicRange=!1),this._hasChangeDepthTestAgainstTerrain&&(this._map.scene.globe.depthTestAgainstTerrain=!1,this._hasChangeDepthTestAgainstTerrain=!1)}addPolygon(t,e){let r=super.addPolygon(t,e);return t&&this.options.image&&(r.pitPrimitive=new a(this._map,{style:{...this.options,...e},positions:r.positions_original})),this._map.scene.highDynamicRange||(this._map.scene.highDynamicRange=!0,this._hasChangeHighDynamicRange=!0),this._map.scene.globe.depthTestAgainstTerrain||(this._map.scene.globe.depthTestAgainstTerrain=!0,this._hasChangeDepthTestAgainstTerrain=!0),r}removePolygon(t){super.removePolygon(t),t.pitPrimitive._removePit()}beginTailor(){this._map.scene.globe._surface.tileProvider.applyTailor=!0,this.terrainEditCtl.inverTailorCenterMat=this.inverTrans,this.terrainEditCtl.tailorArea=this.yanmoFbo,this.terrainEditCtl.enableTailor=!0,this.terrainEditCtl.tailorRect=this.floodRect}}e.exports=n},{"./Pit":89,"./TerrainEditBase":92}],92:[function(t,e,r){e.exports=class{constructor(t,e={}){this.options=e,this.floodVar=Cesium.defaultValue(e.floodVar,[0,0,0,500]),this._map=t,this._maxCanvasSize=Cesium.defaultValue(e.maxCanvasSize,4096),this._areaList=[],this._cache_id=0}get terrainEditCtl(){return this._map.scene.globe._surface.tileProvider._floodAnalysis||{}}get list(){return this._areaList}get showElseArea(){return this.terrainEditCtl.showElseArea}set showElseArea(t){this.terrainEditCtl.showElseArea=t}get positions(){return 0<this.length?this._areaList[0].positions:null}set positions(t){this.clear(),this.addPolygon(t)}get length(){return this._areaList?this._areaList.length:0}clear(){this._map.scene.globe.material=null,this._map.scene.globe._surface.tileProvider.resetFloodAnalysis(),this._map.scene.globe._surface.tileProvider.resetExcavateAnalysis(),this._areaList=[],this.tailorTex&&this.tailorTex.destroy()}getPolygonById(e){for(let t=0;t<this._areaList.length;t++){var r=this._areaList[t];if(r.id==e)return r}return null}hidePolygon(t){let e=this.getPolygonById(t);e&&(e.show=!1,e.pitPrimitive&&(e.pitPrimitive.show=!1),this.drawPolygon())}showPolygon(t){let e=this.getPolygonById(t);e&&(e.show=!0,e.pitPrimitive&&(e.pitPrimitive.show=!0),this.drawPolygon())}removePolygon(t){t&&(this.removeArrayItem(this._areaList,t),this.drawPolygon())}addPolygon(t,e){if(t&&0!=t.length){t={show:!0,id:++this._cache_id,positions_original:t,positions:t};return this._areaList.push(t),this.computedCenter(),this._prepareFlood(),this.prepareCamera(),this.prepareFBO(),this.drawPolygon(),this.beginTailor(),t}}computedCenter(){let e=new Cesium.Cartesian3;this._areaList.forEach(t=>{var t=t.positions;t&&(t=Cesium.BoundingSphere.fromPoints(t),Cesium.Cartesian3.add(e,t.center,e))}),this.totalCenter=Cesium.Cartesian3.multiplyByScalar(e,1/this._areaList.length,new Cesium.Cartesian3)}_prepareFlood(){const f=this._map.scene.context;this.trans=Cesium.Transforms.eastNorthUpToFixedFrame(this.totalCenter),this.inverTrans=Cesium.Matrix4.inverse(this.trans,new Cesium.Matrix4);let m=99999999,v=99999999,p=-99999999,c=-99999999;this._areaList.forEach(t=>{var e=t.positions,r=new Cesium.PolygonGeometry({polygonHierarchy:new Cesium.PolygonHierarchy(e)}),i=(r=Cesium.PolygonGeometry.createGeometry(r)).indices,a=r.attributes.position.values,n=a.length;let s=[],o=[];for(let e=0;e<n;e+=3){var l=a[e],u=a[e+1],h=a[e+2],h=new Cesium.Cartesian3(l,u,h);let t=Cesium.Matrix4.multiplyByPoint(this.inverTrans,h,new Cesium.Cartesian3);t.z=0,s.push(t),o.push(t.x),o.push(t.y),o.push(t.z),m>=t.x&&(m=t.x),v>=t.y&&(v=t.y),p<=t.x&&(p=t.x),c<=t.y&&(c=t.y)}t.localPos=s;e=new Float64Array(o),r=Cesium.BoundingSphere.fromVertices(e),e=new Cesium.Geometry({attributes:{position:new Cesium.GeometryAttribute({componentDatatype:Cesium.ComponentDatatype.DOUBLE,componentsPerAttribute:3,values:e})},indices:i,primitiveType:Cesium.PrimitiveType.TRIANGLES,boundingSphere:r}),i=Cesium.ShaderProgram.fromCache({context:f,vertexShaderSource:`attribute vec3 position;
void main()
{
    vec4 pos = vec4(position.xyz,1.0);
    gl_Position = czm_projection*pos;
}`,fragmentShaderSource:`#ifdef GL_FRAGMENT_PRECISION_HIGH
    precision highp float;
#else
    precision mediump float;
#endif
void main()
{
    gl_FragColor = vec4(1.0, 0.0, 0.0, 1.0);
}`,attributeLocations:{position:0}}),e=Cesium.VertexArray.fromGeometry({context:f,geometry:e,attributeLocations:i._attributeLocations,bufferUsage:Cesium.BufferUsage.STATIC_DRAW,interleave:!0});let d=new Cesium.RenderState;d.depthRange.near=-1e6,d.depthRange.far=1e6,t.drawAreaCommand=new Cesium.DrawCommand({boundingVolume:r,primitiveType:Cesium.PrimitiveType.TRIANGLES,vertexArray:e,shaderProgram:i,renderState:d,pass:Cesium.Pass.TRANSLUCENT})}),this.ratio=(c-v)/(p-m),this.totalRect=[m,v,p,c]}prepareCamera(){this.ortCamera={viewMatrix:Cesium.Matrix4.IDENTITY,inverseViewMatrix:Cesium.Matrix4.IDENTITY,frustum:new Cesium.OrthographicOffCenterFrustum,positionCartographic:{height:0,latitude:0,longitude:0},positionWC:new Cesium.Cartesian3(0,0,6e4),directionWC:new Cesium.Cartesian3(0,0,-1),upWC:new Cesium.Cartesian3(0,1,0),rightWC:new Cesium.Cartesian3(1,0,0),viewProjectionMatrix:Cesium.Matrix4.IDENTITY},this.ortCamera.frustum.left=this.totalRect[0],this.ortCamera.frustum.top=this.totalRect[3],this.ortCamera.frustum.right=this.totalRect[2],this.ortCamera.frustum.bottom=this.totalRect[1],this.ortCamera.frustum.near=.1,this.ortCamera.frustum.far=-12e4,this.floodRect=new Cesium.Cartesian4(this.totalRect[0],this.totalRect[1],this.totalRect[2]-this.totalRect[0],this.totalRect[3]-this.totalRect[1])}prepareFBO(){let t,e;e=1<this.ratio?(t=this._maxCanvasSize/this.ratio,this._maxCanvasSize):(t=this._maxCanvasSize,t*this.ratio);var r=this._map.scene.context,i=new Cesium.Texture({context:r,width:t,height:e,pixelFormat:Cesium.PixelFormat.RGBA,pixelDatatype:Cesium.PixelDatatype.HALF_FLOAT,flipY:!1});this.tailorTex=i,this.yanmoFbo=new Cesium.Framebuffer({context:r,colorTextures:[i],destroyAttachments:!1}),this._fboClearCommand=new Cesium.ClearCommand({color:new Cesium.Color(0,0,0,0),framebuffer:this.yanmoFbo})}drawPolygon(){let r=this._map.scene.context,t,e;e=1<this.ratio?(t=this._maxCanvasSize/this.ratio,this._maxCanvasSize):(t=this._maxCanvasSize,t*this.ratio);let i=new Cesium.PassState(r);i.viewport=new Cesium.BoundingRectangle(0,0,t,e);let a=r.uniformState;a.updateCamera(this.ortCamera),this._fboClearCommand.execute(r),this._areaList.forEach(t=>{const e=t.drawAreaCommand;e&&t.show&&(a.updatePass(e.pass),e.framebuffer=this.yanmoFbo,e.execute(r,i))})}beginTailor(){this.terrainEditCtl.inverFloodCenterMat=this.inverTrans,this.terrainEditCtl.floodArea=this.yanmoFbo,this.terrainEditCtl.enableFlood=!0,this.terrainEditCtl.floodRect=this.floodRect,this.terrainEditCtl.globe=!1}_setFloodVar(){this.floodVar=[this.minHeight,this.minHeight,this.maxHeight,this.maxHeight-this.minHeight]}removeArrayItem(t,e){e=t.indexOf(e);return-1<e&&(t.splice(e,1),!0)}}},{}],93:[function(t,e,r){t=t("./TilesetEditBase");class i extends t{constructor(t,e={}){super(t,e),e.hasOwnProperty("clipOutSide")&&(this.clipOutSide=e.clipOutSide)}get clipOutSide(){return this.options.clipOutSide}set clipOutSide(t){this.options.clipOutSide=t,this.tileset.modelEditor&&(this.tileset.modelEditor.editVar[0]=t)}_activeModelEditor(){this.tileset.modelEditor.fbo=this.fbo,this.tileset.modelEditor.polygonBounds=this.polygonBounds,this.tileset.modelEditor.IsYaPing[0]=!0,this.tileset.modelEditor.IsYaPing[2]=!0,this.tileset.modelEditor.editVar[0]=this.clipOutSide,this.tileset.modelEditor.enable=this.enabled,this.tileset.modelEditor._inverseTransform=this.matrix,this.tileset.modelEditor.upZ=this.upZ}}e.exports=i},{"./TilesetEditBase":94}],94:[function(t,e,r){e.exports=class{constructor(t,e={}){this.options=e,this._map=t,this._areaList=[],this._cache_id=0,this.options.hasOwnProperty("tileset")&&(this.tileset=this.options.tileset)}get list(){return this._areaList}get tileset(){return this._tileset}set tileset(t){this._tileset=t,this._inverseTransform=null}get matrix(){if(!this._tileset)return null;if(this.upZ="Z"==this._tileset.asset.gltfUpAxis||"z"==this._tileset.asset.gltfUpAxis,!this._inverseTransform){let t,e=this._tileset.root.transform;t=!e||e.equals(Cesium.Matrix4.IDENTITY)?Cesium.Transforms.eastNorthUpToFixedFrame(this._tileset.boundingSphere.center):Cesium.Matrix4.fromArray(this._tileset.root.transform),this._inverseTransform=Cesium.Matrix4.inverseTransformation(t,new Cesium.Matrix4)}return this._inverseTransform}get positions(){return 0<this.length?this._areaList[0].positions:null}set positions(t){this.clear(),this.addPolygon(t)}get length(){return this._areaList?this._areaList.length:0}clear(){this._areaList=[],this._cache_id=0,this._disable()}getPolygonById(e){for(let t=0;t<this._areaList.length;t++){var r=this._areaList[t];if(r.id==e)return r}return null}hidePolygon(t){let e=this.getPolygonById(t);e&&(e.show=!1,this.drawed=!1)}showPolygon(t){let e=this.getPolygonById(t);e&&(e.show=!0,this.drawed=!1)}removePolygon(t){t&&(this.removeArrayItem(this._areaList,t),this._disable(),this._activete())}addPolygon(t){if(t&&0!==t.length){t={show:!0,id:++this._cache_id,positions:t};return this._areaList.push(t),this._disable(),this._activete(),t}}_activete(){this._tileset&&(this._preparePos(),this._createTexture(),this._map.scene.primitives.contains(this)||this._map.scene.primitives.add(this))}_disable(){this.tileset.modelEditor&&(this.fbo&&this.fbo.destroy&&(this.fbo.destroy(),this.fbo=null),this.tileset.modelEditor.IsYaPing=[!1,!1,!1,!1],this.tileset.modelEditor.editVar=[!1,!1,!1,!1],this.tileset.modelEditor.floodColor=[0,0,0,.5],this.tileset.modelEditor.floodVar=[0,0,0,0],this.tileset.modelEditor.heightVar=[0,0],this.tileset.modelEditor.enable=!1),this.drawed=!1}update(t){if(!this.drawed&&this._areaList&&0!=this._areaList.length){this._createCommand(),this._activeModelEditor(),this.drawed=!0;let r=t.context;this._passState||(this._passState=new Cesium.PassState(r)),this._passState.framebuffer=this.fbo,this._passState.viewport=new Cesium.BoundingRectangle(0,0,4096,4096);let i=r.uniformState;i.updateCamera(this._camera),this._fboClearCommand.execute(t.context),this._areaList.forEach(t=>{const e=t.drawCommand;e&&t.show&&(i.updatePass(e.pass),e.framebuffer=this.fbo,e.execute(r,this._passState))})}}_activeModelEditor(){}deActiveEdit(){this.tileset.modelEditor.IsYaPing[0]=!1}_preparePos(){let n,s=99999,o=this.matrix;this._areaList.forEach(t=>{if(t.show){let e=[];var r=t.positions;if(r&&2<r.length){for(let t=0;t<r.length;t++){var i=Cesium.Cartographic.fromCartesian(r[t]).height,a=Cesium.Matrix4.multiplyByPoint(o,r[t],new Cesium.Cartesian3);e.push(a),i<s&&(s=i,n=a.z)}t.localPos=e}}}),this._minLocalZ=n}_createTexture(){var t=this._map.scene.context,e=new Cesium.Texture({context:t,width:4096,height:4096,pixelFormat:Cesium.PixelFormat.RGBA,pixelDatatype:Cesium.PixelDatatype.FLOAT,sampler:new Cesium.Sampler({wrapS:Cesium.TextureWrap.CLAMP_TO_EDGE,wrapT:Cesium.TextureWrap.CLAMP_TO_EDGE,minificationFilter:Cesium.TextureMinificationFilter.NEAREST,magnificationFilter:Cesium.TextureMagnificationFilter.NEAREST})}),r=new Cesium.Texture({context:t,width:4096,height:4096,pixelFormat:Cesium.PixelFormat.DEPTH_STENCIL,pixelDatatype:Cesium.PixelDatatype.UNSIGNED_INT_24_8});this.fbo=new Cesium.Framebuffer({context:t,colorTextures:[e],depthStencilTexture:r,destroyAttachments:!1}),this._fboClearCommand=new Cesium.ClearCommand({color:new Cesium.Color(0,0,0,0),framebuffer:this.fbo})}_createCommand(){let o=this._map.scene.context,l=99999999,u=99999999,h=-99999999,d=-99999999;this._areaList.forEach(r=>{var i=r.localPos;if(i){var a=new Cesium.PolygonGeometry({polygonHierarchy:new Cesium.PolygonHierarchy(i),perPositionHeight:!0}),n=Cesium.PolygonGeometry.createGeometry(a),s=Cesium.ShaderProgram.fromCache({context:o,vertexShaderSource:`uniform mat4 myPorjection;
attribute vec3 position;
varying vec2 depth;
void main()
{
    vec4 pos = vec4(position.xyz,1.0);
    depth = pos.zw;
    pos.z = 0.0;
    gl_Position = czm_projection*pos;
}`,fragmentShaderSource:`#ifdef GL_FRAGMENT_PRECISION_HIGH
    precision highp float;
#else
    precision mediump float;
#endif

#define OES_texture_float_linear

varying vec2 depth;

vec4 packDepth(float depth)
{
    vec4 enc = vec4(1.0, 255.0, 65025.0, 16581375.0) * depth;
    enc = fract(enc);
    enc -= enc.yzww * vec4(1.0 / 255.0, 1.0 / 255.0, 1.0 / 255.0, 0.0);
    return enc;
}

void main()
{
    float fDepth = (depth.x / 5000.0)/2.0 + 0.5;
    // gl_FragColor = packDepth(fDepth);
    gl_FragColor = vec4(1.0,0.0,0.0,1.0);
}`,attributeLocations:{position:0}}),i=Cesium.VertexArray.fromGeometry({context:o,geometry:n,attributeLocations:s._attributeLocations,bufferUsage:Cesium.BufferUsage.STATIC_DRAW,interleave:!0});let t=new Cesium.RenderState;t.depthTest.enabled=!1,t.depthRange.near=-1e6,t.depthRange.far=1e6;a=Cesium.BoundingRectangle.fromPoints(r.localPos,new Cesium.BoundingRectangle);l>a.x&&(l=a.x),u>a.y&&(u=a.y),h<a.x+a.width&&(h=a.x+a.width),d<a.y+a.height&&(d=a.y+a.height);let e=Cesium.Matrix4.computeOrthographicOffCenter(a.x,a.x+a.width,a.y,a.y+a.height,1,5e8,new Cesium.Matrix4);r.polygonBounds=new Cesium.Cartesian4(a.x,a.y,a.x+a.width,a.y+a.height),r.drawCommand=new Cesium.DrawCommand({boundingVolume:n.boundingVolume,primitiveType:Cesium.PrimitiveType.TRIANGLES,vertexArray:i,shaderProgram:s,renderState:t,pass:Cesium.Pass.CESIUM_3D_TILE,uniformMap:{myPorjection:function(){return e}}})}});let t={viewMatrix:Cesium.Matrix4.IDENTITY,inverseViewMatrix:Cesium.Matrix4.IDENTITY,frustum:new Cesium.OrthographicOffCenterFrustum,positionCartographic:new Cesium.Cartographic,positionWC:new Cesium.Cartesian3,directionWC:Cesium.Cartesian3.UNIT_Z,upWC:Cesium.Cartesian3.UNIT_Y,rightWC:Cesium.Cartesian3.UNIT_X,viewProjectionMatrix:Cesium.Matrix4.IDENTITY};t.frustum.left=l,t.frustum.top=d,t.frustum.right=h,t.frustum.bottom=u,this.polygonBounds=new Cesium.Cartesian4(l,u,h,d),this._camera=t}removeArrayItem(t,e){e=t.indexOf(e);return-1<e&&(t.splice(e,1),!0)}}},{}],95:[function(t,e,r){t=t("./TilesetEditBase");class i extends t{constructor(t,e={}){super(t,e),e.hasOwnProperty("height")&&(this.height=e.height)}get height(){return this.options.height}set height(t){this.options.height=t,this.tileset.modelEditor&&(this.tileset.modelEditor.heightVar[1]=t)}_activeModelEditor(){this.tileset.modelEditor.fbo=this.fbo,this.tileset.modelEditor.polygonBounds=this.polygonBounds,this.tileset.modelEditor.IsYaPing[0]=!0,this.tileset.modelEditor.IsYaPing[1]=!0,this.tileset.modelEditor.heightVar[0]=this._minLocalZ,this.tileset.modelEditor.heightVar[1]=this.height||0,this.tileset.modelEditor.enable=this.enabled,this.tileset.modelEditor._inverseTransform=this.matrix,this.tileset.modelEditor.upZ=this.upZ}}e.exports=i},{"./TilesetEditBase":94}],96:[function(t,e,r){e.exports=class{static getLine(e,r,i,a,t,n){var s=t||100,o=(n||1)/(s-1);let l=[];for(let t=0;t<s;t++){var u=this.getBezierNowPoint(e,r,i,a,t,o);l.push(u)}return l}static getBezierNowPoint(t,e,r,i,a,n){return{x:this.bezier(t.x,e.x,r.x,i.x,a*n),y:this.bezier(t.y,e.y,r.y,i.y,a*n),z:this.bezier(t.z,e.z,r.z,i.z,a*n)}}static bezier(t,e,r,i,a){return t*Math.pow(1-a,3)+3*e*a*Math.pow(1-a,2)+3*r*Math.pow(a,2)*(1-a)+i*Math.pow(a,3)}}},{}],97:[function(t,z,e){!function(w){!function(){const n=t("./ieee754"),s=t("./isArray");w.TYPED_ARRAY_SUPPORT=!0;r();function r(){return w.TYPED_ARRAY_SUPPORT?2147483647:1073741823}function a(t,e){if(r()<e)throw new RangeError("Invalid typed array length");return w.TYPED_ARRAY_SUPPORT?(t=new Uint8Array(e)).__proto__=w.prototype:(t=null===t?new w(e):t).length=e,t}function o(t,e,r,i){if("number"==typeof e)throw new TypeError('"value" argument must not be a number');return"undefined"!=typeof ArrayBuffer&&e instanceof ArrayBuffer?function(t,e,r,i){if(e.byteLength,r<0||e.byteLength<r)throw new RangeError("'offset' is out of bounds");if(e.byteLength<r+(i||0))throw new RangeError("'length' is out of bounds");e=void 0===r&&void 0===i?new Uint8Array(e):void 0===i?new Uint8Array(e,r):new Uint8Array(e,r,i);w.TYPED_ARRAY_SUPPORT?(t=e).__proto__=w.prototype:t=h(t,e);return t}(t,e,r,i):"string"==typeof e?function(t,e,r){"string"==typeof r&&""!==r||(r="utf8");if(!w.isEncoding(r))throw new TypeError('"encoding" must be a valid string encoding');var i=0|m(e,r),r=(t=a(t,i)).write(e,r);r!==i&&(t=t.slice(0,r));return t}(t,e,r):function(t,e){if(f(e)){var r=0|d(e.length);return 0===(t=a(t,r)).length?t:(e.copy(t,0,0,r),t)}if(e){if("undefined"!=typeof ArrayBuffer&&e.buffer instanceof ArrayBuffer||"length"in e)return"number"!=typeof e.length||function(t){return t!=t}(e.length)?a(t,0):h(t,e);if("Buffer"===e.type&&s(e.data))return h(t,e.data)}throw new TypeError("First argument must be a string, Buffer, ArrayBuffer, Array, or array-like object.")}(t,e)}function l(t){if("number"!=typeof t)throw new TypeError('"size" argument must be a number');if(t<0)throw new RangeError('"size" argument must not be negative')}function u(t,e){if(l(e),t=a(t,e<0?0:0|d(e)),!w.TYPED_ARRAY_SUPPORT)for(var r=0;r<e;++r)t[r]=0;return t}function h(t,e){var r=e.length<0?0:0|d(e.length);t=a(t,r);for(var i=0;i<r;i+=1)t[i]=255&e[i];return t}function d(t){if(t>=r())throw new RangeError("Attempt to allocate Buffer larger than maximum size: 0x"+r().toString(16)+" bytes");return 0|t}function f(t){return null!=t&&t._isBuffer}function m(t,e){if(f(t))return t.length;if("undefined"!=typeof ArrayBuffer&&"function"==typeof ArrayBuffer.isView&&(ArrayBuffer.isView(t)||t instanceof ArrayBuffer))return t.byteLength;var r=(t="string"!=typeof t?""+t:t).length;if(0===r)return 0;for(var i=!1;;)switch(e){case"ascii":case"latin1":case"binary":return r;case"utf8":case"utf-8":case void 0:return T(t).length;case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return 2*r;case"hex":return r>>>1;default:if(i)return T(t).length;e=(""+e).toLowerCase(),i=!0}}function e(t,e,r){var i=!1;if((e=void 0===e||e<0?0:e)>this.length)return"";if((r=void 0===r||r>this.length?this.length:r)<=0)return"";if((r>>>=0)<=(e>>>=0))return"";for(t=t||"utf8";;)switch(t){case"hex":return function(t,e,r){var i=t.length;(!e||e<0)&&(e=0);(!r||r<0||i<r)&&(r=i);for(var a="",n=e;n<r;++n)a+=function(t){return t<16?"0"+t.toString(16):t.toString(16)}(t[n]);return a}(this,e,r);case"utf8":case"utf-8":return y(this,e,r);case"ascii":return function(t,e,r){var i="";r=Math.min(t.length,r);for(var a=e;a<r;++a)i+=String.fromCharCode(127&t[a]);return i}(this,e,r);case"latin1":case"binary":return function(t,e,r){var i="";r=Math.min(t.length,r);for(var a=e;a<r;++a)i+=String.fromCharCode(t[a]);return i}(this,e,r);case"base64":case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return function(t,e,r){for(var i=t.slice(e,r),a="",n=0;n<i.length;n+=2)a+=String.fromCharCode(i[n]+256*i[n+1]);return a}(this,e,r);default:if(i)throw new TypeError("Unknown encoding: "+t);t=(t+"").toLowerCase(),i=!0}}function i(t,e,r){var i=t[e];t[e]=t[r],t[r]=i}function v(t,e,r,i,a){if(0===t.length)return-1;if("string"==typeof r?(i=r,r=0):2147483647<r?r=2147483647:r<-2147483648&&(r=-2147483648),r=+r,(r=(r=isNaN(r)?a?0:t.length-1:r)<0?t.length+r:r)>=t.length){if(a)return-1;r=t.length-1}else if(r<0){if(!a)return-1;r=0}if(f(e="string"==typeof e?w.from(e,i):e))return 0===e.length?-1:p(t,e,r,i,a);if("number"==typeof e)return e&=255,w.TYPED_ARRAY_SUPPORT&&"function"==typeof Uint8Array.prototype.indexOf?(a?Uint8Array.prototype.indexOf:Uint8Array.prototype.lastIndexOf).call(t,e,r):p(t,[e],r,i,a);throw new TypeError("val must be string, number or Buffer")}function p(t,e,r,i,a){var n=1,s=t.length,o=e.length;if(void 0!==i&&("ucs2"===(i=String(i).toLowerCase())||"ucs-2"===i||"utf16le"===i||"utf-16le"===i)){if(t.length<2||e.length<2)return-1;s/=n=2,o/=2,r/=2}function l(t,e){return 1===n?t[e]:t.readUInt16BE(e*n)}if(a)for(var u=-1,h=r;h<s;h++)if(l(t,h)===l(e,-1===u?0:h-u)){if(h-(u=-1===u?h:u)+1===o)return u*n}else-1!==u&&(h-=h-u),u=-1;else for(h=r=s<r+o?s-o:r;0<=h;h--){for(var d=!0,f=0;f<o;f++)if(l(t,h+f)!==l(e,f)){d=!1;break}if(d)return h}return-1}function c(t,e,r,i){return S(function(t){for(var e=[],r=0;r<t.length;++r)e.push(255&t.charCodeAt(r));return e}(e),t,r,i)}function b(t,e,r,i){return S(function(t,e){for(var r,i,a=[],n=0;n<t.length&&!((e-=2)<0);++n)i=t.charCodeAt(n),r=i>>8,i=i%256,a.push(i),a.push(r);return a}(e,t.length-r),t,r,i)}function y(t,e,r){r=Math.min(t.length,r);for(var i=[],a=e;a<r;){var n,s,o,l,u=t[a],h=null,d=239<u?4:223<u?3:191<u?2:1;if(a+d<=r)switch(d){case 1:u<128&&(h=u);break;case 2:128==(192&(n=t[a+1]))&&127<(l=(31&u)<<6|63&n)&&(h=l);break;case 3:n=t[a+1],s=t[a+2],128==(192&n)&&128==(192&s)&&2047<(l=(15&u)<<12|(63&n)<<6|63&s)&&(l<55296||57343<l)&&(h=l);break;case 4:n=t[a+1],s=t[a+2],o=t[a+3],128==(192&n)&&128==(192&s)&&128==(192&o)&&65535<(l=(15&u)<<18|(63&n)<<12|(63&s)<<6|63&o)&&l<1114112&&(h=l)}null===h?(h=65533,d=1):65535<h&&(h-=65536,i.push(h>>>10&1023|55296),h=56320|1023&h),i.push(h),a+=d}return function(t){var e=t.length;if(e<=V)return String.fromCharCode.apply(String,t);var r="",i=0;for(;i<e;)r+=String.fromCharCode.apply(String,t.slice(i,i+=V));return r}(i)}z.exports=function t(e,r,i){if(!(t.TYPED_ARRAY_SUPPORT||this instanceof t))return new t(e,r,i);if("number"!=typeof e)return o(this,e,r,i);if("string"==typeof r)throw new Error("If encoding is specified then the first argument must be a string");return u(this,e)},w.poolSize=8192,w._augment=function(t){return t.__proto__=w.prototype,t},w.from=function(t,e,r){return o(null,t,e,r)},w.TYPED_ARRAY_SUPPORT&&(w.prototype.__proto__=Uint8Array.prototype,w.__proto__=Uint8Array,"undefined"!=typeof Symbol&&Symbol.species&&w[Symbol.species]),w.alloc=function(t,e,r){return i=null,e=e,r=r,l(t=t),!(t<=0)&&void 0!==e?"string"==typeof r?a(i,t).fill(e,r):a(i,t).fill(e):a(i,t);var i},w.allocUnsafe=function(t){return u(null,t)},w.allocUnsafeSlow=function(t){return u(null,t)},w.isBuffer=function(t){return null!=t&&(!!t._isBuffer||g(t)||function(t){return"function"==typeof t.readFloatLE&&"function"==typeof t.slice&&g(t.slice(0,0))}(t))},w.compare=function(t,e){if(!f(t)||!f(e))throw new TypeError("Arguments must be Buffers");if(t===e)return 0;for(var r=t.length,i=e.length,a=0,n=Math.min(r,i);a<n;++a)if(t[a]!==e[a]){r=t[a],i=e[a];break}return r<i?-1:i<r?1:0},w.isEncoding=function(t){switch(String(t).toLowerCase()){case"hex":case"utf8":case"utf-8":case"ascii":case"latin1":case"binary":case"base64":case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return!0;default:return!1}},w.concat=function(t,e){if(!s(t))throw new TypeError('"list" argument must be an Array of Buffers');if(0===t.length)return w.alloc(0);if(void 0===e)for(a=e=0;a<t.length;++a)e+=t[a].length;for(var r=w.allocUnsafe(e),i=0,a=0;a<t.length;++a){var n=t[a];if(!f(n))throw new TypeError('"list" argument must be an Array of Buffers');n.copy(r,i),i+=n.length}return r},w.byteLength=m,w.prototype._isBuffer=!0,w.prototype.swap16=function(){var t=this.length;if(t%2!=0)throw new RangeError("Buffer size must be a multiple of 16-bits");for(var e=0;e<t;e+=2)i(this,e,e+1);return this},w.prototype.swap32=function(){var t=this.length;if(t%4!=0)throw new RangeError("Buffer size must be a multiple of 32-bits");for(var e=0;e<t;e+=4)i(this,e,e+3),i(this,e+1,e+2);return this},w.prototype.swap64=function(){var t=this.length;if(t%8!=0)throw new RangeError("Buffer size must be a multiple of 64-bits");for(var e=0;e<t;e+=8)i(this,e,e+7),i(this,e+1,e+6),i(this,e+2,e+5),i(this,e+3,e+4);return this},w.prototype.toString=function(){var t=0|this.length;return 0==t?"":0===arguments.length?y(this,0,t):e.apply(this,arguments)},w.prototype.equals=function(t){if(!f(t))throw new TypeError("Argument must be a Buffer");return this===t||0===w.compare(this,t)},w.prototype.inspect=function(){var t="";return 0<this.length&&(t=this.toString("hex",0,50).match(/.{2}/g).join(" "),50<this.length&&(t+=" ... ")),"<Buffer "+t+">"},w.prototype.compare=function(t,e,r,i,a){if(!f(t))throw new TypeError("Argument must be a Buffer");if(void 0===r&&(r=t?t.length:0),void 0===i&&(i=0),void 0===a&&(a=this.length),(e=void 0===e?0:e)<0||r>t.length||i<0||a>this.length)throw new RangeError("out of range index");if(a<=i&&r<=e)return 0;if(a<=i)return-1;if(r<=e)return 1;if(this===t)return 0;for(var n=(a>>>=0)-(i>>>=0),s=(r>>>=0)-(e>>>=0),o=Math.min(n,s),l=this.slice(i,a),u=t.slice(e,r),h=0;h<o;++h)if(l[h]!==u[h]){n=l[h],s=u[h];break}return n<s?-1:s<n?1:0},w.prototype.includes=function(t,e,r){return-1!==this.indexOf(t,e,r)},w.prototype.indexOf=function(t,e,r){return v(this,t,e,r,!0)},w.prototype.lastIndexOf=function(t,e,r){return v(this,t,e,r,!1)},w.prototype.write=function(t,e,r,i){if(void 0===e)i="utf8",r=this.length,e=0;else if(void 0===r&&"string"==typeof e)i=e,r=this.length,e=0;else{if(!isFinite(e))throw new Error("Buffer.write(string, encoding, offset[, length]) is no longer supported");e|=0,isFinite(r)?(r|=0,void 0===i&&(i="utf8")):(i=r,r=void 0)}var a=this.length-e;if((void 0===r||a<r)&&(r=a),0<t.length&&(r<0||e<0)||e>this.length)throw new RangeError("Attempt to write outside buffer bounds");i=i||"utf8";for(var n,s,o,l=!1;;)switch(i){case"hex":return function(t,e,r,i){r=Number(r)||0;var a=t.length-r;if((!i||a<(i=Number(i)))&&(i=a),(a=e.length)%2!=0)throw new TypeError("Invalid hex string");a/2<i&&(i=a/2);for(var n=0;n<i;++n){var s=parseInt(e.substr(2*n,2),16);if(isNaN(s))return n;t[r+n]=s}return n}(this,t,e,r);case"utf8":case"utf-8":return s=e,o=r,S(T(t,(n=this).length-s),n,s,o);case"ascii":return c(this,t,e,r);case"latin1":case"binary":return c(this,t,e,r);case"base64":return n=this,s=e,o=r,S(base64ToBytes(t),n,s,o);case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return b(this,t,e,r);default:if(l)throw new TypeError("Unknown encoding: "+i);i=(""+i).toLowerCase(),l=!0}},w.prototype.toJSON=function(){return{type:"Buffer",data:Array.prototype.slice.call(this._arr||this,0)}};var V=4096;function q(t,e,r){if(t%1!=0||t<0)throw new RangeError("offset is not uint");if(r<t+e)throw new RangeError("Trying to access beyond buffer length")}function x(t,e,r,i,a,n){if(!f(t))throw new TypeError('"buffer" argument must be a Buffer instance');if(a<e||e<n)throw new RangeError('"value" argument is out of bounds');if(r+i>t.length)throw new RangeError("Index out of range")}function W(t,e,r,i){e<0&&(e=65535+e+1);for(var a=0,n=Math.min(t.length-r,2);a<n;++a)t[r+a]=(e&255<<8*(i?a:1-a))>>>8*(i?a:1-a)}function N(t,e,r,i){e<0&&(e=4294967295+e+1);for(var a=0,n=Math.min(t.length-r,4);a<n;++a)t[r+a]=e>>>8*(i?a:3-a)&255}function X(t,e,r,i){if(r+i>t.length)throw new RangeError("Index out of range");if(r<0)throw new RangeError("Index out of range")}function L(t,e,r,i,a){return a||X(t,0,r,4),n.write(t,e,r,i,23,4),r+4}function P(t,e,r,i,a){return a||X(t,0,r,8),n.write(t,e,r,i,52,8),r+8}function T(t,e){var r;e=e||1/0;for(var i=t.length,a=null,n=[],s=0;s<i;++s){if(55295<(r=t.charCodeAt(s))&&r<57344){if(!a){if(56319<r){-1<(e-=3)&&n.push(239,191,189);continue}if(s+1===i){-1<(e-=3)&&n.push(239,191,189);continue}a=r;continue}if(r<56320){-1<(e-=3)&&n.push(239,191,189),a=r;continue}r=65536+(a-55296<<10|r-56320)}else a&&-1<(e-=3)&&n.push(239,191,189);if(a=null,r<128){if(--e<0)break;n.push(r)}else if(r<2048){if((e-=2)<0)break;n.push(r>>6|192,63&r|128)}else if(r<65536){if((e-=3)<0)break;n.push(r>>12|224,r>>6&63|128,63&r|128)}else{if(!(r<1114112))throw new Error("Invalid code point");if((e-=4)<0)break;n.push(r>>18|240,r>>12&63|128,r>>6&63|128,63&r|128)}}return n}function S(t,e,r,i){for(var a=0;a<i&&!(a+r>=e.length||a>=t.length);++a)e[a+r]=t[a];return a}function g(t){return!!t.constructor&&"function"==typeof t.constructor.isBuffer&&t.constructor.isBuffer(t)}w.prototype.slice=function(t,e){var r=this.length;if((t=~~t)<0?(t+=r)<0&&(t=0):r<t&&(t=r),(e=void 0===e?r:~~e)<0?(e+=r)<0&&(e=0):r<e&&(e=r),e<t&&(e=t),w.TYPED_ARRAY_SUPPORT)(a=this.subarray(t,e)).__proto__=w.prototype;else for(var i=e-t,a=new w(i,void 0),n=0;n<i;++n)a[n]=this[n+t];return a},w.prototype.readUIntLE=function(t,e,r){t|=0,e|=0,r||q(t,e,this.length);for(var i=this[t],a=1,n=0;++n<e&&(a*=256);)i+=this[t+n]*a;return i},w.prototype.readUIntBE=function(t,e,r){t|=0,e|=0,r||q(t,e,this.length);for(var i=this[t+--e],a=1;0<e&&(a*=256);)i+=this[t+--e]*a;return i},w.prototype.readUInt8=function(t,e){return e||q(t,1,this.length),this[t]},w.prototype.readUInt16LE=function(t,e){return e||q(t,2,this.length),this[t]|this[t+1]<<8},w.prototype.readUInt16BE=function(t,e){return e||q(t,2,this.length),this[t]<<8|this[t+1]},w.prototype.readUInt32LE=function(t,e){return e||q(t,4,this.length),(this[t]|this[t+1]<<8|this[t+2]<<16)+16777216*this[t+3]},w.prototype.readUInt32BE=function(t,e){return e||q(t,4,this.length),16777216*this[t]+(this[t+1]<<16|this[t+2]<<8|this[t+3])},w.prototype.readIntLE=function(t,e,r){t|=0,e|=0,r||q(t,e,this.length);for(var i=this[t],a=1,n=0;++n<e&&(a*=256);)i+=this[t+n]*a;return(a*=128)<=i&&(i-=Math.pow(2,8*e)),i},w.prototype.readIntBE=function(t,e,r){t|=0,e|=0,r||q(t,e,this.length);for(var i=e,a=1,n=this[t+--i];0<i&&(a*=256);)n+=this[t+--i]*a;return(a*=128)<=n&&(n-=Math.pow(2,8*e)),n},w.prototype.readInt8=function(t,e){return e||q(t,1,this.length),128&this[t]?-1*(255-this[t]+1):this[t]},w.prototype.readInt16LE=function(t,e){e||q(t,2,this.length);t=this[t]|this[t+1]<<8;return 32768&t?4294901760|t:t},w.prototype.readInt16BE=function(t,e){e||q(t,2,this.length);t=this[t+1]|this[t]<<8;return 32768&t?4294901760|t:t},w.prototype.readInt32LE=function(t,e){return e||q(t,4,this.length),this[t]|this[t+1]<<8|this[t+2]<<16|this[t+3]<<24},w.prototype.readInt32BE=function(t,e){return e||q(t,4,this.length),this[t]<<24|this[t+1]<<16|this[t+2]<<8|this[t+3]},w.prototype.readFloatLE=function(t,e){return e||q(t,4,this.length),n.read(this,t,!0,23,4)},w.prototype.readFloatBE=function(t,e){return e||q(t,4,this.length),n.read(this,t,!1,23,4)},w.prototype.readDoubleLE=function(t,e){return e||q(t,8,this.length),n.read(this,t,!0,52,8)},w.prototype.readDoubleBE=function(t,e){return e||q(t,8,this.length),n.read(this,t,!1,52,8)},w.prototype.writeUIntLE=function(t,e,r,i){t=+t,e|=0,r|=0,i||x(this,t,e,r,Math.pow(2,8*r)-1,0);var a=1,n=0;for(this[e]=255&t;++n<r&&(a*=256);)this[e+n]=t/a&255;return e+r},w.prototype.writeUIntBE=function(t,e,r,i){t=+t,e|=0,r|=0,i||x(this,t,e,r,Math.pow(2,8*r)-1,0);var a=r-1,n=1;for(this[e+a]=255&t;0<=--a&&(n*=256);)this[e+a]=t/n&255;return e+r},w.prototype.writeUInt8=function(t,e,r){return t=+t,e|=0,r||x(this,t,e,1,255,0),w.TYPED_ARRAY_SUPPORT||(t=Math.floor(t)),this[e]=255&t,e+1},w.prototype.writeUInt16LE=function(t,e,r){return t=+t,e|=0,r||x(this,t,e,2,65535,0),w.TYPED_ARRAY_SUPPORT?(this[e]=255&t,this[e+1]=t>>>8):W(this,t,e,!0),e+2},w.prototype.writeUInt16BE=function(t,e,r){return t=+t,e|=0,r||x(this,t,e,2,65535,0),w.TYPED_ARRAY_SUPPORT?(this[e]=t>>>8,this[e+1]=255&t):W(this,t,e,!1),e+2},w.prototype.writeUInt32LE=function(t,e,r){return t=+t,e|=0,r||x(this,t,e,4,4294967295,0),w.TYPED_ARRAY_SUPPORT?(this[e+3]=t>>>24,this[e+2]=t>>>16,this[e+1]=t>>>8,this[e]=255&t):N(this,t,e,!0),e+4},w.prototype.writeUInt32BE=function(t,e,r){return t=+t,e|=0,r||x(this,t,e,4,4294967295,0),w.TYPED_ARRAY_SUPPORT?(this[e]=t>>>24,this[e+1]=t>>>16,this[e+2]=t>>>8,this[e+3]=255&t):N(this,t,e,!1),e+4},w.prototype.writeIntLE=function(t,e,r,i){t=+t,e|=0,i||x(this,t,e,r,(i=Math.pow(2,8*r-1))-1,-i);var a=0,n=1,s=0;for(this[e]=255&t;++a<r&&(n*=256);)t<0&&0===s&&0!==this[e+a-1]&&(s=1),this[e+a]=(t/n>>0)-s&255;return e+r},w.prototype.writeIntBE=function(t,e,r,i){t=+t,e|=0,i||x(this,t,e,r,(i=Math.pow(2,8*r-1))-1,-i);var a=r-1,n=1,s=0;for(this[e+a]=255&t;0<=--a&&(n*=256);)t<0&&0===s&&0!==this[e+a+1]&&(s=1),this[e+a]=(t/n>>0)-s&255;return e+r},w.prototype.writeInt8=function(t,e,r){return t=+t,e|=0,r||x(this,t,e,1,127,-128),w.TYPED_ARRAY_SUPPORT||(t=Math.floor(t)),this[e]=255&(t=t<0?255+t+1:t),e+1},w.prototype.writeInt16LE=function(t,e,r){return t=+t,e|=0,r||x(this,t,e,2,32767,-32768),w.TYPED_ARRAY_SUPPORT?(this[e]=255&t,this[e+1]=t>>>8):W(this,t,e,!0),e+2},w.prototype.writeInt16BE=function(t,e,r){return t=+t,e|=0,r||x(this,t,e,2,32767,-32768),w.TYPED_ARRAY_SUPPORT?(this[e]=t>>>8,this[e+1]=255&t):W(this,t,e,!1),e+2},w.prototype.writeInt32LE=function(t,e,r){return t=+t,e|=0,r||x(this,t,e,4,2147483647,-2147483648),w.TYPED_ARRAY_SUPPORT?(this[e]=255&t,this[e+1]=t>>>8,this[e+2]=t>>>16,this[e+3]=t>>>24):N(this,t,e,!0),e+4},w.prototype.writeInt32BE=function(t,e,r){return t=+t,e|=0,r||x(this,t,e,4,2147483647,-2147483648),t<0&&(t=4294967295+t+1),w.TYPED_ARRAY_SUPPORT?(this[e]=t>>>24,this[e+1]=t>>>16,this[e+2]=t>>>8,this[e+3]=255&t):N(this,t,e,!1),e+4},w.prototype.writeFloatLE=function(t,e,r){return L(this,t,e,!0,r)},w.prototype.writeFloatBE=function(t,e,r){return L(this,t,e,!1,r)},w.prototype.writeDoubleLE=function(t,e,r){return P(this,t,e,!0,r)},w.prototype.writeDoubleBE=function(t,e,r){return P(this,t,e,!1,r)},w.prototype.copy=function(t,e,r,i){if(r=r||0,i||0===i||(i=this.length),e>=t.length&&(e=t.length),(i=0<i&&i<r?r:i)===r)return 0;if(0===t.length||0===this.length)return 0;if((e=e||0)<0)throw new RangeError("targetStart out of bounds");if(r<0||r>=this.length)throw new RangeError("sourceStart out of bounds");if(i<0)throw new RangeError("sourceEnd out of bounds");i>this.length&&(i=this.length);var a,n=(i=t.length-e<i-r?t.length-e+r:i)-r;if(this===t&&r<e&&e<i)for(a=n-1;0<=a;--a)t[a+e]=this[a+r];else if(n<1e3||!w.TYPED_ARRAY_SUPPORT)for(a=0;a<n;++a)t[a+e]=this[a+r];else Uint8Array.prototype.set.call(t,this.subarray(r,r+n),e);return n},w.prototype.fill=function(t,e,r,i){if("string"==typeof t){var a;if("string"==typeof e?(i=e,e=0,r=this.length):"string"==typeof r&&(i=r,r=this.length),1!==t.length||(a=t.charCodeAt(0))<256&&(t=a),void 0!==i&&"string"!=typeof i)throw new TypeError("encoding must be a string");if("string"==typeof i&&!w.isEncoding(i))throw new TypeError("Unknown encoding: "+i)}else"number"==typeof t&&(t&=255);if(e<0||this.length<e||this.length<r)throw new RangeError("Out of range index");if(r<=e)return this;if(e>>>=0,r=void 0===r?this.length:r>>>0,"number"==typeof(t=t||0))for(o=e;o<r;++o)this[o]=t;else for(var n=f(t)?t:T(new w(t,i).toString()),s=n.length,o=0;o<r-e;++o)this[o+e]=n[o%s];return this}}.call(this)}.call(this,t("buffer").Buffer)},{"./ieee754":114,"./isArray":115,buffer:2}],98:[function(t,e,r){!function(a){!function(){e.exports=class{constructor(){}static getHeaderArray(e){let r=[];for(let t=0;t<e;t++)r[t]=this._getRandomNum();return r}static _getRandomNum(){var t=Math.random();return 50+Math.round(80*t)}static stringToByte(t,e){let r=[];var i=a.from(t,e=void 0===e?"utf8":e);for(let t=0;t<i.length;t++)r.push(i[t]);return r}static byteToString(t,e){return void 0===e&&(e="utf8"),a.from(t).toString(e)}static intToBytes(t){return[t>>24&255,t>>16&255,t>>8&255,255&t]}static bytesToInt(t){return t[0]<<24|t[1]<<16|t[2]<<8|t[3]}static varintToInt(e){let r=[],i=[],a=3,n=0;for(let t=e.length-1;0<=t&&(0<=t-1?i[0]=e[t-1]<<7-n:i[0]=0,-1!==a);t--)r[a]=(127&e[t])>>n|i[0],a--,n++;var t=r[0]<<24&4278190080|r[1]<<16&16711680|r[2]<<8&65280|255&r[3];return t=t>>1^-(1&t)}static intToVarint(e){if(0===e)return[0];e=this._zigZagEncoding(e);let r=[],i,a=0;for(let t=5;0<t;t--)i=e>>7*(t-1)&127,0!==a&&(i|=128),0!==i&&r.push(i),a=i;return r}static varintToIntArray(e){let r=[];let i=0,a=[];for(let t=0;t<e.length;t++)0==(0|e[t]>>7&1)&&0<i&&i<=5&&(a.push(this.varintToInt(r)),r=[],i=0),r.push(e[t]),i++;return a.push(this.varintToInt(r)),a}static intArrayToVarintBuffer(e){let r=[];var i;for(let t=0;t<e.length;t++)i=this.intToVarint(e[t]),r.push(...i);return a.from(r)}static _zigZagEncoding(t){return t>>31^t<<1}}}.call(this)}.call(this,t("buffer").Buffer)},{buffer:2}],99:[function(t,e,r){e.exports=class{constructor(t){this._viewer=t,this.entity=null,this.handler=null,this.moving=!1,this._leftDown=this._leftDownHandler.bind(this),this._leftUp=this._leftUpHandler.bind(this),this._move=this._moveHandler.bind(this),this.handler=new Cesium.ScreenSpaceEventHandler(this._viewer.canvas)}enable(){this.handler.setInputAction(this._leftDown,Cesium.ScreenSpaceEventType.LEFT_DOWN),this.handler.setInputAction(this._leftUp,Cesium.ScreenSpaceEventType.LEFT_UP),this.handler.setInputAction(this._move,Cesium.ScreenSpaceEventType.MOUSE_MOVE)}disable(){this._viewer.scene.screenSpaceCameraController.enableRotate=!0,this.handler.removeInputAction(Cesium.ScreenSpaceEventType.LEFT_DOWN),this.handler.removeInputAction(Cesium.ScreenSpaceEventType.LEFT_UP),this.handler.removeInputAction(Cesium.ScreenSpaceEventType.MOUSE_MOVE),this.moving=!1,this.entity=null}_leftDownHandler(t){this.entity=this._viewer.scene.pick(t.position),this.moving=!0,this.entity&&(this._viewer.scene.screenSpaceCameraController.enableRotate=!1)}_leftUpHandler(){this.moving=!1,this.entity=null,this._viewer.scene.screenSpaceCameraController.enableRotate=!0}_moveHandler(t){if(this.moving&&this.entity&&this.entity.id){t=this._viewer.camera.getPickRay(t.endPosition),t=this._viewer.scene.globe.pick(t,this._viewer.scene);const e=viewer.scene.globe.ellipsoid,r=e.cartesianToCartographic(t);t=this.entity.id.position.getValue();const i=e.cartesianToCartographic(t);this.entity.id.position=new Cesium.CallbackProperty(function(){return new Cesium.Cartesian3.fromRadians(r.longitude,r.latitude,i.height)},!1)}}}},{}],100:[function(t,e,r){e.exports=class{constructor(t){this._viewer=t,this.entity=null,this.handler=null,this.moving=!1,this._leftDown=this._leftDownHandler.bind(this),this._leftUp=this._leftUpHandler.bind(this),this._move=this._moveHandler.bind(this),this.handler=new Cesium.ScreenSpaceEventHandler(this._viewer.canvas)}enable(){this.handler.setInputAction(this._leftDown,Cesium.ScreenSpaceEventType.LEFT_DOWN),this.handler.setInputAction(this._leftUp,Cesium.ScreenSpaceEventType.LEFT_UP),this.handler.setInputAction(this._move,Cesium.ScreenSpaceEventType.MOUSE_MOVE)}disable(){this._viewer.scene.screenSpaceCameraController.enableRotate=!0,this.handler.removeInputAction(Cesium.ScreenSpaceEventType.LEFT_DOWN),this.handler.removeInputAction(Cesium.ScreenSpaceEventType.LEFT_UP),this.handler.removeInputAction(Cesium.ScreenSpaceEventType.MOUSE_MOVE),this.moving=!1,this.entity=null}_leftDownHandler(t){this.entity=this._viewer.scene.pick(t.position),this.moving=!0,this.entity&&(this._viewer.scene.screenSpaceCameraController.enableRotate=!1)}_leftUpHandler(){this.moving=!1,this.entity=null,this._viewer.scene.screenSpaceCameraController.enableRotate=!0}_moveHandler(t){this.moving&&this.entity&&this.entity.primitive&&(t=this._viewer.camera.getPickRay(t.endPosition),t=this._viewer.scene.globe.pick(t,this._viewer.scene),this.entity.primitive.modelMatrix=Cesium.Matrix4.setTranslation(this.entity.primitive.modelMatrix,t,new Cesium.Matrix4),this.entity.primitive.resetDrawCommands&&this.entity.primitive.resetDrawCommands())}}},{}],101:[function(t,e,r){const f=Cesium.when;e.exports=class{static getDBMap(r,n){let t=f.defer(),s=[];for(let e=0;e<r.length;e++){let i=r[e],a=f.defer(),t=indexedDB.open(i,1);t.onerror=function(){console.log(i+"数据库创建失败或者异常~"),a.reject()},t.onsuccess=function(t){console.log(i+"数据库连接成功~"),n[i]=t.target.result,a.resolve(!0)},t.onupgradeneeded=function(t){let e=t.target.result;n[i]=e;let r=e.createObjectStore(i,{keyPath:"key",autoIncrement:!1});r.createIndex("data","data",{unique:!1}),a.resolve(!0)},s.push(a.promise)}return f.all(s,function(){t.resolve(!0)}),t}static getElevation(o,l,u){let t=f.defer(),h=[],d=[];for(let s=0;s<l.length;s++){let e=l[s],t=o[e],r=t.transaction([e]),i=r.objectStore(e),a=f.defer(),n=i.get(u);n.onerror=function(t){d[e]=null,a.resolve(null)},n.onsuccess=function(t){n.result?(d[e]=n.result,a.resolve(n.result)):(d[e]=null,a.resolve(null))},h.push(a.promise)}return f.all(h,function(){t.resolve(d)}),t}static updateElevation(t,e,r,i){let a=f.defer(),n=t.transaction([e],"readwrite").objectStore(e).put({key:r,data:i});return n.onsuccess=function(t){a.resolve(!0)},n.onerror=function(t){a.reject()},a}}},{}],102:[function(t,e,r){e.exports=class{constructor(){this.ingest={FeatureCollection:function(t){var r=t.features;for(let t=0,e=r.length;t<e;t++){var i=r[t];if(!i.geometry)return;var a=i.geometry.type;if(!this.ingest[a])throw new RuntimeError("Unknown geometry type: "+a);var n=this.ingest[a].apply(this,[i]);this.pushComponents(n,i.properties,a)}},Feature:function(t){var e=t;if(e.geometry){var r=e.geometry.type;if(!this.ingest[r])throw new RuntimeError("Unknown geometry type: "+r);t=this.ingest[r].apply(this,[e]);this.pushComponents(t,e.properties,r)}},GeometryCollection:function(t){for(var e=t.geometries,r=0,i=e.length;r<i;r++){var a=e[r],n=a.type;if(!this.ingest[n])throw new RuntimeError("Unknown geometry type: "+n);var s=this.ingest[n].apply(this,[feature]);this.pushComponents(s,a.properties,n)}},Point:function(t){t=t.geometry.coordinates;return[{x:parseFloat(t[0]),y:parseFloat(t[1])}]},MultiPoint:function(t){for(var e=t.geometry.coordinates,r=[],i=0;i<e.length;i+=1)r.push(this.ingest.Point.apply(this,[{geometry:{coordinates:e[i]}}]));return r},LineString:function(t){for(var e=this.ingest.MultiPoint.apply(this,[t]),r=[],i=0;i<e.length;i+=1)r=r.concat(e[i]);return r},MultiLineString:function(t){for(var e=[],r=t.geometry.coordinates,i=0;i<r.length;i+=1)e.push(this.ingest.LineString.apply(this,[{geometry:{coordinates:r[i]}}]));return e},Polygon:function(t){for(var e=t.geometry.coordinates,r=[],i=0;i<e.length;i+=1){for(var a=e[i],n=[],s=0;s<a.length;s+=1){var o=a[s],l=o[0],o=o[1];n.push({x:parseFloat(l),y:parseFloat(o)})}r.push(n)}return r},MultiPolygon:function(t){for(var e=[],r=t.geometry.coordinates,i=0;i<r.length;i+=1){var a=r[i];e.push(this.ingest.Polygon.apply(this,[{geometry:{coordinates:a}}]))}return e}}}read(t){return this.pointArray=[],this.lineArray=[],this.polygonArray=[],this.ingest[t.type].apply(this,[t]),this}readToPrimitives(t,e){return this.read(t),this.componentsToPrimitives(e)}pushComponents(e,r,t){if("Point"!=t&&"MultiPoint"!=t)if("LineString"!=t)if("MultiLineString"!=t)if("Polygon"!=t){if("MultiPolygon"==t)for(let t=0;t<e.length;t++){var i={properties:r,geometry:this.createPolygon(e[t])};this.polygonArray.push(i)}}else{var a={properties:r,geometry:this.createPolygon(e)};this.polygonArray.push(a)}else for(let t=0;t<e.length;t++){var n={properties:r,geometry:this.createLine(e[t])};this.lineArray.push(n)}else{a={properties:r,geometry:this.createLine(e)};this.lineArray.push(a)}}componentsToPrimitives(e){(e=e||{}).asynchronous=e.asynchronous||!1,e.clampToGround=e.clampToGround||!1,e.fillColor=e.fillColor||"#ff0000",e.fillOpacity=e.hasOwnProperty("fillOpacity")?e.fillOpacity:1,e.pixelSize=e.pixelSize||10,e.strokeColor=e.strokeColor||"#ff0000",e.strokeOpacity=e.hasOwnProperty("strokeOpacity")?e.strokeOpacity:1,e.lineWidth=e.hasOwnProperty("lineWidth")?e.lineWidth:2,e.outlineWidth=e.hasOwnProperty("outlineWidth")?e.outlineWidth:0,e.translucent=!1,1==e.fillOpacity&&1==e.strokeOpacity||(e.translucent=!0);let r=[],i=[],a=[];for(let t=0;t<this.pointArray.length;t++){var n=this.pointArray[t].geometry;r.push(this.getPointInstance(n,e))}for(let t=0;t<this.lineArray.length;t++){var s=this.lineArray[t].geometry;i.push(this.getLineInstance(s,e))}for(let t=0;t<this.polygonArray.length;t++){var o=this.polygonArray[t].geometry;a.push(this.getPolygonInstance(o,e))}var t=this.getPointPrimitive(r,e),l=this.getLinePrimitive(i,e),u=this.getPolygonPrimitive(a,e);let h=[];return t&&h.push(t),l&&h.push(l),u&&h.push(u),h}getPointInstance(t,e,r){return t}getPointPrimitive(e,r){if(0==e.length)return null;let i=new Cesium.PointPrimitiveCollection;for(let t=0;t<e.length;t++)i.add({pixelSize:r.pixelSize,color:Cesium.Color.fromCssColorString(r.fillColor).withAlpha(r.fillOpacity),outlineColor:Cesium.Color.fromCssColorString(r.strokeColor).withAlpha(r.strokeOpacity),outlineWidth:r.outlineWidth,position:Cesium.Cartesian3.fromDegrees(e[t].x,e[t].y,0)});return i}getLineInstance(t,e){let r=null;return r=e.clampToGround?new Cesium.GeometryInstance({geometry:new Cesium.GroundPolylineGeometry({positions:Cesium.Cartesian3.fromDegreesArray(t),width:e.lineWidth}),attributes:{color:Cesium.ColorGeometryInstanceAttribute.fromColor(Cesium.Color.fromCssColorString(e.strokeColor).withAlpha(e.strokeOpacity))}}):new Cesium.GeometryInstance({geometry:new Cesium.PolylineGeometry({positions:Cesium.Cartesian3.fromDegreesArray(t),width:e.lineWidth}),attributes:{color:Cesium.ColorGeometryInstanceAttribute.fromColor(Cesium.Color.fromCssColorString(e.strokeColor).withAlpha(e.strokeOpacity))}}),r}getLinePrimitive(t,e){if(0==t.length)return null;let r=null;return r=new(e.clampToGround?Cesium.GroundPolylinePrimitive:Cesium.Primitive)({asynchronous:e.asynchronous,geometryInstances:t,appearance:new Cesium.PolylineColorAppearance({flat:!0,translucent:e.translucent})}),r}createLine(e){let r=[];for(let t=0;t<e.length;t++){var i=e[t];r.push(i.x),r.push(i.y)}return r}getPolygonInstance(e,t){var r=Cesium.Cartesian3.fromDegreesArray(e.pts);let i=[];for(let t=0;t<e.holes.length;t++)i.push({positions:Cesium.Cartesian3.fromDegreesArray(e.holes[t])});return new Cesium.GeometryInstance({geometry:new Cesium.PolygonGeometry({polygonHierarchy:{positions:r,holes:i},vertexFormat:Cesium.PerInstanceColorAppearance.VERTEX_FORMAT,height:0}),attributes:{color:Cesium.ColorGeometryInstanceAttribute.fromColor(Cesium.Color.fromCssColorString(t.fillColor).withAlpha(t.fillOpacity))}})}getPolygonPrimitive(t,e){if(0==t.length)return null;let r=null;return r=new(e.clampToGround?Cesium.GroundPrimitive:Cesium.Primitive)({asynchronous:e.asynchronous,geometryInstances:t,appearance:new Cesium.PerInstanceColorAppearance({translucent:e.translucent,closed:!0})}),r}createPolygon(e){let r=[],i=[];var t={pts:r,holes:i};for(let t=0;t<e.length;t++){var a=e[t];if(0==t)for(let t=0;t<a.length;t++){var n=a[t];r.push(n.x),r.push(n.y)}else{let e=[];for(let t=0;t<a.length;t++){var s=a[t];e.push(s.x),e.push(s.y)}i.push(e)}}return t}beginsWith(t,e){return t.substring(0,e.length)===e}endsWith(t,e){return t.substring(t.length-e.length)===e}trim(t,e){for(e=e||" ";this.beginsWith(t,e);)t=t.substring(1);for(;this.endsWith(t,e);)t=t.substring(0,t.length-1);return t}}},{}],103:[function(t,e,r){class v{static pointDistToLine(t,e,r,i,a,n){var s=((t-r)*(a-r)+(e-i)*(n-i))/((r-a)*(r-a)+(i-n)*(i-n)),r=r+s*(a-r),i=i+s*(n-i);return Math.sqrt((t-r)*(t-r)+(e-i)*(e-i))}static isPointOnSegment(t,e,r,i,a,n){return!(r<t-5&&a<t+5||t+5<r&&t-5<a)&&!(i<e-5&&n<e+5||e+5<i&&e-5<n)&&v.pointDistToLine(t,e,r,i,a,n)<5?1:0}static pointInLine(t,e,r){let i=[];Array.isArray(r[0])?i=r:i.push(r);for(var a=0;a<i.length;a++)for(var n=i[a],s=n.length/2,o=0;o<s-1;o++){var l=o+1,u=n[2*o],h=n[2*o+1],d=n[2*l],l=n[2*l+1];if(1==v.isPointOnSegment(t,e,u,h,d,l))return 1}return 0}static pointInPolygon(t,e,r){let i=0,a=[];Array.isArray(r[0])?a=r:a.push(r);for(var n=0;n<a.length;n++)for(var s=a[n],o=0,l=s.length/2,u=l-1;o<l;u=o,o++){var h=s[2*o],d=s[2*o+1],f=s[2*u],m=s[2*u+1];if(h===t&&d===e||f===t&&m===e)return 1;if(d<e&&e<=m||e<=d&&m<e){d=h+(e-d)*(f-h)/(m-d);if(d===t)return 1;t<d&&(i=!i)}}return i?1:0}static lineIntersects(t,e,r,i,a,n,s,o){var l=[null,null],u=(o-n)*(r-t)-(s-a)*(i-e);return 0==u?null!==l[0]&&null!==l[1]&&l:(a=(s-a)*(s=e-n)-(o-n)*(n=t-a),n=((r-t)*s-(i-e)*n)/u,l[0]=t+(s=a/u)*(r-t),l[1]=e+s*(i-e),0<n&&n<1&&l)}static polyWith(e,r){var i=e.length/2,a=r.length/2;let n,s,o,l,u,h,d,f;for(let t=0;t<i;t++){n=t!=i-1?(s=e[2*t],o=e[2*t+1],l=e[2*t+2],e[2*t+3]):(s=e[2*t],o=e[2*t+1],l=e[0],e[1]);for(let t=0;t<a;t++)if(u=t!=a-1?(h=r[2*t],d=r[2*t+1],f=r[2*t+2],r[2*t+3]):(h=r[2*t],d=r[2*t+1],f=r[0],r[1]),0!=v.lineIntersects(s,o,l,n,h,d,f,u))return 1}var t=r[0],m=r[1];return v.pointInPolygon(t,m,e)?2:3}static boxToPolyArr(t,e,r,i){let a=[];return a.push(t),a.push(e),a.push(t),a.push(i),a.push(r),a.push(i),a.push(r),a.push(e),a.push(t),a.push(e),a}static getExtensionPoint(e,r,i){var a=r[0]-e[0],e=r[1]-e[1];let n=r[0],s=r[1];if(0==a)s=0<e?r[1]+i:r[1]-i;else{let t=Math.sqrt(i*i/(e/a*(e/a)+1));a<0&&(t=-t),n=r[0]+t,s=r[1]+e/a*t}return[n,s]}static lineOffset(a,t){let n=[],s=[];return a.forEach(function(r,i){if(i!==a.length-1){let e=v.processSegment(r,a[i+1],t);if(n.push(e),0<i){let t=n[i-1];r=v.lineIntersects(e[0][0],e[0][1],e[1][0],e[1][1],t[0][0],t[0][1],t[1][0],t[1][1]);!1!==r&&(t[1]=r,e[0]=r),s.push(t[0]),i===a.length-2&&(s.push(e[0]),s.push(e[1]))}2===a.length&&(s.push(e[0]),s.push(e[1]))}}),s}static processSegment(t,e,r){var i=t[0],a=e[0],n=Math.sqrt((i[0]-a[0])*(i[0]-a[0])+(i[1]-a[1])*(i[1]-a[1])),s=i[0]+r*(a[1]-i[1])/n,o=a[0]+r*(a[1]-i[1])/n,l=i[1]+r*(i[0]-a[0])/n,n=a[1]+r*(i[0]-a[0])/n;return[[[s,l],t[1]],[[o,n],e[1]]]}static isInBox(t,e){return t[0]>=e[0]&&t[1]>=e[1]&&t[2]<=e[2]&&t[3]<=e[3]}static Utf8ArrayToStr(t){for(var e,r,i,a="",n=t.length,s=0;s<n;)switch((e=t[s++])>>4){case 0:case 1:case 2:case 3:case 4:case 5:case 6:case 7:a+=String.fromCharCode(e);break;case 12:case 13:r=t[s++],a+=String.fromCharCode((31&e)<<6|63&r);break;case 14:r=t[s++],i=t[s++],a+=String.fromCharCode((15&e)<<12|(63&r)<<6|(63&i)<<0)}return a}}e.exports=v},{}],104:[function(t,e,r){!function(t){!function(){e.exports=class{constructor(){this.layerHeaderProBuffer=t.alloc(0),this.coordinateBufferArray=[],this.featureArray=[]}getLayerHeaderProBuffer(){return this.layerHeaderProBuffer}setLayerHeaderProBuffer(t){this.layerHeaderProBuffer=t}getFeatureArray(){return this.featureArray}setFeatureArray(t){this.featureArray=t}getCoordinateBufferArray(){return this.coordinateBufferArray}setCoordinateBufferArray(t){this.coordinateBufferArray=t}}}.call(this)}.call(this,t("buffer").Buffer)},{buffer:2}],105:[function(t,e,r){e.exports=class{static composeShader(t){var e,r;let i="",a="";for(r in t){var n=t[r];i=i+n.name+"();",a+=n.shader}return e="void main(){\n"+i+"}",a+e}static composeMainShader(t,e){var r=t.split(/void\s+main\s*\(\s*(?:void)?\s*\)/g),t=r[0];let i=r[1];r=i.lastIndexOf("}");i=i.substring(0,r);let a="",n="";for(var s in e){var o=e[s];a=a+o.name+"();",n+=o.shader}return t=t+n+"void main()\n"+i+a+"}",console.log(t),t}}},{}],106:[function(t,e,r){function n(t,e,r={}){return e&&(t&&t.scene&&(t=t.scene),(Cesium.defaultValue(r.has3dtiles,!1)?i:s)(t,e,r))}function i(r,i,a={}){a.cartographic=a.cartographic||Cesium.Cartographic.fromCartesian(i);var t=a.cartographic;let n=a.callback;if(a.asyn)r.clampToHeightMostDetailed([i],a.objectsToExclude,.2).then(function(t){var e=t[0];if(Cesium.defined(e)){t=Cesium.Cartographic.fromCartesian(e),e=t.height;if(Cesium.defined(e)&&-1e3<e)return void(n&&n(e,t))}s(r,i,a)});else{var e=r.sampleHeight(t,a.objectsToExclude,.2);if(Cesium.defined(e)&&-1e3<e)return n&&n(e,t),e}return 0}function s(r,t,e={}){let i=e.cartographic||Cesium.Cartographic.fromCartesian(t),a=e.callback;if(!Boolean(r.terrainProvider._layers))return a&&a(i.height,i),i.height;if(e.asyn)return Cesium.when(Cesium.sampleTerrainMostDetailed(r.terrainProvider,[i]),function(t){t=t[0];let e;e=Cesium.defined(t)&&Cesium.defined(t.height)?t.height:r.globe.getHeight(i),a&&a(e,i)}),0;e=r.globe.getHeight(i);return e&&-1e3<e?(a&&a(e,i),e):i.height}e.exports={getSurfaceHeight:n,getSurface3DTilesHeight:i,getSurfaceTerrainHeight:s,getSurfacePosition:function(t,e,r={}){if(!e)return e;var i=Cesium.Cartographic.fromCartesian(e);let a=n(t,e,r);return 0!=a||Cesium.defined(r.maxHeight)&&a<=r.maxHeight?(r.relativeHeight&&(a+=i.height),Cesium.Cartesian3.fromRadians(i.longitude,i.latitude,a)):e}}},{}],107:[function(t,e,r){"use strict";e.exports=class{constructor(t,e){this.gl=t,this.queue=[],this.map={},this.intZoomMap={},this.intZoomCountMap={},this.size=2e3,!e&&0!=e||(this.size=e)}add(t,e,r,i){e=e+"_"+r+"_"+t;this.map[e]||(this.queue.length==this.size&&(r=this.queue.shift(),delete this.map[r.id],this.gl.deleteTexture(r.value),this.intZoomCountMap[r.key]=this.intZoomCountMap[r.key]-1,this.intZoomCountMap[r.key]||delete this.intZoomMap[r.key]),this.queue.push({id:e,key:t,value:i}),this.map[e]=i,this.intZoomMap[t]=i,i=this.intZoomCountMap[t],this.intZoomCountMap[t]=i?i+1:1)}getOne(t,e,r){t=e+"_"+r+"_"+t;return this.map[t]||null}get(t,e,r){r=e+"_"+r+"_"+t;return this.map[r]||this.intZoomMap[t]}remove(e){let r=[];for(let t=0;t<this.queue.length;t++){var i=this.queue[t];e==i.key&&(this.queue.splice(t,1),r.push(i))}for(let t=0;t<r.length;t++){var a=r[t];delete this.map[a.id],this.gl.deleteTexture(a.value)}this.intZoomCountMap[e]=0,delete this.intZoomMap[e]}setSize(t){this.size=t,this.empty()}empty(){for(let t=0;t<this.queue.length;t++){var e=this.queue[t];this.gl.deleteTexture(e.value)}for(var t in this.intZoomMap){t=this.intZoomMap[t];this.gl.deleteTexture(t)}this.queue=[],this.map={},this.intZoomMap={},this.intZoomCountMap={}}}},{}],108:[function(t,e,r){function o(){this.id=this.createUUID()}o.prototype.valueOf=function(){return this.id},o.prototype.toString=function(){return this.id},o.prototype.createUUID=function(){var t=new Date(1582,10,15,0,0,0,0),t=(new Date).getTime()-t.getTime();return o.getIntegerBits(t,0,31)+o.getIntegerBits(t,32,47)+(o.getIntegerBits(t,48,59)+"2")+o.getIntegerBits(o.rand(4095),0,7)+o.getIntegerBits(o.rand(4095),0,7)+(o.getIntegerBits(o.rand(8191),0,7)+o.getIntegerBits(o.rand(8191),8,15)+o.getIntegerBits(o.rand(8191),0,7)+o.getIntegerBits(o.rand(8191),8,15)+o.getIntegerBits(o.rand(8191),0,15))},o.getIntegerBits=function(t,e,r){for(var i=o.returnBase(t,16),a=new Array,n="",s=0,s=0;s<i.length;s++)a.push(i.substring(s,s+1));for(s=Math.floor(e/4);s<=Math.floor(r/4);s++)a[s]&&""!=a[s]?n+=a[s]:n+="0";return n},o.returnBase=function(t,e){var r,i=["0","1","2","3","4","5","6","7","8","9","A","B","C","D","E","F","G","H","I","J","K","L","M","N","O","P","Q","R","S","T","U","V","W","X","Y","Z"];return t<e?i[t]:(t=t-(r=""+Math.floor(t/e))*e,e<=r?this.returnBase(r,e)+i[t]:i[r]+i[t])},o.rand=function(t){return Math.floor(Math.random()*t)},e.exports=o},{}],109:[function(t,e,r){const n=t("./snappyJs"),d=t("./CodeTool"),u=t("./LayerContentModel"),l=t("./GisTools");e.exports=class{constructor(t,e,r){this.headerLength=e,this.proSizeObj=r,this.intLength=4,this.vectorName="vector",this.gTypeKey="gType",this.encoding="utf8",this.featureSpace="#@",this.vectorVarintBuffer=t,this.layerMap=new Object,this.vectorHeaderProMap=new Object,this.layerHeaderProMap=new Object,this.layerHeaderProBuffer=new Object,this.geometyTypeMap=new Object,this.featureMap=new Object,this.featureArrayMap=new Object,this.offsetBufferMap=new Object,this.offsetArrayMap=new Object,this.varintMap=new Object,this._parseVector(t)}getVectorHeaderProMap(){return this.vectorHeaderProMap}getLayerHeaderProMap(){return this.layerHeaderProMap}getLayerBuffer(t){return this.layerMap[t]}getLayerProByFilter(e,r){let i=[];var a,n,s=this.offsetArrayMap[e],o=this._lazyParseFeature(e);let l=[];this.proSizeObj[e];for(let t=0;t<r.length;t++)n=r[t],l.push(...o[n]),a=s[2*n],n=s[2*n+1],i.push(this.varintMap[e].slice(a,a+n));let t=new u;return t.setLayerHeaderProBuffer(this.layerHeaderProBuffer[e]),t.setFeatureArray(l),t.setCoordinateBufferArray(i),t}getAllLayerNames(){let t=[];for(var e in this.layerMap)t.push(e);return t}getGeometryType(t){return this.geometyTypeMap[t]}getLayerProByIndex(t,e){return this._lazyParseFeature(t)[e]}getLayerPro(t){return this._lazyParseFeature(t)}getOffsetArray(t){return this.offsetArrayMap[t]}getOffsetByIndex(t,e){t=this.offsetArrayMap[t];let r=[];return r.push(t[2*e]),r.push(t[2*e+1]),r}getLayerCoordinate(t){return this.varintMap[t]}getLayerFeature(t){return[this.featureMap[t],this.offsetArrayMap[t],this.varintMap[t]]}getAllCoordinates(t,e){var r,i,a=this.offsetArrayMap[t];let n=this.varintMap[t],s=[];for(let t=0;t<a.length/2;t++)r=a[2*t],i=a[2*t+1],i=n.slice(r,r+i),s.push(this._bufferToDoubleArray(i,e)[0]);return s}getCoordinatesByIndex(t,e,r){e=this.getOffsetByIndex(t,e);let i=this.varintMap[t];t=e[0],e=e[1],e=i.slice(t,t+e);return this._bufferToDoubleArray(e,r)[0]}_parseVector(t){var a=this.headerLength,e=t.readInt32BE(a);a+=this.intLength;var n=t.slice(a,a+e).toString("utf-8");if(a+=e,n===this.vectorName){n=this._parseHeaderPro(t,a),a=n[0];this.vectorHeaderProMap=n[1];n=t.readInt32BE(a);a+=this.intLength;let e=t.slice(a,a+n),r=t.slice(a+=n,this.vectorVarintBuffer.length);var s,o;let i=0;var l,u=0;for(let t=0;t<e.length;)u=t,o=e.readInt32BE(u),l=(u+=this.intLength)+o,s=e.toString(this.encoding,u,l),u=l,o=e.readInt32BE(u),u+=this.intLength,l=r.slice(i,i+o),i+=o,this.layerMap[s]=l,this._parseLayer(s,l),t=u}else console.error("不是瓦片数据!")}_parseLayer(t,e){var r,i,a;0!==e.length&&(a=this.headerLength,a=(r=this._parseHeaderPro(e,a))[0],this.layerHeaderProMap[t]=r[1],this.layerHeaderProBuffer[t]=r[2],i=this.layerHeaderProMap[t][this.gTypeKey],this.geometyTypeMap[t]=i,r=e.readInt32BE(a),a+=this.intLength,i=e.slice(a,a+r),i=n(i),a+=r,this.featureMap[t]=i,a=(i=this._parseIndex(e,a)).offset,this.offsetBufferMap[t]=i.buffer,this.offsetArrayMap[t]=i.array,a=e.slice(a),this.varintMap[t]=a)}_parseHeaderPro(t,e){let r=new Object;var i=t.readInt32BE(e);e+=this.intLength;t=t.slice(e,e+i);if(e+=i,0==i)return[e,r];var a=l.Utf8ArrayToStr(n(t)).split(":");for(let t=0;t<a.length/2;t++)r[a[2*t]]=a[2*t+1];return[e,r,t]}_parseIndex(t,e){var r=t.readInt32BE(e);e+=this.intLength;t=t.slice(e,e+r);return{offset:e+=r,buffer:t,array:d.varintToIntArray(t)}}_lazyParseFeature(t){let i=this.featureArrayMap[t];var a=this.proSizeObj[t];if(null==i){let e=[];if(!(0<this.featureMap[t].length))return this.featureArrayMap[t]=[],[];e=l.Utf8ArrayToStr(this.featureMap[t]).split(this.featureSpace);var n,s=(e.length-1)/a;i=[];let r=0;var o;r;for(let t=0;t<s;t++)o=r+a,n=e.slice(r,o),i.push(n),r=o;this.featureArrayMap[t]=i}return i}_bufferToDoubleArray(e,r){let i=[],a=[];var n;let s=0,o=[],l=0,u=0,h=!0;for(let t=0;t<=e.length;t++)0==(0|e[t]>>7&1)&&0<s&&(0<s&&s<=5?(h?(n=d.varintToInt(i)+l,a.push(n/r),h=!1,l=n):(n=d.varintToInt(i)+u,a.push(n/r),h=!0,u=n),s=0,i=[]):5<s&&(l=0,u=0,s=0,i=[],o.push(a),a=[])),t!==e.length?(i.push(e[t]),s++):0<a.length&&o.push(a);return o}}},{"./CodeTool":98,"./GisTools":103,"./LayerContentModel":104,"./snappyJs":117}],110:[function(t,e,r){e.exports=class{constructor(){this.ingest={point:function(t){t=this.trim(t).split(this.regExes.spaces);return[{x:parseFloat(this.regExes.numeric.exec(t[0])[0]),y:parseFloat(this.regExes.numeric.exec(t[1])[0])}]},multipoint:function(t){for(var e=[],r=this.trim(t).split(this.regExes.comma),i=0;i<r.length;i+=1)e.push(this.ingest.point.apply(this,[r[i]]));return e},linestring:function(t){for(var e=this.ingest.multipoint.apply(this,[t]),r=[],i=0;i<e.length;i+=1)r=r.concat(e[i]);return r},multilinestring:function(t){var e,r,i=[],a=this.trim(t).split(this.regExes.doubleParenComma);for(1===a.length&&(a=this.trim(t).split(this.regExes.parenComma)),e=0;e<a.length;e+=1)r=this._stripWhitespaceAndParens(a[e]),i.push(this.ingest.linestring.apply(this,[r]));return i},polygon:function(t){for(var e,r,i,a=this.trim(t).split(this.regExes.parenComma),n=[],s=0;s<a.length;s+=1){for(i=this._stripWhitespaceAndParens(a[s]).split(this.regExes.comma),r=[],e=0;e<i.length;e+=1){var o,l=i[e].split(this.regExes.spaces);2===(l=2<l.length?l.filter(function(t){return""!=t}):l).length&&(o=l[0],l=l[1],r.push({x:parseFloat(o),y:parseFloat(l)}))}n.push(r)}return n},box:function(t){for(var e=this.ingest.multipoint.apply(this,[t]),r=[],i=0;i<e.length;i+=1)r=r.concat(e[i]);return r},multipolygon:function(t){for(var e,r=[],i=this.trim(t).split(this.regExes.doubleParenComma),a=0;a<i.length;a+=1)e=this._stripWhitespaceAndParens(i[a]),r.push(this.ingest.polygon.apply(this,[e]));return r}},this.regExes={typeStr:/^\s*(\w+)\s*\(\s*(.*)\s*\)\s*$/,spaces:/\s+|\+/,numeric:/-*\d+(\.*\d+)?/,comma:/\s*,\s*/,parenComma:/\)\s*,\s*\(/,coord:/-*\d+\.*\d+ -*\d+\.*\d+/,doubleParenComma:/\)\s*\)\s*,\s*\(\s*\(/,ogcTypes:/^(multi)?(point|line|polygon|box)?(string)?$/i,crudeJson:/^{.*"(type|coordinates|geometries|features)":.*}$/,collectionParse:/,(?=[a-zA-Z])/},this.components=void 0}read(t){t=this.regExes.typeStr.exec(t);return t&&(this.type=t[1].toLowerCase(),this.base=t[2],this.ingest[this.type]?this.components=this.ingest[this.type].apply(this,[this.base]):this.base=this.base.split(this.regExes.collectionParse)),this}readToPrimitives(t,e){(e=e||{}).asynchronous=e.asynchronous||!1,e.clampToGround=e.clampToGround||!1,e.fillColor=e.fillColor||"#ff0000",e.fillOpacity=e.fillOpacity||1,e.pixelSize=e.pixelSize||10,e.strokeColor=e.strokeColor||"#ff0000",e.strokeOpacity=e.strokeOpacity||1,e.lineWidth=e.lineWidth||2,e.outlineWidth=e.outlineWidth||0;let r=[t],i=this.regExes.typeStr.exec(t);i&&"geometrycollection"==i[1].toLowerCase()&&(r=i[2].split(this.regExes.collectionParse));let a=[],n=[],s=[];for(let t=0;t<r.length;t++){var o=this.regExes.typeStr.exec(r[t]);o&&(this.type=o[1].toLowerCase(),this.base=o[2],this.ingest[this.type]&&(this.components=this.ingest[this.type].apply(this,[this.base]))),a=a.concat(this.getPointInstances(e)),n=n.concat(this.getLineInstances(e)),s=s.concat(this.getPolygonInstances(e))}var l=this.getPointPrimitive(a,e),u=this.getLinePrimitive(n,e),t=this.getPolygonPrimitive(s,e);let h=[];return l&&h.push(l),u&&h.push(u),t&&h.push(t),h}getPointInstances(t){return"point"!=this.type?[]:this.components}getPointPrimitive(e,r){if(0==e.length)return null;let i=new Cesium.PointPrimitiveCollection;for(let t=0;t<e.length;t++)i.add({pixelSize:r.pixelSize,color:Cesium.Color.fromCssColorString(r.fillColor).withAlpha(r.fillOpacity),outlineColor:Cesium.Color.fromCssColorString(r.strokeColor).withAlpha(r.strokeOpacity),outlineWidth:r.outlineWidth,position:Cesium.Cartesian3.fromDegrees(e[t].x,e[t].y,0)});return i}getLineInstances(r){let i=[];if("linestring"==this.type&&i.push(this.createLine(this.components)),"multilinestring"==this.type)for(let t=0;t<this.components.length;t++)i.push(this.createLine(this.components[t]));let a=[];for(let e=0;e<i.length;e++){let t=null;t=r.clampToGround?new Cesium.GeometryInstance({geometry:new Cesium.GroundPolylineGeometry({positions:Cesium.Cartesian3.fromDegreesArray(i[e]),width:r.lineWidth}),attributes:{color:Cesium.ColorGeometryInstanceAttribute.fromColor(Cesium.Color.fromCssColorString(r.strokeColor).withAlpha(r.strokeOpacity))}}):new Cesium.GeometryInstance({geometry:new Cesium.PolylineGeometry({positions:Cesium.Cartesian3.fromDegreesArray(i[e]),width:r.lineWidth}),attributes:{color:Cesium.ColorGeometryInstanceAttribute.fromColor(Cesium.Color.fromCssColorString(r.strokeColor).withAlpha(r.strokeOpacity))}}),a.push(t)}return a}getLinePrimitive(t,e){if(0==t.length)return null;let r=null;return r=new(e.clampToGround?Cesium.GroundPolylinePrimitive:Cesium.Primitive)({asynchronous:e.asynchronous,geometryInstances:t,appearance:new Cesium.PolylineColorAppearance({flat:!0,translucent:!1})}),r}createLine(e){let r=[];for(let t=0;t<e.length;t++){var i=e[t];r.push(i.x),r.push(i.y)}return r}getPolygonInstances(r){let i=[];if("polygon"==this.type&&i.push(this.createPolygon(this.components)),"multipolygon"==this.type)for(let t=0;t<this.components.length;t++)i.push(this.createPolygon(this.components[t]));let a=[];for(let t=0;t<i.length;t++){var n=i[t],s=Cesium.Cartesian3.fromDegreesArray(n.pts);let e=[];for(let t=0;t<n.holes.length;t++)e.push({positions:Cesium.Cartesian3.fromDegreesArray(n.holes[t])});s=new Cesium.GeometryInstance({geometry:new Cesium.PolygonGeometry({polygonHierarchy:{positions:s,holes:e},vertexFormat:Cesium.PerInstanceColorAppearance.VERTEX_FORMAT,height:0}),attributes:{color:Cesium.ColorGeometryInstanceAttribute.fromColor(Cesium.Color.fromCssColorString(r.fillColor).withAlpha(r.fillOpacity))}});a.push(s)}return a}getPolygonPrimitive(t,e){if(0==t.length)return null;let r=null;return r=new(e.clampToGround?Cesium.GroundPrimitive:Cesium.Primitive)({asynchronous:e.asynchronous,geometryInstances:t,appearance:new Cesium.PerInstanceColorAppearance({translucent:!1,closed:!0})}),r}createPolygon(e){let r=[],i=[];var t={pts:r,holes:i};for(let t=0;t<e.length;t++){var a=e[t];if(0==t)for(let t=0;t<a.length;t++){var n=a[t];r.push(n.x),r.push(n.y)}else{let e=[];for(let t=0;t<a.length;t++){var s=a[t];e.push(s.x),e.push(s.y)}i.push(e)}}return t}beginsWith(t,e){return t.substring(0,e.length)===e}endsWith(t,e){return t.substring(t.length-e.length)===e}trim(t,e){for(e=e||" ";this.beginsWith(t,e);)t=t.substring(1);for(;this.endsWith(t,e);)t=t.substring(0,t.length-1);return t}_stripWhitespaceAndParens(t){return t.trim().replace(/^\(?(.*?)\)?$/,"$1")}}},{}],111:[function(t,e,r){const o=t("./jx");function a(r,i,a,n){var t,e=a.type.toUpperCase();"GET"==e&&(t=o.get(a.url)),"POST"==e&&(t=o.post(a.url,a.data));var s=!1;return setTimeout(function(){(300<=t.request.status||t.request.status<200)&&(s=!0,t.request.abort(),console.warn("timeout: "+a.url),i({param:a,data:"getParamJSON: "+a.url+" timeout "}))},3e4),t.success(function(t,e){s||("json"==a.dataType&&"string"==typeof t&&(t=JSON.parse(t)),r(n?{param:a,data:t}:t))}),t.error(function(t,e){s||i({param:a,data:"getParamJSON: "+a.url+" failed with status: "+e.status})}),t.request}e.exports={Deferred:function(){this.promise=new Promise(function(t,e){this.resolve=t,this.reject=e}.bind(this)),this.then=this.promise.then.bind(this.promise),this.catch=this.promise.catch.bind(this.promise)},getJSON:function(r){return r.type||(r.type="GET"),r.dataType||(r.dataType="json"),new Promise(function(t,e){a(t,e,r)})},getParamJSON:function(r){var i;r.type||(r.type="GET"),r.dataType||(r.dataType="json");var t=new Promise(function(t,e){i=a(t,e,r,!0)});return t.xhr=i,t}}},{"./jx":116}],112:[function(t,e,r){class v{static pointDistToLine(t,e,r,i,a,n){var s=((t-r)*(a-r)+(e-i)*(n-i))/((r-a)*(r-a)+(i-n)*(i-n)),r=r+s*(a-r),i=i+s*(n-i);return Math.sqrt((t-r)*(t-r)+(e-i)*(e-i))}static isPointOnSegment(t,e,r,i,a,n){return!(r<t-5&&a<t+5||t+5<r&&t-5<a)&&!(i<e-5&&n<e+5||e+5<i&&e-5<n)&&v.pointDistToLine(t,e,r,i,a,n)<5?1:0}static pointInLine(t,e,r){let i=[];Array.isArray(r[0])?i=r:i.push(r);for(var a=0;a<i.length;a++)for(var n=i[a],s=n.length/2,o=0;o<s-1;o++){var l=o+1,u=n[2*o],h=n[2*o+1],d=n[2*l],l=n[2*l+1];if(1==v.isPointOnSegment(t,e,u,h,d,l))return 1}return 0}static pointInPolygon(t,e,r){let i=0,a=[];Array.isArray(r[0])?a=r:a.push(r);for(var n=0;n<a.length;n++)for(var s=a[n],o=0,l=s.length/2,u=l-1;o<l;u=o,o++){var h=s[2*o],d=s[2*o+1],f=s[2*u],m=s[2*u+1];if(h===t&&d===e||f===t&&m===e)return 1;if(d<e&&e<=m||e<=d&&m<e){d=h+(e-d)*(f-h)/(m-d);if(d===t)return 1;t<d&&(i=!i)}}return i?1:0}static lineIntersects(t,e,r,i,a,n,s,o){var l=[null,null],u=(o-n)*(r-t)-(s-a)*(i-e);return 0==u?null!==l[0]&&null!==l[1]&&l:(a=(s-a)*(s=e-n)-(o-n)*(n=t-a),n=((r-t)*s-(i-e)*n)/u,l[0]=t+(s=a/u)*(r-t),l[1]=e+s*(i-e),0<n&&n<1&&l)}static polyWith(e,r){var i=e.length/2,a=r.length/2;let n,s,o,l,u,h,d,f;for(let t=0;t<i;t++){n=t!=i-1?(s=e[2*t],o=e[2*t+1],l=e[2*t+2],e[2*t+3]):(s=e[2*t],o=e[2*t+1],l=e[0],e[1]);for(let t=0;t<a;t++)if(u=t!=a-1?(h=r[2*t],d=r[2*t+1],f=r[2*t+2],r[2*t+3]):(h=r[2*t],d=r[2*t+1],f=r[0],r[1]),0!=v.lineIntersects(s,o,l,n,h,d,f,u))return 1}var t=r[0],m=r[1];return v.pointInPolygon(t,m,e)?2:3}static boxToPolyArr(t,e,r,i){let a=[];return a.push(t),a.push(e),a.push(t),a.push(i),a.push(r),a.push(i),a.push(r),a.push(e),a.push(t),a.push(e),a}static getExtensionPoint(e,r,i){var a=r[0]-e[0],e=r[1]-e[1];let n=r[0],s=r[1];if(0==a)s=0<e?r[1]+i:r[1]-i;else{let t=Math.sqrt(i*i/(e/a*(e/a)+1));a<0&&(t=-t),n=r[0]+t,s=r[1]+e/a*t}return[n,s]}static lineOffset(a,t){let n=[],s=[];return a.forEach(function(r,i){if(i!==a.length-1){let e=v.processSegment(r,a[i+1],t);if(n.push(e),0<i){let t=n[i-1];r=v.lineIntersects(e[0][0],e[0][1],e[1][0],e[1][1],t[0][0],t[0][1],t[1][0],t[1][1]);!1!==r&&(t[1]=r,e[0]=r),s.push(t[0]),i===a.length-2&&(s.push(e[0]),s.push(e[1]))}2===a.length&&(s.push(e[0]),s.push(e[1]))}}),s}static processSegment(t,e,r){var i=t[0],a=e[0],n=Math.sqrt((i[0]-a[0])*(i[0]-a[0])+(i[1]-a[1])*(i[1]-a[1])),s=i[0]+r*(a[1]-i[1])/n,o=a[0]+r*(a[1]-i[1])/n,l=i[1]+r*(i[0]-a[0])/n,n=a[1]+r*(i[0]-a[0])/n;return[[[s,l],t[1]],[[o,n],e[1]]]}static isInBox(t,e){return t[0]>=e[0]&&t[1]>=e[1]&&t[2]<=e[2]&&t[3]<=e[3]}}e.exports=v},{}],113:[function(t,e,r){e.exports=class{constructor(t,e,r,i){var a=t/e,e=r/e;this.maxPerCell=null==i?1:i,this.cells={},this.d=a+2*e,this.n=a,this.padding=e,this.scale=a/t;a=e/a*t;this.min=-a,this.max=t+a}filter(t,e){if(t<this.min||t>this.max||e<this.min||e>this.max)return!1;t=this.convertToCellCoord(t),e=this.convertToCellCoord(e),e=this.d*e+t;if(this.cells[e]>=this.maxPerCell)return!1;t=this.cells[e];return this.cells[e]=null==t?1:+t,!0}filterByBox(t){var r=this.convertToCellCoord(t[0]),i=this.convertToCellCoord(t[2]),a=this.convertToCellCoord(t[1]),n=this.convertToCellCoord(t[3]);for(let e=r;e<=i;e++)for(let t=a;t<=n;t++){var s=this.d*t+e;if(this.cells[s])return!1}for(let e=r;e<=i;e++)for(let t=a;t<=n;t++){var o=this.d*t+e;this.cells[o]=1}return!0}clean(){this.cells={},this.saveCount=0}convertToCellCoord(t){return Math.max(0,Math.min(this.d-1,Math.floor(t*this.scale)+this.padding))}}},{}],114:[function(t,e,r){e.exports={read:function(t,e,r,i,a){var n,s,o=8*a-i-1,l=(1<<o)-1,u=l>>1,h=-7,d=r?a-1:0,f=r?-1:1,r=t[e+d];for(d+=f,n=r&(1<<-h)-1,r>>=-h,h+=o;0<h;n=256*n+t[e+d],d+=f,h-=8);for(s=n&(1<<-h)-1,n>>=-h,h+=i;0<h;s=256*s+t[e+d],d+=f,h-=8);if(0===n)n=1-u;else{if(n===l)return s?NaN:1/0*(r?-1:1);s+=Math.pow(2,i),n-=u}return(r?-1:1)*s*Math.pow(2,n-i)},write:function(t,e,r,i,a,n){var s,o,l=8*n-a-1,u=(1<<l)-1,h=u>>1,d=23===a?Math.pow(2,-24)-Math.pow(2,-77):0,f=i?0:n-1,m=i?1:-1,n=e<0||0===e&&1/e<0?1:0;for(e=Math.abs(e),isNaN(e)||e===1/0?(o=isNaN(e)?1:0,s=u):(s=Math.floor(Math.log(e)/Math.LN2),e*(i=Math.pow(2,-s))<1&&(s--,i*=2),2<=(e+=1<=s+h?d/i:d*Math.pow(2,1-h))*i&&(s++,i/=2),u<=s+h?(o=0,s=u):1<=s+h?(o=(e*i-1)*Math.pow(2,a),s+=h):(o=e*Math.pow(2,h-1)*Math.pow(2,a),s=0));8<=a;t[r+f]=255&o,f+=m,o/=256,a-=8);for(s=s<<a|o,l+=a;0<l;t[r+f]=255&s,f+=m,s/=256,l-=8);t[r+f-m]|=128*n}}},{}],115:[function(t,e,r){var i={}.toString;e.exports=Array.isArray||function(t){return"[object Array]"==i.call(t)}},{}],116:[function(u,i,a){!function(r){!function(){var t,e;t=function(){return function i(a,n,s){function o(r,t){if(!n[r]){if(!a[r]){var e="function"==typeof u&&u;if(!t&&e)return e(r,!0);if(l)return l(r,!0);e=new Error("Cannot find module '"+r+"'");throw e.code="MODULE_NOT_FOUND",e}e=n[r]={exports:{}};a[r][0].call(e.exports,function(t){var e=a[r][1][t];return o(e||t)},e,e.exports,i,a,n,s)}return n[r].exports}for(var l="function"==typeof u&&u,t=0;t<s.length;t++)o(s[t]);return o}({1:[function(t,e,r){function u(t,e,r){t.setRequestHeader(e,r)}function h(){}var d=!1,f=!1;function i(t,e,r,i){var a,n={success:h,error:h};d||((a=navigator.appVersion.split(";"))[1]&&(o=a[1].replace(/[ ]/g,""),f="MSIE9.0"==o),d=!0);var s,o="POST"===e||"PATCH"===e||"DELETE"===e;(s=f?new XDomainRequest:window.XMLHttpRequest?new XMLHttpRequest:new ActiveXObject("Microsoft.XMLHTTP")).open(e,t,!0),f||(r?(u(s,"Content-Type","application/json"),u(s,"Accept","application/json")):u(s,"Content-Type","application/x-www-form-urlencoded; charset=UTF-8")),o&&r&&(i=JSON.stringify(i)),s.onreadystatechange=function(){4===s.readyState&&(200<=s.status&&s.status<300?n.success:n.error).call(s,s.responseText,s)},s.onerror=function(){n.error.call(s,s.responseText,s)},s.onload=function(){n.success.call(s,s.responseText,s)},o?s.send(i):s.send();var l={success:function(t){return n.success=t,l},error:function(t){return n.error=t,l},request:s};return l}e.exports={get:function(t){return i(t,"GET",!1,null)},post:function(t,e){return i(t,"POST",!1,e)},patch:function(t,e){return i(t,"PATCH",!1,e)},delete:function(t){return i(t,"DELETE",!1,null)},json:{get:function(t){return i(t,"GET",!0,null)},post:function(t,e){return i(t,"POST",!0,e)},patch:function(t,e){return i(t,"PATCH",!0,e)}}}},{}]},{},[1])(1)},"object"==typeof a&&void 0!==i?i.exports=t():("undefined"!=typeof window?e=window:void 0!==r?e=r:"undefined"!=typeof self&&(e=self),e.jx=t())}.call(this)}.call(this,"undefined"!=typeof global?global:"undefined"!=typeof self?self:"undefined"!=typeof window?window:{})},{}],117:[function(t,e,r){!function(t,h){!function(){"use strict";var u=[0,255,65535,16777215,4294967295];function n(t){this.array=t,this.pos=0}function s(){return"object"==typeof t&&"object"==typeof t.versions&&void 0!==t.versions.node}function o(t){return t instanceof Uint8Array&&(!s()||!h.isBuffer(t))}function l(t){return t instanceof ArrayBuffer}n.prototype.readUncompressedLength=function(){for(var t,e,r=0,i=0;i<32&&this.pos<this.array.length;){if(t=this.array[this.pos],this.pos+=1,(e=127&t)<<i>>>i!=e)return-1;if(r|=e<<i,t<128)return r;i+=7}return-1},n.prototype.uncompressToBuffer=function(t){for(var e,r,i,a,n=this.array,s=n.length,o=this.pos,l=0;o<n.length;)if(e=n[o],o+=1,0==(3&e)){if(60<(r=1+(e>>>2))){if(s<=o+3)return!1;i=r-60,r=1+((r=n[o]+(n[o+1]<<8)+(n[o+2]<<16)+(n[o+3]<<24))&u[i]),o+=i}if(s<o+r)return!1;!function(t,e,r,i,a){for(var n=0;n<a;n++)r[i+n]=t[e+n]}(n,o,t,l,r),o+=r,l+=r}else{switch(3&e){case 1:r=4+(e>>>2&7),a=n[o]+(e>>>5<<8),o+=1;break;case 2:if(s<=o+1)return!1;r=1+(e>>>2),a=n[o]+(n[o+1]<<8),o+=2;break;case 3:if(s<=o+3)return!1;r=1+(e>>>2),a=n[o]+(n[o+1]<<8)+(n[o+2]<<16)+(n[o+3]<<24),o+=4}if(0===a||l<a)return!1;!function(t,e,r,i){for(var a=0;a<i;a++)t[e+a]=t[e-r+a]}(t,l,a,r),l+=r}return!0};e.exports=function(t){if(!(o(t)||l(t)||(a=t,s()&&h.isBuffer(a))))throw new TypeError("Argument compressed must be type of ArrayBuffer, Buffer, or Uint8Array");var e=!1,r=!1;o(t)?e=!0:l(t)&&(r=!0,t=new Uint8Array(t));var i,a=new n(t);if(-1===(t=a.readUncompressedLength()))throw new Error("Invalid Snappy bitstream");if(e){if(i=new Uint8Array(t),!a.uncompressToBuffer(i))throw new Error("Invalid Snappy bitstream")}else if(r){if(i=new ArrayBuffer(t),r=new Uint8Array(i),!a.uncompressToBuffer(r))throw new Error("Invalid Snappy bitstream")}else if(i=h.alloc(t),!a.uncompressToBuffer(i))throw new Error("Invalid Snappy bitstream");return i}}.call(this)}.call(this,t("_process"),t("buffer").Buffer)},{_process:4,buffer:2}]},{},[25])(25)});