mars3d-wind 3.11.2 → 3.11.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/mars3d-wind.js +3 -3
- package/package.json +2 -2
package/mars3d-wind.js
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* Mars3D平台插件,支持气象 风向图 功能插件 mars3d-wind
|
|
3
3
|
*
|
|
4
|
-
* 版本信息:v3.11.
|
|
5
|
-
* 编译日期:2026-
|
|
4
|
+
* 版本信息:v3.11.3
|
|
5
|
+
* 编译日期:2026-05-13 11:57
|
|
6
6
|
* 版权所有:Copyright by http://mars3d.cn
|
|
7
7
|
* 使用单位:免费公开版 ,2026-02-01
|
|
8
8
|
*/
|
|
@@ -11,5 +11,5 @@
|
|
|
11
11
|
typeof define === 'function' && define.amd ? define(['exports', 'mars3d'], factory) :
|
|
12
12
|
(global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory(global["mars3d-wind"] = {}, global.mars3d));
|
|
13
13
|
})(this, (function (exports, mars3d) {
|
|
14
|
-
'use strict';(function(_0x4db8e9,_0x622875){const _0x36bc73=_0x4db8e9();function _0x1927a2(_0x80b20e,_0xd5864e){return _0x34ed(_0xd5864e-0x296,_0x80b20e);}function _0x4ac8f3(_0x1d8c1d,_0x2bfbf7){return _0x34ed(_0x1d8c1d- -0x2bd,_0x2bfbf7);}while(!![]){try{const _0x5e9345=parseInt(_0x1927a2(0x42d,0x489))/0x1*(-parseInt(_0x1927a2(0x4e0,0x482))/0x2)+-parseInt(_0x4ac8f3(-0x69,-0x2))/0x3+parseInt(_0x4ac8f3(-0x2,-0x65))/0x4*(-parseInt(_0x1927a2(0x491,0x491))/0x5)+parseInt(_0x1927a2(0x512,0x48a))/0x6+parseInt(_0x1927a2(0x491,0x4a6))/0x7+-parseInt(_0x4ac8f3(-0x67,-0x3f))/0x8*(parseInt(_0x4ac8f3(-0x5e,-0x3d))/0x9)+parseInt(_0x4ac8f3(-0x98,-0xd6))/0xa;if(_0x5e9345===_0x622875)break;else _0x36bc73['push'](_0x36bc73['shift']());}catch(_0x4203be){_0x36bc73['push'](_0x36bc73['shift']());}}}(_0x55d3,0x74d76));function _interopNamespace(_0x2eed67){if(_0x2eed67&&_0x2eed67[_0x1b255f(0x3a2,0x35a)])return _0x2eed67;var _0x2839a3=Object['create'](null);_0x2eed67&&Object[_0x1b255f(0x30e,0x327)](_0x2eed67)[_0x1b255f(0x293,0x28b)](function(_0x362c9c){function _0x3e58b5(_0x539b5b,_0xdb1a3d){return _0x1b255f(_0xdb1a3d,_0x539b5b-0x22d);}if(_0x362c9c!==_0x3e58b5(0x4e7,0x523)){var _0x49d022=Object['getOwnPropertyDescriptor'](_0x2eed67,_0x362c9c);Object['defineProperty'](_0x2839a3,_0x362c9c,_0x49d022['get']?_0x49d022:{'enumerable':!![],'get':function(){return _0x2eed67[_0x362c9c];}});}});_0x2839a3[_0x4668bb(0x58f,0x59c)]=_0x2eed67;function _0x1b255f(_0x57c468,_0x210260){return _0x34ed(_0x210260-0xa2,_0x57c468);}function _0x4668bb(_0x42119b,_0x40233b){return _0x34ed(_0x40233b-0x384,_0x42119b);}return _0x2839a3;}var mars3d__namespace=_interopNamespace(mars3d);const Cesium$2=mars3d__namespace['Cesium'];function getU(_0x59525a,_0x599916){function _0x402c2b(_0x2fdff2,_0x34cbd8){return _0x34ed(_0x34cbd8- -0x99,_0x2fdff2);}const _0x4b06ed=_0x59525a*Math['cos'](Cesium$2['Math'][_0x402c2b(0x1eb,0x1e3)](_0x599916));return _0x4b06ed;}function getV(_0x572f4d,_0x120021){const _0x1548f2=_0x572f4d*Math['sin'](Cesium$2[_0x4c535a(0x2cc,0x31f)]['toRadians'](_0x120021));function _0x4c535a(_0x12c768,_0x321062){return _0x34ed(_0x321062-0xcd,_0x12c768);}return _0x1548f2;}function getSpeed(_0x24da37,_0x4a80c7){const _0x5d1981=Math['sqrt'](Math['pow'](_0x24da37,0x2)+Math['pow'](_0x4a80c7,0x2));return _0x5d1981;}function getDirection(_0x56e068,_0x55bb35){function _0x5866cd(_0x1e4aaa,_0x478954){return _0x34ed(_0x478954-0x357,_0x1e4aaa);}let _0x43596c=Cesium$2[_0x5866cd(0x54a,0x5a9)]['toDegrees'](Math['atan2'](_0x55bb35,_0x56e068));return _0x43596c+=_0x43596c<0x0?0x168:0x0,_0x43596c;}const _0x60ab1b={};_0x60ab1b[_0x27febc(0x1a,-0x6c)]=null,_0x60ab1b[_0x27febc(-0x8e,-0xed)]=getU,_0x60ab1b['getV']=getV,_0x60ab1b['getSpeed']=getSpeed,_0x60ab1b['getDirection']=getDirection;function _0x27febc(_0x198352,_0x3b426f){return _0x34ed(_0x198352- -0x295,_0x3b426f);}var WindUtil=_0x60ab1b;const version=_0x27febc(-0x9d,-0x50),buildTime='2026-04-08\x2016:11';var updatePositionShader='#version\x20300\x20es\x0aprecision\x20highp\x20float;\x0a\x0auniform\x20sampler2D\x20currentParticlesPosition;\x0auniform\x20sampler2D\x20particlesSpeed;\x0a\x0ain\x20vec2\x20v_textureCoordinates;\x0a\x0aout\x20vec4\x20fragColor;\x0a\x0avoid\x20main()\x20{\x0a\x20\x20\x20\x20//\x20获取当前粒子的位置\x0a\x20\x20vec2\x20currentPos\x20=\x20texture(currentParticlesPosition,\x20v_textureCoordinates).rg;\x0a\x20\x20\x20\x20//\x20获取粒子的速度\x0a\x20\x20vec2\x20speed\x20=\x20texture(particlesSpeed,\x20v_textureCoordinates).rg;\x0a\x20\x20\x20\x20//\x20计算下一个位置\x0a\x20\x20vec2\x20nextPos\x20=\x20currentPos\x20+\x20speed;\x0a\x0a\x20\x20\x20\x20//\x20将新的位置写入\x20fragColor\x0a\x20\x20fragColor\x20=\x20vec4(nextPos,\x200.0f,\x201.0f);\x0a}\x0a',calculateSpeedShader='#version\x20300\x20es\x0a\x0a//\x20the\x20size\x20of\x20UV\x20textures:\x20width\x20=\x20lon,\x20height\x20=\x20lat\x0auniform\x20sampler2D\x20U;\x20//\x20eastward\x20wind\x0auniform\x20sampler2D\x20V;\x20//\x20northward\x20wind\x0auniform\x20sampler2D\x20currentParticlesPosition;\x20//\x20(lon,\x20lat,\x20lev)\x0a\x0auniform\x20vec2\x20uRange;\x20//\x20(min,\x20max)\x0auniform\x20vec2\x20vRange;\x20//\x20(min,\x20max)\x0auniform\x20vec2\x20speedRange;\x20//\x20(min,\x20max)\x0auniform\x20vec2\x20dimension;\x20//\x20(lon,\x20lat)\x0auniform\x20vec2\x20minimum;\x20//\x20minimum\x20of\x20each\x20dimension\x0auniform\x20vec2\x20maximum;\x20//\x20maximum\x20of\x20each\x20dimension\x0a\x0auniform\x20float\x20speedScaleFactor;\x0auniform\x20float\x20frameRateAdjustment;\x0a\x0ain\x20vec2\x20v_textureCoordinates;\x0a\x0avec2\x20getInterval(vec2\x20maximum,\x20vec2\x20minimum,\x20vec2\x20dimension)\x20{\x0a\x20\x20return\x20(maximum\x20-\x20minimum)\x20/\x20(dimension\x20-\x201.0f);\x0a}\x0a\x0avec2\x20mapPositionToNormalizedIndex2D(vec2\x20lonLat)\x20{\x0a\x20\x20\x20\x20//\x20ensure\x20the\x20range\x20of\x20longitude\x20and\x20latitude\x0a\x20\x20lonLat.x\x20=\x20clamp(lonLat.x,\x20minimum.x,\x20maximum.x);\x0a\x20\x20lonLat.y\x20=\x20clamp(lonLat.y,\x20minimum.y,\x20maximum.y);\x0a\x0a\x20\x20vec2\x20interval\x20=\x20getInterval(maximum,\x20minimum,\x20dimension);\x0a\x0a\x20\x20vec2\x20index2D\x20=\x20vec2(0.0f);\x0a\x20\x20index2D.x\x20=\x20(lonLat.x\x20-\x20minimum.x)\x20/\x20interval.x;\x0a\x20\x20index2D.y\x20=\x20(lonLat.y\x20-\x20minimum.y)\x20/\x20interval.y;\x0a\x0a\x20\x20vec2\x20normalizedIndex2D\x20=\x20vec2(index2D.x\x20/\x20dimension.x,\x20index2D.y\x20/\x20dimension.y);\x0a\x20\x20return\x20normalizedIndex2D;\x0a}\x0a\x0afloat\x20getWindComponent(sampler2D\x20componentTexture,\x20vec2\x20lonLat)\x20{\x0a\x20\x20vec2\x20normalizedIndex2D\x20=\x20mapPositionToNormalizedIndex2D(lonLat);\x0a\x20\x20float\x20result\x20=\x20texture(componentTexture,\x20normalizedIndex2D).r;\x0a\x20\x20return\x20result;\x0a}\x0a\x0avec2\x20getWindComponents(vec2\x20lonLat)\x20{\x0a\x20\x20vec2\x20normalizedIndex2D\x20=\x20mapPositionToNormalizedIndex2D(lonLat);\x0a\x20\x20float\x20u\x20=\x20texture(U,\x20normalizedIndex2D).r;\x0a\x20\x20float\x20v\x20=\x20texture(V,\x20normalizedIndex2D).r;\x0a\x20\x20return\x20vec2(u,\x20v);\x0a}\x0a\x0avec2\x20bilinearInterpolation(vec2\x20lonLat)\x20{\x0a\x20\x20float\x20lon\x20=\x20lonLat.x;\x0a\x20\x20float\x20lat\x20=\x20lonLat.y;\x0a\x0a\x20\x20vec2\x20interval\x20=\x20getInterval(maximum,\x20minimum,\x20dimension);\x0a\x0a\x20\x20\x20\x20//\x20Calculate\x20grid\x20cell\x20coordinates\x0a\x20\x20float\x20lon0\x20=\x20floor(lon\x20/\x20interval.x)\x20*\x20interval.x;\x0a\x20\x20float\x20lon1\x20=\x20lon0\x20+\x20interval.x;\x0a\x20\x20float\x20lat0\x20=\x20floor(lat\x20/\x20interval.y)\x20*\x20interval.y;\x0a\x20\x20float\x20lat1\x20=\x20lat0\x20+\x20interval.y;\x0a\x0a\x20\x20\x20\x20//\x20Get\x20wind\x20vectors\x20at\x20four\x20corners\x0a\x20\x20vec2\x20v00\x20=\x20getWindComponents(vec2(lon0,\x20lat0));\x0a\x20\x20vec2\x20v10\x20=\x20getWindComponents(vec2(lon1,\x20lat0));\x0a\x20\x20vec2\x20v01\x20=\x20getWindComponents(vec2(lon0,\x20lat1));\x0a\x20\x20vec2\x20v11\x20=\x20getWindComponents(vec2(lon1,\x20lat1));\x0a\x0a\x20\x20\x20\x20//\x20Check\x20if\x20all\x20wind\x20vectors\x20are\x20zero\x0a\x20\x20if(length(v00)\x20==\x200.0f\x20&&\x20length(v10)\x20==\x200.0f\x20&&\x20length(v01)\x20==\x200.0f\x20&&\x20length(v11)\x20==\x200.0f)\x20{\x0a\x20\x20\x20\x20return\x20vec2(0.0f,\x200.0f);\x0a\x20\x20}\x0a\x0a\x20\x20\x20\x20//\x20Calculate\x20interpolation\x20weights\x0a\x20\x20float\x20s\x20=\x20(lon\x20-\x20lon0)\x20/\x20interval.x;\x0a\x20\x20float\x20t\x20=\x20(lat\x20-\x20lat0)\x20/\x20interval.y;\x0a\x0a\x20\x20\x20\x20//\x20Perform\x20bilinear\x20interpolation\x20on\x20vector\x20components\x0a\x20\x20vec2\x20v0\x20=\x20mix(v00,\x20v10,\x20s);\x0a\x20\x20vec2\x20v1\x20=\x20mix(v01,\x20v11,\x20s);\x0a\x20\x20return\x20mix(v0,\x20v1,\x20t);\x0a}\x0a\x0avec2\x20lengthOfLonLat(vec2\x20lonLat)\x20{\x0a\x20\x20\x20\x20//\x20unit\x20conversion:\x20meters\x20->\x20longitude\x20latitude\x20degrees\x0a\x20\x20\x20\x20//\x20see\x20https://en.wikipedia.org/wiki/Geographic_coordinate_system#Length_of_a_degree\x20for\x20detail\x0a\x0a\x20\x20\x20\x20//\x20Calculate\x20the\x20length\x20of\x20a\x20degree\x20of\x20latitude\x20and\x20longitude\x20in\x20meters\x0a\x20\x20float\x20latitude\x20=\x20radians(lonLat.y);\x0a\x0a\x20\x20float\x20term1\x20=\x20111132.92f;\x0a\x20\x20float\x20term2\x20=\x20559.82f\x20*\x20cos(2.0f\x20*\x20latitude);\x0a\x20\x20float\x20term3\x20=\x201.175f\x20*\x20cos(4.0f\x20*\x20latitude);\x0a\x20\x20float\x20term4\x20=\x200.0023f\x20*\x20cos(6.0f\x20*\x20latitude);\x0a\x20\x20float\x20latLength\x20=\x20term1\x20-\x20term2\x20+\x20term3\x20-\x20term4;\x0a\x0a\x20\x20float\x20term5\x20=\x20111412.84f\x20*\x20cos(latitude);\x0a\x20\x20float\x20term6\x20=\x2093.5f\x20*\x20cos(3.0f\x20*\x20latitude);\x0a\x20\x20float\x20term7\x20=\x200.118f\x20*\x20cos(5.0f\x20*\x20latitude);\x0a\x20\x20float\x20longLength\x20=\x20term5\x20-\x20term6\x20+\x20term7;\x0a\x0a\x20\x20return\x20vec2(longLength,\x20latLength);\x0a}\x0a\x0avec2\x20convertSpeedUnitToLonLat(vec2\x20lonLat,\x20vec2\x20speed)\x20{\x0a\x20\x20vec2\x20lonLatLength\x20=\x20lengthOfLonLat(lonLat);\x0a\x20\x20float\x20u\x20=\x20speed.x\x20/\x20lonLatLength.x;\x0a\x20\x20float\x20v\x20=\x20speed.y\x20/\x20lonLatLength.y;\x0a\x20\x20vec2\x20windVectorInLonLat\x20=\x20vec2(u,\x20v);\x0a\x0a\x20\x20return\x20windVectorInLonLat;\x0a}\x0a\x0avec2\x20calculateSpeedByRungeKutta2(vec2\x20lonLat)\x20{\x0a\x20\x20\x20\x20//\x20see\x20https://en.wikipedia.org/wiki/Runge%E2%80%93Kutta_methods#Second-order_methods_with_two_stages\x20for\x20detail\x0a\x20\x20const\x20float\x20h\x20=\x200.5f;\x0a\x0a\x20\x20vec2\x20y_n\x20=\x20lonLat;\x0a\x20\x20vec2\x20f_n\x20=\x20bilinearInterpolation(lonLat);\x0a\x20\x20vec2\x20midpoint\x20=\x20y_n\x20+\x200.5f\x20*\x20h\x20*\x20convertSpeedUnitToLonLat(y_n,\x20f_n)\x20*\x20speedScaleFactor;\x0a\x20\x20vec2\x20speed\x20=\x20h\x20*\x20bilinearInterpolation(midpoint)\x20*\x20speedScaleFactor;\x0a\x0a\x20\x20return\x20speed;\x0a}\x0a\x0avec2\x20calculateWindNorm(vec2\x20speed)\x20{\x0a\x20\x20float\x20speedLength\x20=\x20length(speed.xy);\x0a\x20\x20if(speedLength\x20==\x200.0f)\x20{\x0a\x20\x20\x20\x20return\x20vec2(0.0f);\x0a\x20\x20}\x0a\x0a\x20\x20\x20\x20//\x20Clamp\x20speedLength\x20to\x20range\x0a\x20\x20float\x20clampedSpeed\x20=\x20clamp(speedLength,\x20speedRange.x,\x20speedRange.y);\x0a\x20\x20float\x20normalizedSpeed\x20=\x20(clampedSpeed\x20-\x20speedRange.x)\x20/\x20(speedRange.y\x20-\x20speedRange.x);\x0a\x20\x20return\x20vec2(speedLength,\x20normalizedSpeed);\x0a}\x0a\x0aout\x20vec4\x20fragColor;\x0a\x0avoid\x20main()\x20{\x0a\x20\x20\x20\x20//\x20texture\x20coordinate\x20must\x20be\x20normalized\x0a\x20\x20vec2\x20lonLat\x20=\x20texture(currentParticlesPosition,\x20v_textureCoordinates).rg;\x0a\x20\x20vec2\x20speedOrigin\x20=\x20bilinearInterpolation(lonLat);\x0a\x20\x20vec2\x20speed\x20=\x20calculateSpeedByRungeKutta2(lonLat)\x20*\x20frameRateAdjustment;\x0a\x20\x20vec2\x20speedInLonLat\x20=\x20convertSpeedUnitToLonLat(lonLat,\x20speed);\x0a\x0a\x20\x20fragColor\x20=\x20vec4(speedInLonLat,\x20calculateWindNorm(speedOrigin));\x0a}\x0a',postProcessingPositionFragmentShader='#version\x20300\x20es\x0aprecision\x20highp\x20float;\x0a\x0auniform\x20sampler2D\x20nextParticlesPosition;\x0auniform\x20sampler2D\x20particlesSpeed;\x20//\x20(u,\x20v,\x20norm)\x0a\x0a//\x20range\x20(min,\x20max)\x0auniform\x20vec2\x20lonRange;\x0auniform\x20vec2\x20latRange;\x0a\x0a//\x20range\x20(min,\x20max)\x0auniform\x20vec2\x20dataLonRange;\x0auniform\x20vec2\x20dataLatRange;\x0a\x0auniform\x20float\x20randomCoefficient;\x0auniform\x20float\x20dropRate;\x0auniform\x20float\x20dropRateBump;\x0a\x0a//\x20添加新的\x20uniform\x20变量\x0auniform\x20bool\x20useViewerBounds;\x0a\x0ain\x20vec2\x20v_textureCoordinates;\x0a\x0a//\x20pseudo-random\x20generator\x0aconst\x20vec3\x20randomConstants\x20=\x20vec3(12.9898f,\x2078.233f,\x204375.85453f);\x0aconst\x20vec2\x20normalRange\x20=\x20vec2(0.0f,\x201.0f);\x0afloat\x20rand(vec2\x20seed,\x20vec2\x20range)\x20{\x0a\x20\x20vec2\x20randomSeed\x20=\x20randomCoefficient\x20*\x20seed;\x0a\x20\x20float\x20temp\x20=\x20dot(randomConstants.xy,\x20randomSeed);\x0a\x20\x20temp\x20=\x20fract(sin(temp)\x20*\x20(randomConstants.z\x20+\x20temp));\x0a\x20\x20return\x20temp\x20*\x20(range.y\x20-\x20range.x)\x20+\x20range.x;\x0a}\x0a\x0avec2\x20generateRandomParticle(vec2\x20seed)\x20{\x0a\x20\x20vec2\x20range;\x0a\x20\x20float\x20randomLon,\x20randomLat;\x0a\x0a\x20\x20if(useViewerBounds)\x20{\x0a\x20\x20\x20\x20\x20\x20\x20\x20//\x20在当前视域范围内生成粒子\x0a\x20\x20\x20\x20randomLon\x20=\x20rand(seed,\x20lonRange);\x0a\x20\x20\x20\x20randomLat\x20=\x20rand(-seed,\x20latRange);\x0a\x20\x20}\x20else\x20{\x0a\x20\x20\x20\x20\x20\x20\x20\x20//\x20在数据范围内生成粒子\x0a\x20\x20\x20\x20randomLon\x20=\x20rand(seed,\x20dataLonRange);\x0a\x20\x20\x20\x20randomLat\x20=\x20rand(-seed,\x20dataLatRange);\x0a\x20\x20}\x0a\x0a\x20\x20return\x20vec2(randomLon,\x20randomLat);\x0a}\x0a\x0abool\x20particleOutbound(vec2\x20particle)\x20{\x0a\x20\x20return\x20particle.y\x20<\x20dataLatRange.x\x20||\x20particle.y\x20>\x20dataLatRange.y\x20||\x20particle.x\x20<\x20dataLonRange.x\x20||\x20particle.x\x20>\x20dataLonRange.y;\x0a}\x0a\x0aout\x20vec4\x20fragColor;\x0a\x0avoid\x20main()\x20{\x0a\x20\x20vec2\x20nextParticle\x20=\x20texture(nextParticlesPosition,\x20v_textureCoordinates).rg;\x0a\x20\x20vec4\x20nextSpeed\x20=\x20texture(particlesSpeed,\x20v_textureCoordinates);\x0a\x20\x20float\x20speedNorm\x20=\x20nextSpeed.a;\x0a\x20\x20float\x20particleDropRate\x20=\x20dropRate\x20+\x20dropRateBump\x20*\x20speedNorm;\x0a\x0a\x20\x20vec2\x20seed1\x20=\x20nextParticle.xy\x20+\x20v_textureCoordinates;\x0a\x20\x20vec2\x20seed2\x20=\x20nextSpeed.rg\x20+\x20v_textureCoordinates;\x0a\x20\x20vec2\x20randomParticle\x20=\x20generateRandomParticle(seed1);\x0a\x20\x20float\x20randomNumber\x20=\x20rand(seed2,\x20normalRange);\x0a\x0a\x20\x20if(randomNumber\x20<\x20particleDropRate\x20||\x20particleOutbound(nextParticle))\x20{\x0a\x20\x20\x20\x20fragColor\x20=\x20vec4(randomParticle,\x200.0f,\x201.0f);\x20//\x201.0\x20means\x20this\x20is\x20a\x20random\x20particle\x0a\x20\x20}\x20else\x20{\x0a\x20\x20\x20\x20fragColor\x20=\x20vec4(nextParticle,\x200.0f,\x200.0f);\x0a\x20\x20}\x0a}\x0a',renderParticlesFragmentShader=_0x27febc(-0xbc,-0x5a),renderParticlesVertexShader='#version\x20300\x20es\x0aprecision\x20highp\x20float;\x0a\x0ain\x20vec2\x20st;\x0ain\x20vec3\x20normal;\x0a\x0auniform\x20sampler2D\x20previousParticlesPosition;\x0auniform\x20sampler2D\x20currentParticlesPosition;\x0auniform\x20sampler2D\x20postProcessingPosition;\x0auniform\x20sampler2D\x20particlesSpeed;\x0a\x0auniform\x20float\x20frameRateAdjustment;\x0auniform\x20float\x20particleHeight;\x0auniform\x20float\x20aspect;\x0auniform\x20float\x20pixelSize;\x0auniform\x20vec2\x20lineWidth;\x0auniform\x20vec2\x20lineLength;\x0auniform\x20vec2\x20domain;\x0auniform\x20bool\x20is3D;\x0a\x0a//\x20添加输出变量传递给片元着色器\x0aout\x20vec4\x20speed;\x0aout\x20float\x20v_segmentPosition;\x0aout\x20vec2\x20textureCoordinate;\x0a\x0a//\x20添加结构体定义\x0astruct\x20adjacentPoints\x20{\x0a\x20\x20vec4\x20previous;\x0a\x20\x20vec4\x20current;\x0a\x20\x20vec4\x20next;\x0a};\x0a\x0avec3\x20convertCoordinate(vec2\x20lonLat)\x20{\x0a\x20\x20\x20\x20//\x20WGS84\x20(lon,\x20lat,\x20lev)\x20->\x20ECEF\x20(x,\x20y,\x20z)\x0a\x20\x20\x20\x20//\x20read\x20https://en.wikipedia.org/wiki/Geographic_coordinate_conversion#From_geodetic_to_ECEF_coordinates\x20for\x20detail\x0a\x0a\x20\x20\x20\x20//\x20WGS\x2084\x20geometric\x20constants\x0a\x20\x20float\x20a\x20=\x206378137.0f;\x20//\x20Semi-major\x20axis\x0a\x20\x20float\x20b\x20=\x206356752.3142f;\x20//\x20Semi-minor\x20axis\x0a\x20\x20float\x20e2\x20=\x206.69437999014e-3f;\x20//\x20First\x20eccentricity\x20squared\x0a\x0a\x20\x20float\x20latitude\x20=\x20radians(lonLat.y);\x0a\x20\x20float\x20longitude\x20=\x20radians(lonLat.x);\x0a\x0a\x20\x20float\x20cosLat\x20=\x20cos(latitude);\x0a\x20\x20float\x20sinLat\x20=\x20sin(latitude);\x0a\x20\x20float\x20cosLon\x20=\x20cos(longitude);\x0a\x20\x20float\x20sinLon\x20=\x20sin(longitude);\x0a\x0a\x20\x20float\x20N_Phi\x20=\x20a\x20/\x20sqrt(1.0f\x20-\x20e2\x20*\x20sinLat\x20*\x20sinLat);\x0a\x20\x20float\x20h\x20=\x20particleHeight;\x20//\x20it\x20should\x20be\x20high\x20enough\x20otherwise\x20the\x20particle\x20may\x20not\x20pass\x20the\x20terrain\x20depth\x20test\x0a\x20\x20vec3\x20cartesian\x20=\x20vec3(0.0f);\x0a\x20\x20cartesian.x\x20=\x20(N_Phi\x20+\x20h)\x20*\x20cosLat\x20*\x20cosLon;\x0a\x20\x20cartesian.y\x20=\x20(N_Phi\x20+\x20h)\x20*\x20cosLat\x20*\x20sinLon;\x0a\x20\x20cartesian.z\x20=\x20((b\x20*\x20b)\x20/\x20(a\x20*\x20a)\x20*\x20N_Phi\x20+\x20h)\x20*\x20sinLat;\x0a\x20\x20return\x20cartesian;\x0a}\x0a\x0avec4\x20calculateProjectedCoordinate(vec2\x20lonLat)\x20{\x0a\x20\x20if(is3D)\x20{\x0a\x20\x20\x20\x20vec3\x20particlePosition\x20=\x20convertCoordinate(lonLat);\x0a\x20\x20\x20\x20\x20\x20\x20\x20//\x20使用\x20modelViewProjection\x20矩阵进行投影变换\x0a\x20\x20\x20\x20vec4\x20projectedPosition\x20=\x20czm_modelViewProjection\x20*\x20vec4(particlePosition,\x201.0f);\x0a\x20\x20\x20\x20return\x20projectedPosition;\x0a\x20\x20}\x20else\x20{\x0a\x20\x20\x20\x20vec3\x20position2D\x20=\x20vec3(radians(lonLat.x),\x20radians(lonLat.y),\x200.0f);\x0a\x20\x20\x20\x20return\x20czm_modelViewProjection\x20*\x20vec4(position2D,\x201.0f);\x0a\x20\x20}\x0a}\x0a\x0avec4\x20calculateOffsetOnNormalDirection(vec4\x20pointA,\x20vec4\x20pointB,\x20float\x20offsetSign,\x20float\x20widthFactor)\x20{\x0a\x20\x20vec2\x20aspectVec2\x20=\x20vec2(aspect,\x201.0f);\x0a\x20\x20vec2\x20pointA_XY\x20=\x20(pointA.xy\x20/\x20pointA.w)\x20*\x20aspectVec2;\x0a\x20\x20vec2\x20pointB_XY\x20=\x20(pointB.xy\x20/\x20pointB.w)\x20*\x20aspectVec2;\x0a\x0a\x20\x20\x20\x20//\x20计算方向向量\x0a\x20\x20vec2\x20direction\x20=\x20normalize(pointB_XY\x20-\x20pointA_XY);\x0a\x0a\x20\x20\x20\x20//\x20计算法向量\x0a\x20\x20vec2\x20normalVector\x20=\x20vec2(-direction.y,\x20direction.x);\x0a\x20\x20normalVector.x\x20=\x20normalVector.x\x20/\x20aspect;\x0a\x0a\x20\x20\x20\x20//\x20使用\x20widthFactor\x20调整宽度\x0a\x20\x20float\x20offsetLength\x20=\x20widthFactor\x20*\x20lineWidth.y;\x0a\x20\x20normalVector\x20=\x20offsetLength\x20*\x20normalVector;\x0a\x0a\x20\x20vec4\x20offset\x20=\x20vec4(offsetSign\x20*\x20normalVector,\x200.0f,\x200.0f);\x0a\x20\x20return\x20offset;\x0a}\x0a\x0avoid\x20main()\x20{\x0a\x20\x20\x20\x20//\x20翻转\x20Y\x20轴坐标\x0a\x20\x20vec2\x20flippedIndex\x20=\x20vec2(st.x,\x201.0f\x20-\x20st.y);\x0a\x0a\x20\x20vec2\x20particleIndex\x20=\x20flippedIndex;\x0a\x20\x20speed\x20=\x20texture(particlesSpeed,\x20particleIndex);\x0a\x0a\x20\x20vec2\x20previousPosition\x20=\x20texture(previousParticlesPosition,\x20particleIndex).rg;\x0a\x20\x20vec2\x20currentPosition\x20=\x20texture(currentParticlesPosition,\x20particleIndex).rg;\x0a\x20\x20vec2\x20nextPosition\x20=\x20texture(postProcessingPosition,\x20particleIndex).rg;\x0a\x0a\x20\x20float\x20isAnyRandomPointUsed\x20=\x20texture(postProcessingPosition,\x20particleIndex).a\x20+\x0a\x20\x20\x20\x20texture(currentParticlesPosition,\x20particleIndex).a\x20+\x0a\x20\x20\x20\x20texture(previousParticlesPosition,\x20particleIndex).a;\x0a\x0a\x20\x20adjacentPoints\x20projectedCoordinates;\x0a\x20\x20if(isAnyRandomPointUsed\x20>\x200.0f)\x20{\x0a\x20\x20\x20\x20projectedCoordinates.previous\x20=\x20calculateProjectedCoordinate(previousPosition);\x0a\x20\x20\x20\x20projectedCoordinates.current\x20=\x20projectedCoordinates.previous;\x0a\x20\x20\x20\x20projectedCoordinates.next\x20=\x20projectedCoordinates.previous;\x0a\x20\x20}\x20else\x20{\x0a\x20\x20\x20\x20projectedCoordinates.previous\x20=\x20calculateProjectedCoordinate(previousPosition);\x0a\x20\x20\x20\x20projectedCoordinates.current\x20=\x20calculateProjectedCoordinate(currentPosition);\x0a\x20\x20\x20\x20projectedCoordinates.next\x20=\x20calculateProjectedCoordinate(nextPosition);\x0a\x20\x20}\x0a\x0a\x20\x20int\x20pointToUse\x20=\x20int(normal.x);\x0a\x20\x20float\x20offsetSign\x20=\x20normal.y;\x0a\x20\x20vec4\x20offset\x20=\x20vec4(0.0f);\x0a\x0a\x20\x20\x20\x20//\x20计算速度相关的宽度和长度因子\x0a\x20\x20float\x20speedLength\x20=\x20clamp(speed.b,\x20domain.x,\x20domain.y);\x0a\x20\x20float\x20normalizedSpeed\x20=\x20(speedLength\x20-\x20domain.x)\x20/\x20(domain.y\x20-\x20domain.x);\x0a\x0a\x20\x20\x20\x20//\x20根据速度计算宽度\x0a\x20\x20float\x20widthFactor\x20=\x20mix(lineWidth.x,\x20lineWidth.y,\x20normalizedSpeed);\x0a\x20\x20widthFactor\x20*=\x20(pointToUse\x20<\x200\x20?\x201.0f\x20:\x200.5f);\x20//\x20头部更宽,尾部更窄\x0a\x0a\x20\x20\x20\x20//\x20Calculate\x20length\x20based\x20on\x20speed\x0a\x20\x20float\x20lengthFactor\x20=\x20mix(lineLength.x,\x20lineLength.y,\x20normalizedSpeed)\x20*\x20pixelSize;\x0a\x0a\x20\x20if(pointToUse\x20==\x201)\x20{\x0a\x20\x20\x20\x20\x20\x20\x20\x20//\x20头部位置\x0a\x20\x20\x20\x20offset\x20=\x20pixelSize\x20*\x20calculateOffsetOnNormalDirection(projectedCoordinates.previous,\x20projectedCoordinates.current,\x20offsetSign,\x20widthFactor);\x0a\x20\x20\x20\x20gl_Position\x20=\x20projectedCoordinates.previous\x20+\x20offset;\x0a\x20\x20\x20\x20v_segmentPosition\x20=\x200.0f;\x20//\x20头部\x0a\x20\x20}\x20else\x20if(pointToUse\x20==\x20-1)\x20{\x0a\x20\x20\x20\x20\x20\x20\x20\x20//\x20Get\x20direction\x20and\x20normalize\x20it\x20to\x20length\x201.0\x0a\x20\x20\x20\x20vec4\x20direction\x20=\x20normalize(projectedCoordinates.next\x20-\x20projectedCoordinates.current);\x0a\x20\x20\x20\x20vec4\x20extendedPosition\x20=\x20projectedCoordinates.current\x20+\x20direction\x20*\x20lengthFactor;\x0a\x0a\x20\x20\x20\x20offset\x20=\x20pixelSize\x20*\x20calculateOffsetOnNormalDirection(projectedCoordinates.current,\x20extendedPosition,\x20offsetSign,\x20widthFactor);\x0a\x20\x20\x20\x20gl_Position\x20=\x20extendedPosition\x20+\x20offset;\x0a\x20\x20\x20\x20v_segmentPosition\x20=\x201.0f;\x20//\x20尾部\x0a\x20\x20}\x0a\x0a\x20\x20textureCoordinate\x20=\x20st;\x0a}\x0a';const {ShaderSource:ShaderSource$1}=mars3d__namespace[_0x27febc(-0x7b,0xc)];class ShaderManager{static['getCalculateSpeedShader'](){const _0x3dc1c5={};return _0x3dc1c5['sources']=[calculateSpeedShader],new ShaderSource$1(_0x3dc1c5);}static['getUpdatePositionShader'](){const _0x16a733={};return _0x16a733['sources']=[updatePositionShader],new ShaderSource$1(_0x16a733);}static['getSegmentDrawVertexShader'](){function _0x5d5b33(_0x461bf7,_0x42d864){return _0x4445ca(_0x461bf7,_0x42d864- -0xef);}const _0x208715={};return _0x208715[_0x5d5b33(0x3fc,0x45f)]=[renderParticlesVertexShader],new ShaderSource$1(_0x208715);}static['getSegmentDrawFragmentShader'](){const _0x5ceef4={};return _0x5ceef4['sources']=[renderParticlesFragmentShader],new ShaderSource$1(_0x5ceef4);}static['getPostProcessingPositionShader'](){function _0x5cb7a3(_0x73efab,_0x14474e){return _0x27febc(_0x14474e- -0xa2,_0x73efab);}const _0x383c96={};return _0x383c96[_0x5cb7a3(-0xde,-0x114)]=[postProcessingPositionFragmentShader],new ShaderSource$1(_0x383c96);}}const {BufferUsage:BufferUsage$1,ClearCommand:ClearCommand$1,Color:Color$2,ComputeCommand,DrawCommand,Geometry:Geometry$1,Matrix4,Pass:Pass$1,PrimitiveType:PrimitiveType$1,RenderState,ShaderProgram,ShaderSource,VertexArray:VertexArray$1,defined,destroyObject}=mars3d__namespace[_0x4445ca(0x4c6,0x545)];class CustomPrimitive{constructor(_0x3f3413){this['commandType']=_0x3f3413['commandType'];function _0x45aa87(_0x2d228c,_0x4d88d5){return _0x4445ca(_0x2d228c,_0x4d88d5- -0x66e);}this['geometry']=_0x3f3413[_0x4cd839(0x17c,0x1ae)],this[_0x4cd839(0x21c,0x1b4)]=_0x3f3413[_0x45aa87(-0x10c,-0x11f)],this['primitiveType']=_0x3f3413[_0x45aa87(-0x1c5,-0x15d)],this['uniformMap']=_0x3f3413['uniformMap']||{},this[_0x4cd839(0x246,0x256)]=_0x3f3413[_0x4cd839(0x234,0x256)],this[_0x45aa87(-0xe0,-0xf6)]=_0x3f3413['fragmentShaderSource'],this['rawRenderState']=_0x3f3413[_0x45aa87(-0x3,-0x7f)],this[_0x45aa87(-0x7c,-0x6d)]=_0x3f3413['framebuffer'],this[_0x45aa87(-0xbc,-0xde)]=_0x3f3413[_0x45aa87(-0xde,-0xde)],this['autoClear']=_0x3f3413['autoClear']??![],this[_0x45aa87(-0x179,-0x136)]=_0x3f3413['preExecute'],this['show']=!![],this[_0x45aa87(-0x11b,-0xcf)]=undefined,this[_0x45aa87(-0x195,-0x16f)]=undefined,this[_0x4cd839(0x135,0x17e)]=_0x3f3413[_0x4cd839(0x162,0x17e)]??(()=>!![]);function _0x4cd839(_0x1c12f1,_0x20effd){return _0x4445ca(_0x1c12f1,_0x20effd- -0x39b);}this['autoClear']&&(this['clearCommand']=new ClearCommand$1({'color':new Color$2(0x0,0x0,0x0,0x0),'depth':0x1,'framebuffer':this['framebuffer'],'pass':Pass$1['OPAQUE']}));}['createCommand'](_0x10f39f){function _0x4bc518(_0x1866b8,_0x4e7f28){return _0x27febc(_0x4e7f28-0x429,_0x1866b8);}function _0x5e9f88(_0x17f0f3,_0x3261a8){return _0x27febc(_0x17f0f3-0x17f,_0x3261a8);}if(this['commandType']==='Draw'){const _0x374514={};_0x374514['context']=_0x10f39f,_0x374514[_0x5e9f88(0x108,0x176)]=this['geometry'],_0x374514['attributeLocations']=this['attributeLocations'],_0x374514['bufferUsage']=BufferUsage$1['STATIC_DRAW'];const _0x490c4e=VertexArray$1[_0x5e9f88(0x18b,0x165)](_0x374514),_0x2a3601={};_0x2a3601[_0x4bc518(0x4a7,0x429)]=_0x10f39f,_0x2a3601['vertexShaderSource']=this[_0x4bc518(0x3ec,0x45a)],_0x2a3601['fragmentShaderSource']=this[_0x5e9f88(0x137,0x175)],_0x2a3601[_0x5e9f88(0x10e,0xf7)]=this['attributeLocations'];const _0x3abbdf=ShaderProgram['fromCache'](_0x2a3601),_0x4e6014=RenderState[_0x5e9f88(0xbc,0xe3)](this['rawRenderState']),_0x10da6d={};return _0x10da6d[_0x5e9f88(0x159,0x138)]=this,_0x10da6d[_0x5e9f88(0xed,0x9e)]=_0x490c4e,_0x10da6d[_0x4bc518(0x34e,0x37a)]=this[_0x4bc518(0x3df,0x37a)],_0x10da6d['modelMatrix']=Matrix4['IDENTITY'],_0x10da6d['renderState']=_0x4e6014,_0x10da6d['shaderProgram']=_0x3abbdf,_0x10da6d['framebuffer']=this['framebuffer'],_0x10da6d['uniformMap']=this['uniformMap'],_0x10da6d['pass']=Pass$1[_0x5e9f88(0x18e,0x1b6)],new DrawCommand(_0x10da6d);}else{if(this['commandType']==='Compute'){const _0x5dda8e={};return _0x5dda8e[_0x5e9f88(0x159,0x108)]=this,_0x5dda8e['fragmentShaderSource']=this[_0x5e9f88(0x137,0x112)],_0x5dda8e[_0x5e9f88(0x190,0x138)]=this[_0x4bc518(0x47f,0x43a)],_0x5dda8e['outputTexture']=this['outputTexture'],_0x5dda8e[_0x4bc518(0x48a,0x400)]=!![],new ComputeCommand(_0x5dda8e);}else throw new Error(_0x4bc518(0x367,0x3c8));}}['setGeometry'](_0x21e9da,_0x398575){this[_0x2a1cb7(0x4bd,0x435)]=_0x398575;function _0x2a1cb7(_0x1ef2d1,_0x4284c7){return _0x27febc(_0x4284c7-0x4ac,_0x1ef2d1);}function _0x237a8f(_0x4de1c4,_0x45c3cf){return _0x4445ca(_0x4de1c4,_0x45c3cf- -0x539);}defined(this['commandToExecute'])&&(this['commandToExecute'][_0x2a1cb7(0x3f0,0x41a)]=VertexArray$1[_0x2a1cb7(0x4bc,0x4b8)]({'context':_0x21e9da,'geometry':this[_0x237a8f(-0x1c,0x10)],'attributeLocations':this[_0x2a1cb7(0x421,0x43b)],'bufferUsage':BufferUsage$1['STATIC_DRAW']}));}[_0x4445ca(0x528,0x55b)](_0x58ec54){function _0x57ee08(_0x319731,_0x1fc88d){return _0x4445ca(_0x319731,_0x1fc88d- -0x22b);}if(!this['isDynamic']())return;if(!this[_0x37579d(0x61d,0x69f)]||!defined(_0x58ec54))return;function _0x37579d(_0x553b35,_0x2a04df){return _0x4445ca(_0x2a04df,_0x553b35-0x1f);}!defined(this[_0x57ee08(0x314,0x374)])&&(this[_0x37579d(0x5be,0x5d6)]=this['createCommand'](_0x58ec54['context']));defined(this[_0x37579d(0x557,0x5ad)])&&this[_0x37579d(0x557,0x5e1)]();if(!_0x58ec54['commandList']){console['warn'](_0x37579d(0x554,0x4f3));return;}defined(this[_0x37579d(0x51e,0x572)])&&_0x58ec54[_0x57ee08(0x43f,0x3c5)]['push'](this['clearCommand']),defined(this['commandToExecute'])&&_0x58ec54['commandList']['push'](this[_0x57ee08(0x390,0x374)]);}['isDestroyed'](){return![];}['destroy'](){if(defined(this[_0x129430(0x572,0x519)])){var _0x70a61b;(_0x70a61b=this['commandToExecute'][_0x10247d(0x584,0x507)])===null||_0x70a61b===void 0x0||_0x70a61b[_0x129430(0x4a1,0x503)](),this[_0x10247d(0x577,0x571)]['shaderProgram']=undefined;}function _0x129430(_0x170c12,_0x281cab){return _0x4445ca(_0x170c12,_0x281cab- -0x86);}function _0x10247d(_0x2055de,_0x50b1c2){return _0x27febc(_0x2055de-0x598,_0x50b1c2);}return destroyObject(this);}}function deepMerge(_0x53361e,_0xc12b0e){if(!_0x53361e)return _0xc12b0e;if(!_0xc12b0e)return _0x53361e;function _0x426586(_0x189e64,_0x4b02e1){return _0x27febc(_0x4b02e1-0x5b9,_0x189e64);}const _0x5d9cab={..._0xc12b0e};function _0x355838(_0x2012ee,_0xa6ee25){return _0x4445ca(_0xa6ee25,_0x2012ee-0x8e);}const _0x1bc1ab=_0x5d9cab;for(const _0x524041 in _0x53361e){if(Object['prototype']['hasOwnProperty']['call'](_0x53361e,_0x524041)){const _0x102919=_0x53361e[_0x524041],_0x1cee42=_0xc12b0e[_0x524041];if(Array['isArray'](_0x102919)){_0x1bc1ab[_0x524041]=_0x102919[_0x355838(0x65e,0x61a)]();continue;}if(_0x102919&&typeof _0x102919===_0x426586(0x4b2,0x50c)){_0x1bc1ab[_0x524041]=deepMerge(_0x102919,_0x1cee42||{});continue;}_0x102919!==undefined&&(_0x1bc1ab[_0x524041]=_0x102919);}}return _0x1bc1ab;}const {Cartesian2:Cartesian2$1,FrameRateMonitor,PixelDatatype:PixelDatatype$1,PixelFormat:PixelFormat$1,Sampler:Sampler$1,Texture:Texture$1,TextureMagnificationFilter:TextureMagnificationFilter$1,TextureMinificationFilter:TextureMinificationFilter$1}=mars3d__namespace['Cesium'];class WindParticlesComputing{constructor(_0xf50c62,_0x16c741,_0x6bcb31,_0x393705,_0x2bd38f){this[_0xa11870(-0x6,0x17)]=_0xf50c62,this[_0x213d62(0x26e,0x2a1)]=_0x6bcb31,this['viewerParameters']=_0x393705,this[_0x213d62(0x23d,0x20c)]=_0x16c741;function _0xa11870(_0x20745e,_0x55f647){return _0x4445ca(_0x20745e,_0x55f647- -0x5a9);}this['frameRate']=0x3c,this['frameRateAdjustment']=0x1;const _0x605e5b={};_0x605e5b['scene']=_0x2bd38f,_0x605e5b[_0xa11870(0x9,-0x1b)]=0x1,_0x605e5b[_0x213d62(0x1ea,0x17c)]=0x0,this['frameRateMonitor']=new FrameRateMonitor(_0x605e5b),this[_0x213d62(0x28e,0x215)](),this['createWindTextures']();function _0x213d62(_0x6a68ec,_0x1828fc){return _0x27febc(_0x6a68ec-0x249,_0x1828fc);}this[_0x213d62(0x281,0x295)](),this[_0x213d62(0x27f,0x213)]();}[_0x4445ca(0x65f,0x605)](){const _0x506c9d=()=>{function _0x3badba(_0x52dedc,_0xf3896e){return _0x34ed(_0x52dedc- -0x38e,_0xf3896e);}function _0x42c9f8(_0x424184,_0x29f1b2){return _0x34ed(_0x424184- -0xc4,_0x29f1b2);}this[_0x42c9f8(0x205,0x196)]['lastFramesPerSecond']>0x14&&(this['frameRate']=this[_0x3badba(-0xc5,-0x47)][_0x42c9f8(0x163,0x161)],this[_0x3badba(-0xb3,-0x50)]=0x3c/Math[_0x3badba(-0xc0,-0x88)](this[_0x42c9f8(0x14b,0x134)],0x1));};function _0x738ec7(_0x5ca6b4,_0x436bd3){return _0x27febc(_0x5ca6b4-0x674,_0x436bd3);}_0x506c9d();const _0x182074=setInterval(_0x506c9d,0x3e8),_0x248f03=this['destroy']['bind'](this);this[_0x738ec7(0x63d,0x604)]=()=>{clearInterval(_0x182074),_0x248f03();};}['createWindTextures'](){const _0x3b15d6={};function _0x358e60(_0x1407e9,_0x56f73f){return _0x4445ca(_0x56f73f,_0x1407e9- -0x30e);}_0x3b15d6['minificationFilter']=TextureMinificationFilter$1['LINEAR'];function _0x52a162(_0x43b4e3,_0x59d306){return _0x27febc(_0x59d306-0x11a,_0x43b4e3);}_0x3b15d6['magnificationFilter']=TextureMagnificationFilter$1[_0x52a162(0x114,0x107)];const _0x1f7f78={'context':this[_0x52a162(0x10f,0x11a)],'width':this['windData'][_0x52a162(0x1ba,0x143)],'height':this['windData']['height'],'pixelFormat':PixelFormat$1[_0x52a162(0x149,0x144)],'pixelDatatype':PixelDatatype$1[_0x52a162(0xb5,0xef)],'flipY':this[_0x358e60(0x2d7,0x33e)][_0x52a162(0xe4,0x6f)]??![],'sampler':new Sampler$1(_0x3b15d6)};this[_0x52a162(0xdf,0xc1)]={'U':new Texture$1({..._0x1f7f78,'source':{'arrayBufferView':new Float32Array(this['windData']['u']['array'])}}),'V':new Texture$1({..._0x1f7f78,'source':{'arrayBufferView':new Float32Array(this['windData']['v']['array'])}})};}['createParticlesTextures'](){const _0x2293f0={};_0x2293f0[_0x3f0853(0xf6,0x9b)]=TextureMinificationFilter$1['NEAREST'];function _0x3f0853(_0x335100,_0x3fcbba){return _0x4445ca(_0x3fcbba,_0x335100- -0x4bf);}_0x2293f0[_0x3f0853(0x125,0x158)]=TextureMagnificationFilter$1[_0x2b140c(0x2bc,0x2a3)];function _0x2b140c(_0x49c248,_0x3efc2c){return _0x4445ca(_0x3efc2c,_0x49c248- -0x305);}const _0xa28d0f={'context':this[_0x3f0853(0x101,0x16d)],'width':this['options'][_0x3f0853(0x44,0x86)],'height':this['options'][_0x3f0853(0x44,0xce)],'pixelFormat':PixelFormat$1['RGBA'],'pixelDatatype':PixelDatatype$1[_0x3f0853(0xd6,0xb6)],'flipY':![],'source':{'arrayBufferView':new Float32Array(this['options']['particlesTextureSize']*this[_0x3f0853(0x126,0x159)][_0x2b140c(0x1fe,0x21e)]*0x4)['fill'](0x0)},'sampler':new Sampler$1(_0x2293f0)};this[_0x2b140c(0x216,0x205)]={'previousParticlesPosition':new Texture$1(_0xa28d0f),'currentParticlesPosition':new Texture$1(_0xa28d0f),'nextParticlesPosition':new Texture$1(_0xa28d0f),'postProcessingPosition':new Texture$1(_0xa28d0f),'particlesSpeed':new Texture$1(_0xa28d0f)};}[_0x4445ca(0x5d2,0x5a9)](){Object['values'](this['particlesTextures'])['forEach'](_0x56f463=>_0x56f463['destroy']());}[_0x27febc(0x36,0x96)](){function _0x109418(_0x7bc12e,_0x4b959c){return _0x4445ca(_0x7bc12e,_0x4b959c- -0x589);}function _0x4fd1e2(_0x53c48e,_0x36b221){return _0x27febc(_0x53c48e- -0x1a,_0x36b221);}this['primitives']={'calculateSpeed':new CustomPrimitive({'commandType':'Compute','uniformMap':{'U':()=>this['windTextures']['U'],'V':()=>this['windTextures']['V'],'uRange':()=>new Cartesian2$1(this[_0x4fd1e2(-0x26,-0x68)]['u']['min'],this[_0x109418(-0x52,0x2b)]['u']['max']),'vRange':()=>new Cartesian2$1(this[_0x109418(0x49,0x2b)]['v'][_0x4fd1e2(-0x60,-0x60)],this[_0x4fd1e2(-0x26,0x37)]['v']['max']),'speedRange':()=>new Cartesian2$1(this[_0x4fd1e2(-0x26,0x1c)]['speed']['min'],this[_0x109418(-0x12,0x2b)]['speed']['max']),'currentParticlesPosition':()=>this['particlesTextures'][_0x109418(-0x13,0x58)],'speedScaleFactor':()=>{function _0x59efa2(_0x21348b,_0x22913e){return _0x109418(_0x22913e,_0x21348b- -0x11);}return(this['viewerParameters'][_0x59efa2(0x71,0x98)]+0x32)*this['options']['speedFactor'];},'frameRateAdjustment':()=>this[_0x4fd1e2(0x2c,-0x4d)],'dimension':()=>new Cartesian2$1(this[_0x4fd1e2(-0x26,-0xab)]['width'],this['windData']['height']),'minimum':()=>new Cartesian2$1(this['windData']['bounds']['west'],this['windData']['bounds'][_0x4fd1e2(0x2,0x2b)]),'maximum':()=>new Cartesian2$1(this['windData']['bounds'][_0x4fd1e2(-0xc,0x4d)],this[_0x109418(0x79,0x2b)]['bounds'][_0x109418(0x4,-0x68)])},'fragmentShaderSource':ShaderManager[_0x4fd1e2(-0x63,-0x10)](),'outputTexture':this[_0x109418(-0x17,-0x6e)][_0x109418(-0x3b,-0x48)],'preExecute':()=>{function _0x381766(_0xc1e707,_0x205d77){return _0x109418(_0xc1e707,_0x205d77-0x28);}const _0x46be6b=this['particlesTextures'][_0x9d19f9(0x3df,0x419)];this['particlesTextures']['previousParticlesPosition']=this['particlesTextures']['currentParticlesPosition'],this[_0x9d19f9(0x473,0x429)]['currentParticlesPosition']=this['particlesTextures'][_0x381766(0x85,0xa9)];function _0x9d19f9(_0x48d3f7,_0x49a08f){return _0x4fd1e2(_0x49a08f-0x4e8,_0x48d3f7);}this['particlesTextures']['postProcessingPosition']=_0x46be6b,this[_0x9d19f9(0x44c,0x461)]['calculateSpeed'][_0x381766(0x3c,0x3e)]&&(this[_0x381766(-0x1e,-0xe)]['calculateSpeed'][_0x381766(0xa9,0x3e)][_0x381766(0x85,0x2f)]=this['particlesTextures']['particlesSpeed']);},'isDynamic':()=>this[_0x4fd1e2(0xb,0x34)]['dynamic']}),'updatePosition':new CustomPrimitive({'commandType':'Compute','uniformMap':{'currentParticlesPosition':()=>this['particlesTextures']['currentParticlesPosition'],'particlesSpeed':()=>this['particlesTextures']['particlesSpeed']},'fragmentShaderSource':ShaderManager[_0x109418(-0xa8,-0x80)](),'outputTexture':this['particlesTextures'][_0x4fd1e2(0x3,0x41)],'preExecute':()=>{function _0x5208ff(_0x2cdf9e,_0x451184){return _0x4fd1e2(_0x451184-0x378,_0x2cdf9e);}function _0x42c8d4(_0x410df3,_0x5e0c18){return _0x109418(_0x5e0c18,_0x410df3-0x130);}this['primitives'][_0x42c8d4(0xfb,0x146)]['commandToExecute']&&(this['primitives'][_0x42c8d4(0xfb,0xdd)][_0x5208ff(0x2fa,0x33d)]['outputTexture']=this[_0x5208ff(0x245,0x2b9)][_0x42c8d4(0x184,0x1be)]);},'isDynamic':()=>this['options'][_0x4fd1e2(0x14,0x21)]}),'postProcessingPosition':new CustomPrimitive({'commandType':_0x109418(-0x65,0xa),'uniformMap':{'nextParticlesPosition':()=>this['particlesTextures'][_0x109418(0x5b,0x54)],'particlesSpeed':()=>this[_0x109418(-0xf9,-0x6e)]['particlesSpeed'],'lonRange':()=>this['viewerParameters'][_0x4fd1e2(-0x13,0x1d)],'latRange':()=>this['viewerParameters']['latRange'],'dataLonRange':()=>new Cartesian2$1(this[_0x4fd1e2(-0x26,0x49)][_0x4fd1e2(-0xcb,-0x47)]['west'],this[_0x109418(0x5e,0x2b)]['bounds']['east']),'dataLatRange':()=>new Cartesian2$1(this['windData']['bounds'][_0x4fd1e2(0x2,-0x43)],this['windData'][_0x109418(-0xb0,-0x7a)]['north']),'randomCoefficient':function(){function _0x9ede30(_0x284d07,_0x3341af){return _0x109418(_0x3341af,_0x284d07-0x4e);}return Math[_0x9ede30(0x37,0xb1)]();},'dropRate':()=>this['options']['dropRate'],'dropRateBump':()=>this[_0x4fd1e2(0xb,-0x1)][_0x109418(-0x64,-0x26)],'useViewerBounds':()=>this[_0x109418(0x4c,0x5c)][_0x109418(0x52,0x63)]},'fragmentShaderSource':ShaderManager['getPostProcessingPositionShader'](),'outputTexture':this[_0x4fd1e2(-0xbf,-0x5c)]['postProcessingPosition'],'preExecute':()=>{function _0x1441f6(_0x2a61a9,_0x1a9765){return _0x4fd1e2(_0x1a9765-0x53c,_0x2a61a9);}function _0x33c5b2(_0x546a5b,_0x415bd5){return _0x109418(_0x415bd5,_0x546a5b-0x489);}this[_0x1441f6(0x480,0x4b5)]['postProcessingPosition'][_0x33c5b2(0x49f,0x42a)]&&(this['primitives'][_0x1441f6(0x5ed,0x56c)][_0x33c5b2(0x49f,0x483)]['outputTexture']=this['particlesTextures']['postProcessingPosition']);},'isDynamic':()=>this[_0x109418(0x57,0x5c)][_0x109418(0x87,0x65)]})};}['reCreateWindTextures'](){function _0x185f46(_0x1caaf7,_0x4814d8){return _0x27febc(_0x1caaf7- -0x132,_0x4814d8);}this[_0x185f46(-0x18b,-0x1d4)]['U']['destroy'](),this['windTextures']['V']['destroy'](),this['createWindTextures']();}[_0x4445ca(0x578,0x551)](_0x3bad27){function _0x4ae8a9(_0x4d38ee,_0x236966){return _0x4445ca(_0x236966,_0x4d38ee-0xc);}this['windData']=_0x3bad27,this[_0x4ae8a9(0x54b,0x57d)]();}['updateOptions'](_0x1f55d3){const _0x4d4ca4=_0x1f55d3['flipY']!==undefined&&_0x1f55d3[_0x121889(0x1ab,0x1f8)]!==this['options']['flipY'];function _0x121889(_0x18dda3,_0x3f6537){return _0x27febc(_0x18dda3-0x256,_0x3f6537);}this['options']=deepMerge(_0x1f55d3,this[_0x121889(0x27b,0x222)]);function _0x397aef(_0xf2c78a,_0x4b46a9){return _0x4445ca(_0xf2c78a,_0x4b46a9- -0x388);}_0x4d4ca4&&this[_0x121889(0x1d5,0x1c5)]();}[_0x27febc(-0x42,-0x99)](_0x1c27e7){const {array:_0x34c4ad}=_0x1c27e7;function _0x5ef094(_0x11c85d,_0x425a60){return _0x4445ca(_0x425a60,_0x11c85d- -0x54b);}let {min:_0x3c6e70,max:_0x5f188d}=_0x1c27e7;const _0x2be7a6=new Float32Array(_0x34c4ad[_0x1b2d24(-0x1f9,-0x1e6)]);_0x3c6e70===undefined&&(console['warn'](_0x1b2d24(-0x1c2,-0x1c8)),_0x3c6e70=Math['min'](..._0x34c4ad));function _0x1b2d24(_0x5a2e0d,_0x109be2){return _0x4445ca(_0x5a2e0d,_0x109be2- -0x6ed);}_0x5f188d===undefined&&(console[_0x5ef094(0x82,0xf2)](_0x1b2d24(-0x137,-0xfa)),_0x5f188d=Math[_0x1b2d24(-0x123,-0xf4)](..._0x34c4ad));const _0x401303=Math[_0x1b2d24(-0xd0,-0xf4)](Math[_0x5ef094(0x3b,-0x48)](_0x3c6e70),Math[_0x1b2d24(-0x101,-0x167)](_0x5f188d));for(let _0x38ff8d=0x0;_0x38ff8d<_0x34c4ad[_0x5ef094(-0x44,0x36)];_0x38ff8d++){const _0x3fb78c=_0x34c4ad[_0x38ff8d]/_0x401303;_0x2be7a6[_0x38ff8d]=_0x3fb78c;}return _0x2be7a6;}[_0x4445ca(0x580,0x589)](){function _0x41a14e(_0x22a490,_0x36f54f){return _0x27febc(_0x36f54f-0x2b,_0x22a490);}function _0x359a81(_0x33650b,_0x122f6b){return _0x27febc(_0x33650b-0x13b,_0x122f6b);}Object['values'](this[_0x41a14e(0x2f,-0x2e)])['forEach'](_0x58210b=>_0x58210b['destroy']()),Object[_0x41a14e(-0x1e,0x23)](this[_0x41a14e(-0x13,-0x7a)])['forEach'](_0x218b23=>_0x218b23['destroy']()),Object['values'](this['primitives'])[_0x41a14e(-0x57,-0x81)](_0x2ff09e=>_0x2ff09e[_0x41a14e(0x15,-0xc)]()),this[_0x41a14e(0xa9,0x5f)][_0x41a14e(-0x4f,-0xc)]();}}const {Appearance,BufferUsage,Cartesian2,Color:Color$1,ComponentDatatype,Framebuffer,Geometry,GeometryAttribute,GeometryAttributes,PixelDatatype,PixelFormat,PrimitiveType,Sampler,SceneMode,Texture,TextureMagnificationFilter,TextureMinificationFilter,TextureWrap,VertexArray}=mars3d__namespace['Cesium'];class WindParticlesRendering{constructor(_0x2ba58c,_0x1c41dd,_0x28f45f,_0xe8e89f){this['context']=_0x2ba58c,this['options']=_0x1c41dd,this['viewerParameters']=_0x28f45f,this[_0x4ab8c2(0x335,0x37d)]=_0xe8e89f;function _0x4ab8c2(_0x2e6ab7,_0x4e12bd){return _0x4445ca(_0x4e12bd,_0x2e6ab7- -0x25c);}function _0x24febf(_0x3031b1,_0x1cdb00){return _0x27febc(_0x3031b1-0x239,_0x1cdb00);}(typeof this[_0x24febf(0x25e,0x2c6)][_0x24febf(0x17c,0x15e)]!=='number'||this[_0x24febf(0x25e,0x29d)][_0x24febf(0x17c,0x146)]<=0x0)&&(console[_0x4ab8c2(0x37f,0x338)](_0x4ab8c2(0x2e8,0x28a)),this[_0x24febf(0x25e,0x229)][_0x24febf(0x17c,0x1e7)]=0x100),this[_0x4ab8c2(0x32b,0x2ed)]=this[_0x24febf(0x23e,0x23a)](),this['textures']=this['createRenderingTextures'](),this[_0x24febf(0x243,0x290)]=this[_0x4ab8c2(0x345,0x3b5)](),this[_0x24febf(0x1cc,0x1a4)]=this['createPrimitives']();}['createRenderingTextures'](){const _0x25f4b9={};_0x25f4b9['context']=this['context'],_0x25f4b9[_0x33145c(0x24b,0x2a6)]=this[_0x33145c(0x273,0x27d)]['drawingBufferWidth'],_0x25f4b9[_0x1fcffa(0x311,0x2c7)]=this[_0x1fcffa(0x35b,0x3b9)]['drawingBufferHeight'],_0x25f4b9['pixelFormat']=PixelFormat['RGBA'];function _0x33145c(_0x27db25,_0x2be6e9){return _0x4445ca(_0x27db25,_0x2be6e9- -0x343);}_0x25f4b9[_0x1fcffa(0x39a,0x416)]=PixelDatatype['UNSIGNED_BYTE'];const _0x2c9334=_0x25f4b9,_0x1cfe68={};function _0x1fcffa(_0x170349,_0xdc3722){return _0x4445ca(_0xdc3722,_0x170349- -0x265);}_0x1cfe68['context']=this['context'],_0x1cfe68[_0x1fcffa(0x384,0x327)]=this[_0x1fcffa(0x35b,0x35f)][_0x33145c(0x233,0x265)],_0x1cfe68['height']=this[_0x33145c(0x283,0x27d)]['drawingBufferHeight'],_0x1cfe68[_0x33145c(0x272,0x283)]=PixelFormat['DEPTH_COMPONENT'],_0x1cfe68['pixelDatatype']=PixelDatatype['UNSIGNED_INT'];const _0x227b58=_0x1cfe68;return{'segmentsColor':new Texture(_0x2c9334),'segmentsDepth':new Texture(_0x227b58)};}[_0x27febc(-0x1f,-0x3c)](){const _0x156f78={};_0x156f78[_0x3c61dd(-0x104,-0x18c)]=this['context'];function _0x3c61dd(_0x1d0e2a,_0x5167fc){return _0x27febc(_0x1d0e2a- -0x104,_0x5167fc);}_0x156f78[_0x12a42b(0x6e,0x6)]=[this['textures'][_0x3c61dd(-0x11a,-0xaf)]];function _0x12a42b(_0x5382d9,_0x4fe162){return _0x27febc(_0x4fe162-0x69,_0x5382d9);}return _0x156f78['depthTexture']=this[_0x3c61dd(-0xbd,-0x121)]['segmentsDepth'],{'segments':new Framebuffer(_0x156f78)};}['destoryRenderingFramebuffers'](){function _0x1394a4(_0x39dc88,_0x4c0a68){return _0x27febc(_0x4c0a68-0x3c,_0x39dc88);}Object[_0x1394a4(0xb4,0x34)](this['framebuffers'])['forEach'](_0x4cd803=>{_0x4cd803['destroy']();});}[_0x27febc(0x5,0x3b)](){const _0x16f25a=new Float32Array(this['options'][_0x2649fe(0x49,0x1)]['flatMap'](_0x4102c1=>{function _0x1b6bfb(_0x236841,_0x5cf69a){return _0x2649fe(_0x236841,_0x5cf69a- -0x7c);}const _0x117c76=Color$1['fromCssColorString'](_0x4102c1);return[_0x117c76['red'],_0x117c76[_0x1b6bfb(-0x42,-0x36)],_0x117c76['blue'],_0x117c76['alpha']];}));function _0x38fb76(_0x47c599,_0x3cafa1){return _0x4445ca(_0x47c599,_0x3cafa1- -0x228);}const _0x5687b2={};_0x5687b2['minificationFilter']=TextureMinificationFilter['LINEAR'],_0x5687b2['magnificationFilter']=TextureMagnificationFilter['LINEAR'],_0x5687b2['wrapS']=TextureWrap[_0x2649fe(-0x86,-0x34)];function _0x2649fe(_0xba8097,_0x1593d1){return _0x27febc(_0x1593d1-0x34,_0xba8097);}return _0x5687b2['wrapT']=TextureWrap[_0x38fb76(0x350,0x330)],new Texture({'context':this['context'],'width':this[_0x2649fe(0xb8,0x59)][_0x2649fe(-0x88,0x1)]['length'],'height':0x1,'pixelFormat':PixelFormat['RGBA'],'pixelDatatype':PixelDatatype['FLOAT'],'sampler':new Sampler(_0x5687b2),'source':{'width':this['options']['colors'][_0x2649fe(-0xb2,-0x85)],'height':0x1,'arrayBufferView':_0x16f25a}});}[_0x4445ca(0x5ce,0x560)](){const _0x7c279a=0x4,_0x19f607=this[_0x363333(0x449,0x44d)]['particlesTextureSize'];function _0x267446(_0x157e68,_0x1c70ea){return _0x27febc(_0x1c70ea-0x7,_0x157e68);}let _0x1e8ec3=[];for(let _0x28b003=0x0;_0x28b003<_0x19f607;_0x28b003++){for(let _0x9a07e7=0x0;_0x9a07e7<_0x19f607;_0x9a07e7++){for(let _0x1772db=0x0;_0x1772db<_0x7c279a;_0x1772db++){_0x1e8ec3['push'](_0x28b003/_0x19f607),_0x1e8ec3[_0x363333(0x378,0x39b)](_0x9a07e7/_0x19f607);}}}_0x1e8ec3=new Float32Array(_0x1e8ec3);const _0x2f925a=this['options']['particlesTextureSize']**0x2;let _0x5a4290=[];for(let _0x456224=0x0;_0x456224<_0x2f925a;_0x456224++){_0x5a4290['push'](-0x1,-0x1,0x0,-0x1,0x1,0x0,0x1,-0x1,0x0,0x1,0x1,0x0);}_0x5a4290=new Float32Array(_0x5a4290);let _0x505f5f=[];for(let _0x360caa=0x0,_0x2898a2=0x0;_0x360caa<_0x2f925a;_0x360caa++){_0x505f5f[_0x363333(0x414,0x39b)](_0x2898a2+0x0,_0x2898a2+0x1,_0x2898a2+0x2,_0x2898a2+0x2,_0x2898a2+0x1,_0x2898a2+0x3),_0x2898a2+=_0x7c279a;}_0x505f5f=new Uint32Array(_0x505f5f);const _0xbb3701={};function _0x363333(_0x11f590,_0x3dcb7f){return _0x27febc(_0x3dcb7f-0x428,_0x11f590);}_0xbb3701[_0x363333(0x3c1,0x3a4)]=ComponentDatatype['FLOAT'],_0xbb3701['componentsPerAttribute']=0x2,_0xbb3701['values']=_0x1e8ec3;const _0x2314a8={};_0x2314a8['componentDatatype']=ComponentDatatype['FLOAT'],_0x2314a8['componentsPerAttribute']=0x3,_0x2314a8['values']=_0x5a4290;const _0x261e55=new Geometry({'attributes':new GeometryAttributes({'st':new GeometryAttribute(_0xbb3701),'normal':new GeometryAttribute(_0x2314a8)}),'indices':_0x505f5f});return _0x261e55;}['createRawRenderState'](_0x8799ba){const _0xf0a13c={'viewport':undefined,'depthTest':undefined,'depthMask':undefined,'blending':undefined,..._0x8799ba};return Appearance['getDefaultRenderState'](!![],![],_0xf0a13c);}[_0x27febc(-0x3e,0x14)](){const _0x1dd820={};_0x1dd820['st']=0x0,_0x1dd820['normal']=0x1;const _0x525c51={};_0x525c51[_0x3feff1(0x42a,0x412)]=!![];const _0x3c0837={};_0x3c0837['enabled']=!![],_0x3c0837[_0x15d2e5(0x4b7,0x4f8)]=WebGLRenderingContext[_0x3feff1(0x49e,0x417)],_0x3c0837['blendFuncSource']=WebGLRenderingContext[_0x3feff1(0x3bb,0x3ed)],_0x3c0837[_0x15d2e5(0x49b,0x480)]=WebGLRenderingContext['ONE_MINUS_SRC_ALPHA'];const _0x256a22={};_0x256a22[_0x15d2e5(0x49f,0x491)]=undefined,_0x256a22['depthTest']=_0x525c51,_0x256a22[_0x3feff1(0x3bb,0x3b4)]=!![],_0x256a22['blending']=_0x3c0837;const _0x166659=new CustomPrimitive({'commandType':_0x15d2e5(0x54f,0x4cf),'attributeLocations':_0x1dd820,'geometry':this['createSegmentsGeometry'](),'primitiveType':PrimitiveType[_0x15d2e5(0x474,0x428)],'uniformMap':{'previousParticlesPosition':()=>this[_0x15d2e5(0x4b4,0x48c)]['particlesTextures'][_0x15d2e5(0x3a9,0x406)],'currentParticlesPosition':()=>this['computing']['particlesTextures']['currentParticlesPosition'],'postProcessingPosition':()=>this[_0x15d2e5(0x4c6,0x48c)]['particlesTextures'][_0x3feff1(0x507,0x48d)],'particlesSpeed':()=>this[_0x15d2e5(0x4da,0x48c)]['particlesTextures']['particlesSpeed'],'frameRateAdjustment':()=>this['computing'][_0x15d2e5(0x4a0,0x501)],'colorTable':()=>this[_0x3feff1(0x47c,0x40a)],'domain':()=>{function _0x845f07(_0x3dc9b2,_0x501bda){return _0x15d2e5(_0x501bda,_0x3dc9b2- -0x42f);}var _0x33019e,_0x596306;const _0x4da1c0=new Cartesian2(((_0x33019e=this[_0x845f07(0xb1,0xce)][_0x3a522c(0x5ad,0x5b9)])===null||_0x33019e===void 0x0?void 0x0:_0x33019e['min'])??this['computing']['windData']['speed']['min'],((_0x596306=this['options']['domain'])===null||_0x596306===void 0x0?void 0x0:_0x596306['max'])??this['computing'][_0x845f07(0x80,0xc4)][_0x845f07(0x2e,0x9)]['max']);function _0x3a522c(_0x388dbb,_0x490c09){return _0x15d2e5(_0x490c09,_0x388dbb-0xf4);}return _0x4da1c0;},'displayRange':()=>{function _0x1364eb(_0x24a26d,_0x2b2869){return _0x3feff1(_0x2b2869,_0x24a26d- -0x199);}function _0x49a1d5(_0x13a857,_0x5e3338){return _0x15d2e5(_0x13a857,_0x5e3338-0xee);}var _0x360fb1,_0x3b7615;const _0x2fdfe8=new Cartesian2(((_0x360fb1=this['options'][_0x1364eb(0x2b5,0x260)])===null||_0x360fb1===void 0x0?void 0x0:_0x360fb1[_0x49a1d5(0x59e,0x563)])??this['computing']['windData']['speed']['min'],((_0x3b7615=this['options']['displayRange'])===null||_0x3b7615===void 0x0?void 0x0:_0x3b7615[_0x1364eb(0x2e3,0x304)])??this['computing']['windData']['speed']['max']);return _0x2fdfe8;},'particleHeight':()=>this[_0x15d2e5(0x4d8,0x4e0)]['fixedHeight']||0x0,'aspect':()=>this['context']['drawingBufferWidth']/this['context']['drawingBufferHeight'],'pixelSize':()=>this['viewerParameters'][_0x15d2e5(0x58f,0x506)],'lineWidth':()=>{function _0x3c6ccc(_0x5082b4,_0x14035f){return _0x3feff1(_0x14035f,_0x5082b4- -0x568);}const _0x1462d0={};_0x1462d0[_0x560ae7(0x327,0x2ca)]=0x1,_0x1462d0['max']=0x2;const _0x3a447=this[_0x560ae7(0x2ba,0x335)]['lineWidth']||_0x1462d0;function _0x560ae7(_0x41db3a,_0xc4f0d9){return _0x15d2e5(_0x41db3a,_0xc4f0d9- -0x1ab);}return new Cartesian2(_0x3a447['min'],_0x3a447[_0x560ae7(0x3ae,0x349)]);},'lineLength':()=>{const _0x26890d={};_0x26890d['min']=0x14,_0x26890d['max']=0x64;const _0x557759=this['options']['lineLength']||_0x26890d;return new Cartesian2(_0x557759['min'],_0x557759['max']);},'is3D':()=>this['viewerParameters']['sceneMode']===SceneMode['SCENE3D'],'segmentsDepthTexture':()=>this[_0x15d2e5(0x498,0x502)]['segmentsDepth']},'vertexShaderSource':ShaderManager['getSegmentDrawVertexShader'](),'fragmentShaderSource':ShaderManager[_0x15d2e5(0x519,0x4f6)](),'rawRenderState':this['createRawRenderState'](_0x256a22)}),_0x3e7f9={};_0x3e7f9[_0x3feff1(0x43d,0x3e9)]=_0x166659;function _0x15d2e5(_0x208de9,_0x27ed27){return _0x4445ca(_0x208de9,_0x27ed27- -0x105);}function _0x3feff1(_0x268fd6,_0x3beda2){return _0x27febc(_0x3beda2-0x443,_0x268fd6);}return _0x3e7f9;}[_0x4445ca(0x524,0x569)](){const _0x2e7ad9=this['createSegmentsGeometry']();this[_0xe7cdcf(0x4ec,0x494)][_0x411c44(-0x17,0x59)]['geometry']=_0x2e7ad9;const _0x246969={};_0x246969[_0x411c44(0x43,0xbd)]=this['context'],_0x246969[_0x411c44(-0x34,-0x71)]=_0x2e7ad9,_0x246969['attributeLocations']=this[_0x411c44(-0x2a,-0xd)][_0x411c44(-0x17,0x1b)]['attributeLocations'],_0x246969['bufferUsage']=BufferUsage['STATIC_DRAW'];function _0xe7cdcf(_0x753c0c,_0x960095){return _0x27febc(_0x960095-0x501,_0x753c0c);}const _0x556c4d=VertexArray[_0x411c44(0x4f,-0x1b)](_0x246969);function _0x411c44(_0x179e83,_0x138990){return _0x27febc(_0x179e83-0x43,_0x138990);}this['primitives'][_0x411c44(-0x17,-0x17)]['commandToExecute']&&(this['primitives']['segments'][_0xe7cdcf(0x4f1,0x4e0)][_0x411c44(-0x4f,-0x41)]=_0x556c4d);}['onColorTableChange'](){function _0x5d434a(_0x51223e,_0x207263){return _0x4445ca(_0x51223e,_0x207263- -0x24);}function _0x271b07(_0x4206b8,_0x24900b){return _0x27febc(_0x24900b-0x5e7,_0x4206b8);}this[_0x5d434a(0x4ea,0x563)]['destroy'](),this[_0x271b07(0x621,0x5ae)]=this['createColorTableTexture']();}['updateOptions'](_0x1c6606){const _0x1557d1=_0x1c6606['colors']&&JSON[_0x390b43(0x59d,0x513)](_0x1c6606['colors'])!==JSON['stringify'](this[_0x390b43(0x586,0x608)]['colors']);function _0x28b387(_0x239db4,_0x4fb29a){return _0x4445ca(_0x4fb29a,_0x239db4-0xa9);}this['options']=deepMerge(_0x1c6606,this['options']);function _0x390b43(_0x571c46,_0x1ee9af){return _0x4445ca(_0x1ee9af,_0x571c46- -0x5f);}_0x1557d1&&this['onColorTableChange']();}['destroy'](){function _0x2e4540(_0x3f0ad6,_0x582c26){return _0x4445ca(_0x582c26,_0x3f0ad6- -0x40);}Object['values'](this[_0x2e4540(0x58a,0x50b)])['forEach'](_0xfc4e2f=>{_0xfc4e2f['destroy']();}),Object['values'](this['primitives'])['forEach'](_0x4eb2fe=>{_0x4eb2fe['destroy']();});function _0x57b48d(_0x4c499a,_0x1a3b58){return _0x27febc(_0x4c499a-0xc3,_0x1a3b58);}this[_0x57b48d(0x8a,0xbe)][_0x2e4540(0x549,0x560)]();}}const {ClearCommand,Color,Pass}=mars3d__namespace[_0x4445ca(0x558,0x545)];class WindParticleSystem{constructor(_0x23aa6b,_0x2ff768,_0x23ecd4,_0x10fd4d,_0x5f442e){this[_0x58d9a2(0x180,0x1ac)]=_0x23aa6b,this['options']=_0x23ecd4,this['viewerParameters']=_0x10fd4d;function _0x542c83(_0x46e1a8,_0x34a751){return _0x4445ca(_0x34a751,_0x46e1a8- -0x67d);}this[_0x542c83(-0xec,-0xa1)]=new WindParticlesComputing(_0x23aa6b,_0x2ff768,_0x23ecd4,_0x10fd4d,_0x5f442e),this[_0x542c83(-0xcc,-0x133)]=new WindParticlesRendering(_0x23aa6b,_0x23ecd4,_0x10fd4d,this['computing']);function _0x58d9a2(_0x19a7e0,_0x667e9c){return _0x27febc(_0x667e9c-0x1ac,_0x19a7e0);}this[_0x542c83(-0xf1,-0xd5)]();}['getPrimitives'](){function _0x2e6e11(_0x4f511a,_0x32a0b0){return _0x4445ca(_0x32a0b0,_0x4f511a- -0x57d);}const _0x4e83bd=[this['computing'][_0x5aced8(0x53d,0x4b7)]['calculateSpeed'],this[_0x2e6e11(0x14,-0x12)]['primitives']['updatePosition'],this[_0x5aced8(0x4c2,0x4f5)][_0x2e6e11(-0x2a,0x5a)]['postProcessingPosition'],this[_0x5aced8(0x54e,0x515)]['primitives'][_0x2e6e11(-0x17,0x16)]];function _0x5aced8(_0x51e6c6,_0xdc4624){return _0x4445ca(_0x51e6c6,_0xdc4624- -0x9c);}return _0x4e83bd;}[_0x27febc(-0x34,-0x50)](){function _0x4be84e(_0x1cc6b7,_0x5b260b){return _0x4445ca(_0x5b260b,_0x1cc6b7- -0x6bd);}const _0x2447ff=new ClearCommand({'color':new Color(0x0,0x0,0x0,0x0),'depth':0x1,'framebuffer':undefined,'pass':Pass['OPAQUE']});function _0x4fc10b(_0x8efce1,_0x35b073){return _0x4445ca(_0x8efce1,_0x35b073- -0x56f);}Object[_0x4be84e(-0x10d,-0xcb)](this[_0x4fc10b(0x88,0x42)][_0x4fc10b(-0x18,0x5b)])['forEach'](_0x1a762f=>{_0x2447ff['framebuffer']=this[_0x4a5a92(0x130,0x117)]['framebuffers'][_0x1a762f];function _0x4a5a92(_0x4adb12,_0x290070){return _0x4be84e(_0x290070-0x223,_0x4adb12);}_0x2447ff['execute'](this['context']);});}['changeOptions'](_0x119a1c){function _0xfa039(_0x183b7e,_0x1d94f7){return _0x27febc(_0x1d94f7-0x4b7,_0x183b7e);}let _0x22faa2=![];_0x119a1c['particlesTextureSize']&&this['options']['particlesTextureSize']!==_0x119a1c['particlesTextureSize']&&(_0x22faa2=!![]);const _0x78f6=deepMerge(_0x119a1c,this[_0xfa039(0x457,0x4dc)]);if(_0x78f6['particlesTextureSize']<0x1)throw new Error('particlesTextureSize\x20must\x20be\x20greater\x20than\x200');this['options']=_0x78f6;function _0x362327(_0xdaa3b2,_0x447fe2){return _0x4445ca(_0x447fe2,_0xdaa3b2-0x4e);}this[_0xfa039(0x50c,0x4a8)][_0xfa039(0x4a0,0x467)](_0x119a1c),this['computing']['updateOptions'](_0x119a1c),_0x22faa2&&(this[_0x362327(0x5df,0x564)]['destroyParticlesTextures'](),this[_0xfa039(0x42e,0x488)][_0xfa039(0x49d,0x4ef)](),this['rendering'][_0x362327(0x5b7,0x5c8)]());}['applyViewerParameters'](_0x2d7b54){function _0x30ddfc(_0x4bc860,_0x32093f){return _0x4445ca(_0x4bc860,_0x32093f- -0x4e5);}this[_0x8e174d(0x62c,0x5ea)]=_0x2d7b54,this['computing']['viewerParameters']=_0x2d7b54;function _0x8e174d(_0x2bfd17,_0x555557){return _0x4445ca(_0x555557,_0x2bfd17-0x7e);}this['rendering'][_0x30ddfc(0xb7,0xc9)]=_0x2d7b54;}['destroy'](){function _0x4ce076(_0xa2e43f,_0x2ffde7){return _0x27febc(_0x2ffde7- -0xaf,_0xa2e43f);}this[_0x4ce076(-0x10c,-0xde)]['destroy'](),this['rendering']['destroy']();}}function _0x34ed(_0x168d26,_0xb79efa){const _0x55d3af=_0x55d3();return _0x34ed=function(_0x34ed1d,_0x345800){_0x34ed1d=_0x34ed1d-0x1d2;let _0x3ffc07=_0x55d3af[_0x34ed1d];return _0x3ffc07;},_0x34ed(_0x168d26,_0xb79efa);}const Cesium$1=mars3d__namespace[_0x27febc(-0x7b,-0x4f)],BaseLayer$1=mars3d__namespace[_0x27febc(-0x27,-0x43)]['BaseLayer'],_0x414cde={};_0x414cde['min']=0x1,_0x414cde[_0x4445ca(0x659,0x5f9)]=0x2;const _0x1a4a96={};_0x1a4a96[_0x4445ca(0x5f3,0x57a)]=0x14,_0x1a4a96['max']=0x64;const _0x1eee4f={};_0x1eee4f[_0x4445ca(0x504,0x503)]=0x64,_0x1eee4f['fixedHeight']=0x0,_0x1eee4f['lineWidth']=_0x414cde,_0x1eee4f['lineLength']=_0x1a4a96,_0x1eee4f['speedFactor']=0x1,_0x1eee4f[_0x4445ca(0x502,0x55a)]=0.003,_0x1eee4f['dropRateBump']=0.001,_0x1eee4f[_0x4445ca(0x507,0x58d)]=[_0x4445ca(0x560,0x4fe)],_0x1eee4f[_0x4445ca(0x4fe,0x515)]=![],_0x1eee4f['dynamic']=!![];const DEF_OPTIONS=_0x1eee4f;class WindLayer extends BaseLayer$1{constructor(_0x1fe0da={}){_0x1fe0da={...DEF_OPTIONS,..._0x1fe0da},super(_0x1fe0da),this['_setOptionsHook'](_0x1fe0da,_0x1fe0da);}get['layer'](){function _0x2a30e7(_0x2eed5d,_0x5ac3ff){return _0x27febc(_0x2eed5d-0x35d,_0x5ac3ff);}return this[_0x2a30e7(0x2f0,0x28a)];}get[_0x27febc(-0x2e,0x26)](){return this['options']['data'];}set[_0x4445ca(0x5c5,0x592)](_0x3fe9a7){function _0x47c80b(_0x5a8d51,_0x1a51e8){return _0x27febc(_0x5a8d51-0x242,_0x1a51e8);}this[_0x3101d5(0x214,0x1a5)]['data']=_0x3fe9a7;function _0x3101d5(_0x4e5e42,_0x373f87){return _0x27febc(_0x373f87-0x180,_0x4e5e42);}this[_0x3101d5(0x1e0,0x196)](_0x3fe9a7);}get['colors'](){function _0x5558c4(_0x285242,_0x553928){return _0x27febc(_0x285242- -0x143,_0x553928);}return this['options'][_0x5558c4(-0x176,-0x137)];}set['colors'](_0x469dbb){this['options']['colors']=_0x469dbb;const _0x45f203={};_0x45f203[_0x41dafa(-0x136,-0x15c)]=_0x469dbb;function _0x41dafa(_0xc1dac5,_0x11cfba){return _0x4445ca(_0xc1dac5,_0x11cfba- -0x6e9);}this['_setOptionsHook'](this['options'],_0x45f203);}[_0x4445ca(0x4e7,0x516)](_0x3eebda){function _0x48c17b(_0x3a5224,_0xe96940){return _0x4445ca(_0xe96940,_0x3a5224- -0x3f3);}_0x3eebda?this['_addedHook']():this[_0x48c17b(0x1ca,0x15c)]();}['_mountedHook'](){}['_addedHook'](){this[_0x4337f4(0x3d5,0x411)]=this[_0x4337f4(0x3a9,0x3e3)]['scene'],this['camera']=this[_0x4a70dc(0x32f,0x2c8)]['camera'];this['options']['data']&&this['setData'](this['options'][_0x4337f4(0x422,0x473)]);if(!this[_0x4a70dc(0x326,0x37a)]||!this['show'])return;this[_0x4a70dc(0x34d,0x374)]={'lonRange':new Cesium$1['Cartesian2'](-0xb4,0xb4),'latRange':new Cesium$1['Cartesian2'](-0x5a,0x5a),'pixelSize':0x3e8,'sceneMode':this['scene']['mode']};function _0x4a70dc(_0x54be0c,_0x361eea){return _0x27febc(_0x361eea-0x386,_0x54be0c);}this['updateViewerParameters'](),this[_0x4a70dc(0x401,0x3d2)]=new WindParticleSystem(this[_0x4337f4(0x495,0x411)][_0x4337f4(0x4c6,0x4a1)],this['windData'],this[_0x4337f4(0x54e,0x4c6)],this['viewerParameters'],this[_0x4a70dc(0x346,0x2f6)]),this[_0x4337f4(0x470,0x434)]=this['particleSystem'][_0x4a70dc(0x31e,0x39d)]();function _0x4337f4(_0x398644,_0x2c2e0d){return _0x27febc(_0x2c2e0d-0x4a1,_0x398644);}this[_0x4337f4(0x429,0x434)]['forEach'](_0x5747a1=>{function _0x53493f(_0x3860e6,_0x18f57a){return _0x4a70dc(_0x3860e6,_0x18f57a- -0x1c9);}this[_0x53493f(0x149,0x12d)]['primitives']['add'](_0x5747a1);}),this['camera']['percentageChanged']=0.01,this['camera']['changed']['addEventListener'](this[_0x4337f4(0x3e2,0x42c)][_0x4337f4(0x481,0x490)](this)),this['scene']['morphComplete'][_0x4337f4(0x4c5,0x4ce)](this['updateViewerParameters'][_0x4337f4(0x4f6,0x490)](this)),window['addEventListener']('resize',this[_0x4337f4(0x479,0x42c)]['bind'](this));}['_removedHook'](){this['camera'][_0x4d01e9(0x4a,0x82)][_0x8fe13e(0x35e,0x394)](this['updateViewerParameters']['bind'](this));function _0x8fe13e(_0xc158e5,_0x420f88){return _0x4445ca(_0xc158e5,_0x420f88- -0x1da);}this['scene']['morphComplete'][_0x8fe13e(0x352,0x394)](this['updateViewerParameters']['bind'](this));function _0x4d01e9(_0x17248a,_0x5563c4){return _0x4445ca(_0x5563c4,_0x17248a- -0x56f);}window[_0x8fe13e(0x41f,0x394)](_0x4d01e9(-0x5d,0x15),this['updateViewerParameters']['bind'](this)),this['primitives']&&(this['primitives']['forEach'](_0x22599b=>{this['scene']['primitives']['remove'](_0x22599b);}),delete this[_0x8fe13e(0x3e9,0x379)]),this['particleSystem']&&(this['particleSystem'][_0x8fe13e(0x3b1,0x3af)](),delete this['particleSystem']);}[_0x27febc(0x16,-0xe)](_0xd59f5c,_0x1ef1a0){this['windData']=this[_0x390600(0x37a,0x3b9)](_0xd59f5c);function _0x390600(_0x3d2f44,_0x490b0c){return _0x4445ca(_0x490b0c,_0x3d2f44- -0x204);}function _0x149ca4(_0x4bbc1a,_0x1d1d9e){return _0x27febc(_0x4bbc1a-0x1b9,_0x1d1d9e);}if(_0x1ef1a0){this[_0x149ca4(0x1b6,0x21a)](),this['_addedHook']();return;}this[_0x149ca4(0x205,0x28e)]?(this['particleSystem'][_0x149ca4(0x18a,0x17e)]['updateWindData'](this['windData']),this['scene']['requestRender']()):this['_addedHook']();}['_setOptionsHook'](_0x2624d1,_0xbebb94){function _0xcc140f(_0x2bb7a7,_0x523919){return _0x4445ca(_0x2bb7a7,_0x523919- -0x20f);}function _0x1f28b3(_0x7972f,_0x3a336c){return _0x27febc(_0x3a336c- -0x52,_0x7972f);}this[_0x1f28b3(-0x2d,-0x6)]&&(this['particleSystem'][_0x1f28b3(-0xeb,-0x6e)](_0xbebb94),this['scene']['requestRender']());}['processWindData'](_0x4455d2){var _0x41017b,_0x2ba6c6;function _0x704f5b(_0x5dcf7e,_0x37efc6){return _0x4445ca(_0x5dcf7e,_0x37efc6-0x29);}const _0x4cefed={..._0x4455d2},_0x27e92a=_0x4cefed;function _0x155e55(_0x50991a,_0x1070eb){return _0x27febc(_0x50991a-0x30,_0x1070eb);}!_0x27e92a['height']&&_0x27e92a['rows']&&(_0x27e92a['height']=_0x27e92a['rows']);!_0x27e92a[_0x155e55(0x59,0x6a)]&&_0x27e92a['cols']&&(_0x27e92a['width']=_0x27e92a[_0x155e55(0x78,0xcf)]);!_0x27e92a['bounds']&&(_0x27e92a['bounds']={'west':_0x27e92a['xmin'],'south':_0x27e92a[_0x704f5b(0x6a0,0x629)],'east':_0x27e92a['xmax'],'north':_0x27e92a['ymax']});if(!_0x27e92a['u']){const _0x44a939={};_0x44a939['array']=_0x4455d2['udata'],_0x44a939[_0x155e55(-0x16,0x5b)]=_0x4455d2['umin'],_0x44a939[_0x704f5b(0x604,0x622)]=_0x4455d2['umax'],_0x27e92a['u']=_0x44a939;}if(!_0x27e92a['v']){const _0x2c08d4={};_0x2c08d4['array']=_0x4455d2['vdata'],_0x2c08d4['min']=_0x4455d2['vmin'],_0x2c08d4['max']=_0x4455d2['vmax'],_0x27e92a['v']=_0x2c08d4;}if(((_0x41017b=_0x27e92a['speed'])===null||_0x41017b===void 0x0?void 0x0:_0x41017b['min'])===undefined||((_0x2ba6c6=_0x27e92a[_0x704f5b(0x51b,0x58b)])===null||_0x2ba6c6===void 0x0?void 0x0:_0x2ba6c6['max'])===undefined||_0x27e92a[_0x704f5b(0x59b,0x58b)][_0x155e55(0x22,0x92)]===undefined){const _0x218727={'array':new Float32Array(_0x27e92a['u']['array'][_0x155e55(-0x89,-0xf0)]),'min':Number['MAX_VALUE'],'max':Number[_0x704f5b(0x574,0x582)]};for(let _0xeff64f=0x0;_0xeff64f<_0x27e92a['u']['array'][_0x704f5b(0x4d1,0x530)];_0xeff64f++){_0x218727['array'][_0xeff64f]=Math['sqrt'](_0x27e92a['u']['array'][_0xeff64f]*_0x27e92a['u']['array'][_0xeff64f]+_0x27e92a['v'][_0x155e55(0x22,0x73)][_0xeff64f]*_0x27e92a['v'][_0x155e55(0x22,0x91)][_0xeff64f]),_0x218727[_0x704f5b(0x610,0x5db)][_0xeff64f]!==0x0&&(_0x218727[_0x155e55(-0x16,-0x87)]=Math[_0x704f5b(0x5c7,0x5a3)](_0x218727['min'],_0x218727[_0x155e55(0x22,-0x54)][_0xeff64f]),_0x218727['max']=Math['max'](_0x218727[_0x704f5b(0x652,0x622)],_0x218727['array'][_0xeff64f]));}_0x27e92a['speed']=_0x218727;}return _0x27e92a;}['updateViewerParameters'](){var _0x5d7fd9;const _0x30fe15=this[_0x1b464c(0x163,0x176)];if(!_0x30fe15)return;const _0x249742=_0x30fe15['canvas'],_0x54ddb4={};_0x54ddb4['x']=0x0;function _0x1b464c(_0x2e1ea8,_0x557d0a){return _0x27febc(_0x557d0a-0x206,_0x2e1ea8);}_0x54ddb4['y']=0x0;const _0x175c26={};_0x175c26['x']=0x0,_0x175c26['y']=_0x249742[_0x1b464c(0x234,0x24f)];function _0x5e5e0c(_0x5b2e86,_0x5efda7){return _0x27febc(_0x5b2e86-0x38d,_0x5efda7);}const _0x29f41d={};_0x29f41d['x']=_0x249742[_0x5e5e0c(0x3ad,0x435)],_0x29f41d['y']=0x0;const _0x9b7005={};_0x9b7005['x']=_0x249742['clientWidth'],_0x9b7005['y']=_0x249742['clientHeight'];const _0x506af1=[_0x54ddb4,_0x175c26,_0x29f41d,_0x9b7005];let _0x1305f7=0xb4,_0x51b3e0=-0xb4,_0x493c98=0x5a,_0x4e938a=-0x5a,_0x27bed9=![];for(const _0x5b82e4 of _0x506af1){const _0x5723f7=_0x30fe15['camera']['pickEllipsoid'](new Cesium$1[(_0x1b464c(0x1b5,0x21f))](_0x5b82e4['x'],_0x5b82e4['y']),_0x30fe15[_0x1b464c(0x16b,0x1bf)][_0x1b464c(0x150,0x183)]);if(!_0x5723f7){_0x27bed9=!![];break;}const _0xa21058=_0x30fe15['globe'][_0x1b464c(0x141,0x183)]['cartesianToCartographic'](_0x5723f7),_0x3af2a7=Cesium$1['Math']['toDegrees'](_0xa21058['longitude']),_0x16784f=Cesium$1[_0x1b464c(0x1d4,0x1c3)][_0x1b464c(0x1ec,0x23d)](_0xa21058['latitude']);_0x1305f7=Math[_0x5e5e0c(0x347,0x354)](_0x1305f7,_0x3af2a7),_0x51b3e0=Math['max'](_0x51b3e0,_0x3af2a7),_0x493c98=Math['min'](_0x493c98,_0x16784f),_0x4e938a=Math['max'](_0x4e938a,_0x16784f);}if(!_0x27bed9){const _0x5100b9=new Cesium$1[(_0x5e5e0c(0x3a6,0x425))](Math[_0x1b464c(0x23e,0x23f)](this['windData'][_0x5e5e0c(0x2dc,0x26f)][_0x1b464c(0x153,0x162)],_0x1305f7),Math['min'](this['windData']['bounds']['east'],_0x51b3e0)),_0x1cf93a=new Cesium$1[(_0x5e5e0c(0x3a6,0x329))](Math['max'](this['windData']['bounds']['south'],_0x493c98),Math['min'](this['windData']['bounds'][_0x5e5e0c(0x2ee,0x2c6)],_0x4e938a)),_0x9455b=(_0x5100b9['y']-_0x5100b9['x'])*0.05,_0xde653=(_0x1cf93a['y']-_0x1cf93a['x'])*0.05;_0x5100b9['x']=Math[_0x1b464c(0x243,0x23f)](this[_0x5e5e0c(0x381,0x32c)][_0x1b464c(0x132,0x155)]['west'],_0x5100b9['x']-_0x9455b),_0x5100b9['y']=Math['min'](this[_0x5e5e0c(0x381,0x405)]['bounds']['east'],_0x5100b9['y']+_0x9455b),_0x1cf93a['x']=Math['max'](this['windData']['bounds']['south'],_0x1cf93a['x']-_0xde653),_0x1cf93a['y']=Math[_0x5e5e0c(0x347,0x336)](this[_0x5e5e0c(0x381,0x35b)][_0x1b464c(0x120,0x155)]['north'],_0x1cf93a['y']+_0xde653),this['viewerParameters'][_0x5e5e0c(0x394,0x322)]=_0x5100b9,this[_0x5e5e0c(0x37b,0x3d7)][_0x5e5e0c(0x36d,0x318)]=_0x1cf93a;const _0x2a8fac=this['windData'][_0x5e5e0c(0x2dc,0x2a3)]['east']-this['windData']['bounds'][_0x5e5e0c(0x2e9,0x27c)],_0x54fe10=this[_0x1b464c(0x25f,0x1fa)][_0x5e5e0c(0x2dc,0x2a1)]['north']-this[_0x5e5e0c(0x381,0x380)][_0x5e5e0c(0x2dc,0x30a)]['south'],_0x3f49eb=(_0x5100b9['y']-_0x5100b9['x'])/_0x2a8fac,_0x40fe5b=(_0x1cf93a['y']-_0x1cf93a['x'])/_0x54fe10,_0x3647c4=Math[_0x5e5e0c(0x347,0x2e9)](_0x3f49eb,_0x40fe5b),_0x31632f=0x3e8*_0x3647c4;_0x31632f>0x0&&(this['viewerParameters']['pixelSize']=Math[_0x1b464c(0x2bd,0x23f)](0x0,Math[_0x1b464c(0x16d,0x1c0)](0x3e8,_0x31632f)));}this[_0x1b464c(0x16a,0x1f4)][_0x1b464c(0x234,0x1bb)]=this['scene']['mode'],(_0x5d7fd9=this['particleSystem'])===null||_0x5d7fd9===void 0x0||_0x5d7fd9['applyViewerParameters'](this['viewerParameters']);}['getDataAtLonLat'](_0x1a5cfd,_0x7270fe){const {bounds:_0x51e98c,width:_0x4b840c,height:_0x31609f,u:_0xd64309,v:_0x11725f,speed:_0x36766c}=this[_0x5c04d4(0x616,0x601)],{flipY:_0x293b7b}=this[_0x5c04d4(0x647,0x5ea)];if(_0x1a5cfd<_0x51e98c[_0x761fbd(0x28f,0x21c)]||_0x1a5cfd>_0x51e98c['east']||_0x7270fe<_0x51e98c['south']||_0x7270fe>_0x51e98c['north'])return null;const _0x54df2c=(_0x1a5cfd-_0x51e98c['west'])/(_0x51e98c[_0x761fbd(0x263,0x2ce)]-_0x51e98c['west'])*(_0x4b840c-0x1);let _0x157ea4=(_0x7270fe-_0x51e98c[_0x5c04d4(0x63e,0x628)])/(_0x51e98c['north']-_0x51e98c['south'])*(_0x31609f-0x1);_0x293b7b&&(_0x157ea4=_0x31609f-0x1-_0x157ea4);const _0x2b63c0=Math['floor'](_0x54df2c),_0x54f825=Math['floor'](_0x157ea4),_0x5dc2be=Math[_0x5c04d4(0x5ed,0x64c)](_0x54df2c),_0x4b8c1e=Math[_0x5c04d4(0x5dc,0x616)](_0x5dc2be+0x1,_0x4b840c-0x1),_0x25980b=Math['floor'](_0x157ea4),_0x4b1b64=Math[_0x761fbd(0x248,0x27a)](_0x25980b+0x1,_0x31609f-0x1),_0x3c5163=_0x54df2c-_0x5dc2be,_0x10135f=_0x157ea4-_0x25980b,_0x46c68f=_0x54f825*_0x4b840c+_0x2b63c0,_0x2eded4=_0x25980b*_0x4b840c+_0x5dc2be,_0x3f2fdc=_0x25980b*_0x4b840c+_0x4b8c1e,_0x508192=_0x4b1b64*_0x4b840c+_0x5dc2be,_0x3329ee=_0x4b1b64*_0x4b840c+_0x4b8c1e,_0x3ae4b2=_0xd64309['array'][_0x2eded4],_0x452cf2=_0xd64309['array'][_0x3f2fdc],_0xd38716=_0xd64309['array'][_0x508192],_0x63ddac=_0xd64309[_0x761fbd(0x232,0x2b2)][_0x3329ee];function _0x761fbd(_0x1721aa,_0x17ce8f){return _0x27febc(_0x17ce8f-0x2c0,_0x1721aa);}const _0xb8b1b7=(0x1-_0x3c5163)*(0x1-_0x10135f)*_0x3ae4b2+_0x3c5163*(0x1-_0x10135f)*_0x452cf2+(0x1-_0x3c5163)*_0x10135f*_0xd38716+_0x3c5163*_0x10135f*_0x63ddac,_0x3c1ece=_0x11725f[_0x5c04d4(0x614,0x592)][_0x2eded4],_0x5f5184=_0x11725f['array'][_0x3f2fdc],_0x3961dc=_0x11725f['array'][_0x508192],_0x527a5b=_0x11725f[_0x5c04d4(0x614,0x5c9)][_0x3329ee],_0x324442=(0x1-_0x3c5163)*(0x1-_0x10135f)*_0x3c1ece+_0x3c5163*(0x1-_0x10135f)*_0x5f5184+(0x1-_0x3c5163)*_0x10135f*_0x3961dc+_0x3c5163*_0x10135f*_0x527a5b,_0x194d39=Math[_0x5c04d4(0x5af,0x637)](_0xb8b1b7*_0xb8b1b7+_0x324442*_0x324442),_0x3c501b={};_0x3c501b['u']=_0xd64309['array'][_0x46c68f],_0x3c501b['v']=_0x11725f[_0x761fbd(0x2ca,0x2b2)][_0x46c68f];function _0x5c04d4(_0x20b714,_0x52de99){return _0x4445ca(_0x52de99,_0x20b714-0x62);}_0x3c501b['speed']=_0x36766c['array'][_0x46c68f];const _0x4b4d95={};_0x4b4d95['u']=_0xb8b1b7,_0x4b4d95['v']=_0x324442,_0x4b4d95[_0x5c04d4(0x5c4,0x5a9)]=_0x194d39;const _0xb8a85c={};return _0xb8a85c['original']=_0x3c501b,_0xb8a85c[_0x5c04d4(0x5c0,0x5a4)]=_0x4b4d95,_0xb8a85c;}}mars3d__namespace['LayerUtil']['register']('wind',WindLayer),mars3d__namespace['layer']['WindLayer']=WindLayer;class CanvasParticle{constructor(){this[_0x426556(0x2a2,0x2ca)]=null;function _0x426556(_0x1ff5f7,_0x47c4d9){return _0x4445ca(_0x1ff5f7,_0x47c4d9- -0x278);}this['lat']=null,this['tlng']=null,this[_0x426556(0x32a,0x2de)]=null;function _0x2b39ec(_0x4e7463,_0x2bbf01){return _0x27febc(_0x4e7463-0x1d3,_0x2bbf01);}this[_0x426556(0x31f,0x367)]=null,this['speed']=null;}[_0x27febc(-0x37,-0x34)](){for(const _0x163021 in this){delete this[_0x163021];}}}class CanvasWindField{constructor(_0x4f4860){this['setOptions'](_0x4f4860);}get[_0x27febc(0x9,0x49)](){function _0x3f4742(_0x476f01,_0x2c25a3){return _0x27febc(_0x2c25a3-0x262,_0x476f01);}return this[_0x3f4742(0x214,0x213)];}set[_0x27febc(0x9,-0x8)](_0x33a58a){function _0x288628(_0xfcbc7f,_0x55f65c){return _0x27febc(_0x55f65c-0x59d,_0xfcbc7f);}function _0x9d6bde(_0x30e080,_0x2cff87){return _0x4445ca(_0x30e080,_0x2cff87- -0x33f);}this[_0x9d6bde(0x253,0x232)]=(0x64-(_0x33a58a>0x63?0x63:_0x33a58a))*0x64,this['_calc_speedRate']=[(this['xmax']-this['xmin'])/this[_0x288628(0x512,0x54e)],(this['ymax']-this['ymin'])/this['_speedRate']];}get[_0x27febc(-0x58,0x2f)](){return this['_maxAge'];}set['maxAge'](_0x25d261){this['_maxAge']=_0x25d261;}['setOptions'](_0x19892b){function _0x35329d(_0x26c01e,_0x24c59c){return _0x27febc(_0x24c59c-0x453,_0x26c01e);}this['options']=_0x19892b,this['maxAge']=_0x19892b['maxAge']||0x78;function _0x153138(_0x472f1e,_0x2f78c1){return _0x4445ca(_0x472f1e,_0x2f78c1- -0x4ed);}this['speedRate']=_0x19892b['speedRate']||0x32,this[_0x153138(0xd1,0x108)]=[];const _0x3814b7=_0x19892b['particlesNumber']||0x1000;for(let _0x2f112f=0x0;_0x2f112f<_0x3814b7;_0x2f112f++){const _0x4dbc8e=this[_0x35329d(0x525,0x4a3)](new CanvasParticle());this['particles'][_0x153138(0x12,0x46)](_0x4dbc8e);}}['setDate'](_0x960381){this[_0x887bf9(0x44f,0x3e5)]=_0x960381[_0x191997(-0xb2,-0x42)],this[_0x887bf9(0x435,0x488)]=_0x960381[_0x191997(0xdc,0x61)],this['xmin']=_0x960381['xmin'],this['xmax']=_0x960381['xmax'],this[_0x191997(0x43,0x59)]=_0x960381[_0x887bf9(0x44c,0x480)],this[_0x887bf9(0x39e,0x390)]=_0x960381[_0x887bf9(0x37c,0x390)],this['grid']=[];const _0x31d7d0=_0x960381['udata'];function _0x191997(_0x2a7177,_0x328fe4){return _0x4445ca(_0x2a7177,_0x328fe4- -0x5a7);}const _0x11d16a=_0x960381['vdata'];let _0x76bb0e=![];function _0x887bf9(_0x21371a,_0x134f02){return _0x27febc(_0x134f02-0x440,_0x21371a);}_0x31d7d0['length']===this['rows']&&_0x31d7d0[0x0]['length']===this['cols']&&(_0x76bb0e=!![]);let _0x540fbe=0x0,_0x239ed7=null,_0xc5312c=null;for(let _0xc734dc=0x0;_0xc734dc<this['rows'];_0xc734dc++){_0x239ed7=[];for(let _0x155bc0=0x0;_0x155bc0<this['cols'];_0x155bc0++,_0x540fbe++){_0x76bb0e?_0xc5312c=this[_0x887bf9(0x3e2,0x3f4)](_0x31d7d0[_0xc734dc][_0x155bc0],_0x11d16a[_0xc734dc][_0x155bc0]):_0xc5312c=this['_calcUV'](_0x31d7d0[_0x540fbe],_0x11d16a[_0x540fbe]),_0x239ed7['push'](_0xc5312c);}this[_0x191997(-0x29,-0x9)]['push'](_0x239ed7);}!this[_0x887bf9(0x453,0x465)]['flipY']&&this[_0x887bf9(0x439,0x41e)]['reverse']();}['clear'](){function _0x46f32a(_0x1607e6,_0x301e12){return _0x4445ca(_0x1607e6,_0x301e12- -0x14f);}delete this['rows'];function _0x4f61f3(_0x6f8685,_0x509e71){return _0x4445ca(_0x509e71,_0x6f8685- -0x552);}delete this[_0x4f61f3(0xb6,0xf3)],delete this[_0x46f32a(0x417,0x475)],delete this['xmax'],delete this['ymin'],delete this['ymax'],delete this['grid'],delete this['particles'];}[_0x27febc(-0x23,-0x8f)](_0x589e3b,_0x4c0642){function _0x264d71(_0x37d957,_0x4d3afa){return _0x27febc(_0x4d3afa-0x5a2,_0x37d957);}const _0x19d7f8=(_0x589e3b-this['xmin'])/(this['xmax']-this['xmin'])*(this[_0xd6c77b(0x4e,0x49)]-0x1);function _0xd6c77b(_0x34000d,_0x114ecb){return _0x4445ca(_0x114ecb,_0x34000d- -0x5ba);}const _0x4f9bd9=(this['ymax']-_0x4c0642)/(this[_0x264d71(0x4c3,0x4f2)]-this['ymin'])*(this['rows']-0x1);return[_0x19d7f8,_0x4f9bd9];}[_0x4445ca(0x50c,0x52c)](_0x1b6f81,_0x29ade4){if(_0x1b6f81<0x0||_0x1b6f81>=this[_0x3aade5(0x129,0x155)]||_0x29ade4>=this['rows'])return[0x0,0x0,0x0];const _0x4296e9=Math['floor'](_0x1b6f81),_0x5ac5a1=Math['floor'](_0x29ade4);if(_0x4296e9===_0x1b6f81&&_0x5ac5a1===_0x29ade4)return this['grid'][_0x29ade4][_0x1b6f81];const _0xaa43cf=_0x4296e9+0x1;function _0x3aade5(_0x5cc5d7,_0x1e6f16){return _0x4445ca(_0x1e6f16,_0x5cc5d7- -0x4df);}const _0x4af8ec=_0x5ac5a1+0x1,_0x58652e=this['getUVByXY'](_0x4296e9,_0x5ac5a1),_0x16ff27=this[_0x299209(0x15f,0x11d)](_0xaa43cf,_0x5ac5a1);function _0x299209(_0x232553,_0x14ec50){return _0x4445ca(_0x232553,_0x14ec50- -0x40f);}const _0x19973f=this['getUVByXY'](_0x4296e9,_0x4af8ec),_0x437c9c=this[_0x299209(0x16d,0x11d)](_0xaa43cf,_0x4af8ec);let _0x429c4f=null;try{_0x429c4f=this['_bilinearInterpolation'](_0x1b6f81-_0x4296e9,_0x29ade4-_0x5ac5a1,_0x58652e,_0x16ff27,_0x19973f,_0x437c9c);}catch(_0x2cf33c){console[_0x299209(0x114,0x11b)](_0x1b6f81,_0x29ade4);}return _0x429c4f;}['_bilinearInterpolation'](_0x26c5e3,_0x51f1e2,_0x4a4dcd,_0x336b74,_0x4cb6a4,_0x2fea48){const _0xc051bf=0x1-_0x26c5e3,_0x114a7c=0x1-_0x51f1e2,_0x16b9c3=_0xc051bf*_0x114a7c,_0x3e7b81=_0x26c5e3*_0x114a7c,_0xaabec2=_0xc051bf*_0x51f1e2,_0x582a13=_0x26c5e3*_0x51f1e2,_0x47e6d4=_0x4a4dcd[0x0]*_0x16b9c3+_0x336b74[0x0]*_0x3e7b81+_0x4cb6a4[0x0]*_0xaabec2+_0x2fea48[0x0]*_0x582a13,_0x335ea7=_0x4a4dcd[0x1]*_0x16b9c3+_0x336b74[0x1]*_0x3e7b81+_0x4cb6a4[0x1]*_0xaabec2+_0x2fea48[0x1]*_0x582a13;return this['_calcUV'](_0x47e6d4,_0x335ea7);}['_calcUV'](_0x4f4465,_0xb9e396){function _0x45c571(_0x41788b,_0x113df8){return _0x4445ca(_0x113df8,_0x41788b- -0x558);}return[+_0x4f4465,+_0xb9e396,Math[_0x45c571(-0xb,0x7)](_0x4f4465*_0x4f4465+_0xb9e396*_0xb9e396)];}['getUVByPoint'](_0x4d502a,_0x10602f){if(!this[_0x27d962(-0xfb,-0x163)](_0x4d502a,_0x10602f))return null;function _0x545a4b(_0x1d3e26,_0x133043){return _0x27febc(_0x133043-0x244,_0x1d3e26);}const _0xfe510f=this[_0x27d962(-0x162,-0x103)](_0x4d502a,_0x10602f),_0x53eed7=this['getUVByXY'](_0xfe510f[0x0],_0xfe510f[0x1]);function _0x27d962(_0x2a9414,_0x478203){return _0x4445ca(_0x478203,_0x2a9414- -0x6ff);}return _0x53eed7;}[_0x27febc(0x44,0xa4)](_0x497dc1,_0x2068eb){function _0x4ac8c2(_0x303ee5,_0x12e81b){return _0x4445ca(_0x303ee5,_0x12e81b- -0x36b);}function _0x4df925(_0x466b4f,_0x501d77){return _0x27febc(_0x501d77-0x46d,_0x466b4f);}return _0x497dc1>=this[_0x4ac8c2(0x2ce,0x259)]&&_0x497dc1<=this[_0x4df925(0x3b5,0x3e4)]&&_0x2068eb>=this[_0x4df925(0x516,0x4ad)]&&_0x2068eb<=this['ymax']?!![]:![];}['getRandomLatLng'](){const _0x3667de=fRandomByfloat(this[_0x12d04a(0xf9,0xca)],this['xmax']),_0x4afbae=fRandomByfloat(this['ymin'],this['ymax']);function _0x39b21b(_0xb71763,_0x3dbee2){return _0x27febc(_0x3dbee2-0xbe,_0xb71763);}const _0x44ab68={};_0x44ab68['lat']=_0x4afbae,_0x44ab68[_0x12d04a(0x77,-0x4)]=_0x3667de;function _0x12d04a(_0x29030b,_0x1a475f){return _0x27febc(_0x29030b-0xf5,_0x1a475f);}return _0x44ab68;}[_0x4445ca(0x636,0x5e8)](){let _0x49471b,_0x388389,_0x326ab4;for(let _0x29ae34=0x0,_0x2fb3ca=this['particles'][_0x11d7f1(0x4e2,0x549)];_0x29ae34<_0x2fb3ca;_0x29ae34++){let _0x187034=this['particles'][_0x29ae34];_0x187034['age']<=0x0&&(_0x187034=this[_0x524e82(0x3e6,0x39d)](_0x187034));if(_0x187034['age']>0x0){const _0x18c21e=_0x187034['tlng'],_0x5c0862=_0x187034['tlat'];_0x326ab4=this['getUVByPoint'](_0x18c21e,_0x5c0862),_0x326ab4?(_0x49471b=_0x18c21e+this['_calc_speedRate'][0x0]*_0x326ab4[0x0],_0x388389=_0x5c0862+this['_calc_speedRate'][0x1]*_0x326ab4[0x1],_0x187034[_0x11d7f1(0x51d,0x57e)]=_0x18c21e,_0x187034[_0x524e82(0x35a,0x315)]=_0x5c0862,_0x187034['tlng']=_0x49471b,_0x187034[_0x524e82(0x32f,0x2e3)]=_0x388389,_0x187034['speed']=_0x326ab4[0x2],_0x187034[_0x524e82(0x3da,0x36c)]--):_0x187034[_0x11d7f1(0x5ba,0x53a)]=0x0;}}function _0x11d7f1(_0x6649ab,_0x190cd8){return _0x27febc(_0x6649ab-0x59b,_0x190cd8);}function _0x524e82(_0x2c01a2,_0x5d4e39){return _0x4445ca(_0x2c01a2,_0x5d4e39- -0x273);}return this[_0x11d7f1(0x5d0,0x620)];}[_0x27febc(0x50,0x1d)](_0x4143d8){let _0x4d009b,_0x56a8de;function _0x5a4b2e(_0x10b44c,_0x379ec0){return _0x4445ca(_0x10b44c,_0x379ec0-0x27);}for(let _0x24beff=0x0;_0x24beff<0x1e;_0x24beff++){_0x4d009b=this['getRandomLatLng'](),_0x56a8de=this[_0x562862(0x4ad,0x46e)](_0x4d009b[_0x5a4b2e(0x528,0x569)],_0x4d009b['lat']);if(_0x56a8de&&_0x56a8de[0x2]>0x0)break;}if(!_0x56a8de)return _0x4143d8;const _0x537e81=_0x4d009b['lng']+this[_0x5a4b2e(0x66c,0x634)][0x0]*_0x56a8de[0x0],_0x8e49a8=_0x4d009b['lat']+this['_calc_speedRate'][0x1]*_0x56a8de[0x1];_0x4143d8[_0x5a4b2e(0x51a,0x569)]=_0x4d009b[_0x562862(0x3e6,0x3fa)];function _0x562862(_0x2581b1,_0x50b1bc){return _0x4445ca(_0x2581b1,_0x50b1bc- -0x148);}return _0x4143d8['lat']=_0x4d009b['lat'],_0x4143d8[_0x562862(0x3e7,0x463)]=_0x537e81,_0x4143d8['tlat']=_0x8e49a8,_0x4143d8['age']=Math[_0x562862(0x372,0x3d2)](0xa+Math[_0x5a4b2e(0x615,0x599)]()*this['maxAge']),_0x4143d8[_0x562862(0x453,0x41a)]=_0x56a8de[0x2],_0x4143d8;}[_0x27febc(-0x37,-0x99)](){for(const _0x21b05b in this){delete this[_0x21b05b];}}}function fRandomByfloat(_0xfdff4f,_0x14743d){function _0x39eb5f(_0x2aaa8a,_0x3f71cc){return _0x4445ca(_0x3f71cc,_0x2aaa8a- -0x49a);}return _0xfdff4f+Math[_0x39eb5f(0xd8,0x52)]()*(_0x14743d-_0xfdff4f);}const Cesium=mars3d__namespace[_0x4445ca(0x526,0x545)],BaseLayer=mars3d__namespace['layer']['BaseLayer'];class CanvasWindLayer extends BaseLayer{constructor(_0x12a0d4={}){function _0xb2a53c(_0xf30bab,_0x3c5615){return _0x4445ca(_0xf30bab,_0x3c5615- -0x6e5);}super(_0x12a0d4),this['_setOptionsHook'](_0x12a0d4),this['canvas']=null;function _0x1dd362(_0x1658f5,_0x45edd4){return _0x4445ca(_0x45edd4,_0x1658f5- -0x29f);}_0x12a0d4[_0xb2a53c(-0x1b3,-0x158)]&&_0x12a0d4['steps']&&(this[_0xb2a53c(-0x21f,-0x1af)]=new mars3d__namespace[(_0x1dd362(0x2dd,0x320))](_0x12a0d4));}[_0x4445ca(0x5e6,0x5c8)](_0xfccc45,_0x293f4a){function _0x43f1c1(_0x5b3908,_0x326a18){return _0x4445ca(_0x326a18,_0x5b3908-0x7);}this['frameTime']=0x3e8/(_0xfccc45['frameRate']||0xa),this['_pointerEvents']=this['options']['pointerEvents']??![],this['color']=_0xfccc45[_0x43f1c1(0x5dc,0x57a)]||'#ffffff',this[_0x43f1c1(0x57a,0x5dc)]=_0xfccc45['lineWidth']||0x1,this['fixedHeight']=_0xfccc45['fixedHeight']??0x0,this['flipY']=_0xfccc45['flipY']??![];function _0x15b7ef(_0x4660bc,_0x3a25ff){return _0x27febc(_0x3a25ff-0x644,_0x4660bc);}this[_0x43f1c1(0x576,0x51f)]&&this['windField'][_0x15b7ef(0x5e9,0x5c4)](_0xfccc45);}get['layer'](){function _0x35113f(_0xa9537,_0x5cdd94){return _0x27febc(_0xa9537-0x2a9,_0x5cdd94);}return this[_0x35113f(0x2d0,0x2d8)];}get['canvasWidth'](){return this['_map']['scene']['canvas']['clientWidth'];}get[_0x27febc(0x4e,0x14)](){function _0x2876c6(_0xe96394,_0x6e7217){return _0x27febc(_0x6e7217-0x2ad,_0xe96394);}function _0x406c04(_0x320501,_0x14e1a5){return _0x4445ca(_0x14e1a5,_0x320501- -0x7f);}return this[_0x406c04(0x483,0x469)][_0x406c04(0x4b1,0x4b4)]['canvas']['clientHeight'];}get[_0x27febc(-0x6,-0x2)](){return this['_pointerEvents'];}set['pointerEvents'](_0x2d286e){function _0x5f2c2a(_0x597978,_0x11412e){return _0x4445ca(_0x597978,_0x11412e- -0x389);}this[_0x3d05f0(-0xd,-0x33)]=_0x2d286e;function _0x3d05f0(_0x59a6f7,_0x5373a8){return _0x27febc(_0x59a6f7-0x38,_0x5373a8);}if(!this[_0x3d05f0(0x5f,-0xa)])return;_0x2d286e?this['canvas'][_0x3d05f0(0x56,0x8e)][_0x3d05f0(-0x4a,-0x74)]='all':this[_0x3d05f0(0x5f,0xd1)]['style'][_0x3d05f0(-0x4a,-0x33)]=_0x3d05f0(-0x8,0x6f);}get['particlesNumber'](){function _0x1bf6c2(_0x2af336,_0x162a7b){return _0x4445ca(_0x2af336,_0x162a7b- -0x400);}function _0xefefe6(_0x1b25b8,_0x163a43){return _0x27febc(_0x163a43-0xc8,_0x1b25b8);}return this[_0x1bf6c2(0x23e,0x1e5)][_0xefefe6(0x93,0x10b)];}set['particlesNumber'](_0x4d49c8){function _0x4e6a02(_0x555a31,_0xeb7113){return _0x27febc(_0x555a31-0xbe,_0xeb7113);}this['options'][_0x4e6a02(0x101,0xb3)]=_0x4d49c8,clearTimeout(this['_canrefresh']);function _0x51c566(_0x5e8568,_0x14571b){return _0x4445ca(_0x5e8568,_0x14571b- -0x3f7);}this[_0x4e6a02(0x29,0x5e)]=setTimeout(()=>{this['redraw']();},0x1f4);}get[_0x4445ca(0x5ec,0x5c9)](){function _0x4e0fd7(_0x739bf9,_0x49d14a){return _0x27febc(_0x49d14a-0x60,_0x739bf9);}function _0x5bb07b(_0x570c4a,_0x433077){return _0x4445ca(_0x433077,_0x570c4a- -0x7b);}return this[_0x4e0fd7(0x18,0x85)][_0x5bb07b(0x54e,0x4ee)];}set[_0x27febc(0x9,0x25)](_0xd96477){this['options']['speedRate']=_0xd96477;function _0x4c9ee3(_0x5c3c97,_0x15faf5){return _0x4445ca(_0x15faf5,_0x5c3c97-0x4);}this[_0x4c9ee3(0x573,0x588)]&&(this['windField']['speedRate']=_0xd96477);}get['maxAge'](){function _0x5456e5(_0xa71a24,_0x3a73fd){return _0x4445ca(_0x3a73fd,_0xa71a24- -0xb4);}return this[_0x5456e5(0x531,0x529)]['maxAge'];}set['maxAge'](_0x10d90f){function _0x5bdd37(_0x112654,_0x1bd1cd){return _0x4445ca(_0x112654,_0x1bd1cd- -0x57);}function _0x12510a(_0x17b97c,_0x383f9d){return _0x4445ca(_0x383f9d,_0x17b97c- -0x365);}this[_0x12510a(0x280,0x232)][_0x12510a(0x203,0x20a)]=_0x10d90f,this['windField']&&(this[_0x12510a(0x20a,0x259)]['maxAge']=_0x10d90f);}get['data'](){return this['windData'];}set['data'](_0x20d466){this['setData'](_0x20d466);}get[_0x4445ca(0x582,0x522)](){function _0x253ab4(_0x458b6c,_0x2ff4a2){return _0x4445ca(_0x458b6c,_0x2ff4a2- -0x5c1);}let _0x18e637=this['windData'][_0x253ab4(-0x68,0x3)];function _0x1efccc(_0x4a91df,_0x3bff86){return _0x27febc(_0x3bff86- -0x46,_0x4a91df);}let _0xed1995=this[_0x253ab4(0x33,-0xd)]['xmax'],_0x6035aa=this[_0x253ab4(-0x94,-0xd)]['ymin'],_0x291354=this['windData']['ymax'];return _0xed1995>=0x167&&_0x18e637===0x0&&(_0x18e637=-0xb4,_0xed1995=0xb4),_0x18e637=Math['max'](_0x18e637,-0xb4),_0xed1995=Math[_0x253ab4(-0x6e,-0x47)](_0xed1995,0xb4),_0x6035aa=Math['max'](_0x6035aa,-0x5a),_0x291354=Math['min'](_0x291354,0x5a),Cesium['Rectangle']['fromDegrees'](_0x18e637,_0x6035aa,_0xed1995,_0x291354);}['_showHook'](_0x16e18b){function _0x3bc1dd(_0x17f268,_0x551911){return _0x4445ca(_0x551911,_0x17f268- -0x361);}function _0x554d38(_0x1ac979,_0x205a16){return _0x4445ca(_0x1ac979,_0x205a16- -0x456);}_0x16e18b?this['_addedHook']():(this[_0x3bc1dd(0x253,0x1e0)]&&(this['options']['data']=this[_0x3bc1dd(0x253,0x295)]),this[_0x3bc1dd(0x25c,0x2d6)]());}[_0x27febc(0x18,0x97)](){function _0x2ef02e(_0x4a3171,_0x24057c){return _0x4445ca(_0x4a3171,_0x24057c- -0x4da);}function _0x296403(_0x1b546e,_0x51acba){return _0x4445ca(_0x1b546e,_0x51acba- -0x10c);}this['options'][_0x296403(0x44b,0x423)]?this['initWorker']():this['windField']=new CanvasWindField(this[_0x296403(0x485,0x4d9)]);}[_0x27febc(-0x1a,0x64)](){this[_0x25fbaa(0x1ea,0x1cc)]=this['_createCanvas']();function _0x25fbaa(_0x29576f,_0x5b44dc){return _0x27febc(_0x29576f-0x1c3,_0x5b44dc);}const _0x39c607={};function _0x4a693c(_0x260136,_0x4eb842){return _0x27febc(_0x260136-0x10c,_0x4eb842);}_0x39c607[_0x25fbaa(0x16f,0x1b9)]=!![],this['canvasContext']=this[_0x25fbaa(0x1ea,0x1d5)]['getContext']('2d',_0x39c607),this['bindEvent'](),this['options'][_0x4a693c(0xde,0x54)]&&this['setData'](this[_0x4a693c(0x131,0x106)][_0x4a693c(0xde,0x64)]);}['_removedHook'](){function _0x11488c(_0x59f614,_0x4da999){return _0x4445ca(_0x59f614,_0x4da999- -0x16c);}this['clear']();function _0x9a47f6(_0x544119,_0x3e00d0){return _0x4445ca(_0x544119,_0x3e00d0- -0x2f1);}this[_0x9a47f6(0x249,0x233)](),this['canvas']&&(this['_map']['container'][_0x9a47f6(0x32b,0x2b2)](this['canvas']),delete this['canvas']);}['_createCanvas'](){const _0x19d4f3=mars3d__namespace['DomUtil'][_0x5e09f4(0x3ec,0x41d)](_0x5e09f4(0x449,0x448),'mars3d-canvasWind',this[_0x1663d4(0x2ef,0x372)]['container']);function _0x5e09f4(_0x429e7f,_0x1568bf){return _0x27febc(_0x1568bf-0x421,_0x429e7f);}_0x19d4f3['style']['position']='absolute',_0x19d4f3[_0x1663d4(0x3cb,0x40b)][_0x5e09f4(0x4e7,0x472)]='0px',_0x19d4f3[_0x1663d4(0x3cb,0x3be)][_0x5e09f4(0x3ee,0x37e)]=_0x5e09f4(0x3f9,0x423),_0x19d4f3[_0x1663d4(0x3cb,0x3ad)][_0x5e09f4(0x450,0x44a)]=this[_0x5e09f4(0x2ff,0x363)][_0x1663d4(0x31d,0x38d)]['canvas']['clientWidth']+'px',_0x19d4f3['style']['height']=this['_map'][_0x5e09f4(0x40b,0x391)]['canvas'][_0x5e09f4(0x42a,0x46a)]+'px',_0x19d4f3[_0x5e09f4(0x454,0x43f)]['pointerEvents']=this[_0x5e09f4(0x44e,0x3dc)]?'auto':_0x1663d4(0x36d,0x3f0),_0x19d4f3['style']['zIndex']=this[_0x5e09f4(0x45c,0x446)]['zIndex']??0x9,_0x19d4f3[_0x1663d4(0x3d6,0x34d)]=this['_map']['scene'][_0x5e09f4(0x429,0x448)]['clientWidth'],_0x19d4f3['height']=this['_map']['scene'][_0x1663d4(0x3d4,0x3a3)]['clientHeight'];function _0x1663d4(_0xfc9f59,_0x5bc277){return _0x27febc(_0xfc9f59-0x3ad,_0x5bc277);}return _0x19d4f3;}[_0x4445ca(0x48e,0x512)](){function _0x4114e3(_0xade68a,_0x3a36bf){return _0x27febc(_0x3a36bf-0x534,_0xade68a);}function _0x47667d(_0x371c26,_0x50ee7e){return _0x27febc(_0x50ee7e-0x599,_0x371c26);}this['canvas']&&(this[_0x47667d(0x60f,0x5c0)]['style']['width']=this[_0x4114e3(0x3fd,0x476)][_0x47667d(0x568,0x509)]['canvas']['clientWidth']+'px',this['canvas']['style']['height']=this['_map'][_0x47667d(0x519,0x509)]['canvas']['clientHeight']+'px',this[_0x4114e3(0x527,0x55b)]['width']=this['_map']['scene']['canvas']['clientWidth'],this['canvas']['height']=this['_map']['scene'][_0x4114e3(0x594,0x55b)][_0x47667d(0x647,0x5e2)]);}['bindEvent'](){function _0x486cbf(_0x1e35ee,_0x4b5f4b){return _0x4445ca(_0x1e35ee,_0x4b5f4b- -0x6e9);}const _0x43e2df=this;let _0x12a721=Date[_0x486cbf(-0x15b,-0x1a2)]();(function _0x170142(){if(_0x43e2df['isDestroy'])return;function _0x82f0ee(_0x435325,_0xc57a23){return _0x486cbf(_0x435325,_0xc57a23-0x3ef);}_0x43e2df['_animateFrame']=window['requestAnimationFrame'](_0x170142);function _0x4196f1(_0x1b8015,_0x15a10e){return _0x486cbf(_0x15a10e,_0x1b8015-0x605);}if(_0x43e2df['show']&&_0x43e2df['windField']){const _0x422eb7=Date[_0x82f0ee(0x2c1,0x24d)](),_0xc0cda7=_0x422eb7-_0x12a721;_0xc0cda7>_0x43e2df['frameTime']&&(_0x12a721=_0x422eb7-_0xc0cda7%_0x43e2df['frameTime'],_0x43e2df[_0x4196f1(0x477,0x40b)]());}}(),window['addEventListener']('resize',this['resize']['bind'](this),![]),this['mouse_down']=![]);function _0x401504(_0x1359b4,_0x5cd8a6){return _0x4445ca(_0x1359b4,_0x5cd8a6- -0x63c);}this['mouse_move']=![],this['options']['mouseHidden']&&(this['_map']['on'](mars3d__namespace['EventType']['wheel'],this['_onMapWhellEvent'],this),this[_0x486cbf(-0x182,-0x1e7)]['on'](mars3d__namespace[_0x486cbf(-0x16f,-0x1d1)][_0x401504(-0x1b5,-0x132)],this[_0x401504(-0x1a3,-0x12e)],this),this['_map']['on'](mars3d__namespace['EventType']['mouseUp'],this[_0x486cbf(-0xe0,-0x107)],this));}[_0x27febc(-0x9c,-0x46)](){window['cancelAnimationFrame'](this['_animateFrame']),delete this['_animateFrame'];function _0x28b280(_0x452260,_0x19609b){return _0x4445ca(_0x452260,_0x19609b- -0x566);}function _0x45718f(_0x15065b,_0x69b42e){return _0x27febc(_0x15065b-0x281,_0x69b42e);}window[_0x45718f(0x22f,0x1bb)]('resize',this[_0x28b280(-0xc2,-0x54)]),this['options'][_0x45718f(0x1e1,0x195)]&&(this['_map'][_0x28b280(-0x64,0x1d)](mars3d__namespace[_0x28b280(0x7,-0x4e)]['wheel'],this['_onMapWhellEvent'],this),this['_map']['off'](mars3d__namespace[_0x45718f(0x1d9,0x18d)][_0x28b280(-0x90,-0x5c)],this[_0x45718f(0x1cf,0x229)],this),this[_0x45718f(0x1c3,0x1d5)]['off'](mars3d__namespace['EventType'][_0x28b280(-0xa5,-0x1e)],this['_onMouseUpEvent'],this),this[_0x28b280(0x4,-0x64)]['off'](mars3d__namespace['EventType']['mouseMove'],this['_onMouseMoveEvent'],this));}[_0x4445ca(0x5c5,0x54a)](_0x2b0f28){function _0xe2d57c(_0x132e7a,_0x42de62){return _0x4445ca(_0x42de62,_0x132e7a- -0xfb);}function _0x142e27(_0x11576a,_0x4303a0){return _0x27febc(_0x11576a-0x1e2,_0x4303a0);}clearTimeout(this['refreshTimer']);if(!this['show']||!this[_0xe2d57c(0x4ec,0x54a)])return;this['canvas'][_0x142e27(0x200,0x242)][_0x142e27(0x1c7,0x212)]='hidden',this[_0x142e27(0x1d9,0x262)]=setTimeout(()=>{function _0x22ca80(_0x466a08,_0x18e697){return _0x142e27(_0x18e697- -0x220,_0x466a08);}if(!this['show'])return;function _0x5d2f1d(_0x145dc7,_0x781df0){return _0x142e27(_0x145dc7- -0x15e,_0x781df0);}this[_0x22ca80(-0x119,-0xf8)](),this[_0x22ca80(0x1c,-0x17)]['style']['visibility']='visible';},0xc8);}['_onMouseDownEvent'](_0x1bcf96){function _0x1f0a76(_0x323ac8,_0x1b0159){return _0x27febc(_0x1b0159-0x148,_0x323ac8);}this[_0x1f0a76(0x9d,0xf5)]=!![];function _0x3d8ccf(_0x25834d,_0x328be4){return _0x27febc(_0x328be4-0xfd,_0x25834d);}this['_map']['off'](mars3d__namespace[_0x3d8ccf(0x3,0x55)][_0x3d8ccf(0x95,0xd8)],this[_0x3d8ccf(0xfe,0xfc)],this),this['_map']['on'](mars3d__namespace[_0x3d8ccf(0xa0,0x55)]['mouseMove'],this[_0x1f0a76(0x17a,0x147)],this);}[_0x4445ca(0x640,0x5bf)](_0x19074d){function _0x529093(_0xae9016,_0x310955){return _0x4445ca(_0xae9016,_0x310955- -0x3fa);}function _0xe20fcf(_0x4d3d72,_0x3fc510){return _0x27febc(_0x4d3d72-0x64f,_0x3fc510);}if(!this['show']||!this['canvas'])return;this['mouse_down']&&(this[_0x529093(0x240,0x1ed)]['style']['visibility']='hidden',this[_0xe20fcf(0x652,0x604)]=!![]);}[_0x27febc(0x22,0x97)](_0x5d12c3){function _0x23409a(_0x1eed03,_0x34ccb7){return _0x4445ca(_0x1eed03,_0x34ccb7- -0x1a1);}if(!this['show']||!this[_0x14c33d(0x97,0x61)])return;this['_map'][_0x14c33d(0x33,0x51)](mars3d__namespace[_0x14c33d(-0x38,0x4c)][_0x14c33d(0x4b,-0x1c)],this[_0x23409a(0x3c5,0x41e)],this);this['mouse_down']&&this[_0x23409a(0x4ab,0x422)]&&this[_0x23409a(0x34e,0x365)]();this[_0x23409a(0x407,0x446)]['style'][_0x14c33d(0x55,0x9c)]='visible';function _0x14c33d(_0x5772e1,_0x1255cb){return _0x4445ca(_0x1255cb,_0x5772e1- -0x550);}this[_0x23409a(0x442,0x3cc)]=![],this['mouse_move']=![];}[_0x27febc(0x16,0x51)](_0x5a667b){function _0x3f80a9(_0x494e81,_0x567b20){return _0x4445ca(_0x567b20,_0x494e81- -0x6fb);}this['clear'](),this[_0x3f80a9(-0x147,-0xf4)]=_0x5a667b,this[_0x415410(-0x64,-0xe7)][_0x3f80a9(-0xec,-0x85)](_0x5a667b);function _0x415410(_0x3d66d3,_0x255d1f){return _0x4445ca(_0x3d66d3,_0x255d1f- -0x656);}this['redraw']();}['redraw'](){function _0x224198(_0x4fea09,_0x52915e){return _0x4445ca(_0x52915e,_0x4fea09- -0x591);}function _0x3b1b40(_0x3edd22,_0x1107f8){return _0x4445ca(_0x3edd22,_0x1107f8- -0xe4);}if(!this['show'])return;this[_0x224198(-0x22,0x56)][_0x3b1b40(0x400,0x45c)](this[_0x224198(0x54,0x8e)]),this['update']();}['update'](){function _0x3c2f0a(_0x4bcf3f,_0x41babe){return _0x4445ca(_0x41babe,_0x4bcf3f- -0x366);}if(this['_updateIng'])return;function _0x5ec637(_0x13438b,_0x4f7f00){return _0x4445ca(_0x13438b,_0x4f7f00- -0x67d);}this[_0x3c2f0a(0x255,0x2b5)]=!![];if(this['worker'])this[_0x5ec637(-0xc5,-0x10e)]['update']();else{const _0x334a71=this[_0x3c2f0a(0x209,0x240)]['getParticles']();this['_drawLines'](_0x334a71);}this['_updateIng']=![];}['_drawLines'](_0x4dd270){this['_canvasParticles']=_0x4dd270,this['canvasContext'][_0x38918d(-0x46,0x1c)]='destination-in';function _0x4d4543(_0x7c134d,_0x162203){return _0x27febc(_0x7c134d-0x5b2,_0x162203);}this['canvasContext']['fillRect'](0x0,0x0,this['canvasWidth'],this['canvasHeight']);function _0x38918d(_0x1c41f3,_0x1f6563){return _0x4445ca(_0x1c41f3,_0x1f6563- -0x518);}this[_0x38918d(0xfc,0x8a)][_0x38918d(0x50,0x1c)]=_0x4d4543(0x549,0x5a9),this[_0x4d4543(0x594,0x539)]['globalAlpha']=0.9;const _0x57811d=this['_map'][_0x38918d(0x17,0x18)]['mode']!==Cesium['SceneMode'][_0x38918d(-0x71,-0x17)],_0x2eb1e8=this['canvasWidth']*0.25;if(this['_colorRamp'])for(let _0x7901dc=0x0,_0x17b045=_0x4dd270['length'];_0x7901dc<_0x17b045;_0x7901dc++){const _0x160dc1=_0x4dd270[_0x7901dc],_0x5c85f2=this[_0x38918d(0x65,-0x13)](_0x160dc1,_0x160dc1[_0x38918d(0xaa,0x2a)],_0x160dc1['lat'],_0x160dc1[_0x4d4543(0x4fe,0x582)]),_0x35ef53=this[_0x38918d(0x16,-0x13)](_0x160dc1,_0x160dc1['tlng'],_0x160dc1[_0x38918d(0x81,0x3e)],_0x160dc1['talt']);if(!_0x5c85f2||!_0x35ef53)continue;if(_0x57811d&&Math[_0x38918d(-0x5,0x6e)](_0x5c85f2[0x0]-_0x35ef53[0x0])>=_0x2eb1e8)continue;this['canvasContext']['beginPath'](),this['canvasContext'][_0x4d4543(0x565,0x4e8)]=this['lineWidth'],this[_0x38918d(0x95,0x8a)]['strokeStyle']=this[_0x38918d(0x6b,0x1e)]['getColor'](_0x160dc1['speed']),this[_0x4d4543(0x594,0x517)][_0x38918d(-0x8a,-0x10)](_0x5c85f2[0x0],_0x5c85f2[0x1]),this['canvasContext'][_0x38918d(0x86,0x9b)](_0x35ef53[0x0],_0x35ef53[0x1]),this['canvasContext']['stroke']();}else{this[_0x38918d(0xf2,0x8a)][_0x38918d(0x21,0x84)](),this[_0x38918d(0x5d,0x8a)][_0x4d4543(0x565,0x586)]=this[_0x4d4543(0x565,0x4ee)],this[_0x4d4543(0x594,0x555)][_0x4d4543(0x5dd,0x653)]=this['color'];for(let _0x2d9d93=0x0,_0x1c526d=_0x4dd270[_0x38918d(-0x13,-0x11)];_0x2d9d93<_0x1c526d;_0x2d9d93++){const _0x3fc465=_0x4dd270[_0x2d9d93],_0x586d97=this[_0x38918d(-0x7a,-0x13)](_0x3fc465,_0x3fc465['lng'],_0x3fc465['lat'],_0x3fc465['alt']),_0x511faf=this['_tomap'](_0x3fc465,_0x3fc465[_0x4d4543(0x59d,0x600)],_0x3fc465[_0x4d4543(0x548,0x4da)],_0x3fc465['talt']);if(!_0x586d97||!_0x511faf)continue;if(_0x57811d&&Math['abs'](_0x586d97[0x0]-_0x511faf[0x0])>=_0x2eb1e8)continue;this['canvasContext']['moveTo'](_0x586d97[0x0],_0x586d97[0x1]),this[_0x4d4543(0x594,0x5c3)][_0x38918d(0x76,0x9b)](_0x511faf[0x0],_0x511faf[0x1]);}this['canvasContext']['stroke']();}}['_tomap'](_0x5a831a,_0x57bdf3,_0x55fcf1,_0x4296ae){const _0x3bd017=Cesium[_0x2ff29a(0x489,0x4a1)]['fromDegrees'](_0x57bdf3,_0x55fcf1,_0x4296ae??this[_0x5ec0bb(-0x1c0,-0x1bd)]);function _0x5ec0bb(_0x30e818,_0x19cb6a){return _0x4445ca(_0x19cb6a,_0x30e818- -0x6c0);}const _0x2557d9=this['_map']['scene'];if(_0x2557d9['mode']===Cesium[_0x5ec0bb(-0x155,-0x1d8)][_0x2ff29a(0x49e,0x446)]){const _0x2d8c9b=new Cesium[(_0x2ff29a(0x476,0x452))](_0x2557d9['globe']['ellipsoid'],_0x2557d9[_0x5ec0bb(-0xce,-0x13f)][_0x2ff29a(0x4aa,0x48b)]),_0x30ddfe=_0x2d8c9b['isPointVisible'](_0x3bd017);if(!_0x30ddfe)return _0x5a831a['age']=0x0,null;}function _0x2ff29a(_0x32a4fd,_0x5e136b){return _0x27febc(_0x5e136b-0x505,_0x32a4fd);}const _0x3a1664=mars3d__namespace[_0x5ec0bb(-0x16b,-0x1db)][_0x2ff29a(0x3e3,0x46e)](this[_0x2ff29a(0x454,0x447)]['scene'],_0x3bd017);return _0x3a1664?[_0x3a1664['x'],_0x3a1664['y']]:null;}['clear'](){this[_0x3f8c46(0x26,0x69)]['clear']();function _0x3f8c46(_0x240e9f,_0x2ce695){return _0x27febc(_0x240e9f-0x77,_0x2ce695);}delete this['windData'];}['initWorker'](){this[_0x398ff0(0x29,-0x20)]=new Worker(this['options'][_0x23530c(0x559,0x592)]);function _0x398ff0(_0x562437,_0x2844f4){return _0x27febc(_0x562437-0xba,_0x2844f4);}this['worker'][_0x398ff0(0xfc,0x149)]=_0x380bca=>{this[_0x36de5e(0x118,0xf4)](_0x380bca['data'][_0x2b1808(0x3dc,0x36e)]);function _0x2b1808(_0x834687,_0x3810f4){return _0x398ff0(_0x834687-0x2ed,_0x3810f4);}function _0x36de5e(_0x3a0536,_0x43cbd1){return _0x23530c(_0x3a0536- -0x43a,_0x43cbd1);}this['_updateIng2']=![];};function _0x23530c(_0x428546,_0x7fe77b){return _0x27febc(_0x428546-0x5ea,_0x7fe77b);}this['windField']={'init':_0x4a7a14=>{function _0x1bb825(_0x2eb2e5,_0x35baa9){return _0x398ff0(_0x35baa9-0x1c2,_0x2eb2e5);}const _0x5ce180={};_0x5ce180['type']=_0x1d867e(0x4bb,0x479),_0x5ce180['options']=_0x4a7a14;function _0x1d867e(_0x2dbb08,_0x46534f){return _0x398ff0(_0x2dbb08-0x49a,_0x46534f);}this[_0x1d867e(0x4c3,0x44c)]['postMessage'](_0x5ce180);},'setOptions':_0x37f933=>{const _0x397936={};_0x397936[_0x2cace7(-0x20f,-0x188)]='setOptions',_0x397936[_0xb22568(0x2cb,0x30d)]=_0x37f933;function _0x2cace7(_0x1ef036,_0xe1e226){return _0x398ff0(_0xe1e226- -0x206,_0x1ef036);}function _0xb22568(_0x3d2587,_0x41831f){return _0x398ff0(_0x3d2587-0x1ec,_0x41831f);}this['worker']['postMessage'](_0x397936);},'setDate':_0x31c7b7=>{function _0x3fe3f0(_0x3c2abd,_0x3b77dc){return _0x398ff0(_0x3b77dc-0x49d,_0x3c2abd);}const _0x5357a1={};_0x5357a1[_0x361899(-0x128,-0x1b0)]=_0x361899(-0x9d,-0x11e);function _0x361899(_0x4c00f3,_0x6115f0){return _0x23530c(_0x4c00f3- -0x6d6,_0x6115f0);}_0x5357a1['data']=_0x31c7b7,this['worker'][_0x361899(-0x148,-0x140)](_0x5357a1);},'update':()=>{if(this['_updateIng2'])return;this['_updateIng2']=!![];function _0x3e4fb7(_0x3a6d0d,_0x45c663){return _0x398ff0(_0x45c663-0x11f,_0x3a6d0d);}function _0xef3d69(_0x19219d,_0x5b2a8b){return _0x398ff0(_0x19219d-0x4f8,_0x5b2a8b);}const _0x40abf5={};_0x40abf5['type']=_0x3e4fb7(0x1e4,0x174),this['worker'][_0x3e4fb7(0x139,0x17d)](_0x40abf5);},'clear':()=>{function _0x14433d(_0x1680bc,_0x1ce7e7){return _0x398ff0(_0x1ce7e7- -0x8b,_0x1680bc);}function _0x490b8d(_0x29a95a,_0x30446){return _0x398ff0(_0x30446-0x37f,_0x29a95a);}const _0x1168b0={};_0x1168b0[_0x490b8d(0x3ee,0x3fd)]='clear',this['worker'][_0x490b8d(0x41f,0x3dd)](_0x1168b0);}},this[_0x398ff0(0x69,0x96)][_0x398ff0(0x21,-0x2c)](this['options']);}}mars3d__namespace['LayerUtil']['register'](_0x27febc(0x3a,0xc2),CanvasWindLayer),mars3d__namespace['layer']['CanvasWindLayer']=CanvasWindLayer,mars3d__namespace[_0x4445ca(0x4fd,0x54c)]=CanvasWindField,mars3d__namespace['Log'][_0x4445ca(0x5d8,0x598)]('mars3d-wind插件注册成功\x20\x20\x20\x20\x20版本:'+version+'\x20\x20\x20\x20编译日期:'+buildTime),mars3d__namespace[_0x27febc(-0x87,-0xb9)]=WindUtil,exports['CanvasWindField']=CanvasWindField,exports[_0x27febc(0x13,-0x6e)]=CanvasWindLayer;function _0x4445ca(_0x22b220,_0x5c245e){return _0x34ed(_0x5c245e-0x32b,_0x22b220);}exports['WindLayer']=WindLayer,exports['WindUtil']=WindUtil;function _0x55d3(){const _0x2daba2=['tlat','lighter','CLAMP_TO_EDGE','MIN_VALUE','dropRate','update','Cartesian3','colorTextures','interpolated','Unknown\x20command\x20type','createSegmentsGeometry','quietPeriod','speed','dropRateBump','postMessage','rows','segments','windTextures','maxAge','onParticlesTextureSizeChange','SRC_ALPHA','SceneMode','willReadFrequently','mouse_down','removeEventListener','windField','updateOptions','_speedRate','random','lineWidth','_calcUV','sceneMode','height','getCalculateSpeedShader','fragmentShaderSource','globe','min','_pointerEvents','ColorRamp','Math','processWindData','2318325GcIoOY','none','48qsSROK','createPrimitives','off','type','blendFuncDestination','abs','colorTable','lat','destroy','1185876EpPzMq','floor','clearFramebuffers','colors','samplingWindow','enabled','outputTexture','computing','data','Compute','FUNC_ADD','FLOAT','viewport','persists','logInfo','layer','owner','mouseMove','beginPath','toGridXY','grid','commandToExecute','latRange','createRenderingFramebuffers','canvasContext','removeChild','changeOptions','visibility','_addedHook','toRadians','drawingBufferWidth','destroyParticlesTextures','segmentsColor','tlng','shaderProgram','LINEAR','viewerParameters','bind','keys','rendering','array','lineTo','windData','minificationFilter','getUVByPoint','refreshTimer','values','changed','pointerEvents','_updateIng','create','_removedHook','domain','_onMouseMoveEvent','context','NEAREST','0px','mouse_move','xmin','createColorTableTexture','pixelFormat','lonRange','_setOptionsHook','speedRate','framebuffers','displayRange','fromGeometry','warn','east','OPAQUE','slice','uniformMap','green','CanvasWindLayer','Draw','color','setData','getPrimitives','_mountedHook','Cartesian2','__proto__','error','south','nextParticlesPosition','style','age','clientWidth','currentParticlesPosition','_onMouseUpEvent','__esModule','magnificationFilter','options','1032qOZySI','canvas','getParticles','width','RED','strokeStyle','useViewerBounds','addEventListener','dynamic','rawRenderState','commandList','vertexShaderSource','camera','max\x20is\x20undefined,\x20calculate\x20max','frameRateMonitor','particles','createComputingPrimitives','toDegrees','createParticlesTextures','max','canvasWind','getSegmentDrawFragmentShader','stringify','blendEquation','show','pixelDatatype','ymin','framebuffer','onmessage','particlesNumber','isInExtent','initFrameRate','frameRateAdjustment','textures','cols','clientHeight','postProcessingPosition','pixelSize','particleSystem','_calc_speedRate','canvasHeight','setDate','_randomParticle','top','fromCache','rgb(206,255,255)','clearCommand','fixedHeight','SCENE3D','_map','particlesTextureSize','#version\x20300\x20es\x0aprecision\x20highp\x20float;\x0a\x0ain\x20vec4\x20speed;\x0ain\x20float\x20v_segmentPosition;\x0ain\x20vec2\x20textureCoordinate;\x0a\x0auniform\x20vec2\x20domain;\x0auniform\x20vec2\x20displayRange;\x0auniform\x20sampler2D\x20colorTable;\x0auniform\x20sampler2D\x20segmentsDepthTexture;\x0a\x0aout\x20vec4\x20fragColor;\x0a\x0avoid\x20main()\x20{\x0a\x20\x20const\x20float\x20zero\x20=\x200.0f;\x0a\x20\x20if(speed.a\x20>\x20zero\x20&&\x20speed.b\x20>\x20displayRange.x\x20&&\x20speed.b\x20<\x20displayRange.y)\x20{\x0a\x20\x20\x20\x20float\x20speedLength\x20=\x20clamp(speed.b,\x20domain.x,\x20domain.y);\x0a\x20\x20\x20\x20float\x20normalizedSpeed\x20=\x20(speedLength\x20-\x20domain.x)\x20/\x20(domain.y\x20-\x20domain.x);\x0a\x20\x20\x20\x20vec4\x20baseColor\x20=\x20texture(colorTable,\x20vec2(normalizedSpeed,\x20zero));\x0a\x0a\x20\x20\x20\x20\x20\x20\x20\x20//\x20使用更平滑的渐变效果\x0a\x20\x20\x20\x20float\x20alpha\x20=\x20smoothstep(0.0f,\x201.0f,\x20v_segmentPosition);\x0a\x20\x20\x20\x20alpha\x20=\x20pow(alpha,\x201.5f);\x20//\x20调整透明度渐变曲线\x0a\x0a\x20\x20\x20\x20\x20\x20\x20\x20//\x20根据速度调整透明度\x0a\x20\x20\x20\x20float\x20speedAlpha\x20=\x20mix(0.3f,\x201.0f,\x20speed.a);\x0a\x0a\x20\x20\x20\x20\x20\x20\x20\x20//\x20组合颜色和透明度\x0a\x20\x20\x20\x20fragColor\x20=\x20vec4(baseColor.rgb,\x20baseColor.a\x20*\x20alpha\x20*\x20speedAlpha);\x0a\x20\x20}\x20else\x20{\x0a\x20\x20\x20\x20fragColor\x20=\x20vec4(zero);\x0a\x20\x20}\x0a\x0a\x20\x20float\x20segmentsDepth\x20=\x20texture(segmentsDepthTexture,\x20textureCoordinate).r;\x0a\x20\x20float\x20globeDepth\x20=\x20czm_unpackDepth(texture(czm_globeDepthTexture,\x20textureCoordinate));\x0a\x20\x20if(segmentsDepth\x20<\x20globeDepth)\x20{\x0a\x20\x20\x20\x20fragColor\x20=\x20vec4(zero);\x0a\x20\x20}\x0a}\x0a','_tomap','redraw','length','moveTo','getUpdatePositionShader','mouseDown','previousParticlesPosition','alt','EllipsoidalOccluder','_onMouseDownEvent','bounds','ymax','primitiveType','resize','object','forEach','flipY','_showHook','1466264SiNPyd','EventType','isDynamic','round','particlesTextures','west','left','1CRkcEM','3041646cHWSxd','mouseHidden','north','rectangle','3.11.2','unbindEvent','min\x20is\x20undefined,\x20calculate\x20min','11495zdLfzx','init','_drawLines','toWindowCoordinates','log','_canrefresh','getUVByXY','TRIANGLES','vertexArray','worker','scene','depthMask','getU','push','globalCompositeOperation','frameState.commandList\x20is\x20undefined','_colorRamp','xmax','preExecute','WindUtil','frameRate','5305433MSDnFO','componentDatatype','ellipsoid','pointer-events','reCreateWindTextures','setOptions','particlesSpeed','lng','default','Invalid\x20particlesTextureSize.\x20Using\x20default\x20value\x20of\x20256.','Cesium','positionWC','now','mouseUp','geometry','_onMapWhellEvent','updateViewerParameters','CanvasWindField','sqrt','sources','attributeLocations','21033550DKjFJg','updateWindData','lastFramesPerSecond','primitives','updatePosition','PointTrans'];_0x55d3=function(){return _0x2daba2;};return _0x55d3();}const _0xf8226={};_0xf8226['value']=!![],Object['defineProperty'](exports,_0x4445ca(0x559,0x5e3),_0xf8226);
|
|
14
|
+
'use strict';(function(_0x55b43d,_0x31d27b){function _0x9287c6(_0x5aaeff,_0x3d0ff2){return _0x5ea3(_0x5aaeff-0x1c7,_0x3d0ff2);}const _0x3bdcfb=_0x55b43d();function _0x17add5(_0x1d6d12,_0x468e40){return _0x5ea3(_0x1d6d12- -0x1e9,_0x468e40);}while(!![]){try{const _0x170e9b=parseInt(_0x17add5(-0x156,-0x1cb))/0x1*(parseInt(_0x9287c6(0x34e,0x3d6))/0x2)+parseInt(_0x9287c6(0x303,0x31a))/0x3*(parseInt(_0x17add5(-0x119,-0x111))/0x4)+parseInt(_0x9287c6(0x2d8,0x285))/0x5+parseInt(_0x9287c6(0x30d,0x2a8))/0x6+-parseInt(_0x17add5(-0x11a,-0x128))/0x7+parseInt(_0x17add5(-0x134,-0x1b0))/0x8+-parseInt(_0x9287c6(0x315,0x2de))/0x9;if(_0x170e9b===_0x31d27b)break;else _0x3bdcfb['push'](_0x3bdcfb['shift']());}catch(_0x3b8d15){_0x3bdcfb['push'](_0x3bdcfb['shift']());}}}(_0x3488,0xe8ba0));function _interopNamespace(_0x59e061){if(_0x59e061&&_0x59e061[_0x1b571d(0x3c5,0x418)])return _0x59e061;function _0x1b571d(_0x35b999,_0x4ab5b){return _0x5ea3(_0x35b999-0x295,_0x4ab5b);}var _0x1f3e89=Object['create'](null);_0x59e061&&Object[_0x1b571d(0x3e6,0x3d9)](_0x59e061)[_0x1b571d(0x3e2,0x462)](function(_0x1f3202){function _0x1dcf64(_0x338298,_0x3b75ea){return _0x1b571d(_0x338298- -0x540,_0x3b75ea);}if(_0x1f3202!=='default'){var _0x2ef887=Object['getOwnPropertyDescriptor'](_0x59e061,_0x1f3202);Object[_0x1dcf64(-0x130,-0xf3)](_0x1f3e89,_0x1f3202,_0x2ef887['get']?_0x2ef887:{'enumerable':!![],'get':function(){return _0x59e061[_0x1f3202];}});}});_0x1f3e89[_0x1b571d(0x3b5,0x3a6)]=_0x59e061;function _0xc463b2(_0x4b80d7,_0x406267){return _0x5ea3(_0x406267- -0x15a,_0x4b80d7);}return _0x1f3e89;}var mars3d__namespace=_interopNamespace(mars3d);const Cesium$2=mars3d__namespace['Cesium'];function getU(_0x46033d,_0x155e52){const _0x228c4b=_0x46033d*Math['cos'](Cesium$2['Math']['toRadians'](_0x155e52));return _0x228c4b;}function getV(_0x3996da,_0xaa1115){const _0x2292c0=_0x3996da*Math['sin'](Cesium$2['Math']['toRadians'](_0xaa1115));return _0x2292c0;}function getSpeed(_0x274a7f,_0x279865){const _0x1d0eef=Math['sqrt'](Math['pow'](_0x274a7f,0x2)+Math['pow'](_0x279865,0x2));return _0x1d0eef;}function getDirection(_0x3f0f15,_0x38af22){let _0x2f80d3=Cesium$2[_0x14339f(0x1df,0x220)]['toDegrees'](Math['atan2'](_0x38af22,_0x3f0f15));_0x2f80d3+=_0x2f80d3<0x0?0x168:0x0;function _0x14339f(_0x556bb5,_0x1b06ee){return _0x5ea3(_0x556bb5-0x12e,_0x1b06ee);}return _0x2f80d3;}const _0x1f77f8={};_0x1f77f8[_0x5c4e84(0x1d2,0x162)]=null,_0x1f77f8['getU']=getU,_0x1f77f8['getV']=getV,_0x1f77f8['getSpeed']=getSpeed,_0x1f77f8['getDirection']=getDirection;var WindUtil=_0x1f77f8;const version=_0x580342(0x432,0x3b5),buildTime='2026-05-13\x2011:55';var updatePositionShader='#version\x20300\x20es\x0aprecision\x20highp\x20float;\x0a\x0auniform\x20sampler2D\x20currentParticlesPosition;\x0auniform\x20sampler2D\x20particlesSpeed;\x0a\x0ain\x20vec2\x20v_textureCoordinates;\x0a\x0aout\x20vec4\x20fragColor;\x0a\x0avoid\x20main()\x20{\x0a\x20\x20\x20\x20//\x20获取当前粒子的位置\x0a\x20\x20vec2\x20currentPos\x20=\x20texture(currentParticlesPosition,\x20v_textureCoordinates).rg;\x0a\x20\x20\x20\x20//\x20获取粒子的速度\x0a\x20\x20vec2\x20speed\x20=\x20texture(particlesSpeed,\x20v_textureCoordinates).rg;\x0a\x20\x20\x20\x20//\x20计算下一个位置\x0a\x20\x20vec2\x20nextPos\x20=\x20currentPos\x20+\x20speed;\x0a\x0a\x20\x20\x20\x20//\x20将新的位置写入\x20fragColor\x0a\x20\x20fragColor\x20=\x20vec4(nextPos,\x200.0f,\x201.0f);\x0a}\x0a',calculateSpeedShader='#version\x20300\x20es\x0a\x0a//\x20the\x20size\x20of\x20UV\x20textures:\x20width\x20=\x20lon,\x20height\x20=\x20lat\x0auniform\x20sampler2D\x20U;\x20//\x20eastward\x20wind\x0auniform\x20sampler2D\x20V;\x20//\x20northward\x20wind\x0auniform\x20sampler2D\x20currentParticlesPosition;\x20//\x20(lon,\x20lat,\x20lev)\x0a\x0auniform\x20vec2\x20uRange;\x20//\x20(min,\x20max)\x0auniform\x20vec2\x20vRange;\x20//\x20(min,\x20max)\x0auniform\x20vec2\x20speedRange;\x20//\x20(min,\x20max)\x0auniform\x20vec2\x20dimension;\x20//\x20(lon,\x20lat)\x0auniform\x20vec2\x20minimum;\x20//\x20minimum\x20of\x20each\x20dimension\x0auniform\x20vec2\x20maximum;\x20//\x20maximum\x20of\x20each\x20dimension\x0a\x0auniform\x20float\x20speedScaleFactor;\x0auniform\x20float\x20frameRateAdjustment;\x0a\x0ain\x20vec2\x20v_textureCoordinates;\x0a\x0avec2\x20getInterval(vec2\x20maximum,\x20vec2\x20minimum,\x20vec2\x20dimension)\x20{\x0a\x20\x20return\x20(maximum\x20-\x20minimum)\x20/\x20(dimension\x20-\x201.0f);\x0a}\x0a\x0avec2\x20mapPositionToNormalizedIndex2D(vec2\x20lonLat)\x20{\x0a\x20\x20\x20\x20//\x20ensure\x20the\x20range\x20of\x20longitude\x20and\x20latitude\x0a\x20\x20lonLat.x\x20=\x20clamp(lonLat.x,\x20minimum.x,\x20maximum.x);\x0a\x20\x20lonLat.y\x20=\x20clamp(lonLat.y,\x20minimum.y,\x20maximum.y);\x0a\x0a\x20\x20vec2\x20interval\x20=\x20getInterval(maximum,\x20minimum,\x20dimension);\x0a\x0a\x20\x20vec2\x20index2D\x20=\x20vec2(0.0f);\x0a\x20\x20index2D.x\x20=\x20(lonLat.x\x20-\x20minimum.x)\x20/\x20interval.x;\x0a\x20\x20index2D.y\x20=\x20(lonLat.y\x20-\x20minimum.y)\x20/\x20interval.y;\x0a\x0a\x20\x20vec2\x20normalizedIndex2D\x20=\x20vec2(index2D.x\x20/\x20dimension.x,\x20index2D.y\x20/\x20dimension.y);\x0a\x20\x20return\x20normalizedIndex2D;\x0a}\x0a\x0afloat\x20getWindComponent(sampler2D\x20componentTexture,\x20vec2\x20lonLat)\x20{\x0a\x20\x20vec2\x20normalizedIndex2D\x20=\x20mapPositionToNormalizedIndex2D(lonLat);\x0a\x20\x20float\x20result\x20=\x20texture(componentTexture,\x20normalizedIndex2D).r;\x0a\x20\x20return\x20result;\x0a}\x0a\x0avec2\x20getWindComponents(vec2\x20lonLat)\x20{\x0a\x20\x20vec2\x20normalizedIndex2D\x20=\x20mapPositionToNormalizedIndex2D(lonLat);\x0a\x20\x20float\x20u\x20=\x20texture(U,\x20normalizedIndex2D).r;\x0a\x20\x20float\x20v\x20=\x20texture(V,\x20normalizedIndex2D).r;\x0a\x20\x20return\x20vec2(u,\x20v);\x0a}\x0a\x0avec2\x20bilinearInterpolation(vec2\x20lonLat)\x20{\x0a\x20\x20float\x20lon\x20=\x20lonLat.x;\x0a\x20\x20float\x20lat\x20=\x20lonLat.y;\x0a\x0a\x20\x20vec2\x20interval\x20=\x20getInterval(maximum,\x20minimum,\x20dimension);\x0a\x0a\x20\x20\x20\x20//\x20Calculate\x20grid\x20cell\x20coordinates\x0a\x20\x20float\x20lon0\x20=\x20floor(lon\x20/\x20interval.x)\x20*\x20interval.x;\x0a\x20\x20float\x20lon1\x20=\x20lon0\x20+\x20interval.x;\x0a\x20\x20float\x20lat0\x20=\x20floor(lat\x20/\x20interval.y)\x20*\x20interval.y;\x0a\x20\x20float\x20lat1\x20=\x20lat0\x20+\x20interval.y;\x0a\x0a\x20\x20\x20\x20//\x20Get\x20wind\x20vectors\x20at\x20four\x20corners\x0a\x20\x20vec2\x20v00\x20=\x20getWindComponents(vec2(lon0,\x20lat0));\x0a\x20\x20vec2\x20v10\x20=\x20getWindComponents(vec2(lon1,\x20lat0));\x0a\x20\x20vec2\x20v01\x20=\x20getWindComponents(vec2(lon0,\x20lat1));\x0a\x20\x20vec2\x20v11\x20=\x20getWindComponents(vec2(lon1,\x20lat1));\x0a\x0a\x20\x20\x20\x20//\x20Check\x20if\x20all\x20wind\x20vectors\x20are\x20zero\x0a\x20\x20if(length(v00)\x20==\x200.0f\x20&&\x20length(v10)\x20==\x200.0f\x20&&\x20length(v01)\x20==\x200.0f\x20&&\x20length(v11)\x20==\x200.0f)\x20{\x0a\x20\x20\x20\x20return\x20vec2(0.0f,\x200.0f);\x0a\x20\x20}\x0a\x0a\x20\x20\x20\x20//\x20Calculate\x20interpolation\x20weights\x0a\x20\x20float\x20s\x20=\x20(lon\x20-\x20lon0)\x20/\x20interval.x;\x0a\x20\x20float\x20t\x20=\x20(lat\x20-\x20lat0)\x20/\x20interval.y;\x0a\x0a\x20\x20\x20\x20//\x20Perform\x20bilinear\x20interpolation\x20on\x20vector\x20components\x0a\x20\x20vec2\x20v0\x20=\x20mix(v00,\x20v10,\x20s);\x0a\x20\x20vec2\x20v1\x20=\x20mix(v01,\x20v11,\x20s);\x0a\x20\x20return\x20mix(v0,\x20v1,\x20t);\x0a}\x0a\x0avec2\x20lengthOfLonLat(vec2\x20lonLat)\x20{\x0a\x20\x20\x20\x20//\x20unit\x20conversion:\x20meters\x20->\x20longitude\x20latitude\x20degrees\x0a\x20\x20\x20\x20//\x20see\x20https://en.wikipedia.org/wiki/Geographic_coordinate_system#Length_of_a_degree\x20for\x20detail\x0a\x0a\x20\x20\x20\x20//\x20Calculate\x20the\x20length\x20of\x20a\x20degree\x20of\x20latitude\x20and\x20longitude\x20in\x20meters\x0a\x20\x20float\x20latitude\x20=\x20radians(lonLat.y);\x0a\x0a\x20\x20float\x20term1\x20=\x20111132.92f;\x0a\x20\x20float\x20term2\x20=\x20559.82f\x20*\x20cos(2.0f\x20*\x20latitude);\x0a\x20\x20float\x20term3\x20=\x201.175f\x20*\x20cos(4.0f\x20*\x20latitude);\x0a\x20\x20float\x20term4\x20=\x200.0023f\x20*\x20cos(6.0f\x20*\x20latitude);\x0a\x20\x20float\x20latLength\x20=\x20term1\x20-\x20term2\x20+\x20term3\x20-\x20term4;\x0a\x0a\x20\x20float\x20term5\x20=\x20111412.84f\x20*\x20cos(latitude);\x0a\x20\x20float\x20term6\x20=\x2093.5f\x20*\x20cos(3.0f\x20*\x20latitude);\x0a\x20\x20float\x20term7\x20=\x200.118f\x20*\x20cos(5.0f\x20*\x20latitude);\x0a\x20\x20float\x20longLength\x20=\x20term5\x20-\x20term6\x20+\x20term7;\x0a\x0a\x20\x20return\x20vec2(longLength,\x20latLength);\x0a}\x0a\x0avec2\x20convertSpeedUnitToLonLat(vec2\x20lonLat,\x20vec2\x20speed)\x20{\x0a\x20\x20vec2\x20lonLatLength\x20=\x20lengthOfLonLat(lonLat);\x0a\x20\x20float\x20u\x20=\x20speed.x\x20/\x20lonLatLength.x;\x0a\x20\x20float\x20v\x20=\x20speed.y\x20/\x20lonLatLength.y;\x0a\x20\x20vec2\x20windVectorInLonLat\x20=\x20vec2(u,\x20v);\x0a\x0a\x20\x20return\x20windVectorInLonLat;\x0a}\x0a\x0avec2\x20calculateSpeedByRungeKutta2(vec2\x20lonLat)\x20{\x0a\x20\x20\x20\x20//\x20see\x20https://en.wikipedia.org/wiki/Runge%E2%80%93Kutta_methods#Second-order_methods_with_two_stages\x20for\x20detail\x0a\x20\x20const\x20float\x20h\x20=\x200.5f;\x0a\x0a\x20\x20vec2\x20y_n\x20=\x20lonLat;\x0a\x20\x20vec2\x20f_n\x20=\x20bilinearInterpolation(lonLat);\x0a\x20\x20vec2\x20midpoint\x20=\x20y_n\x20+\x200.5f\x20*\x20h\x20*\x20convertSpeedUnitToLonLat(y_n,\x20f_n)\x20*\x20speedScaleFactor;\x0a\x20\x20vec2\x20speed\x20=\x20h\x20*\x20bilinearInterpolation(midpoint)\x20*\x20speedScaleFactor;\x0a\x0a\x20\x20return\x20speed;\x0a}\x0a\x0avec2\x20calculateWindNorm(vec2\x20speed)\x20{\x0a\x20\x20float\x20speedLength\x20=\x20length(speed.xy);\x0a\x20\x20if(speedLength\x20==\x200.0f)\x20{\x0a\x20\x20\x20\x20return\x20vec2(0.0f);\x0a\x20\x20}\x0a\x0a\x20\x20\x20\x20//\x20Clamp\x20speedLength\x20to\x20range\x0a\x20\x20float\x20clampedSpeed\x20=\x20clamp(speedLength,\x20speedRange.x,\x20speedRange.y);\x0a\x20\x20float\x20normalizedSpeed\x20=\x20(clampedSpeed\x20-\x20speedRange.x)\x20/\x20(speedRange.y\x20-\x20speedRange.x);\x0a\x20\x20return\x20vec2(speedLength,\x20normalizedSpeed);\x0a}\x0a\x0aout\x20vec4\x20fragColor;\x0a\x0avoid\x20main()\x20{\x0a\x20\x20\x20\x20//\x20texture\x20coordinate\x20must\x20be\x20normalized\x0a\x20\x20vec2\x20lonLat\x20=\x20texture(currentParticlesPosition,\x20v_textureCoordinates).rg;\x0a\x20\x20vec2\x20speedOrigin\x20=\x20bilinearInterpolation(lonLat);\x0a\x20\x20vec2\x20speed\x20=\x20calculateSpeedByRungeKutta2(lonLat)\x20*\x20frameRateAdjustment;\x0a\x20\x20vec2\x20speedInLonLat\x20=\x20convertSpeedUnitToLonLat(lonLat,\x20speed);\x0a\x0a\x20\x20fragColor\x20=\x20vec4(speedInLonLat,\x20calculateWindNorm(speedOrigin));\x0a}\x0a',postProcessingPositionFragmentShader='#version\x20300\x20es\x0aprecision\x20highp\x20float;\x0a\x0auniform\x20sampler2D\x20nextParticlesPosition;\x0auniform\x20sampler2D\x20particlesSpeed;\x20//\x20(u,\x20v,\x20norm)\x0a\x0a//\x20range\x20(min,\x20max)\x0auniform\x20vec2\x20lonRange;\x0auniform\x20vec2\x20latRange;\x0a\x0a//\x20range\x20(min,\x20max)\x0auniform\x20vec2\x20dataLonRange;\x0auniform\x20vec2\x20dataLatRange;\x0a\x0auniform\x20float\x20randomCoefficient;\x0auniform\x20float\x20dropRate;\x0auniform\x20float\x20dropRateBump;\x0a\x0a//\x20添加新的\x20uniform\x20变量\x0auniform\x20bool\x20useViewerBounds;\x0a\x0ain\x20vec2\x20v_textureCoordinates;\x0a\x0a//\x20pseudo-random\x20generator\x0aconst\x20vec3\x20randomConstants\x20=\x20vec3(12.9898f,\x2078.233f,\x204375.85453f);\x0aconst\x20vec2\x20normalRange\x20=\x20vec2(0.0f,\x201.0f);\x0afloat\x20rand(vec2\x20seed,\x20vec2\x20range)\x20{\x0a\x20\x20vec2\x20randomSeed\x20=\x20randomCoefficient\x20*\x20seed;\x0a\x20\x20float\x20temp\x20=\x20dot(randomConstants.xy,\x20randomSeed);\x0a\x20\x20temp\x20=\x20fract(sin(temp)\x20*\x20(randomConstants.z\x20+\x20temp));\x0a\x20\x20return\x20temp\x20*\x20(range.y\x20-\x20range.x)\x20+\x20range.x;\x0a}\x0a\x0avec2\x20generateRandomParticle(vec2\x20seed)\x20{\x0a\x20\x20vec2\x20range;\x0a\x20\x20float\x20randomLon,\x20randomLat;\x0a\x0a\x20\x20if(useViewerBounds)\x20{\x0a\x20\x20\x20\x20\x20\x20\x20\x20//\x20在当前视域范围内生成粒子\x0a\x20\x20\x20\x20randomLon\x20=\x20rand(seed,\x20lonRange);\x0a\x20\x20\x20\x20randomLat\x20=\x20rand(-seed,\x20latRange);\x0a\x20\x20}\x20else\x20{\x0a\x20\x20\x20\x20\x20\x20\x20\x20//\x20在数据范围内生成粒子\x0a\x20\x20\x20\x20randomLon\x20=\x20rand(seed,\x20dataLonRange);\x0a\x20\x20\x20\x20randomLat\x20=\x20rand(-seed,\x20dataLatRange);\x0a\x20\x20}\x0a\x0a\x20\x20return\x20vec2(randomLon,\x20randomLat);\x0a}\x0a\x0abool\x20particleOutbound(vec2\x20particle)\x20{\x0a\x20\x20return\x20particle.y\x20<\x20dataLatRange.x\x20||\x20particle.y\x20>\x20dataLatRange.y\x20||\x20particle.x\x20<\x20dataLonRange.x\x20||\x20particle.x\x20>\x20dataLonRange.y;\x0a}\x0a\x0aout\x20vec4\x20fragColor;\x0a\x0avoid\x20main()\x20{\x0a\x20\x20vec2\x20nextParticle\x20=\x20texture(nextParticlesPosition,\x20v_textureCoordinates).rg;\x0a\x20\x20vec4\x20nextSpeed\x20=\x20texture(particlesSpeed,\x20v_textureCoordinates);\x0a\x20\x20float\x20speedNorm\x20=\x20nextSpeed.a;\x0a\x20\x20float\x20particleDropRate\x20=\x20dropRate\x20+\x20dropRateBump\x20*\x20speedNorm;\x0a\x0a\x20\x20vec2\x20seed1\x20=\x20nextParticle.xy\x20+\x20v_textureCoordinates;\x0a\x20\x20vec2\x20seed2\x20=\x20nextSpeed.rg\x20+\x20v_textureCoordinates;\x0a\x20\x20vec2\x20randomParticle\x20=\x20generateRandomParticle(seed1);\x0a\x20\x20float\x20randomNumber\x20=\x20rand(seed2,\x20normalRange);\x0a\x0a\x20\x20if(randomNumber\x20<\x20particleDropRate\x20||\x20particleOutbound(nextParticle))\x20{\x0a\x20\x20\x20\x20fragColor\x20=\x20vec4(randomParticle,\x200.0f,\x201.0f);\x20//\x201.0\x20means\x20this\x20is\x20a\x20random\x20particle\x0a\x20\x20}\x20else\x20{\x0a\x20\x20\x20\x20fragColor\x20=\x20vec4(nextParticle,\x200.0f,\x200.0f);\x0a\x20\x20}\x0a}\x0a',renderParticlesFragmentShader=_0x5c4e84(0x217,0x287),renderParticlesVertexShader='#version\x20300\x20es\x0aprecision\x20highp\x20float;\x0a\x0ain\x20vec2\x20st;\x0ain\x20vec3\x20normal;\x0a\x0auniform\x20sampler2D\x20previousParticlesPosition;\x0auniform\x20sampler2D\x20currentParticlesPosition;\x0auniform\x20sampler2D\x20postProcessingPosition;\x0auniform\x20sampler2D\x20particlesSpeed;\x0a\x0auniform\x20float\x20frameRateAdjustment;\x0auniform\x20float\x20particleHeight;\x0auniform\x20float\x20aspect;\x0auniform\x20float\x20pixelSize;\x0auniform\x20vec2\x20lineWidth;\x0auniform\x20vec2\x20lineLength;\x0auniform\x20vec2\x20domain;\x0auniform\x20bool\x20is3D;\x0a\x0a//\x20添加输出变量传递给片元着色器\x0aout\x20vec4\x20speed;\x0aout\x20float\x20v_segmentPosition;\x0aout\x20vec2\x20textureCoordinate;\x0a\x0a//\x20添加结构体定义\x0astruct\x20adjacentPoints\x20{\x0a\x20\x20vec4\x20previous;\x0a\x20\x20vec4\x20current;\x0a\x20\x20vec4\x20next;\x0a};\x0a\x0avec3\x20convertCoordinate(vec2\x20lonLat)\x20{\x0a\x20\x20\x20\x20//\x20WGS84\x20(lon,\x20lat,\x20lev)\x20->\x20ECEF\x20(x,\x20y,\x20z)\x0a\x20\x20\x20\x20//\x20read\x20https://en.wikipedia.org/wiki/Geographic_coordinate_conversion#From_geodetic_to_ECEF_coordinates\x20for\x20detail\x0a\x0a\x20\x20\x20\x20//\x20WGS\x2084\x20geometric\x20constants\x0a\x20\x20float\x20a\x20=\x206378137.0f;\x20//\x20Semi-major\x20axis\x0a\x20\x20float\x20b\x20=\x206356752.3142f;\x20//\x20Semi-minor\x20axis\x0a\x20\x20float\x20e2\x20=\x206.69437999014e-3f;\x20//\x20First\x20eccentricity\x20squared\x0a\x0a\x20\x20float\x20latitude\x20=\x20radians(lonLat.y);\x0a\x20\x20float\x20longitude\x20=\x20radians(lonLat.x);\x0a\x0a\x20\x20float\x20cosLat\x20=\x20cos(latitude);\x0a\x20\x20float\x20sinLat\x20=\x20sin(latitude);\x0a\x20\x20float\x20cosLon\x20=\x20cos(longitude);\x0a\x20\x20float\x20sinLon\x20=\x20sin(longitude);\x0a\x0a\x20\x20float\x20N_Phi\x20=\x20a\x20/\x20sqrt(1.0f\x20-\x20e2\x20*\x20sinLat\x20*\x20sinLat);\x0a\x20\x20float\x20h\x20=\x20particleHeight;\x20//\x20it\x20should\x20be\x20high\x20enough\x20otherwise\x20the\x20particle\x20may\x20not\x20pass\x20the\x20terrain\x20depth\x20test\x0a\x20\x20vec3\x20cartesian\x20=\x20vec3(0.0f);\x0a\x20\x20cartesian.x\x20=\x20(N_Phi\x20+\x20h)\x20*\x20cosLat\x20*\x20cosLon;\x0a\x20\x20cartesian.y\x20=\x20(N_Phi\x20+\x20h)\x20*\x20cosLat\x20*\x20sinLon;\x0a\x20\x20cartesian.z\x20=\x20((b\x20*\x20b)\x20/\x20(a\x20*\x20a)\x20*\x20N_Phi\x20+\x20h)\x20*\x20sinLat;\x0a\x20\x20return\x20cartesian;\x0a}\x0a\x0avec4\x20calculateProjectedCoordinate(vec2\x20lonLat)\x20{\x0a\x20\x20if(is3D)\x20{\x0a\x20\x20\x20\x20vec3\x20particlePosition\x20=\x20convertCoordinate(lonLat);\x0a\x20\x20\x20\x20\x20\x20\x20\x20//\x20使用\x20modelViewProjection\x20矩阵进行投影变换\x0a\x20\x20\x20\x20vec4\x20projectedPosition\x20=\x20czm_modelViewProjection\x20*\x20vec4(particlePosition,\x201.0f);\x0a\x20\x20\x20\x20return\x20projectedPosition;\x0a\x20\x20}\x20else\x20{\x0a\x20\x20\x20\x20vec3\x20position2D\x20=\x20vec3(radians(lonLat.x),\x20radians(lonLat.y),\x200.0f);\x0a\x20\x20\x20\x20return\x20czm_modelViewProjection\x20*\x20vec4(position2D,\x201.0f);\x0a\x20\x20}\x0a}\x0a\x0avec4\x20calculateOffsetOnNormalDirection(vec4\x20pointA,\x20vec4\x20pointB,\x20float\x20offsetSign,\x20float\x20widthFactor)\x20{\x0a\x20\x20vec2\x20aspectVec2\x20=\x20vec2(aspect,\x201.0f);\x0a\x20\x20vec2\x20pointA_XY\x20=\x20(pointA.xy\x20/\x20pointA.w)\x20*\x20aspectVec2;\x0a\x20\x20vec2\x20pointB_XY\x20=\x20(pointB.xy\x20/\x20pointB.w)\x20*\x20aspectVec2;\x0a\x0a\x20\x20\x20\x20//\x20计算方向向量\x0a\x20\x20vec2\x20direction\x20=\x20normalize(pointB_XY\x20-\x20pointA_XY);\x0a\x0a\x20\x20\x20\x20//\x20计算法向量\x0a\x20\x20vec2\x20normalVector\x20=\x20vec2(-direction.y,\x20direction.x);\x0a\x20\x20normalVector.x\x20=\x20normalVector.x\x20/\x20aspect;\x0a\x0a\x20\x20\x20\x20//\x20使用\x20widthFactor\x20调整宽度\x0a\x20\x20float\x20offsetLength\x20=\x20widthFactor\x20*\x20lineWidth.y;\x0a\x20\x20normalVector\x20=\x20offsetLength\x20*\x20normalVector;\x0a\x0a\x20\x20vec4\x20offset\x20=\x20vec4(offsetSign\x20*\x20normalVector,\x200.0f,\x200.0f);\x0a\x20\x20return\x20offset;\x0a}\x0a\x0avoid\x20main()\x20{\x0a\x20\x20\x20\x20//\x20翻转\x20Y\x20轴坐标\x0a\x20\x20vec2\x20flippedIndex\x20=\x20vec2(st.x,\x201.0f\x20-\x20st.y);\x0a\x0a\x20\x20vec2\x20particleIndex\x20=\x20flippedIndex;\x0a\x20\x20speed\x20=\x20texture(particlesSpeed,\x20particleIndex);\x0a\x0a\x20\x20vec2\x20previousPosition\x20=\x20texture(previousParticlesPosition,\x20particleIndex).rg;\x0a\x20\x20vec2\x20currentPosition\x20=\x20texture(currentParticlesPosition,\x20particleIndex).rg;\x0a\x20\x20vec2\x20nextPosition\x20=\x20texture(postProcessingPosition,\x20particleIndex).rg;\x0a\x0a\x20\x20float\x20isAnyRandomPointUsed\x20=\x20texture(postProcessingPosition,\x20particleIndex).a\x20+\x0a\x20\x20\x20\x20texture(currentParticlesPosition,\x20particleIndex).a\x20+\x0a\x20\x20\x20\x20texture(previousParticlesPosition,\x20particleIndex).a;\x0a\x0a\x20\x20adjacentPoints\x20projectedCoordinates;\x0a\x20\x20if(isAnyRandomPointUsed\x20>\x200.0f)\x20{\x0a\x20\x20\x20\x20projectedCoordinates.previous\x20=\x20calculateProjectedCoordinate(previousPosition);\x0a\x20\x20\x20\x20projectedCoordinates.current\x20=\x20projectedCoordinates.previous;\x0a\x20\x20\x20\x20projectedCoordinates.next\x20=\x20projectedCoordinates.previous;\x0a\x20\x20}\x20else\x20{\x0a\x20\x20\x20\x20projectedCoordinates.previous\x20=\x20calculateProjectedCoordinate(previousPosition);\x0a\x20\x20\x20\x20projectedCoordinates.current\x20=\x20calculateProjectedCoordinate(currentPosition);\x0a\x20\x20\x20\x20projectedCoordinates.next\x20=\x20calculateProjectedCoordinate(nextPosition);\x0a\x20\x20}\x0a\x0a\x20\x20int\x20pointToUse\x20=\x20int(normal.x);\x0a\x20\x20float\x20offsetSign\x20=\x20normal.y;\x0a\x20\x20vec4\x20offset\x20=\x20vec4(0.0f);\x0a\x0a\x20\x20\x20\x20//\x20计算速度相关的宽度和长度因子\x0a\x20\x20float\x20speedLength\x20=\x20clamp(speed.b,\x20domain.x,\x20domain.y);\x0a\x20\x20float\x20normalizedSpeed\x20=\x20(speedLength\x20-\x20domain.x)\x20/\x20(domain.y\x20-\x20domain.x);\x0a\x0a\x20\x20\x20\x20//\x20根据速度计算宽度\x0a\x20\x20float\x20widthFactor\x20=\x20mix(lineWidth.x,\x20lineWidth.y,\x20normalizedSpeed);\x0a\x20\x20widthFactor\x20*=\x20(pointToUse\x20<\x200\x20?\x201.0f\x20:\x200.5f);\x20//\x20头部更宽,尾部更窄\x0a\x0a\x20\x20\x20\x20//\x20Calculate\x20length\x20based\x20on\x20speed\x0a\x20\x20float\x20lengthFactor\x20=\x20mix(lineLength.x,\x20lineLength.y,\x20normalizedSpeed)\x20*\x20pixelSize;\x0a\x0a\x20\x20if(pointToUse\x20==\x201)\x20{\x0a\x20\x20\x20\x20\x20\x20\x20\x20//\x20头部位置\x0a\x20\x20\x20\x20offset\x20=\x20pixelSize\x20*\x20calculateOffsetOnNormalDirection(projectedCoordinates.previous,\x20projectedCoordinates.current,\x20offsetSign,\x20widthFactor);\x0a\x20\x20\x20\x20gl_Position\x20=\x20projectedCoordinates.previous\x20+\x20offset;\x0a\x20\x20\x20\x20v_segmentPosition\x20=\x200.0f;\x20//\x20头部\x0a\x20\x20}\x20else\x20if(pointToUse\x20==\x20-1)\x20{\x0a\x20\x20\x20\x20\x20\x20\x20\x20//\x20Get\x20direction\x20and\x20normalize\x20it\x20to\x20length\x201.0\x0a\x20\x20\x20\x20vec4\x20direction\x20=\x20normalize(projectedCoordinates.next\x20-\x20projectedCoordinates.current);\x0a\x20\x20\x20\x20vec4\x20extendedPosition\x20=\x20projectedCoordinates.current\x20+\x20direction\x20*\x20lengthFactor;\x0a\x0a\x20\x20\x20\x20offset\x20=\x20pixelSize\x20*\x20calculateOffsetOnNormalDirection(projectedCoordinates.current,\x20extendedPosition,\x20offsetSign,\x20widthFactor);\x0a\x20\x20\x20\x20gl_Position\x20=\x20extendedPosition\x20+\x20offset;\x0a\x20\x20\x20\x20v_segmentPosition\x20=\x201.0f;\x20//\x20尾部\x0a\x20\x20}\x0a\x0a\x20\x20textureCoordinate\x20=\x20st;\x0a}\x0a';const {ShaderSource:ShaderSource$1}=mars3d__namespace[_0x580342(0x333,0x366)];function _0x5ea3(_0x4664be,_0x226f3c){const _0x3488c0=_0x3488();return _0x5ea3=function(_0x5ea326,_0x4e748b){_0x5ea326=_0x5ea326-0x7f;let _0x31b150=_0x3488c0[_0x5ea326];return _0x31b150;},_0x5ea3(_0x4664be,_0x226f3c);}class ShaderManager{static[_0x5c4e84(0x1d4,0x219)](){const _0x267f79={};_0x267f79[_0x5d2ade(0x1d2,0x1b0)]=[calculateSpeedShader];function _0x5d2ade(_0x953902,_0x5c8dd7){return _0x580342(_0x5c8dd7,_0x953902- -0x11d);}return new ShaderSource$1(_0x267f79);}static['getUpdatePositionShader'](){const _0xc45e25={};function _0x3f5dab(_0x208429,_0x1f3879){return _0x580342(_0x208429,_0x1f3879- -0x413);}return _0xc45e25[_0x3f5dab(-0xcf,-0x124)]=[updatePositionShader],new ShaderSource$1(_0xc45e25);}static[_0x5c4e84(0x244,0x24d)](){function _0x6a6a93(_0x24e1ef,_0x3eeaab){return _0x5c4e84(_0x3eeaab-0x10c,_0x24e1ef);}const _0x3ccaae={};return _0x3ccaae[_0x6a6a93(0x34b,0x2df)]=[renderParticlesVertexShader],new ShaderSource$1(_0x3ccaae);}static['getSegmentDrawFragmentShader'](){const _0x28f7d6={};function _0x3f985a(_0x42fd18,_0x3a4ca1){return _0x580342(_0x42fd18,_0x3a4ca1- -0x39d);}return _0x28f7d6[_0x3f985a(-0x103,-0xae)]=[renderParticlesFragmentShader],new ShaderSource$1(_0x28f7d6);}static['getPostProcessingPositionShader'](){const _0x50b4b4={};return _0x50b4b4['sources']=[postProcessingPositionFragmentShader],new ShaderSource$1(_0x50b4b4);}}const {BufferUsage:BufferUsage$1,ClearCommand:ClearCommand$1,Color:Color$2,ComputeCommand,DrawCommand,Geometry:Geometry$1,Matrix4,Pass:Pass$1,PrimitiveType:PrimitiveType$1,RenderState,ShaderProgram,ShaderSource,VertexArray:VertexArray$1,defined,destroyObject}=mars3d__namespace['Cesium'];class CustomPrimitive{constructor(_0x202d14){this[_0x191404(-0x146,-0x141)]=_0x202d14[_0x4415b4(0x1a,0x3d)];function _0x4415b4(_0x379eec,_0x555a95){return _0x580342(_0x555a95,_0x379eec- -0x37a);}function _0x191404(_0x319db1,_0x136600){return _0x580342(_0x136600,_0x319db1- -0x4da);}this[_0x191404(-0x1b3,-0x1a0)]=_0x202d14[_0x4415b4(-0x53,-0x64)],this['attributeLocations']=_0x202d14[_0x191404(-0x140,-0xbf)],this[_0x191404(-0x15e,-0x198)]=_0x202d14[_0x4415b4(0x2,0x7a)],this['uniformMap']=_0x202d14['uniformMap']||{},this['vertexShaderSource']=_0x202d14['vertexShaderSource'],this['fragmentShaderSource']=_0x202d14['fragmentShaderSource'],this['rawRenderState']=_0x202d14[_0x191404(-0x14c,-0x13a)],this[_0x191404(-0x184,-0xff)]=_0x202d14['framebuffer'],this['outputTexture']=_0x202d14['outputTexture'],this['autoClear']=_0x202d14[_0x4415b4(0x17,0x2c)]??![],this[_0x4415b4(-0x44,-0xba)]=_0x202d14['preExecute'],this['show']=!![],this[_0x191404(-0x18d,-0x1b4)]=undefined,this['clearCommand']=undefined,this[_0x191404(-0x232,-0x25a)]=_0x202d14[_0x191404(-0x232,-0x1f4)]??(()=>!![]),this['autoClear']&&(this['clearCommand']=new ClearCommand$1({'color':new Color$2(0x0,0x0,0x0,0x0),'depth':0x1,'framebuffer':this[_0x4415b4(-0x24,-0x80)],'pass':Pass$1[_0x191404(-0x22a,-0x26b)]}));}['createCommand'](_0xd42dc2){function _0x578e35(_0x4675e1,_0x94ed9){return _0x5c4e84(_0x94ed9- -0x12d,_0x4675e1);}function _0x1c00d9(_0x38a9be,_0x298e43){return _0x5c4e84(_0x38a9be-0x53,_0x298e43);}if(this[_0x1c00d9(0x2cb,0x25e)]==='Draw'){const _0x13b395={};_0x13b395['context']=_0xd42dc2,_0x13b395['geometry']=this['geometry'],_0x13b395[_0x1c00d9(0x2d1,0x30a)]=this['attributeLocations'],_0x13b395[_0x1c00d9(0x2e4,0x2e8)]=BufferUsage$1['STATIC_DRAW'];const _0x44d41e=VertexArray$1['fromGeometry'](_0x13b395),_0x3ac360={};_0x3ac360['context']=_0xd42dc2,_0x3ac360['vertexShaderSource']=this['vertexShaderSource'],_0x3ac360['fragmentShaderSource']=this['fragmentShaderSource'],_0x3ac360[_0x1c00d9(0x2d1,0x280)]=this[_0x1c00d9(0x2d1,0x256)];const _0x5341b6=ShaderProgram['fromCache'](_0x3ac360),_0x4ee906=RenderState[_0x578e35(0x1f,0x62)](this['rawRenderState']),_0x305933={};return _0x305933['owner']=this,_0x305933[_0x1c00d9(0x249,0x281)]=_0x44d41e,_0x305933['primitiveType']=this['primitiveType'],_0x305933[_0x578e35(0xf9,0x111)]=Matrix4['IDENTITY'],_0x305933['renderState']=_0x4ee906,_0x305933['shaderProgram']=_0x5341b6,_0x305933['framebuffer']=this['framebuffer'],_0x305933['uniformMap']=this['uniformMap'],_0x305933[_0x1c00d9(0x258,0x2dc)]=Pass$1['OPAQUE'],new DrawCommand(_0x305933);}else{if(this['commandType']===_0x1c00d9(0x1ee,0x213)){const _0x309e0f={};return _0x309e0f[_0x578e35(0x10f,0xa1)]=this,_0x309e0f['fragmentShaderSource']=this[_0x578e35(0x54,0x68)],_0x309e0f['uniformMap']=this[_0x1c00d9(0x28f,0x2b9)],_0x309e0f['outputTexture']=this[_0x1c00d9(0x216,0x251)],_0x309e0f[_0x578e35(0x1b0,0x134)]=!![],new ComputeCommand(_0x309e0f);}else throw new Error('Unknown\x20command\x20type');}}[_0x580342(0x342,0x2fa)](_0x457de0,_0x2dfe7e){this['geometry']=_0x2dfe7e;function _0x358689(_0xeebd31,_0x49a808){return _0x5c4e84(_0xeebd31- -0x1f7,_0x49a808);}function _0x51852b(_0x4391e0,_0x58c747){return _0x5c4e84(_0x58c747- -0x138,_0x4391e0);}defined(this['commandToExecute'])&&(this['commandToExecute']['vertexArray']=VertexArray$1['fromGeometry']({'context':_0x457de0,'geometry':this[_0x358689(0x14,-0x67)],'attributeLocations':this['attributeLocations'],'bufferUsage':BufferUsage$1[_0x51852b(0x62,0x82)]}));}[_0x580342(0x3e7,0x39b)](_0x2ed03b){if(!this['isDynamic']())return;if(!this['show']||!defined(_0x2ed03b))return;!defined(this[_0x409684(-0x1e4,-0x1e8)])&&(this[_0x55ffcf(0x164,0x189)]=this[_0x55ffcf(0x1c9,0x19d)](_0x2ed03b[_0x55ffcf(0x1b2,0x1b5)]));function _0x409684(_0x41ada4,_0x5dc1c1){return _0x580342(_0x41ada4,_0x5dc1c1- -0x535);}defined(this[_0x409684(-0x226,-0x1ff)])&&this['preExecute']();if(!_0x2ed03b['commandList']){console['warn']('frameState.commandList\x20is\x20undefined');return;}defined(this['clearCommand'])&&_0x2ed03b['commandList']['push'](this[_0x409684(-0x255,-0x1e0)]);function _0x55ffcf(_0x493e88,_0x4f267a){return _0x580342(_0x493e88,_0x4f267a- -0x1c4);}defined(this[_0x409684(-0x185,-0x1e8)])&&_0x2ed03b['commandList']['push'](this[_0x409684(-0x19c,-0x1e8)]);}['isDestroyed'](){return![];}['destroy'](){function _0x52b3f4(_0x9e6111,_0x560c93){return _0x580342(_0x560c93,_0x9e6111- -0x7e);}function _0x29e99e(_0x3421ab,_0x428330){return _0x580342(_0x3421ab,_0x428330- -0x580);}if(defined(this['commandToExecute'])){var _0x39a39e;(_0x39a39e=this['commandToExecute']['shaderProgram'])===null||_0x39a39e===void 0x0||_0x39a39e['destroy'](),this[_0x29e99e(-0x1c7,-0x233)][_0x29e99e(-0x2c3,-0x2ab)]=undefined;}return destroyObject(this);}}function deepMerge(_0x11d246,_0x48b53e){if(!_0x11d246)return _0x48b53e;if(!_0x48b53e)return _0x11d246;const _0x4a4c29={..._0x48b53e},_0x21bae1=_0x4a4c29;function _0xd12f52(_0x52819b,_0x45abdd){return _0x580342(_0x52819b,_0x45abdd- -0xf6);}function _0x11af50(_0x265a32,_0x388ddf){return _0x5c4e84(_0x388ddf- -0x3df,_0x265a32);}for(const _0x52f508 in _0x11d246){if(Object['prototype'][_0x11af50(-0x1cd,-0x1fd)]['call'](_0x11d246,_0x52f508)){const _0x1fc211=_0x11d246[_0x52f508],_0x287bba=_0x48b53e[_0x52f508];if(Array['isArray'](_0x1fc211)){_0x21bae1[_0x52f508]=_0x1fc211['slice']();continue;}if(_0x1fc211&&typeof _0x1fc211===_0x11af50(-0x1fc,-0x1d8)){_0x21bae1[_0x52f508]=deepMerge(_0x1fc211,_0x287bba||{});continue;}_0x1fc211!==undefined&&(_0x21bae1[_0x52f508]=_0x1fc211);}}return _0x21bae1;}const {Cartesian2:Cartesian2$1,FrameRateMonitor,PixelDatatype:PixelDatatype$1,PixelFormat:PixelFormat$1,Sampler:Sampler$1,Texture:Texture$1,TextureMagnificationFilter:TextureMagnificationFilter$1,TextureMinificationFilter:TextureMinificationFilter$1}=mars3d__namespace[_0x580342(0x34a,0x366)];class WindParticlesComputing{constructor(_0x4b6651,_0x2b60ad,_0x575ac7,_0x1dcb89,_0x1e1950){this[_0x2f05e8(0xe9,0x95)]=_0x4b6651,this[_0x4863b0(-0x5f,-0x94)]=_0x575ac7,this['viewerParameters']=_0x1dcb89,this[_0x4863b0(-0xe0,-0x69)]=_0x2b60ad,this['frameRate']=0x3c,this[_0x4863b0(-0x101,-0xba)]=0x1;function _0x4863b0(_0x431add,_0x3eb14c){return _0x580342(_0x431add,_0x3eb14c- -0x408);}const _0x62df8e={};_0x62df8e[_0x2f05e8(0xb8,0x4a)]=_0x1e1950;function _0x2f05e8(_0x520ba4,_0x24b742){return _0x580342(_0x520ba4,_0x24b742- -0x2e4);}_0x62df8e[_0x4863b0(-0xcc,-0x73)]=0x1,_0x62df8e['quietPeriod']=0x0,this['frameRateMonitor']=new FrameRateMonitor(_0x62df8e),this['initFrameRate'](),this['createWindTextures'](),this['createParticlesTextures'](),this['createComputingPrimitives']();}['initFrameRate'](){const _0x58aaa2=()=>{function _0x5afdf5(_0x5105fd,_0x11a326){return _0x5ea3(_0x5105fd-0x20b,_0x11a326);}function _0x2b2c89(_0x390739,_0x576c05){return _0x5ea3(_0x390739-0xb4,_0x576c05);}this['frameRateMonitor']['lastFramesPerSecond']>0x14&&(this['frameRate']=this['frameRateMonitor']['lastFramesPerSecond'],this[_0x2b2c89(0x1d9,0x1d2)]=0x3c/Math[_0x2b2c89(0x21d,0x1f2)](this['frameRate'],0x1));};_0x58aaa2();const _0x3efed1=setInterval(_0x58aaa2,0x3e8);function _0x33c5c1(_0x4c4aac,_0x34fb61){return _0x580342(_0x4c4aac,_0x34fb61- -0x129);}const _0x2e11e6=this['destroy']['bind'](this);this[_0x33c5c1(0x290,0x233)]=()=>{clearInterval(_0x3efed1),_0x2e11e6();};}[_0x5c4e84(0x1c9,0x1c9)](){const _0x393781={};_0x393781[_0x21dffa(0x1ba,0x1f2)]=TextureMinificationFilter$1[_0x38fda7(0x2dc,0x30d)],_0x393781[_0x21dffa(0x1f2,0x243)]=TextureMagnificationFilter$1['LINEAR'];const _0x48b2fc={'context':this[_0x38fda7(0x2d0,0x2f3)],'width':this['windData']['width'],'height':this[_0x38fda7(0x2c2,0x319)]['height'],'pixelFormat':PixelFormat$1[_0x38fda7(0x1f3,0x240)],'pixelDatatype':PixelDatatype$1['FLOAT'],'flipY':this[_0x21dffa(0x1be,0x185)]['flipY']??![],'sampler':new Sampler$1(_0x393781)};function _0x21dffa(_0x85e8a4,_0x419457){return _0x5c4e84(_0x85e8a4- -0x9a,_0x419457);}function _0x38fda7(_0x2b4edb,_0x11016b){return _0x5c4e84(_0x11016b-0x96,_0x2b4edb);}this[_0x38fda7(0x26c,0x2b1)]={'U':new Texture$1({..._0x48b2fc,'source':{'arrayBufferView':new Float32Array(this['windData']['u']['array'])}}),'V':new Texture$1({..._0x48b2fc,'source':{'arrayBufferView':new Float32Array(this['windData']['v']['array'])}})};}['createParticlesTextures'](){function _0x18af6e(_0x2f1af3,_0xffc085){return _0x5c4e84(_0xffc085-0xf6,_0x2f1af3);}const _0x553542={};_0x553542['minificationFilter']=TextureMinificationFilter$1[_0x384356(0x45e,0x46c)],_0x553542['magnificationFilter']=TextureMagnificationFilter$1[_0x384356(0x45e,0x439)];const _0xf95c08={'context':this[_0x18af6e(0x2ef,0x353)],'width':this[_0x18af6e(0x367,0x34e)]['particlesTextureSize'],'height':this[_0x384356(0x51c,0x52b)]['particlesTextureSize'],'pixelFormat':PixelFormat$1['RGBA'],'pixelDatatype':PixelDatatype$1['FLOAT'],'flipY':![],'source':{'arrayBufferView':new Float32Array(this[_0x18af6e(0x3c7,0x34e)]['particlesTextureSize']*this['options']['particlesTextureSize']*0x4)[_0x18af6e(0x2d0,0x283)](0x0)},'sampler':new Sampler$1(_0x553542)};function _0x384356(_0xf44597,_0x208531){return _0x580342(_0x208531,_0xf44597-0x1a8);}this['particlesTextures']={'previousParticlesPosition':new Texture$1(_0xf95c08),'currentParticlesPosition':new Texture$1(_0xf95c08),'nextParticlesPosition':new Texture$1(_0xf95c08),'postProcessingPosition':new Texture$1(_0xf95c08),'particlesSpeed':new Texture$1(_0xf95c08)};}['destroyParticlesTextures'](){Object['values'](this['particlesTextures'])['forEach'](_0x3be755=>_0x3be755['destroy']());}[_0x5c4e84(0x290,0x28a)](){function _0x2df44f(_0x50414e,_0x13bf46){return _0x580342(_0x50414e,_0x13bf46- -0x3e);}function _0x149fc4(_0xfdcaba,_0x171a6e){return _0x580342(_0xfdcaba,_0x171a6e-0x41);}this['primitives']={'calculateSpeed':new CustomPrimitive({'commandType':'Compute','uniformMap':{'U':()=>this['windTextures']['U'],'V':()=>this['windTextures']['V'],'uRange':()=>new Cartesian2$1(this['windData']['u']['min'],this[_0x2df44f(0x352,0x361)]['u']['max']),'vRange':()=>new Cartesian2$1(this[_0x149fc4(0x417,0x3e0)]['v'][_0x2df44f(0x35f,0x349)],this[_0x2df44f(0x389,0x361)]['v']['max']),'speedRange':()=>new Cartesian2$1(this['windData']['speed'][_0x2df44f(0x32f,0x349)],this[_0x2df44f(0x30e,0x361)][_0x2df44f(0x36a,0x306)]['max']),'currentParticlesPosition':()=>this[_0x2df44f(0x391,0x321)]['currentParticlesPosition'],'speedScaleFactor':()=>{function _0x18c417(_0x5d4da2,_0x5ad227){return _0x149fc4(_0x5ad227,_0x5d4da2- -0x165);}function _0x2472b3(_0x268ea9,_0x377c3e){return _0x149fc4(_0x377c3e,_0x268ea9- -0x202);}return(this[_0x2472b3(0x156,0xfd)]['pixelSize']+0x32)*this[_0x18c417(0x250,0x279)]['speedFactor'];},'frameRateAdjustment':()=>this[_0x2df44f(0x397,0x310)],'dimension':()=>new Cartesian2$1(this[_0x2df44f(0x3b5,0x361)]['width'],this[_0x2df44f(0x3d8,0x361)][_0x2df44f(0x279,0x2c6)]),'minimum':()=>new Cartesian2$1(this['windData'][_0x149fc4(0x3d2,0x3e2)]['west'],this['windData'][_0x2df44f(0x393,0x363)]['south']),'maximum':()=>new Cartesian2$1(this[_0x2df44f(0x302,0x361)]['bounds'][_0x2df44f(0x303,0x32f)],this[_0x149fc4(0x3a1,0x3e0)][_0x149fc4(0x3fa,0x3e2)]['north'])},'fragmentShaderSource':ShaderManager[_0x149fc4(0x39b,0x331)](),'outputTexture':this['particlesTextures']['particlesSpeed'],'preExecute':()=>{function _0x13c903(_0x23baa6,_0x43f13e){return _0x2df44f(_0x43f13e,_0x23baa6- -0x582);}const _0x384ad8=this['particlesTextures'][_0x13c903(-0x215,-0x1cd)];this['particlesTextures']['previousParticlesPosition']=this['particlesTextures']['currentParticlesPosition'];function _0xaf2be8(_0x5afbb2,_0x3afead){return _0x149fc4(_0x5afbb2,_0x3afead- -0x433);}this['particlesTextures']['currentParticlesPosition']=this[_0x13c903(-0x261,-0x2a4)][_0x13c903(-0x2c1,-0x2b0)],this['particlesTextures'][_0xaf2be8(-0x140,-0xf3)]=_0x384ad8,this['primitives'][_0x13c903(-0x23d,-0x247)]['commandToExecute']&&(this['primitives'][_0xaf2be8(-0x8,-0x6f)][_0x13c903(-0x273,-0x211)]['outputTexture']=this['particlesTextures'][_0x13c903(-0x2ed,-0x305)]);},'isDynamic':()=>this[_0x2df44f(0x355,0x336)]['dynamic']}),'updatePosition':new CustomPrimitive({'commandType':'Compute','uniformMap':{'currentParticlesPosition':()=>this['particlesTextures'][_0x149fc4(0x315,0x301)],'particlesSpeed':()=>this['particlesTextures']['particlesSpeed']},'fragmentShaderSource':ShaderManager['getUpdatePositionShader'](),'outputTexture':this['particlesTextures']['nextParticlesPosition'],'preExecute':()=>{function _0x6344ff(_0x3474e5,_0x548e7a){return _0x2df44f(_0x3474e5,_0x548e7a- -0x2a3);}function _0x104cdb(_0x3353f0,_0x560b45){return _0x149fc4(_0x560b45,_0x3353f0- -0x4e1);}this[_0x6344ff(0xe7,0x8d)]['updatePosition']['commandToExecute']&&(this['primitives']['updatePosition'][_0x6344ff(0x80,0x6c)][_0x104cdb(-0x1c1,-0x236)]=this[_0x6344ff(0xd1,0x7e)][_0x6344ff(0x11f,0xb6)]);},'isDynamic':()=>this[_0x2df44f(0x3af,0x336)]['dynamic']}),'postProcessingPosition':new CustomPrimitive({'commandType':'Compute','uniformMap':{'nextParticlesPosition':()=>this[_0x2df44f(0x36c,0x321)]['nextParticlesPosition'],'particlesSpeed':()=>this[_0x149fc4(0x425,0x3a0)]['particlesSpeed'],'lonRange':()=>this['viewerParameters']['lonRange'],'latRange':()=>this[_0x2df44f(0x2b1,0x2d9)][_0x149fc4(0x35e,0x36a)],'dataLonRange':()=>new Cartesian2$1(this[_0x2df44f(0x390,0x361)]['bounds'][_0x149fc4(0x382,0x2ff)],this['windData'][_0x149fc4(0x45b,0x3e2)][_0x149fc4(0x344,0x3ae)]),'dataLatRange':()=>new Cartesian2$1(this[_0x149fc4(0x38f,0x3e0)][_0x2df44f(0x352,0x363)][_0x2df44f(0x2c0,0x335)],this['windData'][_0x2df44f(0x3d4,0x363)][_0x2df44f(0x367,0x34e)]),'randomCoefficient':function(){function _0x164059(_0x291993,_0x1e9ccf){return _0x2df44f(_0x1e9ccf,_0x291993- -0x242);}return Math[_0x164059(0x5d,0xd0)]();},'dropRate':()=>this[_0x149fc4(0x374,0x3b5)][_0x149fc4(0x2c7,0x2fe)],'dropRateBump':()=>this[_0x149fc4(0x3dd,0x3b5)][_0x2df44f(0x319,0x2d8)],'useViewerBounds':()=>this['options']['useViewerBounds']},'fragmentShaderSource':ShaderManager['getPostProcessingPositionShader'](),'outputTexture':this['particlesTextures'][_0x149fc4(0x2c3,0x340)],'preExecute':()=>{function _0x122859(_0x16a5a0,_0xadf102){return _0x2df44f(_0x16a5a0,_0xadf102- -0x218);}function _0x850cc3(_0x501d6e,_0x199482){return _0x149fc4(_0x199482,_0x501d6e-0x11b);}this['primitives'][_0x850cc3(0x45b,0x497)]['commandToExecute']&&(this['primitives']['postProcessingPosition'][_0x122859(0xf7,0xf7)]['outputTexture']=this['particlesTextures']['postProcessingPosition']);},'isDynamic':()=>this['options'][_0x149fc4(0x3db,0x3a5)]})};}[_0x580342(0x2fc,0x36a)](){this['windTextures']['U'][_0x2008a6(-0x175,-0x10f)]();function _0x2008a6(_0x5b152b,_0xa23159){return _0x580342(_0xa23159,_0x5b152b- -0x4d1);}this[_0x34cb5f(-0x69,-0xf0)]['V']['destroy']();function _0x34cb5f(_0x6cbfd8,_0x5d4dc4){return _0x5c4e84(_0x6cbfd8- -0x284,_0x5d4dc4);}this['createWindTextures']();}['updateWindData'](_0x10bdb4){function _0x4ac491(_0x2028a8,_0x46d98c){return _0x5c4e84(_0x2028a8- -0x314,_0x46d98c);}this[_0x4ac491(-0x91,-0xd)]=_0x10bdb4,this['reCreateWindTextures']();}['updateOptions'](_0x3690b8){const _0x540569=_0x3690b8['flipY']!==undefined&&_0x3690b8['flipY']!==this['options'][_0x3b4e5a(0x31,0x35)];function _0x269d24(_0x15485b,_0x44ff55){return _0x5c4e84(_0x15485b-0x244,_0x44ff55);}this[_0x3b4e5a(0xa3,0xc8)]=deepMerge(_0x3690b8,this[_0x3b4e5a(0xf2,0xc8)]);function _0x3b4e5a(_0x44d082,_0x2a66c2){return _0x580342(_0x44d082,_0x2a66c2- -0x2ac);}_0x540569&&this['reCreateWindTextures']();}['processWindData'](_0x40f63a){const {array:_0x1f04d3}=_0x40f63a;function _0x45d636(_0x870f4,_0x60acc8){return _0x580342(_0x60acc8,_0x870f4- -0x3dd);}let {min:_0x3532c1,max:_0x5765a3}=_0x40f63a;const _0x4ed7a9=new Float32Array(_0x1f04d3['length']);_0x3532c1===undefined&&(console['warn']('min\x20is\x20undefined,\x20calculate\x20min'),_0x3532c1=Math['min'](..._0x1f04d3));_0x5765a3===undefined&&(console['warn'](_0x45d636(-0xc5,-0xee)),_0x5765a3=Math['max'](..._0x1f04d3));const _0x2a2bfd=Math[_0x45d636(-0x4b,-0x2a)](Math['abs'](_0x3532c1),Math[_0x48da68(0x2cc,0x251)](_0x5765a3));function _0x48da68(_0x54bf7a,_0x53f896){return _0x580342(_0x54bf7a,_0x53f896- -0xd3);}for(let _0x56aae6=0x0;_0x56aae6<_0x1f04d3[_0x45d636(-0xf9,-0x117)];_0x56aae6++){const _0x265d2a=_0x1f04d3[_0x56aae6]/_0x2a2bfd;_0x4ed7a9[_0x56aae6]=_0x265d2a;}return _0x4ed7a9;}['destroy'](){Object['values'](this['windTextures'])['forEach'](_0x838f36=>_0x838f36['destroy']()),Object['values'](this['particlesTextures'])['forEach'](_0x1f3996=>_0x1f3996[_0x1be11f(0x333,0x398)]());function _0x3de2bd(_0x1673bf,_0x207456){return _0x5c4e84(_0x207456- -0x26b,_0x1673bf);}Object[_0x3de2bd(-0xf4,-0xc8)](this[_0x1be11f(0x345,0x34f)])['forEach'](_0x1b052b=>_0x1b052b['destroy']());function _0x1be11f(_0x416c5a,_0x72b522){return _0x580342(_0x72b522,_0x416c5a- -0x29);}this['frameRateMonitor'][_0x3de2bd(-0x86,-0x2b)]();}}const {Appearance,BufferUsage,Cartesian2,Color:Color$1,ComponentDatatype,Framebuffer,Geometry,GeometryAttribute,GeometryAttributes,PixelDatatype,PixelFormat,PrimitiveType,Sampler,SceneMode,Texture,TextureMagnificationFilter,TextureMinificationFilter,TextureWrap,VertexArray}=mars3d__namespace[_0x5c4e84(0x24a,0x25b)];class WindParticlesRendering{constructor(_0x61684b,_0x36888a,_0x1e07f4,_0x4b0980){this[_0x5a8572(-0x289,-0x243)]=_0x61684b,this['options']=_0x36888a,this[_0x5a8572(-0x2eb,-0x336)]=_0x1e07f4,this['computing']=_0x4b0980;function _0x5a8572(_0x91c674,_0xdbffb6){return _0x580342(_0xdbffb6,_0x91c674- -0x602);}(typeof this['options'][_0x53a1dc(0x5ab,0x531)]!=='number'||this[_0x5a8572(-0x28e,-0x2c4)]['particlesTextureSize']<=0x0)&&(console[_0x53a1dc(0x549,0x4db)]('Invalid\x20particlesTextureSize.\x20Using\x20default\x20value\x20of\x20256.'),this['options'][_0x5a8572(-0x269,-0x287)]=0x100);this['colorTable']=this['createColorTableTexture']();function _0x53a1dc(_0x465cd8,_0x4f9730){return _0x5c4e84(_0x4f9730-0x2b4,_0x465cd8);}this[_0x53a1dc(0x4e7,0x4f6)]=this['createRenderingTextures'](),this['framebuffers']=this['createRenderingFramebuffers'](),this[_0x5a8572(-0x294,-0x2e9)]=this['createPrimitives']();}['createRenderingTextures'](){const _0x5d1bfb={};_0x5d1bfb['context']=this[_0x5bc7b8(0x52c,0x547)],_0x5d1bfb[_0x5bc7b8(0x4b3,0x46a)]=this['context']['drawingBufferWidth'],_0x5d1bfb[_0x276f15(0x262,0x2d8)]=this[_0x5bc7b8(0x52c,0x4d5)][_0x5bc7b8(0x565,0x4ed)],_0x5d1bfb['pixelFormat']=PixelFormat['RGBA'];function _0x276f15(_0x303f66,_0x24404d){return _0x580342(_0x24404d,_0x303f66- -0xa2);}function _0x5bc7b8(_0xcc30a3,_0x28198f){return _0x580342(_0x28198f,_0xcc30a3-0x1b3);}_0x5d1bfb['pixelDatatype']=PixelDatatype['UNSIGNED_BYTE'];const _0x37aaa2=_0x5d1bfb,_0x5341b5={};_0x5341b5['context']=this['context'],_0x5341b5[_0x276f15(0x25e,0x217)]=this['context']['drawingBufferWidth'],_0x5341b5['height']=this[_0x276f15(0x2d7,0x285)][_0x276f15(0x310,0x355)],_0x5341b5[_0x5bc7b8(0x4b9,0x488)]=PixelFormat['DEPTH_COMPONENT'],_0x5341b5['pixelDatatype']=PixelDatatype['UNSIGNED_INT'];const _0x3ab6bb=_0x5341b5;return{'segmentsColor':new Texture(_0x37aaa2),'segmentsDepth':new Texture(_0x3ab6bb)};}['createRenderingFramebuffers'](){const _0x4de42e={};function _0x5055c4(_0x351883,_0x574709){return _0x580342(_0x351883,_0x574709-0x70);}function _0x46f53e(_0x15c2f3,_0x3c8aca){return _0x580342(_0x3c8aca,_0x15c2f3- -0x49f);}return _0x4de42e[_0x5055c4(0x43c,0x3e9)]=this[_0x5055c4(0x469,0x3e9)],_0x4de42e['colorTextures']=[this[_0x5055c4(0x3c3,0x3ce)][_0x46f53e(-0x167,-0x161)]],_0x4de42e['depthTexture']=this['textures']['segmentsDepth'],{'segments':new Framebuffer(_0x4de42e)};}['destoryRenderingFramebuffers'](){Object['values'](this['framebuffers'])['forEach'](_0x36a520=>{_0x36a520['destroy']();});}['createColorTableTexture'](){const _0x41afbd=new Float32Array(this[_0x39fa3d(0x350,0x37a)][_0x3d9c45(0x2ed,0x33e)][_0x39fa3d(0x33f,0x349)](_0x189102=>{const _0x2613dc=Color$1[_0x25eb8e(0x390,0x3f6)](_0x189102);function _0x25eb8e(_0x33f5dd,_0x28c27c){return _0x3d9c45(_0x33f5dd,_0x28c27c-0x94);}return[_0x2613dc['red'],_0x2613dc['green'],_0x2613dc['blue'],_0x2613dc['alpha']];})),_0x54cc3e={};_0x54cc3e['minificationFilter']=TextureMinificationFilter[_0x39fa3d(0x36f,0x3cd)];function _0x3d9c45(_0xdf23f7,_0x43d305){return _0x5c4e84(_0x43d305-0x183,_0xdf23f7);}function _0x39fa3d(_0x355f27,_0x5171ca){return _0x580342(_0x5171ca,_0x355f27- -0x24);}return _0x54cc3e['magnificationFilter']=TextureMagnificationFilter[_0x3d9c45(0x47a,0x3fa)],_0x54cc3e['wrapS']=TextureWrap['CLAMP_TO_EDGE'],_0x54cc3e[_0x3d9c45(0x2d7,0x339)]=TextureWrap['CLAMP_TO_EDGE'],new Texture({'context':this[_0x3d9c45(0x3df,0x3e0)],'width':this[_0x39fa3d(0x350,0x36d)]['colors'][_0x39fa3d(0x2c0,0x31c)],'height':0x1,'pixelFormat':PixelFormat['RGBA'],'pixelDatatype':PixelDatatype['FLOAT'],'sampler':new Sampler(_0x54cc3e),'source':{'width':this[_0x39fa3d(0x350,0x35f)][_0x39fa3d(0x2b3,0x2c3)][_0x39fa3d(0x2c0,0x271)],'height':0x1,'arrayBufferView':_0x41afbd}});}['createSegmentsGeometry'](){const _0x4056f3=0x4,_0xecce6e=this[_0x5783c8(0x125,0xc2)]['particlesTextureSize'];let _0x4f95e4=[];for(let _0x3399ea=0x0;_0x3399ea<_0xecce6e;_0x3399ea++){for(let _0x5846eb=0x0;_0x5846eb<_0xecce6e;_0x5846eb++){for(let _0x4952b2=0x0;_0x4952b2<_0x4056f3;_0x4952b2++){_0x4f95e4['push'](_0x3399ea/_0xecce6e),_0x4f95e4[_0x3de1de(-0x27c,-0x2ec)](_0x5846eb/_0xecce6e);}}}_0x4f95e4=new Float32Array(_0x4f95e4);const _0x3e0a52=this['options']['particlesTextureSize']**0x2;let _0x3a72c8=[];for(let _0x2e93bb=0x0;_0x2e93bb<_0x3e0a52;_0x2e93bb++){_0x3a72c8['push'](-0x1,-0x1,0x0,-0x1,0x1,0x0,0x1,-0x1,0x0,0x1,0x1,0x0);}_0x3a72c8=new Float32Array(_0x3a72c8);let _0x1c225f=[];for(let _0x4456d3=0x0,_0x1b089=0x0;_0x4456d3<_0x3e0a52;_0x4456d3++){_0x1c225f['push'](_0x1b089+0x0,_0x1b089+0x1,_0x1b089+0x2,_0x1b089+0x2,_0x1b089+0x1,_0x1b089+0x3),_0x1b089+=_0x4056f3;}_0x1c225f=new Uint32Array(_0x1c225f);const _0x2af791={};_0x2af791['componentDatatype']=ComponentDatatype[_0x5783c8(0x26,-0x8)],_0x2af791['componentsPerAttribute']=0x2;function _0x5783c8(_0xeb2175,_0x427d7d){return _0x5c4e84(_0x427d7d- -0x196,_0xeb2175);}_0x2af791['values']=_0x4f95e4;const _0x11f396={};function _0x3de1de(_0x28764e,_0x5aea39){return _0x5c4e84(_0x28764e- -0x46c,_0x5aea39);}_0x11f396['componentDatatype']=ComponentDatatype[_0x3de1de(-0x2de,-0x2a3)],_0x11f396['componentsPerAttribute']=0x3,_0x11f396['values']=_0x3a72c8;const _0x83c814=new Geometry({'attributes':new GeometryAttributes({'st':new GeometryAttribute(_0x2af791),'normal':new GeometryAttribute(_0x11f396)}),'indices':_0x1c225f});return _0x83c814;}['createRawRenderState'](_0xef1fc2){const _0x5ee91e={'viewport':undefined,'depthTest':undefined,'depthMask':undefined,'blending':undefined,..._0xef1fc2};return Appearance['getDefaultRenderState'](!![],![],_0x5ee91e);}[_0x5c4e84(0x225,0x27f)](){const _0x3812ab={};_0x3812ab['st']=0x0,_0x3812ab[_0x40fd1c(-0x1c3,-0x1be)]=0x1;const _0x20e033={};_0x20e033['enabled']=!![];function _0x40fd1c(_0x134f99,_0x5656b6){return _0x5c4e84(_0x5656b6- -0x38a,_0x134f99);}const _0x2d5863={};_0x2d5863['enabled']=!![],_0x2d5863['blendEquation']=WebGLRenderingContext[_0x40fd1c(-0x81,-0xf7)],_0x2d5863['blendFuncSource']=WebGLRenderingContext['SRC_ALPHA'],_0x2d5863[_0x40fd1c(-0xe8,-0xfd)]=WebGLRenderingContext['ONE_MINUS_SRC_ALPHA'];const _0x102ce1={};function _0x16f7e3(_0x149bc5,_0x29c2b7){return _0x580342(_0x29c2b7,_0x149bc5-0x3d);}_0x102ce1[_0x40fd1c(-0x17a,-0x1e3)]=undefined,_0x102ce1[_0x16f7e3(0x37b,0x3a2)]=_0x20e033,_0x102ce1[_0x16f7e3(0x35d,0x380)]=!![],_0x102ce1['blending']=_0x2d5863;const _0x5dfa27=new CustomPrimitive({'commandType':'Draw','attributeLocations':_0x3812ab,'geometry':this['createSegmentsGeometry'](),'primitiveType':PrimitiveType['TRIANGLES'],'uniformMap':{'previousParticlesPosition':()=>this[_0x16f7e3(0x331,0x39c)][_0x16f7e3(0x39c,0x3b7)][_0x16f7e3(0x3e8,0x470)],'currentParticlesPosition':()=>this[_0x40fd1c(-0x13e,-0x1b2)][_0x40fd1c(-0xdb,-0x147)][_0x16f7e3(0x2fd,0x31c)],'postProcessingPosition':()=>this['computing']['particlesTextures']['postProcessingPosition'],'particlesSpeed':()=>this['computing']['particlesTextures'][_0x16f7e3(0x310,0x32f)],'frameRateAdjustment':()=>this['computing']['frameRateAdjustment'],'colorTable':()=>this[_0x16f7e3(0x328,0x334)],'domain':()=>{var _0x4909d4,_0x2fbb81;function _0x3dd07d(_0xbd78cb,_0x15b74b){return _0x40fd1c(_0xbd78cb,_0x15b74b-0x109);}function _0x5e2054(_0x5dbd8b,_0x2d792e){return _0x16f7e3(_0x2d792e- -0x58d,_0x5dbd8b);}const _0x541618=new Cartesian2(((_0x4909d4=this['options']['domain'])===null||_0x4909d4===void 0x0?void 0x0:_0x4909d4['min'])??this['computing']['windData'][_0x3dd07d(-0xc6,-0x59)]['min'],((_0x2fbb81=this[_0x5e2054(-0x18d,-0x1dc)]['domain'])===null||_0x2fbb81===void 0x0?void 0x0:_0x2fbb81['max'])??this['computing'][_0x5e2054(-0x227,-0x1b1)][_0x3dd07d(-0x2f,-0x59)]['max']);return _0x541618;},'displayRange':()=>{function _0x412464(_0xd3f8d,_0x51c7cd){return _0x40fd1c(_0xd3f8d,_0x51c7cd- -0x147);}function _0x442c3c(_0x3749a6,_0x4212e6){return _0x16f7e3(_0x4212e6- -0x2f5,_0x3749a6);}var _0x390457,_0xc61530;const _0x3e1ea6=new Cartesian2(((_0x390457=this['options']['displayRange'])===null||_0x390457===void 0x0?void 0x0:_0x390457[_0x442c3c(0x7d,0xcf)])??this[_0x412464(-0x2a5,-0x2f9)]['windData'][_0x412464(-0x29d,-0x2a9)]['min'],((_0xc61530=this[_0x412464(-0x22a,-0x279)][_0x412464(-0x269,-0x2b2)])===null||_0xc61530===void 0x0?void 0x0:_0xc61530[_0x442c3c(0xd2,0xda)])??this[_0x442c3c(-0xa,0x3c)][_0x412464(-0x2b5,-0x24e)]['speed'][_0x412464(-0x1d9,-0x25b)]);return _0x3e1ea6;},'particleHeight':()=>this['options'][_0x16f7e3(0x379,0x312)]||0x0,'aspect':()=>this['context']['drawingBufferWidth']/this[_0x16f7e3(0x3b6,0x3f2)]['drawingBufferHeight'],'pixelSize':()=>this['viewerParameters']['pixelSize'],'lineWidth':()=>{const _0x27edc8={};function _0x21754b(_0x5f04c6,_0xd8ff41){return _0x40fd1c(_0x5f04c6,_0xd8ff41-0x4a9);}_0x27edc8['min']=0x1,_0x27edc8[_0x2869fe(0xb4,0x43)]=0x2;function _0x2869fe(_0x362238,_0xaefead){return _0x16f7e3(_0x362238- -0x31b,_0xaefead);}const _0x30a786=this[_0x2869fe(0x96,0x95)]['lineWidth']||_0x27edc8;return new Cartesian2(_0x30a786[_0x2869fe(0xa9,0x11c)],_0x30a786['max']);},'lineLength':()=>{const _0xcd1b84={};_0xcd1b84['min']=0x14,_0xcd1b84[_0x993420(-0x2c9,-0x257)]=0x64;function _0x993420(_0x5ddbb6,_0xc33529){return _0x16f7e3(_0xc33529- -0x626,_0x5ddbb6);}function _0x3379e8(_0x65388a,_0x4c946b){return _0x40fd1c(_0x4c946b,_0x65388a-0x61a);}const _0x4b108a=this['options']['lineLength']||_0xcd1b84;return new Cartesian2(_0x4b108a['min'],_0x4b108a[_0x993420(-0x289,-0x257)]);},'is3D':()=>this[_0x16f7e3(0x354,0x2d6)]['sceneMode']===SceneMode['SCENE3D'],'segmentsDepthTexture':()=>this['textures']['segmentsDepth']},'vertexShaderSource':ShaderManager['getSegmentDrawVertexShader'](),'fragmentShaderSource':ShaderManager['getSegmentDrawFragmentShader'](),'rawRenderState':this['createRawRenderState'](_0x102ce1)}),_0x2392f6={};return _0x2392f6['segments']=_0x5dfa27,_0x2392f6;}[_0x580342(0x373,0x38b)](){const _0x310e7f=this['createSegmentsGeometry']();this[_0x480ac9(0x5c,0x36)]['segments']['geometry']=_0x310e7f;const _0x583c39={};function _0x51671d(_0x38408e,_0x3a31a1){return _0x5c4e84(_0x3a31a1-0x1f8,_0x38408e);}_0x583c39['context']=this[_0x480ac9(0xad,0x41)],_0x583c39['geometry']=_0x310e7f,_0x583c39['attributeLocations']=this['primitives']['segments'][_0x480ac9(0x20,0x62)],_0x583c39['bufferUsage']=BufferUsage[_0x51671d(0x426,0x3b2)];function _0x480ac9(_0x70a382,_0x7269c2){return _0x5c4e84(_0x7269c2- -0x21c,_0x70a382);}const _0x8c5103=VertexArray[_0x480ac9(-0x99,-0x3b)](_0x583c39);this['primitives'][_0x51671d(0x3a6,0x3f6)]['commandToExecute']&&(this[_0x51671d(0x3e0,0x44a)]['segments']['commandToExecute'][_0x480ac9(-0x3d,-0x26)]=_0x8c5103);}['onColorTableChange'](){this['colorTable']['destroy']();function _0x5e5caf(_0x4c3634,_0x1e49da){return _0x580342(_0x4c3634,_0x1e49da- -0x3db);}this[_0x5e5caf(-0xcc,-0xf0)]=this['createColorTableTexture']();}['updateOptions'](_0x42bfa8){const _0x3a9c63=_0x42bfa8['colors']&&JSON[_0x31b93e(0x3e6,0x430)](_0x42bfa8[_0x31b93e(0x3f1,0x3a8)])!==JSON['stringify'](this['options']['colors']);function _0x31b93e(_0x156f17,_0xff116a){return _0x580342(_0xff116a,_0x156f17-0x11a);}function _0x5ed4a9(_0x1c25f2,_0x11043e){return _0x5c4e84(_0x1c25f2-0x58,_0x11043e);}this[_0x5ed4a9(0x2b0,0x293)]=deepMerge(_0x42bfa8,this['options']),_0x3a9c63&&this['onColorTableChange']();}[_0x580342(0x369,0x35c)](){Object['values'](this[_0xd895c8(0x19c,0x134)])['forEach'](_0x3ca063=>{_0x3ca063['destroy']();}),Object[_0xd895c8(0x16c,0x12e)](this['primitives'])['forEach'](_0x21095a=>{_0x21095a['destroy']();});function _0xbd1ae2(_0x3dc6b9,_0x5ca4a0){return _0x5c4e84(_0x3dc6b9- -0x1a,_0x5ca4a0);}function _0xd895c8(_0x5077c5,_0x202319){return _0x580342(_0x5077c5,_0x202319- -0x191);}this['colorTable']['destroy']();}}const {ClearCommand,Color,Pass}=mars3d__namespace[_0x580342(0x346,0x366)];class WindParticleSystem{constructor(_0x3ce626,_0x530167,_0x227218,_0x14d836,_0x535a9a){function _0x2dd058(_0x18de82,_0x4341b2){return _0x5c4e84(_0x4341b2- -0x5b,_0x18de82);}this['context']=_0x3ce626,this['options']=_0x227218;function _0x21e40d(_0x198648,_0x59a8af){return _0x580342(_0x59a8af,_0x198648- -0xe2);}this['viewerParameters']=_0x14d836,this[_0x2dd058(0x115,0x17d)]=new WindParticlesComputing(_0x3ce626,_0x530167,_0x227218,_0x14d836,_0x535a9a),this['rendering']=new WindParticlesRendering(_0x3ce626,_0x227218,_0x14d836,this[_0x21e40d(0x212,0x257)]),this['clearFramebuffers']();}['getPrimitives'](){function _0x4c4329(_0x49b1a4,_0x5b7e69){return _0x580342(_0x49b1a4,_0x5b7e69- -0x33e);}function _0x33e2a7(_0x5e3674,_0x449590){return _0x5c4e84(_0x449590- -0x8f,_0x5e3674);}const _0x30aed4=[this['computing'][_0x4c4329(0xa0,0x30)]['calculateSpeed'],this[_0x33e2a7(0x1af,0x149)][_0x33e2a7(0x1f5,0x1c3)][_0x4c4329(0x95,0x2a)],this[_0x33e2a7(0x138,0x149)][_0x4c4329(0x25,0x30)][_0x4c4329(-0x93,-0x3f)],this[_0x4c4329(-0x35,0x43)]['primitives'][_0x33e2a7(0x13f,0x16f)]];return _0x30aed4;}['clearFramebuffers'](){function _0x21d974(_0x1c81e3,_0xe4d9e1){return _0x580342(_0x1c81e3,_0xe4d9e1- -0x16);}const _0x4a3d96=new ClearCommand({'color':new Color(0x0,0x0,0x0,0x0),'depth':0x1,'framebuffer':undefined,'pass':Pass['OPAQUE']});Object['keys'](this[_0x21d974(0x3c0,0x36b)]['framebuffers'])['forEach'](_0x127f8b=>{function _0xf2a8c8(_0x3cc6da,_0x1d4b62){return _0x21d974(_0x1d4b62,_0x3cc6da- -0x102);}_0x4a3d96[_0xf2a8c8(0x23e,0x1f0)]=this[_0xf2a8c8(0x269,0x255)][_0xf2a8c8(0x1ad,0x1eb)][_0x127f8b];function _0x52a5f5(_0x5a2b47,_0x1270dc){return _0x21d974(_0x1270dc,_0x5a2b47- -0x4d);}_0x4a3d96['execute'](this[_0x52a5f5(0x316,0x2fd)]);});}[_0x580342(0x397,0x39c)](_0x5b99fe){let _0x5c3522=![];_0x5b99fe['particlesTextureSize']&&this['options']['particlesTextureSize']!==_0x5b99fe[_0x518fb9(0x149,0x18b)]&&(_0x5c3522=!![]);function _0x518fb9(_0x3046cf,_0xc55fd9){return _0x580342(_0x3046cf,_0xc55fd9- -0x20e);}function _0x1bb449(_0x4250e1,_0x44881c){return _0x5c4e84(_0x4250e1- -0x2f7,_0x44881c);}const _0x359a5f=deepMerge(_0x5b99fe,this[_0x1bb449(-0x9f,-0x108)]);if(_0x359a5f['particlesTextureSize']<0x1)throw new Error('particlesTextureSize\x20must\x20be\x20greater\x20than\x200');this['options']=_0x359a5f,this[_0x1bb449(-0x92,-0x40)][_0x518fb9(0x11e,0x15d)](_0x5b99fe),this['computing'][_0x518fb9(0xeb,0x15d)](_0x5b99fe),_0x5c3522&&(this[_0x1bb449(-0x11f,-0xa3)]['destroyParticlesTextures'](),this[_0x518fb9(0xbc,0xe6)]['createParticlesTextures'](),this['rendering'][_0x518fb9(0x17f,0x17d)]());}['applyViewerParameters'](_0x5e01e3){this['viewerParameters']=_0x5e01e3;function _0x4dd93a(_0x352070,_0xe560e3){return _0x580342(_0xe560e3,_0x352070-0x40);}function _0x2e02eb(_0x687aee,_0x30b02e){return _0x580342(_0x687aee,_0x30b02e- -0x1d8);}this[_0x2e02eb(0x176,0x11c)]['viewerParameters']=_0x5e01e3,this['rendering'][_0x4dd93a(0x357,0x331)]=_0x5e01e3;}[_0x5c4e84(0x240,0x2bb)](){function _0x5e56ee(_0x1bbcd3,_0x394ffb){return _0x580342(_0x1bbcd3,_0x394ffb- -0x3c3);}this['computing'][_0x5e56ee(0x1e,-0x67)](),this['rendering']['destroy']();}}const Cesium$1=mars3d__namespace['Cesium'],BaseLayer$1=mars3d__namespace[_0x580342(0x31b,0x352)]['BaseLayer'],_0x561378={};function _0x3488(){const _0x1f07f4=['LayerUtil','NEAREST','Compute','mouse_move','steps','setData','isInExtent','1AamVKi','dropRate','west','values','currentParticlesPosition','remove','resize','viewport','cols','framebuffers','RED','pointerEvents','particlesNumber','ymin','bindEvent','canvas','stringify','getDataAtLonLat','tlat','stroke','particles','mouseDown','wrapT','particlesSpeed','MAX_VALUE','shaderProgram','STATIC_DRAW','colors','getUVByXY','mouseUp','Math','visibility','worker','random','4565176yQNmUF','outputTexture','_calcUV','flipY','getContext','_createCanvas','length','createWindTextures','strokeStyle','_randomParticle','normal','WindUtil','owner','colorTable','pickEllipsoid','updateViewerParameters','__proto__','sources','getCalculateSpeedShader','_mountedHook','addEventListener','umax','computing','_setOptionsHook','_animateFrame','unbindEvent','3686690dXoTNH','3036164kMLhll','setGeometry','fromCssColorString','requestAnimationFrame','fromGeometry','hasOwnProperty','postProcessingPosition','width','sqrt','refreshTimer','getPrimitives','height','container','pixelFormat','now','globe','_map','ymax','Cartesian2','push','changed','log','xmin','rows','latitude','vertexArray','getRandomLatLng','PointTrans','lonRange','dropRateBump','viewerParameters','max\x20is\x20undefined,\x20calculate\x20max','CanvasWindField','segments','CanvasWindLayer','xmax','initWorker','speedRate','left','depthMask','pass','vdata','object','abs','particleSystem','ellipsoid','geometry','redraw','latRange','wheel','mouseHidden','_calc_speedRate','_onMouseMoveEvent','scene','_onMouseDownEvent','lighter','sceneMode','lineTo','#version\x20300\x20es\x0aprecision\x20highp\x20float;\x0a\x0ain\x20vec4\x20speed;\x0ain\x20float\x20v_segmentPosition;\x0ain\x20vec2\x20textureCoordinate;\x0a\x0auniform\x20vec2\x20domain;\x0auniform\x20vec2\x20displayRange;\x0auniform\x20sampler2D\x20colorTable;\x0auniform\x20sampler2D\x20segmentsDepthTexture;\x0a\x0aout\x20vec4\x20fragColor;\x0a\x0avoid\x20main()\x20{\x0a\x20\x20const\x20float\x20zero\x20=\x200.0f;\x0a\x20\x20if(speed.a\x20>\x20zero\x20&&\x20speed.b\x20>\x20displayRange.x\x20&&\x20speed.b\x20<\x20displayRange.y)\x20{\x0a\x20\x20\x20\x20float\x20speedLength\x20=\x20clamp(speed.b,\x20domain.x,\x20domain.y);\x0a\x20\x20\x20\x20float\x20normalizedSpeed\x20=\x20(speedLength\x20-\x20domain.x)\x20/\x20(domain.y\x20-\x20domain.x);\x0a\x20\x20\x20\x20vec4\x20baseColor\x20=\x20texture(colorTable,\x20vec2(normalizedSpeed,\x20zero));\x0a\x0a\x20\x20\x20\x20\x20\x20\x20\x20//\x20使用更平滑的渐变效果\x0a\x20\x20\x20\x20float\x20alpha\x20=\x20smoothstep(0.0f,\x201.0f,\x20v_segmentPosition);\x0a\x20\x20\x20\x20alpha\x20=\x20pow(alpha,\x201.5f);\x20//\x20调整透明度渐变曲线\x0a\x0a\x20\x20\x20\x20\x20\x20\x20\x20//\x20根据速度调整透明度\x0a\x20\x20\x20\x20float\x20speedAlpha\x20=\x20mix(0.3f,\x201.0f,\x20speed.a);\x0a\x0a\x20\x20\x20\x20\x20\x20\x20\x20//\x20组合颜色和透明度\x0a\x20\x20\x20\x20fragColor\x20=\x20vec4(baseColor.rgb,\x20baseColor.a\x20*\x20alpha\x20*\x20speedAlpha);\x0a\x20\x20}\x20else\x20{\x0a\x20\x20\x20\x20fragColor\x20=\x20vec4(zero);\x0a\x20\x20}\x0a\x0a\x20\x20float\x20segmentsDepth\x20=\x20texture(segmentsDepthTexture,\x20textureCoordinate).r;\x0a\x20\x20float\x20globeDepth\x20=\x20czm_unpackDepth(texture(czm_globeDepthTexture,\x20textureCoordinate));\x0a\x20\x20if(segmentsDepth\x20<\x20globeDepth)\x20{\x0a\x20\x20\x20\x20fragColor\x20=\x20vec4(zero);\x0a\x20\x20}\x0a}\x0a','canvasContext','frameTime','preExecute','windTextures','segmentsColor','tlng','4409270rEIGqt','displayRange','fixedHeight','setDate','depthTest','pointer-events','age','createPrimitives','umin','error','speed','camera','willReadFrequently','array','_canvasParticles','default','postMessage','maxAge','grid','commandToExecute','frameRateAdjustment','udata','toGridXY','_removedHook','layer','_drawLines','clientWidth','clearCommand','framebuffer','0px','uniformMap','__esModule','modelMatrix','zIndex','destroy','bind','textures','particlesTextures','getSegmentDrawVertexShader','createCommand','off','flatMap','dynamic','3HqVXeV','Cesium','clientHeight','updatePosition','toDegrees','reCreateWindTextures','updateOptions','style','east','primitives','6057624tvDjJp','minificationFilter','cartesianToCartographic','_colorRamp','south','options','_tomap','forEach','28285848nGcEoJ','_addedHook','context','keys','rgb(206,255,255)','primitiveType','persists','canvasWidth','morphComplete','none','rendering','original','calculateSpeed','floor','mouse_down','_onMapWhellEvent','min','data','getParticles','SCENE3D','onParticlesTextureSizeChange','north','lineLength','rawRenderState','onmessage','BaseLayer','autoClear','max','LINEAR','commandType','samplingWindow','lat','nextParticlesPosition','Log','particlesTextureSize','attributeLocations','update','changeOptions','windField','talt','windData','EventType','bounds','mode','lng','defineProperty','mars3d-wind插件注册成功\x20\x20\x20\x20\x20版本:','_canrefresh','MIN_VALUE','magnificationFilter','blendFuncDestination','lineWidth','previousParticlesPosition','createComputingPrimitives','bufferUsage','_pointerEvents','FUNC_ADD','2803288URwxjC','processWindData','drawingBufferHeight','EllipsoidalOccluder','DomUtil','3.11.3','moveTo','isDynamic','fill','FLOAT','fromCache','\x20\x20\x20\x20编译日期:','_updateIng','type','clear','OPAQUE','fragmentShaderSource','beginPath','interpolated','show'];_0x3488=function(){return _0x1f07f4;};return _0x3488();}_0x561378['min']=0x1,_0x561378['max']=0x2;function _0x5c4e84(_0x45ab6c,_0x366b0b){return _0x5ea3(_0x45ab6c-0x10d,_0x366b0b);}const _0x40b1a0={};_0x40b1a0['min']=0x14,_0x40b1a0[_0x5c4e84(0x276,0x2de)]=0x64;const _0x4c11fd={};_0x4c11fd['particlesTextureSize']=0x64,_0x4c11fd['fixedHeight']=0x0,_0x4c11fd[_0x5c4e84(0x28e,0x230)]=_0x561378,_0x4c11fd[_0x5c4e84(0x271,0x2e7)]=_0x40b1a0,_0x4c11fd['speedFactor']=0x1,_0x4c11fd[_0x5c4e84(0x1a1,0x1d9)]=0.003,_0x4c11fd[_0x5c4e84(0x1fa,0x17d)]=0.001,_0x4c11fd['colors']=[_0x5c4e84(0x25f,0x2c9)];function _0x580342(_0x4346f1,_0x418a65){return _0x5ea3(_0x418a65-0x229,_0x4346f1);}_0x4c11fd['flipY']=![],_0x4c11fd[_0x5c4e84(0x248,0x285)]=!![];const DEF_OPTIONS=_0x4c11fd;class WindLayer extends BaseLayer$1{constructor(_0x2efe27={}){function _0x170c1c(_0x2e0d1e,_0x12e187){return _0x580342(_0x12e187,_0x2e0d1e- -0x22b);}_0x2efe27={...DEF_OPTIONS,..._0x2efe27},super(_0x2efe27),this[_0x170c1c(0xca,0x5e)](_0x2efe27,_0x2efe27);}get['layer'](){function _0x50ea31(_0x2dc17b,_0x12b27a){return _0x580342(_0x2dc17b,_0x12b27a- -0x241);}return this[_0x50ea31(0x116,0x12d)];}get['data'](){return this['options']['data'];}set['data'](_0x15f34c){this['options']['data']=_0x15f34c,this['setData'](_0x15f34c);}get['colors'](){function _0x451fb2(_0x42c4a9,_0x5be380){return _0x5c4e84(_0x42c4a9- -0x1d0,_0x5be380);}return this['options'][_0x451fb2(-0x15,0x38)];}set['colors'](_0x32d9f8){function _0x52a0a5(_0x5301cd,_0x43fcdd){return _0x580342(_0x5301cd,_0x43fcdd- -0x3d6);}this['options']['colors']=_0x32d9f8;const _0x49148b={};_0x49148b[_0x52a0a5(-0x114,-0xff)]=_0x32d9f8,this['_setOptionsHook'](this['options'],_0x49148b);}['_showHook'](_0x2c1fa2){_0x2c1fa2?this['_addedHook']():this['_removedHook']();}[_0x580342(0x2d8,0x2f1)](){}['_addedHook'](){this[_0x3ed197(0x49d,0x43e)]=this[_0x3ed197(0x478,0x4d1)][_0x3ed197(0x49d,0x514)],this[_0xb819bb(0x4eb,0x4dd)]=this['_map'][_0x3ed197(0x4b4,0x47e)];this['options'][_0x3ed197(0x4f7,0x493)]&&this['setData'](this['options'][_0x3ed197(0x4f7,0x50d)]);if(!this['windData']||!this['show'])return;this['viewerParameters']={'lonRange':new Cesium$1['Cartesian2'](-0xb4,0xb4),'latRange':new Cesium$1[(_0x3ed197(0x47a,0x4b4))](-0x5a,0x5a),'pixelSize':0x3e8,'sceneMode':this['scene'][_0x3ed197(0x511,0x49e)]},this['updateViewerParameters'](),this['particleSystem']=new WindParticleSystem(this['scene'][_0xb819bb(0x494,0x511)],this['windData'],this[_0x3ed197(0x4e3,0x45e)],this['viewerParameters'],this[_0x3ed197(0x49d,0x439)]),this['primitives']=this[_0x3ed197(0x494,0x411)][_0x3ed197(0x472,0x411)](),this['primitives'][_0xb819bb(0x4fe,0x50e)](_0x137ad0=>{function _0x3763c8(_0x3e577c,_0x2ef80c){return _0xb819bb(_0x2ef80c,_0x3e577c- -0x10d);}this['scene'][_0x3763c8(0x3f9,0x3af)]['add'](_0x137ad0);}),this['camera']['percentageChanged']=0.01,this['camera'][_0xb819bb(0x42d,0x4a5)]['addEventListener'](this['updateViewerParameters'][_0xb819bb(0x54e,0x4f5)](this));function _0x3ed197(_0x2bd08f,_0x2330fb){return _0x580342(_0x2330fb,_0x2bd08f-0x16f);}function _0xb819bb(_0x3dc20d,_0x3767d2){return _0x580342(_0x3dc20d,_0x3767d2-0x198);}this[_0x3ed197(0x49d,0x4e3)]['morphComplete']['addEventListener'](this['updateViewerParameters'][_0xb819bb(0x48f,0x4f5)](this)),window[_0xb819bb(0x508,0x48a)]('resize',this['updateViewerParameters']['bind'](this));}['_removedHook'](){this['camera'][_0x59adac(0x4d7,0x452)]['removeEventListener'](this['updateViewerParameters']['bind'](this)),this[_0x5353bd(0x4e3,0x4e7)][_0x5353bd(0x534,0x4ef)]['removeEventListener'](this['updateViewerParameters'][_0x5353bd(0x512,0x548)](this)),window['removeEventListener']('resize',this[_0x5353bd(0x4a2,0x449)][_0x5353bd(0x512,0x571)](this));this[_0x59adac(0x50a,0x4b3)]&&(this['primitives'][_0x59adac(0x461,0x4bb)](_0x219df=>{function _0x120986(_0x562a2c,_0x4f0203){return _0x5353bd(_0x4f0203- -0x23c,_0x562a2c);}function _0x394129(_0x1ba775,_0x25d57c){return _0x59adac(_0x1ba775,_0x25d57c- -0x6c6);}this[_0x120986(0x24f,0x2a7)]['primitives'][_0x394129(-0x279,-0x2c0)](_0x219df);}),delete this['primitives']);function _0x59adac(_0x300f23,_0x1e6a74){return _0x5c4e84(_0x1e6a74-0x261,_0x300f23);}function _0x5353bd(_0x2a57fb,_0x585f47){return _0x580342(_0x585f47,_0x2a57fb-0x1b5);}this['particleSystem']&&(this['particleSystem'][_0x5353bd(0x511,0x595)](),delete this['particleSystem']);}[_0x5c4e84(0x19e,0x16a)](_0x394c6c,_0x85038a){function _0x522904(_0x1b4d04,_0x25bfcc){return _0x580342(_0x1b4d04,_0x25bfcc- -0x4c7);}this['windData']=this[_0x5c3c9f(0x484,0x418)](_0x394c6c);if(_0x85038a){this[_0x522904(-0x14d,-0x176)](),this['_addedHook']();return;}function _0x5c3c9f(_0xe2856f,_0x3216e5){return _0x5c4e84(_0x3216e5-0x183,_0xe2856f);}this[_0x5c3c9f(0x390,0x38c)]?(this[_0x5c3c9f(0x328,0x38c)]['computing']['updateWindData'](this[_0x5c3c9f(0x3e4,0x406)]),this['scene']['requestRender']()):this['_addedHook']();}['_setOptionsHook'](_0x4ac116,_0xbcf3cf){function _0x10d193(_0x103354,_0x4b4d79){return _0x580342(_0x4b4d79,_0x103354- -0x5e9);}function _0x2c08fb(_0x27a9cc,_0x5eb8eb){return _0x5c4e84(_0x27a9cc- -0x46d,_0x5eb8eb);}this[_0x10d193(-0x2c4,-0x268)]&&(this[_0x2c08fb(-0x264,-0x290)][_0x2c08fb(-0x1ed,-0x262)](_0xbcf3cf),this['scene']['requestRender']());}['processWindData'](_0x5c175b){function _0x3b0af3(_0x51d2ec,_0x2d83ba){return _0x5c4e84(_0x51d2ec- -0x295,_0x2d83ba);}var _0x47c8c3,_0x3bd099;const _0x4f04ca={..._0x5c175b},_0x2102f2=_0x4f04ca;!_0x2102f2['height']&&_0x2102f2['rows']&&(_0x2102f2['height']=_0x2102f2[_0x17cc98(0x2c0,0x2ac)]);!_0x2102f2['width']&&_0x2102f2['cols']&&(_0x2102f2['width']=_0x2102f2[_0x17cc98(0x274,0x217)]);!_0x2102f2[_0x3b0af3(-0x10,-0x55)]&&(_0x2102f2[_0x3b0af3(-0x10,-0x2b)]={'west':_0x2102f2[_0x17cc98(0x2bf,0x2d7)],'south':_0x2102f2['ymin'],'east':_0x2102f2[_0x17cc98(0x2cc,0x332)],'north':_0x2102f2['ymax']});function _0x17cc98(_0x462020,_0x23c2d3){return _0x5c4e84(_0x462020-0xcc,_0x23c2d3);}if(!_0x2102f2['u']){const _0x409853={};_0x409853[_0x17cc98(0x2f7,0x27c)]=_0x5c175b[_0x3b0af3(-0x62,-0x7c)],_0x409853[_0x17cc98(0x337,0x2ca)]=_0x5c175b[_0x3b0af3(-0x6f,0x18)],_0x409853['max']=_0x5c175b[_0x17cc98(0x2a3,0x268)],_0x2102f2['u']=_0x409853;}if(!_0x2102f2['v']){const _0x4de0b0={};_0x4de0b0[_0x17cc98(0x2f7,0x2da)]=_0x5c175b[_0x17cc98(0x2d2,0x29c)],_0x4de0b0['min']=_0x5c175b['vmin'],_0x4de0b0['max']=_0x5c175b['vmax'],_0x2102f2['v']=_0x4de0b0;}if(((_0x47c8c3=_0x2102f2[_0x3b0af3(-0x6d,-0x1b)])===null||_0x47c8c3===void 0x0?void 0x0:_0x47c8c3[_0x3b0af3(-0x2a,-0x8a)])===undefined||((_0x3bd099=_0x2102f2['speed'])===null||_0x3bd099===void 0x0?void 0x0:_0x3bd099['max'])===undefined||_0x2102f2['speed'][_0x17cc98(0x2f7,0x356)]===undefined){const _0x3f1156={'array':new Float32Array(_0x2102f2['u'][_0x17cc98(0x2f7,0x319)]['length']),'min':Number[_0x17cc98(0x284,0x265)],'max':Number[_0x3b0af3(-0xa,-0x4b)]};for(let _0x18d7df=0x0;_0x18d7df<_0x2102f2['u']['array'][_0x17cc98(0x294,0x29d)];_0x18d7df++){_0x3f1156['array'][_0x18d7df]=Math['sqrt'](_0x2102f2['u'][_0x17cc98(0x2f7,0x339)][_0x18d7df]*_0x2102f2['u'][_0x3b0af3(-0x6a,-0xd)][_0x18d7df]+_0x2102f2['v']['array'][_0x18d7df]*_0x2102f2['v'][_0x3b0af3(-0x6a,-0x69)][_0x18d7df]),_0x3f1156['array'][_0x18d7df]!==0x0&&(_0x3f1156[_0x3b0af3(-0x2a,0x45)]=Math[_0x3b0af3(-0x2a,-0x9b)](_0x3f1156['min'],_0x3f1156[_0x3b0af3(-0x6a,-0xb3)][_0x18d7df]),_0x3f1156[_0x3b0af3(-0x1f,-0x54)]=Math[_0x17cc98(0x342,0x340)](_0x3f1156['max'],_0x3f1156['array'][_0x18d7df]));}_0x2102f2['speed']=_0x3f1156;}return _0x2102f2;}['updateViewerParameters'](){var _0x5a7bea;const _0x38d233=this[_0x5036d1(0x273,0x203)];if(!_0x38d233)return;const _0x1fc8d7=_0x38d233[_0x5036d1(0x210,0x242)],_0x330792={};_0x330792['x']=0x0,_0x330792['y']=0x0;const _0x3fceb3={};_0x3fceb3['x']=0x0,_0x3fceb3['y']=_0x1fc8d7[_0x5036d1(0x2ac,0x31d)];const _0x12b35f={};_0x12b35f['x']=_0x1fc8d7[_0xaa6ae0(0x1ba,0x210)],_0x12b35f['y']=0x0;const _0x1a53bc={};_0x1a53bc['x']=_0x1fc8d7['clientWidth'],_0x1a53bc['y']=_0x1fc8d7['clientHeight'];const _0x50b10d=[_0x330792,_0x3fceb3,_0x12b35f,_0x1a53bc];let _0x10ba1b=0xb4,_0x29233a=-0xb4;function _0xaa6ae0(_0x11e975,_0x51bffd){return _0x5c4e84(_0x11e975- -0x7e,_0x51bffd);}let _0x27c9c2=0x5a,_0x5bb831=-0x5a,_0x4b803a=![];for(const _0x23f50b of _0x50b10d){const _0x43d647=_0x38d233['camera'][_0x5036d1(0x231,0x254)](new Cesium$1['Cartesian2'](_0x23f50b['x'],_0x23f50b['y']),_0x38d233[_0x5036d1(0x24d,0x27a)][_0x5036d1(0x26b,0x28b)]);if(!_0x43d647){_0x4b803a=!![];break;}const _0x4358fd=_0x38d233['globe']['ellipsoid'][_0x5036d1(0x2b6,0x255)](_0x43d647),_0x31c8f4=Cesium$1['Math'][_0x5036d1(0x2ae,0x26a)](_0x4358fd['longitude']),_0x4361c3=Cesium$1[_0xaa6ae0(0x140,0xfd)]['toDegrees'](_0x4358fd[_0xaa6ae0(0x177,0x151)]);_0x10ba1b=Math['min'](_0x10ba1b,_0x31c8f4),_0x29233a=Math['max'](_0x29233a,_0x31c8f4),_0x27c9c2=Math['min'](_0x27c9c2,_0x4361c3),_0x5bb831=Math['max'](_0x5bb831,_0x4361c3);}if(!_0x4b803a){const _0x1df4c6=new Cesium$1['Cartesian2'](Math[_0xaa6ae0(0x1f8,0x272)](this[_0xaa6ae0(0x205,0x1ed)][_0x5036d1(0x2e6,0x27f)][_0x5036d1(0x203,0x202)],_0x10ba1b),Math[_0xaa6ae0(0x1ed,0x199)](this[_0xaa6ae0(0x205,0x1da)]['bounds']['east'],_0x29233a)),_0x13abf8=new Cesium$1['Cartesian2'](Math['max'](this[_0xaa6ae0(0x205,0x23c)][_0x5036d1(0x2e6,0x326)][_0x5036d1(0x2b8,0x27e)],_0x27c9c2),Math['min'](this['windData'][_0xaa6ae0(0x207,0x1b3)]['north'],_0x5bb831)),_0x1a8b3e=(_0x1df4c6['y']-_0x1df4c6['x'])*0.05,_0x2d1bcd=(_0x13abf8['y']-_0x13abf8['x'])*0.05;_0x1df4c6['x']=Math[_0xaa6ae0(0x1f8,0x21a)](this[_0xaa6ae0(0x205,0x286)]['bounds']['west'],_0x1df4c6['x']-_0x1a8b3e),_0x1df4c6['y']=Math[_0xaa6ae0(0x1ed,0x1f1)](this[_0x5036d1(0x2e4,0x298)]['bounds']['east'],_0x1df4c6['y']+_0x1a8b3e),_0x13abf8['x']=Math['max'](this[_0xaa6ae0(0x205,0x25a)][_0x5036d1(0x2e6,0x2a6)][_0x5036d1(0x2b8,0x305)],_0x13abf8['x']-_0x2d1bcd),_0x13abf8['y']=Math['min'](this['windData'][_0x5036d1(0x2e6,0x2b5)][_0xaa6ae0(0x1f2,0x216)],_0x13abf8['y']+_0x2d1bcd),this['viewerParameters'][_0x5036d1(0x25a,0x2db)]=_0x1df4c6,this['viewerParameters'][_0x5036d1(0x26e,0x254)]=_0x13abf8;const _0x2927db=this['windData']['bounds']['east']-this['windData']['bounds']['west'],_0x40384c=this['windData']['bounds'][_0xaa6ae0(0x1f2,0x1d0)]-this['windData'][_0x5036d1(0x2e6,0x2a9)]['south'],_0x2b39af=(_0x1df4c6['y']-_0x1df4c6['x'])/_0x2927db,_0xed4ba3=(_0x13abf8['y']-_0x13abf8['x'])/_0x40384c,_0x1d7021=Math[_0x5036d1(0x2cc,0x245)](_0x2b39af,_0xed4ba3),_0x5af5dc=0x3e8*_0x1d7021;_0x5af5dc>0x0&&(this['viewerParameters']['pixelSize']=Math['max'](0x0,Math[_0x5036d1(0x2cc,0x269)](0x3e8,_0x5af5dc)));}function _0x5036d1(_0x1ecc3c,_0xb57034){return _0x580342(_0xb57034,_0x1ecc3c- -0xbb);}this['viewerParameters'][_0x5036d1(0x276,0x20f)]=this[_0x5036d1(0x273,0x2f6)]['mode'],(_0x5a7bea=this['particleSystem'])===null||_0x5a7bea===void 0x0||_0x5a7bea['applyViewerParameters'](this['viewerParameters']);}[_0x580342(0x2b2,0x2cd)](_0x1051f0,_0x2c69c7){const {bounds:_0x24a221,width:_0x258ae9,height:_0x3cf8d1,u:_0x2a1c35,v:_0x1ba374,speed:_0x2600fa}=this[_0x904ae9(0x28a,0x2cc)],{flipY:_0x64ce23}=this[_0x904ae9(0x2c2,0x2a1)];if(_0x1051f0<_0x24a221['west']||_0x1051f0>_0x24a221[_0x904ae9(0x21c,0x29a)]||_0x2c69c7<_0x24a221[_0xaa40a0(0x428,0x406)]||_0x2c69c7>_0x24a221[_0xaa40a0(0x441,0x498)])return null;const _0x561e3d=(_0x1051f0-_0x24a221[_0xaa40a0(0x373,0x343)])/(_0x24a221[_0xaa40a0(0x422,0x3a2)]-_0x24a221['west'])*(_0x258ae9-0x1);let _0x4e89f8=(_0x2c69c7-_0x24a221['south'])/(_0x24a221['north']-_0x24a221['south'])*(_0x3cf8d1-0x1);_0x64ce23&&(_0x4e89f8=_0x3cf8d1-0x1-_0x4e89f8);const _0x24f445=Math['floor'](_0x561e3d),_0x4ec377=Math[_0xaa40a0(0x439,0x40e)](_0x4e89f8),_0x5ada70=Math['floor'](_0x561e3d),_0x15ae54=Math['min'](_0x5ada70+0x1,_0x258ae9-0x1),_0x5543d5=Math[_0x904ae9(0x241,0x2b1)](_0x4e89f8),_0xa359de=Math['min'](_0x5543d5+0x1,_0x3cf8d1-0x1),_0x326284=_0x561e3d-_0x5ada70,_0x4a45d6=_0x4e89f8-_0x5543d5,_0x4b5e30=_0x4ec377*_0x258ae9+_0x24f445,_0x8b373c=_0x5543d5*_0x258ae9+_0x5ada70,_0x3926a3=_0x5543d5*_0x258ae9+_0x15ae54,_0x34c2b3=_0xa359de*_0x258ae9+_0x5ada70,_0x2891a5=_0xa359de*_0x258ae9+_0x15ae54;function _0x904ae9(_0x12d155,_0x499cab){return _0x580342(_0x12d155,_0x499cab- -0xd3);}const _0x2c1ac4=_0x2a1c35[_0x904ae9(0x2b4,0x274)][_0x8b373c],_0x4366c6=_0x2a1c35[_0x904ae9(0x2da,0x274)][_0x3926a3],_0x2db0d1=_0x2a1c35['array'][_0x34c2b3],_0x525be0=_0x2a1c35['array'][_0x2891a5],_0x321390=(0x1-_0x326284)*(0x1-_0x4a45d6)*_0x2c1ac4+_0x326284*(0x1-_0x4a45d6)*_0x4366c6+(0x1-_0x326284)*_0x4a45d6*_0x2db0d1+_0x326284*_0x4a45d6*_0x525be0;function _0xaa40a0(_0x2e725e,_0x2663f5){return _0x580342(_0x2663f5,_0x2e725e-0xb5);}const _0x19656c=_0x1ba374[_0x904ae9(0x2c4,0x274)][_0x8b373c],_0x197b83=_0x1ba374[_0x904ae9(0x20c,0x274)][_0x3926a3],_0x2b35bd=_0x1ba374[_0xaa40a0(0x3fc,0x395)][_0x34c2b3],_0x4b847d=_0x1ba374['array'][_0x2891a5],_0x3518f5=(0x1-_0x326284)*(0x1-_0x4a45d6)*_0x19656c+_0x326284*(0x1-_0x4a45d6)*_0x197b83+(0x1-_0x326284)*_0x4a45d6*_0x2b35bd+_0x326284*_0x4a45d6*_0x4b847d,_0x59019c=Math[_0x904ae9(0x1f2,0x22e)](_0x321390*_0x321390+_0x3518f5*_0x3518f5),_0x3468b3={};_0x3468b3['u']=_0x2a1c35['array'][_0x4b5e30],_0x3468b3['v']=_0x1ba374['array'][_0x4b5e30],_0x3468b3['speed']=_0x2600fa['array'][_0x4b5e30];const _0xe51ce4={};_0xe51ce4['u']=_0x321390,_0xe51ce4['v']=_0x3518f5,_0xe51ce4['speed']=_0x59019c;const _0x1b235e={};return _0x1b235e[_0xaa40a0(0x437,0x41a)]=_0x3468b3,_0x1b235e[_0x904ae9(0x263,0x1e0)]=_0xe51ce4,_0x1b235e;}}mars3d__namespace[_0x580342(0x2ca,0x2b5)]['register']('wind',WindLayer),mars3d__namespace[_0x5c4e84(0x236,0x1c8)]['WindLayer']=WindLayer;class CanvasParticle{constructor(){function _0x3e3327(_0x403b2b,_0x295c44){return _0x580342(_0x403b2b,_0x295c44-0xd2);}function _0x244633(_0x19797f,_0x3f64d9){return _0x580342(_0x19797f,_0x3f64d9- -0x460);}this['lng']=null,this['lat']=null,this[_0x244633(-0x1ac,-0x127)]=null,this[_0x244633(-0x1c7,-0x192)]=null,this[_0x3e3327(0x469,0x412)]=null,this['speed']=null;}['destroy'](){for(const _0x5070e9 in this){delete this[_0x5070e9];}}}class CanvasWindField{constructor(_0x570540){this['setOptions'](_0x570540);}get['speedRate'](){return this['_speedRate'];}set['speedRate'](_0x1c27c7){function _0x4baffc(_0x3b5a29,_0x585390){return _0x580342(_0x585390,_0x3b5a29- -0x5c7);}function _0x97e6a2(_0x7c63eb,_0x299224){return _0x580342(_0x299224,_0x7c63eb- -0x5fe);}this['_speedRate']=(0x64-(_0x1c27c7>0x63?0x63:_0x1c27c7))*0x64,this[_0x97e6a2(-0x2d2,-0x276)]=[(this['xmax']-this[_0x97e6a2(-0x2ef,-0x2b3)])/this['_speedRate'],(this['ymax']-this['ymin'])/this['_speedRate']];}get['maxAge'](){return this['_maxAge'];}set['maxAge'](_0x47b70d){this['_maxAge']=_0x47b70d;}['setOptions'](_0x212442){this['options']=_0x212442,this['maxAge']=_0x212442[_0x2693e2(0x3d7,0x3fd)]||0x78;function _0x56f727(_0x3126ac,_0x997c8){return _0x5c4e84(_0x997c8- -0x2ce,_0x3126ac);}function _0x2693e2(_0x4a00c7,_0x11ba36){return _0x5c4e84(_0x4a00c7-0x1a8,_0x11ba36);}this['speedRate']=_0x212442['speedRate']||0x32,this[_0x56f727(-0x12e,-0x11a)]=[];const _0x180280=_0x212442['particlesNumber']||0x1000;for(let _0x4a0f68=0x0;_0x4a0f68<_0x180280;_0x4a0f68++){const _0x3e36b9=this[_0x2693e2(0x373,0x356)](new CanvasParticle());this[_0x56f727(-0xcf,-0x11a)][_0x2693e2(0x398,0x330)](_0x3e36b9);}}[_0x5c4e84(0x221,0x1c0)](_0x1dd384){this['rows']=_0x1dd384['rows'],this['cols']=_0x1dd384[_0x3d13cb(0x459,0x434)],this[_0x4c1a05(0x170,0x1c7)]=_0x1dd384[_0x4c1a05(0x170,0x1c1)],this[_0x3d13cb(0x449,0x48c)]=_0x1dd384[_0x3d13cb(0x4a4,0x48c)],this[_0x3d13cb(0x40e,0x439)]=_0x1dd384['ymin'],this[_0x4c1a05(0x16b,0x124)]=_0x1dd384['ymax'],this[_0x3d13cb(0x4ea,0x4bc)]=[];const _0xc04011=_0x1dd384['udata'],_0x589765=_0x1dd384[_0x3d13cb(0x48d,0x492)];function _0x4c1a05(_0x50a9c7,_0x13fdfd){return _0x580342(_0x13fdfd,_0x50a9c7- -0x19f);}let _0x310f99=![];_0xc04011['length']===this[_0x4c1a05(0x171,0x1bb)]&&_0xc04011[0x0]['length']===this['cols']&&(_0x310f99=!![]);let _0x29b65a=0x0,_0x485dad=null,_0x2ed97b=null;function _0x3d13cb(_0x24dded,_0x3d8fd7){return _0x580342(_0x24dded,_0x3d8fd7-0x170);}for(let _0x1398cd=0x0;_0x1398cd<this['rows'];_0x1398cd++){_0x485dad=[];for(let _0x7f31d6=0x0;_0x7f31d6<this[_0x4c1a05(0x125,0xd1)];_0x7f31d6++,_0x29b65a++){_0x310f99?_0x2ed97b=this['_calcUV'](_0xc04011[_0x1398cd][_0x7f31d6],_0x589765[_0x1398cd][_0x7f31d6]):_0x2ed97b=this['_calcUV'](_0xc04011[_0x29b65a],_0x589765[_0x29b65a]),_0x485dad[_0x3d13cb(0x473,0x47c)](_0x2ed97b);}this[_0x4c1a05(0x1ad,0x17a)]['push'](_0x485dad);}!this[_0x3d13cb(0x522,0x4e4)][_0x4c1a05(0x142,0x13f)]&&this['grid']['reverse']();}['clear'](){delete this['rows'],delete this['cols'];function _0x563612(_0x61694d,_0x17b918){return _0x580342(_0x17b918,_0x61694d- -0x368);}delete this['xmin'],delete this['xmax'],delete this[_0x264096(-0x281,-0x2a5)];function _0x264096(_0x394cbf,_0x50dc16){return _0x580342(_0x394cbf,_0x50dc16- -0x56e);}delete this['ymax'],delete this[_0x563612(-0x1c,-0xd)],delete this['particles'];}[_0x580342(0x2f0,0x350)](_0xb6dc65,_0x92e705){function _0x4710b5(_0x543674,_0x31ca57){return _0x5c4e84(_0x31ca57-0xa5,_0x543674);}function _0x3a3080(_0x457864,_0x3e915b){return _0x5c4e84(_0x457864-0x13,_0x3e915b);}const _0xcb5da3=(_0xb6dc65-this[_0x4710b5(0x275,0x298)])/(this['xmax']-this[_0x4710b5(0x26e,0x298)])*(this['cols']-0x1),_0x10f2f3=(this[_0x3a3080(0x201,0x27b)]-_0x92e705)/(this['ymax']-this['ymin'])*(this['rows']-0x1);return[_0xcb5da3,_0x10f2f3];}[_0x580342(0x2c8,0x2d8)](_0x3aedfa,_0x16c210){if(_0x3aedfa<0x0||_0x3aedfa>=this['cols']||_0x16c210>=this[_0x278a21(0x476,0x4bf)])return[0x0,0x0,0x0];const _0x1f932e=Math[_0x278a21(0x4ea,0x4e7)](_0x3aedfa),_0x237d49=Math['floor'](_0x16c210);if(_0x1f932e===_0x3aedfa&&_0x237d49===_0x16c210)return this['grid'][_0x16c210][_0x3aedfa];const _0x55a3c7=_0x1f932e+0x1;function _0x278a21(_0x23968b,_0x414177){return _0x5c4e84(_0x23968b-0x282,_0x414177);}const _0x2e94d1=_0x237d49+0x1,_0x4e2db0=this['getUVByXY'](_0x1f932e,_0x237d49);function _0x4acd8e(_0x4b997c,_0x56cd9f){return _0x580342(_0x56cd9f,_0x4b997c- -0x303);}const _0x3f8475=this['getUVByXY'](_0x55a3c7,_0x237d49),_0x240d09=this['getUVByXY'](_0x1f932e,_0x2e94d1),_0x3445c1=this['getUVByXY'](_0x55a3c7,_0x2e94d1);let _0x10a180=null;try{_0x10a180=this['_bilinearInterpolation'](_0x3aedfa-_0x1f932e,_0x16c210-_0x237d49,_0x4e2db0,_0x3f8475,_0x240d09,_0x3445c1);}catch(_0x35ea39){console[_0x4acd8e(0xb,0x46)](_0x3aedfa,_0x16c210);}return _0x10a180;}['_bilinearInterpolation'](_0x79303b,_0x307e49,_0x48965c,_0x4ef418,_0x4cde47,_0x27937f){const _0xc9546e=0x1-_0x79303b,_0x3e0470=0x1-_0x307e49,_0x1dfd07=_0xc9546e*_0x3e0470,_0x317678=_0x79303b*_0x3e0470,_0x38efc2=_0xc9546e*_0x307e49,_0x3a71ff=_0x79303b*_0x307e49,_0x2a6466=_0x48965c[0x0]*_0x1dfd07+_0x4ef418[0x0]*_0x317678+_0x4cde47[0x0]*_0x38efc2+_0x27937f[0x0]*_0x3a71ff,_0x4b57f6=_0x48965c[0x1]*_0x1dfd07+_0x4ef418[0x1]*_0x317678+_0x4cde47[0x1]*_0x38efc2+_0x27937f[0x1]*_0x3a71ff;return this['_calcUV'](_0x2a6466,_0x4b57f6);}[_0x5c4e84(0x1c4,0x1a1)](_0x53decd,_0xc1ce7a){return[+_0x53decd,+_0xc1ce7a,Math['sqrt'](_0x53decd*_0x53decd+_0xc1ce7a*_0xc1ce7a)];}['getUVByPoint'](_0x1a4598,_0x239bbc){function _0x3ad8e7(_0x3d8026,_0x2ea6c6){return _0x5c4e84(_0x2ea6c6-0x4f,_0x3d8026);}if(!this[_0x3ad8e7(0x16a,0x1ee)](_0x1a4598,_0x239bbc))return null;const _0x11b050=this['toGridXY'](_0x1a4598,_0x239bbc),_0x210482=this['getUVByXY'](_0x11b050[0x0],_0x11b050[0x1]);return _0x210482;}[_0x580342(0x338,0x2bb)](_0x13f051,_0x12806c){function _0x558045(_0x3aa231,_0x454f5c){return _0x5c4e84(_0x3aa231- -0x3d6,_0x454f5c);}function _0x39b9cf(_0x2a3c1f,_0x5f1428){return _0x580342(_0x2a3c1f,_0x5f1428- -0x502);}return _0x13f051>=this['xmin']&&_0x13f051<=this[_0x558045(-0x1d6,-0x23a)]&&_0x12806c>=this['ymin']&&_0x12806c<=this[_0x39b9cf(-0x261,-0x1f8)]?!![]:![];}['getRandomLatLng'](){const _0x141973=fRandomByfloat(this[_0x2bd317(0x1fc,0x195)],this['xmax']),_0x27e200=fRandomByfloat(this['ymin'],this[_0x2bd317(0x1ea,0x190)]);function _0x2bd317(_0x1bd439,_0x44566b){return _0x5c4e84(_0x44566b- -0x5e,_0x1bd439);}function _0x59404b(_0x3c49c7,_0x4b3439){return _0x580342(_0x4b3439,_0x3c49c7- -0x15f);}const _0x1cd59f={};return _0x1cd59f['lat']=_0x27e200,_0x1cd59f['lng']=_0x141973,_0x1cd59f;}[_0x5c4e84(0x26d,0x2d0)](){function _0x42fa30(_0x4d1ca4,_0x4842bc){return _0x580342(_0x4d1ca4,_0x4842bc-0x1b2);}let _0x3eacb7,_0x5d3c85,_0x39b948;for(let _0xe677a=0x0,_0x8f82cd=this['particles']['length'];_0xe677a<_0x8f82cd;_0xe677a++){let _0x46eb64=this[_0x3c9ae7(0x1ea,0x20d)][_0xe677a];_0x46eb64[_0x3c9ae7(0x25a,0x2bd)]<=0x0&&(_0x46eb64=this[_0x3c9ae7(0x201,0x1fb)](_0x46eb64));if(_0x46eb64[_0x42fa30(0x4c9,0x4f2)]>0x0){const _0x4cd27e=_0x46eb64['tlng'],_0x332c92=_0x46eb64[_0x3c9ae7(0x1e8,0x1fb)];_0x39b948=this['getUVByPoint'](_0x4cd27e,_0x332c92),_0x39b948?(_0x3eacb7=_0x4cd27e+this['_calc_speedRate'][0x0]*_0x39b948[0x0],_0x5d3c85=_0x332c92+this['_calc_speedRate'][0x1]*_0x39b948[0x1],_0x46eb64['lng']=_0x4cd27e,_0x46eb64['lat']=_0x332c92,_0x46eb64['tlng']=_0x3eacb7,_0x46eb64['tlat']=_0x5d3c85,_0x46eb64['speed']=_0x39b948[0x2],_0x46eb64['age']--):_0x46eb64['age']=0x0;}}function _0x3c9ae7(_0x3b64b4,_0x58d0ea){return _0x580342(_0x58d0ea,_0x3b64b4- -0xe6);}return this[_0x3c9ae7(0x1ea,0x1d6)];}['_randomParticle'](_0x4bd425){let _0x1d54d9,_0x5905d1;function _0x32c8c9(_0x1a4466,_0x17c36e){return _0x5c4e84(_0x17c36e-0xfd,_0x1a4466);}for(let _0x378e3b=0x0;_0x378e3b<0x1e;_0x378e3b++){_0x1d54d9=this[_0x32c8c9(0x26d,0x2f4)](),_0x5905d1=this['getUVByPoint'](_0x1d54d9[_0x32c8c9(0x3a1,0x384)],_0x1d54d9['lat']);if(_0x5905d1&&_0x5905d1[0x2]>0x0)break;}if(!_0x5905d1)return _0x4bd425;const _0x12efa4=_0x1d54d9['lng']+this['_calc_speedRate'][0x0]*_0x5905d1[0x0],_0x759cde=_0x1d54d9['lat']+this[_0x32c8c9(0x295,0x30d)][0x1]*_0x5905d1[0x1];_0x4bd425[_0x4c0516(0x20b,0x1ff)]=_0x1d54d9['lng'],_0x4bd425[_0x4c0516(0x1fe,0x1f7)]=_0x1d54d9['lat'],_0x4bd425[_0x32c8c9(0x2cb,0x31a)]=_0x12efa4,_0x4bd425['tlat']=_0x759cde;function _0x4c0516(_0x52ac46,_0x5c197b){return _0x5c4e84(_0x52ac46- -0x7c,_0x5c197b);}return _0x4bd425['age']=Math['round'](0xa+Math['random']()*this[_0x4c0516(0x1b3,0x14e)]),_0x4bd425[_0x4c0516(0x1ac,0x1b2)]=_0x5905d1[0x2],_0x4bd425;}[_0x580342(0x2d8,0x35c)](){for(const _0x5be871 in this){delete this[_0x5be871];}}}function fRandomByfloat(_0x1b21a4,_0x2f4ef7){return _0x1b21a4+Math['random']()*(_0x2f4ef7-_0x1b21a4);}const Cesium=mars3d__namespace['Cesium'],BaseLayer=mars3d__namespace['layer'][_0x580342(0x384,0x390)];class CanvasWindLayer extends BaseLayer{constructor(_0x4ef524={}){super(_0x4ef524);function _0x170c25(_0x38bf46,_0x2e972a){return _0x5c4e84(_0x38bf46- -0x12,_0x2e972a);}this[_0x29d743(-0x22c,-0x29f)](_0x4ef524),this[_0x29d743(-0x256,-0x2b2)]=null;function _0x29d743(_0x2ae98b,_0x8b13a8){return _0x5c4e84(_0x2ae98b- -0x405,_0x8b13a8);}_0x4ef524['colors']&&_0x4ef524[_0x170c25(0x18b,0x12b)]&&(this['_colorRamp']=new mars3d__namespace['ColorRamp'](_0x4ef524));}[_0x5c4e84(0x1d9,0x15b)](_0x51209f,_0x3a6a8a){this['frameTime']=0x3e8/(_0x51209f['frameRate']||0xa),this[_0x129095(0x276,0x1ff)]=this['options'][_0x440b68(-0x4f,-0x66)]??![];function _0x129095(_0xfd7217,_0x1059c7){return _0x5c4e84(_0x1059c7- -0x93,_0xfd7217);}this['color']=_0x51209f['color']||'#ffffff',this['lineWidth']=_0x51209f[_0x440b68(0x94,0x77)]||0x1,this['fixedHeight']=_0x51209f[_0x440b68(0x26,-0x49)]??0x0;function _0x440b68(_0x4c13e1,_0x5682c4){return _0x5c4e84(_0x4c13e1- -0x1fa,_0x5682c4);}this[_0x129095(0x15c,0x132)]=_0x51209f['flipY']??![],this['windField']&&this[_0x440b68(0x87,0xf4)]['setOptions'](_0x51209f);}get['layer'](){return this['canvas'];}get[_0x580342(0x3d0,0x37e)](){return this['_map']['scene']['canvas']['clientWidth'];}get['canvasHeight'](){return this['_map']['scene']['canvas']['clientHeight'];}get['pointerEvents'](){return this['_pointerEvents'];}set['pointerEvents'](_0x17c6c7){function _0x109090(_0xb24dbd,_0x1a5649){return _0x580342(_0xb24dbd,_0x1a5649- -0x29a);}this[_0x109090(0x101,0x114)]=_0x17c6c7;function _0x2ba3de(_0x4e2238,_0x54bfb7){return _0x580342(_0x54bfb7,_0x4e2238- -0x1ee);}if(!this[_0x2ba3de(0xdd,0x76)])return;_0x17c6c7?this['canvas']['style'][_0x2ba3de(0x151,0x12e)]='all':this['canvas']['style']['pointer-events']=_0x109090(0x146,0xe6);}get[_0x5c4e84(0x1ac,0x12c)](){function _0x7bc718(_0x373971,_0xbe14c){return _0x5c4e84(_0x373971- -0x3da,_0xbe14c);}return this['options'][_0x7bc718(-0x22e,-0x271)];}set[_0x580342(0x2d1,0x2c8)](_0x5440af){function _0x51772f(_0x27800a,_0x429d2f){return _0x580342(_0x429d2f,_0x27800a-0x73);}this[_0x439bd3(0x258,0x27a)]['particlesNumber']=_0x5440af;function _0x439bd3(_0x32387b,_0x53e73e){return _0x5c4e84(_0x32387b-0x0,_0x53e73e);}clearTimeout(this['_canrefresh']),this[_0x439bd3(0x28a,0x20d)]=setTimeout(()=>{this['redraw']();},0x1f4);}get['speedRate'](){function _0xcea81b(_0x253453,_0x22aa7c){return _0x5c4e84(_0x253453- -0x42d,_0x22aa7c);}return this[_0xcea81b(-0x1d5,-0x1e0)]['speedRate'];}set[_0x5c4e84(0x202,0x183)](_0x202c3e){this[_0x3ece73(0x2ba,0x328)]['speedRate']=_0x202c3e;function _0x49a5de(_0x5f4bad,_0x4e0364){return _0x580342(_0x4e0364,_0x5f4bad- -0x2ae);}function _0x3ece73(_0x484cd1,_0x5a8434){return _0x580342(_0x5a8434,_0x484cd1- -0xba);}this['windField']&&(this['windField'][_0x3ece73(0x264,0x20b)]=_0x202c3e);}get['maxAge'](){function _0x41262a(_0x2264d7,_0x3d976d){return _0x580342(_0x2264d7,_0x3d976d-0x185);}return this[_0x41262a(0x49b,0x4f9)]['maxAge'];}set['maxAge'](_0x430066){this['options']['maxAge']=_0x430066;function _0x5335b8(_0x84be5a,_0x5c58ce){return _0x5c4e84(_0x5c58ce- -0x208,_0x84be5a);}function _0x54a25c(_0x945c8a,_0x526e71){return _0x5c4e84(_0x945c8a- -0x125,_0x526e71);}this[_0x5335b8(0xbb,0x79)]&&(this['windField'][_0x5335b8(0x16,0x27)]=_0x430066);}get['data'](){return this['windData'];}set[_0x580342(0x3f2,0x388)](_0x43db70){this['setData'](_0x43db70);}get['rectangle'](){let _0x28da50=this['windData'][_0x590c72(-0x141,-0x1b5)],_0x3a9930=this['windData']['xmax'];function _0x11d272(_0x537b53,_0x5ac059){return _0x5c4e84(_0x5ac059- -0x237,_0x537b53);}let _0x488cbd=this['windData']['ymin'],_0x1ebb97=this[_0x11d272(-0x30,0x4c)][_0x11d272(-0xa8,-0x49)];_0x3a9930>=0x167&&_0x28da50===0x0&&(_0x28da50=-0xb4,_0x3a9930=0xb4);_0x28da50=Math['max'](_0x28da50,-0xb4);function _0x590c72(_0x135800,_0x3cd56e){return _0x580342(_0x3cd56e,_0x135800- -0x450);}return _0x3a9930=Math['min'](_0x3a9930,0xb4),_0x488cbd=Math['max'](_0x488cbd,-0x5a),_0x1ebb97=Math['min'](_0x1ebb97,0x5a),Cesium['Rectangle']['fromDegrees'](_0x28da50,_0x488cbd,_0x3a9930,_0x1ebb97);}['_showHook'](_0x114085){function _0x4fa136(_0x3fd5e3,_0x451c11){return _0x5c4e84(_0x3fd5e3- -0x445,_0x451c11);}function _0x4c9b3b(_0xc45bd5,_0x5d26b0){return _0x5c4e84(_0xc45bd5- -0x3f0,_0x5d26b0);}_0x114085?this[_0x4fa136(-0x1e9,-0x234)]():(this['windData']&&(this['options'][_0x4c9b3b(-0x184,-0x161)]=this[_0x4fa136(-0x1c2,-0x185)]),this['_removedHook']());}['_mountedHook'](){function _0xaba13f(_0x5e81a6,_0x183fe5){return _0x5c4e84(_0x183fe5- -0xe,_0x5e81a6);}function _0x33abf7(_0x29db6e,_0x56e94f){return _0x580342(_0x29db6e,_0x56e94f-0x178);}this[_0x33abf7(0x55a,0x4ec)]['worker']?this[_0x33abf7(0x42d,0x495)]():this[_0xaba13f(0x2db,0x273)]=new CanvasWindField(this['options']);}['_addedHook'](){function _0x2a9fb0(_0x327046,_0x26d2c4){return _0x580342(_0x26d2c4,_0x327046-0xe9);}this[_0xd518ca(0x1c4,0x239)]=this[_0x2a9fb0(0x3cc,0x3db)]();function _0xd518ca(_0x2058fa,_0x270336){return _0x580342(_0x2058fa,_0x270336- -0x92);}const _0x4e2d6e={};_0x4e2d6e[_0xd518ca(0x2b6,0x2b4)]=!![],this[_0xd518ca(0x269,0x2a2)]=this[_0x2a9fb0(0x3b4,0x386)][_0xd518ca(0x1f3,0x250)]('2d',_0x4e2d6e),this['bindEvent'](),this[_0x2a9fb0(0x45d,0x4da)][_0xd518ca(0x2f8,0x2f6)]&&this['setData'](this[_0x2a9fb0(0x45d,0x49f)]['data']);}[_0x580342(0x314,0x351)](){function _0x5cbd99(_0x4917f6,_0x41be45){return _0x580342(_0x4917f6,_0x41be45- -0x509);}this[_0x33991f(-0x106,-0xc5)](),this[_0x5cbd99(-0x1ba,-0x212)]();function _0x33991f(_0x502bd3,_0x36af40){return _0x580342(_0x502bd3,_0x36af40- -0x374);}this['canvas']&&(this[_0x33991f(-0xb5,-0x6b)][_0x5cbd99(-0x21d,-0x204)]['removeChild'](this['canvas']),delete this[_0x5cbd99(-0x2ac,-0x23e)]);}[_0x5c4e84(0x1c7,0x1c0)](){const _0x36c476=mars3d__namespace[_0x36888e(0x549,0x50b)]['create'](_0x13acaa(-0x1b1,-0x167),'mars3d-canvasWind',this[_0x13acaa(-0x11e,-0x129)][_0x36888e(0x3f3,0x45c)]);_0x36c476[_0x36888e(0x4a5,0x4c3)]['position']='absolute',_0x36c476[_0x36888e(0x530,0x4c3)]['top']='0px',_0x36c476[_0x13acaa(-0x72,-0xc6)][_0x13acaa(-0xaa,-0x113)]=_0x13acaa(-0xdc,-0xdb);function _0x13acaa(_0xc67701,_0x1a1d64){return _0x5c4e84(_0x1a1d64- -0x316,_0xc67701);}_0x36c476['style']['width']=this['_map']['scene'][_0x13acaa(-0x131,-0x167)][_0x13acaa(-0x70,-0xde)]+'px',_0x36c476[_0x36888e(0x517,0x4c3)]['height']=this['_map']['scene']['canvas']['clientHeight']+'px',_0x36c476[_0x36888e(0x481,0x4c3)][_0x36888e(0x426,0x41e)]=this['_pointerEvents']?'auto':'none';function _0x36888e(_0xb013ec,_0x1f0956){return _0x5c4e84(_0x1f0956-0x273,_0xb013ec);}return _0x36c476[_0x13acaa(-0x81,-0xc6)][_0x36888e(0x519,0x4b2)]=this['options']['zIndex']??0x9,_0x36c476['width']=this['_map'][_0x13acaa(-0xb6,-0x104)]['canvas'][_0x36888e(0x49b,0x4ab)],_0x36c476[_0x36888e(0x41e,0x45b)]=this[_0x36888e(0x490,0x460)]['scene']['canvas']['clientHeight'],_0x36c476;}[_0x5c4e84(0x1a6,0x1d5)](){function _0x5b5276(_0x7694d2,_0x5ba11c){return _0x5c4e84(_0x7694d2-0x272,_0x5ba11c);}function _0x5cf3c2(_0x338c5b,_0x445e07){return _0x5c4e84(_0x338c5b- -0xc8,_0x445e07);}this['canvas']&&(this['canvas'][_0x5cf3c2(0x188,0x108)][_0x5cf3c2(0x11c,0x169)]=this['_map'][_0x5b5276(0x484,0x4fd)]['canvas'][_0x5b5276(0x4aa,0x459)]+'px',this['canvas']['style'][_0x5b5276(0x45a,0x4c2)]=this['_map']['scene'][_0x5cf3c2(0xe7,0x92)]['clientHeight']+'px',this['canvas']['width']=this['_map'][_0x5b5276(0x484,0x4b4)]['canvas']['clientWidth'],this[_0x5cf3c2(0xe7,0xc5)]['height']=this['_map']['scene'][_0x5b5276(0x421,0x421)][_0x5b5276(0x4bd,0x539)]);}[_0x5c4e84(0x1ae,0x15e)](){function _0x27e796(_0x3d7a2d,_0xabab66){return _0x5c4e84(_0xabab66- -0x1b2,_0x3d7a2d);}const _0xbd4976=this;let _0x3efef1=Date['now']();(function _0x4105a3(){function _0x524e09(_0x39eb21,_0x1a80c1){return _0x5ea3(_0x1a80c1- -0x1d0,_0x39eb21);}function _0x21363e(_0x211067,_0x4677b3){return _0x5ea3(_0x4677b3-0x275,_0x211067);}if(_0xbd4976['isDestroy'])return;_0xbd4976['_animateFrame']=window[_0x524e09(-0x10c,-0xfd)](_0x4105a3);if(_0xbd4976['show']&&_0xbd4976[_0x524e09(-0x7d,-0x5c)]){const _0x29779b=Date[_0x21363e(0x2e0,0x353)](),_0x29c6d8=_0x29779b-_0x3efef1;_0x29c6d8>_0xbd4976[_0x21363e(0x315,0x381)]&&(_0x3efef1=_0x29779b-_0x29c6d8%_0xbd4976['frameTime'],_0xbd4976['update']());}}(),window['addEventListener']('resize',this['resize'][_0x27e796(0x109,0x8f)](this),![]));function _0x413d78(_0x531e20,_0x52b445){return _0x5c4e84(_0x52b445- -0x251,_0x531e20);}this[_0x413d78(0x3f,0x18)]=![],this['mouse_move']=![],this['options']['mouseHidden']&&(this['_map']['on'](mars3d__namespace['EventType'][_0x27e796(0xcb,0x5c)],this['_onMapWhellEvent'],this),this['_map']['on'](mars3d__namespace[_0x27e796(0x96,0xd2)][_0x27e796(0x8a,0x3)],this[_0x413d78(-0xa9,-0x3e)],this),this[_0x27e796(0x33,0x3b)]['on'](mars3d__namespace['EventType'][_0x27e796(0x5c,0xb)],this['_onMouseUpEvent'],this));}['unbindEvent'](){window['cancelAnimationFrame'](this[_0x1f095d(-0x239,-0x251)]),delete this[_0x9903b9(-0x1e2,-0x185)];function _0x1f095d(_0x4f4044,_0x4b1548){return _0x5c4e84(_0x4b1548- -0x42b,_0x4f4044);}function _0x9903b9(_0x2bf523,_0x385890){return _0x5c4e84(_0x2bf523- -0x3bc,_0x385890);}window['removeEventListener'](_0x1f095d(-0x2f7,-0x285),this[_0x1f095d(-0x2cb,-0x285)]),this[_0x9903b9(-0x164,-0x1d0)][_0x9903b9(-0x1ad,-0x15d)]&&(this['_map']['off'](mars3d__namespace[_0x9903b9(-0x138,-0x18b)]['wheel'],this[_0x9903b9(-0x152,-0xf1)],this),this['_map']['off'](mars3d__namespace[_0x9903b9(-0x138,-0x156)][_0x9903b9(-0x207,-0x20b)],this['_onMouseDownEvent'],this),this['_map']['off'](mars3d__namespace[_0x9903b9(-0x138,-0x16b)]['mouseUp'],this['_onMouseUpEvent'],this),this['_map'][_0x1f095d(-0x256,-0x1e5)](mars3d__namespace[_0x1f095d(-0x127,-0x1a7)]['mouseMove'],this[_0x9903b9(-0x1ab,-0x1f5)],this));}[_0x5c4e84(0x26a,0x2e0)](_0x20a55c){function _0x23928c(_0x80f4dd,_0x72c678){return _0x5c4e84(_0x72c678- -0x2d0,_0x80f4dd);}clearTimeout(this[_0x11f735(0x2ea,0x297)]);function _0x11f735(_0x11f3d1,_0x4d117a){return _0x5c4e84(_0x11f3d1-0x104,_0x4d117a);}if(!this['show']||!this[_0x23928c(-0x164,-0x121)])return;this[_0x11f735(0x2b3,0x25f)][_0x23928c(-0x92,-0x80)][_0x11f735(0x2c3,0x241)]='hidden',this[_0x23928c(-0x11d,-0xea)]=setTimeout(()=>{function _0x3398e6(_0x4f3fa6,_0x4f2adb){return _0x23928c(_0x4f2adb,_0x4f3fa6- -0x214);}if(!this['show'])return;function _0x5164e5(_0x219cb5,_0x1035ae){return _0x23928c(_0x219cb5,_0x1035ae-0x445);}this[_0x3398e6(-0x2d8,-0x326)](),this['canvas'][_0x3398e6(-0x294,-0x2ed)][_0x3398e6(-0x325,-0x304)]='visible';},0xc8);}['_onMouseDownEvent'](_0x1a3a98){this['mouse_down']=!![],this[_0xfaa4da(0xa0,0x11f)][_0x4a244e(-0x26a,-0x23c)](mars3d__namespace['EventType']['mouseMove'],this['_onMouseMoveEvent'],this);function _0xfaa4da(_0x54172e,_0x1c3d00){return _0x5c4e84(_0x54172e- -0x14d,_0x1c3d00);}function _0x4a244e(_0x31c7db,_0x219850){return _0x580342(_0x31c7db,_0x219850- -0x59e);}this['_map']['on'](mars3d__namespace['EventType']['mouseMove'],this[_0xfaa4da(0xc4,0x11d)],this);}['_onMouseMoveEvent'](_0x5e78f0){function _0x1a7caa(_0x52cbf6,_0x171947){return _0x580342(_0x171947,_0x52cbf6- -0x517);}function _0x29bfad(_0x5be41a,_0x853d7){return _0x580342(_0x853d7,_0x5be41a- -0xd6);}if(!this['show']||!this['canvas'])return;this['mouse_down']&&(this[_0x1a7caa(-0x24c,-0x27e)][_0x29bfad(0x296,0x290)]['visibility']='hidden',this['mouse_move']=!![]);}['_onMouseUpEvent'](_0x10c5d7){if(!this[_0x19f45c(0x2e5,0x292)]||!this['canvas'])return;this[_0x4b2f09(0x468,0x462)]['off'](mars3d__namespace['EventType']['mouseMove'],this['_onMouseMoveEvent'],this);this['mouse_down']&&this['mouse_move']&&this['redraw']();this['canvas'][_0x4b2f09(0x504,0x4c5)][_0x4b2f09(0x436,0x434)]='visible',this[_0x4b2f09(0x4c9,0x4de)]=![];function _0x19f45c(_0x10403a,_0x5544aa){return _0x580342(_0x10403a,_0x5544aa- -0x22);}function _0x4b2f09(_0x4573b9,_0x38bd48){return _0x580342(_0x4573b9,_0x38bd48-0x159);}this[_0x4b2f09(0x42f,0x411)]=![];}['setData'](_0x3e05e3){function _0x51222a(_0x525f3a,_0x328e6b){return _0x5c4e84(_0x328e6b-0x8f,_0x525f3a);}this[_0xb8b5c9(0x342,0x382)]();function _0xb8b5c9(_0x3fb7f4,_0x40d6cc){return _0x580342(_0x3fb7f4,_0x40d6cc-0xd3);}this[_0x51222a(0x316,0x312)]=_0x3e05e3,this['windField']['setDate'](_0x3e05e3),this[_0xb8b5c9(0x405,0x3fb)]();}['redraw'](){function _0x38411b(_0x11a24a,_0x4e1dc1){return _0x5c4e84(_0x4e1dc1- -0x76,_0x11a24a);}if(!this['show'])return;this[_0x539ba3(0x4f0,0x510)]['setOptions'](this[_0x539ba3(0x4c7,0x4d0)]);function _0x539ba3(_0x5e2d9f,_0x32d359){return _0x580342(_0x32d359,_0x5e2d9f-0x153);}this['update']();}[_0x580342(0x3ca,0x39b)](){if(this[_0x55e383(-0x2bd,-0x2e4)])return;function _0x2830fc(_0x40f4aa,_0x52149c){return _0x580342(_0x52149c,_0x40f4aa- -0x3e2);}this[_0x55e383(-0x2bd,-0x241)]=!![];if(this['worker'])this['windField']['update']();else{const _0x3a3c9f=this['windField'][_0x2830fc(-0x59,-0xa2)]();this['_drawLines'](_0x3a3c9f);}function _0x55e383(_0x56fd81,_0x4573fb){return _0x580342(_0x4573fb,_0x56fd81- -0x56a);}this[_0x2830fc(-0x135,-0x11d)]=![];}['_drawLines'](_0x496424){this[_0x3e88e5(-0x26,-0x3c)]=_0x496424;function _0x2860a2(_0x286db0,_0x1d1d15){return _0x580342(_0x1d1d15,_0x286db0- -0x3a);}this['canvasContext']['globalCompositeOperation']='destination-in',this['canvasContext']['fillRect'](0x0,0x0,this[_0x3e88e5(0x10,0x69)],this['canvasHeight']),this['canvasContext']['globalCompositeOperation']=_0x2860a2(0x2f6,0x325),this[_0x2860a2(0x2fa,0x2b3)]['globalAlpha']=0.9;const _0x1d24cf=this[_0x2860a2(0x2cf,0x254)][_0x3e88e5(-0x40,-0x15)]['mode']!==Cesium['SceneMode']['SCENE3D'];function _0x3e88e5(_0x5e64a4,_0x138eb1){return _0x580342(_0x138eb1,_0x5e64a4- -0x36e);}const _0x2a3a34=this['canvasWidth']*0.25;if(this['_colorRamp'])for(let _0xbd4d35=0x0,_0x5314f0=_0x496424['length'];_0xbd4d35<_0x5314f0;_0xbd4d35++){const _0x5b772d=_0x496424[_0xbd4d35],_0x4dc4b1=this[_0x2860a2(0x33b,0x35a)](_0x5b772d,_0x5b772d[_0x2860a2(0x369,0x380)],_0x5b772d['lat'],_0x5b772d['alt']),_0x59c661=this[_0x2860a2(0x33b,0x311)](_0x5b772d,_0x5b772d[_0x3e88e5(-0x35,0x40)],_0x5b772d[_0x3e88e5(-0xa0,-0x7a)],_0x5b772d['talt']);if(!_0x4dc4b1||!_0x59c661)continue;if(_0x1d24cf&&Math['abs'](_0x4dc4b1[0x0]-_0x59c661[0x0])>=_0x2a3a34)continue;this[_0x2860a2(0x2fa,0x2a3)][_0x3e88e5(-0xbc,-0xb6)](),this['canvasContext'][_0x2860a2(0x370,0x330)]=this['lineWidth'],this[_0x2860a2(0x2fa,0x2fb)]['strokeStyle']=this[_0x2860a2(0x338,0x2ec)]['getColor'](_0x5b772d[_0x3e88e5(-0x2a,0x11)]),this['canvasContext']['moveTo'](_0x4dc4b1[0x0],_0x4dc4b1[0x1]),this[_0x3e88e5(-0x3a,-0x31)][_0x2860a2(0x2f8,0x2b7)](_0x59c661[0x0],_0x59c661[0x1]),this['canvasContext'][_0x2860a2(0x295,0x26a)]();}else{this['canvasContext']['beginPath'](),this['canvasContext']['lineWidth']=this['lineWidth'],this['canvasContext'][_0x2860a2(0x2ac,0x326)]=this['color'];for(let _0x3ba1cb=0x0,_0x454d4f=_0x496424['length'];_0x3ba1cb<_0x454d4f;_0x3ba1cb++){const _0x120eb9=_0x496424[_0x3ba1cb],_0x1fc042=this['_tomap'](_0x120eb9,_0x120eb9['lng'],_0x120eb9['lat'],_0x120eb9['alt']),_0x2068a5=this['_tomap'](_0x120eb9,_0x120eb9[_0x2860a2(0x2ff,0x2dc)],_0x120eb9[_0x3e88e5(-0xa0,-0x1a)],_0x120eb9[_0x3e88e5(0x30,-0xf)]);if(!_0x1fc042||!_0x2068a5)continue;if(_0x1d24cf&&Math['abs'](_0x1fc042[0x0]-_0x2068a5[0x0])>=_0x2a3a34)continue;this[_0x2860a2(0x2fa,0x36b)][_0x3e88e5(0x48,0xc2)](_0x1fc042[0x0],_0x1fc042[0x1]),this[_0x2860a2(0x2fa,0x2b5)]['lineTo'](_0x2068a5[0x0],_0x2068a5[0x1]);}this['canvasContext']['stroke']();}}[_0x5c4e84(0x259,0x258)](_0x356a96,_0x2e8591,_0x232fd7,_0x4d2793){const _0x223f70=Cesium['Cartesian3']['fromDegrees'](_0x2e8591,_0x232fd7,_0x4d2793??this[_0x2f80f3(-0x24f,-0x2a3)]),_0x2dcb78=this[_0x2f80f3(-0x2d8,-0x2d6)]['scene'];if(_0x2dcb78[_0x5b1c26(0x3cd,0x375)]===Cesium['SceneMode'][_0x2f80f3(-0x26b,-0x255)]){const _0x1816bd=new Cesium[(_0x5b1c26(0x3de,0x3e0))](_0x2dcb78[_0x2f80f3(-0x348,-0x2d7)]['ellipsoid'],_0x2dcb78['camera']['positionWC']),_0x3c0233=_0x1816bd['isPointVisible'](_0x223f70);if(!_0x3c0233)return _0x356a96[_0x5b1c26(0x36b,0x320)]=0x0,null;}function _0x5b1c26(_0x539133,_0x48acab){return _0x580342(_0x48acab,_0x539133-0x2b);}function _0x2f80f3(_0x510c2d,_0x5ca455){return _0x5c4e84(_0x5ca455- -0x4c3,_0x510c2d);}const _0x21d4a2=mars3d__namespace[_0x5b1c26(0x33f,0x396)]['toWindowCoordinates'](this[_0x5b1c26(0x334,0x32b)][_0x5b1c26(0x359,0x2f5)],_0x223f70);return _0x21d4a2?[_0x21d4a2['x'],_0x21d4a2['y']]:null;}[_0x5c4e84(0x193,0x112)](){function _0x48a171(_0xfac33c,_0x35bced){return _0x5c4e84(_0x35bced- -0x84,_0xfac33c);}this['windField'][_0x313708(0xfc,0x142)]();function _0x313708(_0x2407b8,_0x33fcea){return _0x580342(_0x33fcea,_0x2407b8- -0x1b3);}delete this[_0x48a171(0x232,0x1ff)];}[_0x5c4e84(0x201,0x1d7)](){function _0x4bb998(_0x24a928,_0x554b26){return _0x580342(_0x24a928,_0x554b26-0xa9);}this[_0x194924(-0x16d,-0xfc)]=new Worker(this[_0x194924(-0xd5,-0x14c)]['worker']);function _0x194924(_0x4bd8c8,_0x4e32f5){return _0x5c4e84(_0x4bd8c8- -0x32d,_0x4e32f5);}this['worker'][_0x194924(-0xba,-0x63)]=_0x2305d2=>{function _0x4a4260(_0xd0217d,_0x597863){return _0x4bb998(_0x597863,_0xd0217d- -0x240);}this[_0x4a4260(0x1bc,0x1d3)](_0x2305d2['data']['particles']),this['_updateIng2']=![];},this['windField']={'init':_0x14a921=>{const _0x2f536a={};_0x2f536a[_0x1218d0(0x243,0x22e)]='init';function _0x222ec6(_0x16b548,_0x15063f){return _0x4bb998(_0x15063f,_0x16b548- -0x3c0);}_0x2f536a['options']=_0x14a921;function _0x1218d0(_0xe6356d,_0x469ef8){return _0x4bb998(_0x469ef8,_0xe6356d- -0x114);}this[_0x1218d0(0x271,0x277)][_0x1218d0(0x2df,0x267)](_0x2f536a);},'setOptions':_0x3d49e0=>{function _0x372be1(_0x422a62,_0x2678c5){return _0x194924(_0x2678c5-0x59a,_0x422a62);}const _0x14d200={};_0x14d200[_0x372be1(0x38d,0x3ff)]='setOptions';function _0x5781e5(_0x5e3918,_0x567490){return _0x4bb998(_0x5e3918,_0x567490- -0x368);}_0x14d200['options']=_0x3d49e0,this[_0x372be1(0x3ed,0x42d)][_0x5781e5(0x62,0x8b)](_0x14d200);},'setDate':_0x48ab56=>{function _0x2803e2(_0x581dfa,_0x476443){return _0x4bb998(_0x476443,_0x581dfa- -0x5fe);}const _0x210e01={};_0x210e01[_0x36a4de(-0x194,-0x1a5)]=_0x36a4de(-0x190,-0x116);function _0x36a4de(_0x4a786a,_0x1d8751){return _0x194924(_0x1d8751- -0xa,_0x4a786a);}_0x210e01['data']=_0x48ab56,this[_0x2803e2(-0x279,-0x2ba)]['postMessage'](_0x210e01);},'update':()=>{function _0x2bd2a6(_0x98fa78,_0x39247c){return _0x4bb998(_0x98fa78,_0x39247c- -0x570);}if(this['_updateIng2'])return;this['_updateIng2']=!![];const _0x30f2af={};_0x30f2af[_0x2bd2a6(-0x25f,-0x219)]='update',this['worker']['postMessage'](_0x30f2af);},'clear':()=>{const _0xd51576={};_0xd51576['type']='clear',this['worker']['postMessage'](_0xd51576);}},this['windField']['init'](this[_0x194924(-0xd5,-0xbd)]);}}mars3d__namespace[_0x5c4e84(0x199,0x18b)]['register']('canvasWind',CanvasWindLayer),mars3d__namespace['layer'][_0x580342(0x391,0x31b)]=CanvasWindLayer,mars3d__namespace['CanvasWindField']=CanvasWindField,mars3d__namespace[_0x580342(0x3e7,0x398)]['logInfo'](_0x5c4e84(0x289,0x30d)+version+_0x580342(0x2c6,0x2ac)+buildTime),mars3d__namespace['WindUtil']=WindUtil,exports[_0x5c4e84(0x1fd,0x1c4)]=CanvasWindField,exports[_0x580342(0x379,0x31b)]=CanvasWindLayer,exports['WindLayer']=WindLayer,exports[_0x5c4e84(0x1cd,0x237)]=WindUtil;const _0x415122={};_0x415122['value']=!![],Object[_0x5c4e84(0x288,0x2c0)](exports,_0x5c4e84(0x23d,0x23b),_0x415122);
|
|
15
15
|
}));
|
package/package.json
CHANGED
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "mars3d-wind",
|
|
3
|
-
"version": "3.11.
|
|
3
|
+
"version": "3.11.3",
|
|
4
4
|
"description": "Mars3D平台插件,支持气象 风向图 功能插件",
|
|
5
5
|
"main": "./mars3d-wind.js",
|
|
6
6
|
"peerDependencies": {},
|
|
7
7
|
"devDependencies": {
|
|
8
|
-
"mars3d": "~3.11.
|
|
8
|
+
"mars3d": "~3.11.3"
|
|
9
9
|
},
|
|
10
10
|
"scripts": {
|
|
11
11
|
"lint": "eslint ./src/**/*.{js,ts} --fix"
|