mapJK.vue 102 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082308330843085308630873088308930903091309230933094309530963097309830993100310131023103310431053106310731083109311031113112311331143115311631173118311931203121312231233124312531263127312831293130313131323133313431353136313731383139314031413142314331443145314631473148314931503151315231533154315531563157315831593160316131623163316431653166316731683169317031713172317331743175317631773178317931803181318231833184318531863187318831893190319131923193319431953196319731983199320032013202320332043205320632073208320932103211321232133214321532163217321832193220322132223223322432253226322732283229323032313232323332343235323632373238323932403241324232433244324532463247324832493250325132523253325432553256325732583259326032613262326332643265326632673268326932703271327232733274327532763277327832793280328132823283
  1. <template>
  2. <div id="map_jk">
  3. <div id="mapDiv" ref="map">
  4. <div id="viewDiv" ref="view">
  5. <div id="menu" class="esri-widget">
  6. </div>
  7. </div>
  8. <div id="viewDiv_2D" ref="view_2D">
  9. <div id="menu" class="esri-widget">
  10. </div>
  11. </div>
  12. <div id = "overviewDiv" ref = "overview" >
  13. </div>
  14. </div>
  15. </div>
  16. </template>
  17. <script>
  18. import $ from 'jquery';
  19. import {getCurrentInstance, onMounted} from "vue";
  20. import SetMapConfig from "../units/map/SetMapConfig.js"
  21. import InitMap from "../units/map/InitMap.js";
  22. import AddBaseMapLayer from "../units/map/AddBaseMapLayer.js";
  23. import AddSingleLayer from "../units/map/AddSingleLayer.js";
  24. import WaterEffect from "../units/map/WaterEffect.js";
  25. import Measurement from "../units/map/Measurement.js";
  26. import SunshineAnalysis from "../units/map/SunshineAnalysis.js";
  27. import AddPointEvent from "../units/map/AddPointEvent.js";
  28. import SetPopupOptions from "../units/map/SetPopuopOptions";
  29. import AddScaleEvent from "../units/map/AddScaleEvent";
  30. import ViewShedAnalysisWidget from "../units/map/ViewShedAnalysis.js";
  31. import AddLightBallEvent from "../units/map/AddLightBallEvent.js";
  32. import AddThreeGridEvent from "../units/map/addThreeGridEvent.js";
  33. import LimitHeightAnalysis from "../units/map/LimitHeightAnalysis.js";
  34. import SetLocation from "../units/map/SetLocation.js";
  35. import GeometryMeshPrismEffect from "../units/map/GeometryMeshPrismEffect.js";
  36. import ReRenderingEvent from "../units/map/ReRenderingEvent.js";
  37. import PathPipeEvent from "../units/map/PathPipeEvent.js";
  38. import FlyGLTFEvent from "../units/map/FlyGLTFEvent.js";
  39. import AddDrawEvent from "../units/map/addDrawEvent.js";
  40. import SymbolPathPipeEvent from "../units/map/SymbolPathPipeEvent.js";
  41. import SymbolPointCubeEvent from "../units/map/SymbolPointCubeEvent.js";
  42. import AddThreeCubeEvent from "../units/map/AddThreeCubeEvent.js";
  43. import AddThreeCubeDetailEvent from "../units/map/AddThreeCubeDetailEvent.js";
  44. import AddThreeNetEvent from "../units/map/AddThreeNetEvent.js";
  45. import dojoConfig from '../config/tsconfig.json'
  46. import ws from 'ws';
  47. import Path from '../config/path_wjc.json'
  48. import routeList from '../config/routeList.json'
  49. import {
  50. getAvoidRoute,
  51. getBuildingPoint,
  52. getNoFlyPointInterface, getOccupyPointByPolygon, getPath,
  53. getPowerInterface,
  54. getPowerPoint, getPowerPointByFrustumCone,
  55. getPowerPointByFunnel, getPowerPointByInvertedCone, getPowerPointByPath,
  56. getPowerPointByPolygon, getPowerPointByPrism, getPrism,
  57. getProxyToken, getQJC,
  58. getRiverPointInterface,
  59. getRoadPointInterface,
  60. gridBaseInfo
  61. } from "../service/http.js";
  62. import FeaturePointsPlottingEvent from "../units/map/FeaturePointsPlottingEvent.js";
  63. import FeaturePolygonPlottingEvent from "../units/map/FeaturePolygonPlottingEvent.js";
  64. import HeatMap from "../units/map/HeatMap.js";
  65. import AddGraphicsEvent from "../units/map/AddGraphicsEvent.js";
  66. import GeometryMeshEffect from "../units/map/GeometryMeshEffect.js";
  67. import QueryIn2D from "../units/map/QueryIn2D.js";
  68. import AddFlowPathEvent from "../units/map/AddFlowPathEvent.js";
  69. import MovePointStreamEvent from "../units/map/MovePointStreamEvent.js";
  70. export default {
  71. name: "mapJK",
  72. setup(){
  73. let socket = null;
  74. let virtualSocket = null;
  75. let flyPointSocket = null;
  76. const ctx = getCurrentInstance();
  77. const bus = ctx?.appContext.config.globalProperties.$bus;
  78. let MapReady = null;
  79. let m_spatialReference = null;
  80. let m_fullExtent = null;
  81. let m_initialExtent = null;
  82. let m_view;
  83. let m_map;
  84. let measureWidget = null;
  85. let sunshineWidget = null;
  86. let m_handles = [];
  87. let viewShedAnalysisWidget = null;
  88. let addLightBallEvent = null;
  89. let addThreeGridEvent = null;
  90. let addThreeCubeEvent = null;
  91. //let addThreeCubeDetailEvent = null;
  92. let powerDataList = [];
  93. let addThreeCubeDetailInstance = {};
  94. let addThreeNetEvent = null;
  95. let limitHeightAnalysisEvent = null;
  96. let reRenderingEvent = null;
  97. let pathPipeInstance = {};
  98. let flyGLTFInstances = {};
  99. let addDrawEvent = null;
  100. let draw_GeometryMeshPrismEffectEvent = null;
  101. let symbolPathPipeEvent = null;
  102. let symbolPointCubeEvent = null;
  103. let addGraphicsEvent = null;
  104. let featurePointsPlottingEvent = null;
  105. let currentShowGridParams = null;
  106. let realFlyPointDataQueue = [];
  107. let addFlowPathEvent = null;
  108. let movePointEvent = null;
  109. let currentRealPowerShow = false;
  110. onMounted(() =>{
  111. bus.on('CreateMap',() =>{
  112. MapReady = $.Deferred();
  113. createMap();
  114. $.when((MapReady).done(()=>{
  115. //发送消息
  116. bus.emit('SendMessage',{
  117. action:"MapIsReady",
  118. data:{
  119. "message":"地图初始化完成"
  120. }
  121. })
  122. }))
  123. })
  124. //调用方法
  125. bus.on('InvokeMethod',(data) =>{
  126. invokeMethod(data);
  127. })
  128. function createMap(){
  129. let setMapConfig = new SetMapConfig({
  130. m_spatialReference,
  131. m_fullExtent,
  132. m_initialExtent,
  133. m_handles
  134. })
  135. m_spatialReference = setMapConfig.m_spatialReference;
  136. m_fullExtent = setMapConfig.m_fullExtent;
  137. m_initialExtent = setMapConfig.m_initialExtent;
  138. m_handles = setMapConfig.m_handles;
  139. let initMap = new InitMap({
  140. m_map,
  141. m_view,
  142. m_spatialReference,
  143. bus
  144. });
  145. m_map = initMap.m_map;
  146. m_view = initMap.m_view;
  147. }
  148. function invokeMethod(data){
  149. //后续设置验证token
  150. runMethod(data);
  151. }
  152. function runMethod(data){
  153. let methodname = data.methodname;
  154. let params = data.params;
  155. if(typeof (params) != "string"&& params)
  156. params = eval(params);
  157. switch (methodname) {
  158. case "SetBackground":
  159. setBackground(params);
  160. break;
  161. case "SetLocation":
  162. setLocation(params);
  163. break;
  164. case "AddBaseMapLayer":
  165. addBaseMapLayer(params);
  166. break;
  167. case "AddSingleLayer":
  168. addSingleLayer(params);
  169. break;
  170. case "QueryIn2D":
  171. queryIn2D(params);
  172. break;
  173. case "ReRendering":
  174. reRendering(params);
  175. break;
  176. case "WaterEffect":
  177. waterEffect(params);
  178. break;
  179. case "HeatMap":
  180. heatMap(params);
  181. break;
  182. case "ThreeDimensionalHeatMap":
  183. threeDimensionalHeatMap(params);
  184. break;
  185. case "PathCompletion":
  186. pathCompletion(params);
  187. break;
  188. case "Measurement":
  189. measurement(params);
  190. break;
  191. case "SunshineAnalysis":
  192. sunshineAnalysis(params);
  193. break
  194. case "AccessFeaturesWithPointEvents":
  195. accessFeaturesWithPointEvents(params);
  196. break;
  197. case "ShowLayersWithScaleEvents":
  198. showLayersWithScaleEvents(params);
  199. break;
  200. case "ViewshedAnalysis":
  201. viewshedAnalysis(params);
  202. break;
  203. case "FeatureLayerThreeDimension":
  204. featureLayerThreeDimension(params);
  205. break;
  206. case "AddLightBall":
  207. addLightBall(params);
  208. break;
  209. case "ThreeGrid":
  210. threeGrid(params);
  211. break;
  212. case "ShowThreeCube":
  213. showThreeCube(params);
  214. break;
  215. case "ShowThreeCubeDetail":
  216. showThreeCubeDetail(params);
  217. break;
  218. case "GetAllPowerPoints":
  219. getAllPowerPoints(params);
  220. break;
  221. case "ShowBuildingThreeCubeByInterface":
  222. showBuildingThreeCubeByInterface(params);
  223. break;
  224. case "ShowNoFlyThreeCubeByInterface":
  225. showNoFlyThreeCubeByInterface(params);
  226. break;
  227. case "ShowNoFlyThreeCubeDetailByInterface":
  228. showNoFlyThreeCubeDetailByInterface(params);
  229. break;
  230. case "ShowRoadThreeCubeByInterface":
  231. showRoadThreeCubeByInterface(params);
  232. break;
  233. case "ShowRoadThreeCubeDetailByInterface":
  234. showRoadThreeCubeDetailByInterface(params);
  235. break;
  236. case "ShowRiverThreeCubeByInterface":
  237. showRiverThreeCubeByInterface(params);
  238. break;
  239. case "ShowRiverThreeCubeDetailByInterface":
  240. showRiverThreeCubeDetailByInterface(params);
  241. break;
  242. case "ShowThreeNet":
  243. showThreeNet(params);
  244. break;
  245. case "RealPositionGrid":
  246. realPositionGrid(params);
  247. break;
  248. case "LimitHeightAnalysis":
  249. limitHeightAnalysis(params);
  250. break;
  251. case "GeometryMeshPrismEffect":
  252. geometryMeshPrismEffect(params);
  253. break;
  254. case "GeometryMeshEffect":
  255. geometryMeshEffect(params);
  256. break;
  257. case "PathPipe":
  258. pathPipe(params);
  259. break;
  260. case "FlyGLTF":
  261. flyGLTF(params);
  262. break;
  263. case "Draw":
  264. draw(params);
  265. break;
  266. case "Draw_GeometryMeshPrismEffect":
  267. draw_GeometryMeshPrismEffect(params);
  268. break;
  269. case "SymbolPathPipe":
  270. symbolPathPipe(params);
  271. break;
  272. case "SymbolPointCube":
  273. symbolPointCube(params);
  274. break;
  275. case "FeaturePointsPlotting":
  276. featurePointsPlotting(params);
  277. break;
  278. case "FeaturePolygonPlotting":
  279. featurePolygonPlotting(params);
  280. break;
  281. case "GetRealFlyPoint":
  282. getRealFlyPoint(params);
  283. break;
  284. case "GetVirtualFlyPoint":
  285. getVirtualFlyPoint(params);
  286. break;
  287. case "ChangePointStatus":
  288. changePointStatus(params);
  289. break;
  290. case "GetRealPower":
  291. getRealPower(params);
  292. break;
  293. case "GetRealPower2":
  294. getRealPower2(params);
  295. break;
  296. case "PathConflict":
  297. pathConflict(params);
  298. break;
  299. case "UavBatteryWarning":
  300. uavBatteryWarning(params);
  301. break;
  302. case "UavYawWarning":
  303. uavYawWarning(params);
  304. break;
  305. case "Conflict_fly":
  306. conflict_fly(params);
  307. break;
  308. case "SituationAssessment":
  309. situationAssessment(params);
  310. break;
  311. case "FlowPathEffect":
  312. flowPathEffect(params);
  313. break;
  314. case "MovePoint":
  315. movePoint(params);
  316. break;
  317. case "GetOccupyCube":
  318. getOccupyCube(params);
  319. break;
  320. case "GetPowerCube":
  321. getPowerCube(params);
  322. break;
  323. case "GetFunnelCube":
  324. getFunnelCube(params);
  325. break;
  326. case "GetFrustumConeCube":
  327. getFrustumConeCube(params);
  328. break;
  329. case "GetInvertedConeCube":
  330. getInvertedConeCube(params);
  331. break;
  332. case "GetCylinderCube":
  333. getCylinderCube(params);
  334. break;
  335. case "GetCuboidCube":
  336. getCuboidCube(params);
  337. break;
  338. case "GetPrismCube":
  339. getPrismCube(params);
  340. break;
  341. case "GetPathCube":
  342. getPathCube(params);
  343. break;
  344. case "GetBasePrism":
  345. getBasePrism(params);
  346. break;
  347. case "GetBasePath":
  348. getBasePath(params);
  349. break;
  350. case "GetBaseQJC":
  351. getBaseQJC(params);
  352. break;
  353. }
  354. }
  355. function setBackground(params){
  356. }
  357. function setLocation(params){
  358. let setLocation = new SetLocation({
  359. view:m_view,
  360. x:params.x,
  361. y:params.y,
  362. z:params.z,
  363. heading:params.heading,
  364. tilt:params.tilt,
  365. isfly:params.isfly,
  366. });
  367. setLocation.start();
  368. }
  369. function addBaseMapLayer(params){
  370. let addBaseMapLayer = new AddBaseMapLayer({
  371. id:params.id,
  372. title:params.title,
  373. visible:params.visible,
  374. opacity:params.opacity,
  375. url:params.url,
  376. m_spatialReference,
  377. m_fullExtent,
  378. })
  379. m_view.map.basemap = addBaseMapLayer.basemap;
  380. }
  381. function addSingleLayer(params){
  382. let addSingleLayer = new AddSingleLayer({
  383. m_map,
  384. type:params.type,
  385. id:params.id,
  386. title:params.title,
  387. visible:params.visible,
  388. opacity:params.opacity,
  389. url:params.url,
  390. where:params.where,
  391. popupEnabled:params.popupEnabled,
  392. renderer:params.renderer,
  393. elevationInfo:params.elevationInfo
  394. })
  395. let layer = addSingleLayer.layer;
  396. m_map.add(layer);
  397. }
  398. async function queryIn2D(params) {
  399. let type = params.type;
  400. let geometry = params.geometry;
  401. let where = params.where;
  402. let url;
  403. let layerId;
  404. if (type === "区县") {
  405. url = await returnProxyUrl(dojoConfig["queryurl_qx_3857"]) + '/0'
  406. layerId = 0;
  407. } else if (type === "街道") {
  408. url = await returnProxyUrl(dojoConfig["queryurl_jd_3857"]) + '/0'
  409. layerId = 0;
  410. }
  411. let queryIn2DInstance = new QueryIn2D({
  412. view: m_view,
  413. map: m_map,
  414. url: url,
  415. layerId: layerId,
  416. geometry: geometry,
  417. where: where
  418. })
  419. let result = await queryIn2DInstance.search();
  420. if(result.length > 0){
  421. bus.emit('SendMessage',{
  422. action:"ReturnResult",
  423. data:{
  424. "message":result
  425. }
  426. })
  427. }
  428. }
  429. async function returnProxyUrl(url){
  430. if(!url){
  431. return;
  432. }
  433. let arr = url.split('/');
  434. let username = '';
  435. let password = '';
  436. if(arr.indexOf('MapProxyApi') !== -1){ //不需要授权服务
  437. for(let i=0;i<arr.length;i++){
  438. if(arr[i] ==='getSceneServer'){
  439. username = arr[i+1];
  440. password = arr[i+2];
  441. const response = await getProxyToken(username,password);
  442. if(response?.data?.length > 0){
  443. arr.splice(i-1, 4);
  444. return arr.join('/')+'/MapServiceProxy/'+response?.data;
  445. }
  446. }
  447. }
  448. }else{
  449. return url
  450. }
  451. }
  452. function getSymbol(params){
  453. return {
  454. type: "mesh-3d",
  455. symbolLayers: [{
  456. type: "fill",
  457. material: {
  458. color: params.color
  459. },
  460. edges: {
  461. type: "solid",
  462. color:[255, 255, 255],
  463. }
  464. }]
  465. };
  466. }
  467. function reRendering(params){
  468. let ids_1 = [];
  469. for(let i=0;i<10000;i++){
  470. ids_1.push(i);
  471. }
  472. let ids_2 = [];
  473. for(let i=10000;i<20000;i++){
  474. ids_2.push(i);
  475. }
  476. let renderer = {
  477. type:"unique-value",
  478. defaultSymbol: getSymbol({color: [0, 255, 0,0.8]}),
  479. defaultLabel: "Other",
  480. field: "OBJECTID",
  481. uniqueValueInfos: [
  482. ]
  483. };
  484. // 每秒更新一次网格颜色
  485. setInterval(() => {
  486. renderer.uniqueValueInfos = []
  487. // 定义分组和对应的颜色
  488. const groups = {
  489. group1: {
  490. ids: ids_1, // 分组1的 ID 列表
  491. color: [Math.floor(Math.random() * 256), Math.floor(Math.random() * 256), Math.floor(Math.random() * 256), 0.8] // 红色
  492. },
  493. group2: {
  494. ids: ids_2, // 分组3的 ID 列表
  495. color: [Math.floor(Math.random() * 256), Math.floor(Math.random() * 256), Math.floor(Math.random() * 256), 0.8] // 蓝色
  496. }
  497. };
  498. // 遍历分组,动态生成渲染规则
  499. Object.keys(groups).forEach(groupKey => {
  500. const group = groups[groupKey];
  501. group.ids.forEach(id => {
  502. renderer.uniqueValueInfos.push({
  503. value: id, // 对应的 ID
  504. symbol: getSymbol(group)
  505. });
  506. });
  507. });
  508. if(reRenderingEvent == null){
  509. reRenderingEvent = new ReRenderingEvent({
  510. m_map,
  511. type:"scene",
  512. id:"WhiteMold",
  513. renderer:renderer
  514. });
  515. }
  516. reRenderingEvent.ReRendering();
  517. }, 5000);
  518. }
  519. function waterEffect(params){
  520. params.id = "waterLayer";
  521. if(params.status === "hide"){
  522. let layer = m_map.layers.find(item => item.id === params.id);
  523. m_map.remove(layer);
  524. return
  525. }
  526. if(params.status === "show"){
  527. let layer = m_map.layers.find(item => item.id === params.id);
  528. if(typeof layer === "undefined"){
  529. let waterEffect = new WaterEffect({
  530. id:params.id,
  531. url:params.url,
  532. waveDirection:params.waveDirection,
  533. waveStrength:params.waveStrength,
  534. color:params.color
  535. })
  536. layer = waterEffect.layer;
  537. m_map.add(layer);
  538. }else{
  539. m_view.environment.lighting.waterReflectionEnabled = true;
  540. const renderer = layer.renderer.clone();
  541. renderer.symbol.symbolLayers.getItemAt(0).waveDirection = params.waveDirection;
  542. renderer.symbol.symbolLayers.getItemAt(0).waveStrength = params.waveStrength;
  543. renderer.symbol.symbolLayers.getItemAt(0).color = params.color;
  544. layer.renderer = renderer;
  545. }
  546. }
  547. }
  548. function heatMap(params){
  549. params.id = "heatMap";
  550. if(!params.visible){
  551. let layer = m_map.layers.find(item => item.id === params.id);
  552. m_map.remove(layer);
  553. return
  554. }
  555. if(params.visible){
  556. let layer = m_map.layers.find(item => item.id === params.id);
  557. if(typeof layer === "undefined"){
  558. let heatMap = new HeatMap({
  559. id:params.id,
  560. url:params.url,
  561. waveDirection:params.waveDirection,
  562. waveStrength:params.waveStrength,
  563. color:params.color
  564. })
  565. layer = heatMap.layer;
  566. m_map.add(layer);
  567. }
  568. }
  569. }
  570. function threeDimensionalHeatMap(params){
  571. let status = params.status;
  572. if(addFlowPathEvent){
  573. addFlowPathEvent.clear();
  574. addFlowPathEvent = null;
  575. }
  576. if(status === "hide"){
  577. return
  578. }
  579. addFlowPathEvent = new AddFlowPathEvent({
  580. view:m_view,
  581. paths:params.paths,
  582. color:params.color,
  583. pipeRadius:params.pipeRadius
  584. })
  585. addFlowPathEvent.start()
  586. }
  587. function pathCompletion(params){
  588. let points = params.points;
  589. let speed1 = params.speed1;
  590. let speed2 = params.speed2;
  591. const result = [];
  592. // 将第一个点添加到结果中
  593. result.push(points[0]);
  594. for (let i = 1; i < points.length; i++) {
  595. const prevPoint = points[i - 1];
  596. const currPoint = points[i];
  597. const distance = Math.sqrt(
  598. Math.pow(currPoint[0] - prevPoint[0], 2) +
  599. Math.pow(currPoint[1] - prevPoint[1], 2) +
  600. Math.pow(currPoint[2] - prevPoint[2], 2)
  601. );
  602. const velocity = prevPoint[2] === currPoint[2] ? speed1 : speed2; // 判断是否是同一高度
  603. // 计算所需的时间
  604. const time = distance / velocity;
  605. const numPoints = Math.floor(time); // 根据时间间隔生成插值点数
  606. for (let j = 1; j <= numPoints; j++) {
  607. // 线性插值,计算插值点
  608. const t = j / (numPoints + 1);
  609. const x = prevPoint[0] + t * (currPoint[0] - prevPoint[0]);
  610. const y = prevPoint[1] + t * (currPoint[1] - prevPoint[1]);
  611. const z = prevPoint[2] + t * (currPoint[2] - prevPoint[2]);
  612. result.push([x, y, z]);
  613. }
  614. // 最后将当前点添加到结果中
  615. result.push(currPoint);
  616. }
  617. console.log("离散的点",result)
  618. return result;
  619. }
  620. function measurement(params){
  621. let status = params.status;
  622. let type = params.type;
  623. let position = params.position;
  624. if(status === "hide"){
  625. if(measureWidget !== null){
  626. m_view.ui.remove(measureWidget);
  627. measureWidget.destroy();
  628. measureWidget = null;
  629. }
  630. return
  631. }
  632. if(status === "show"){
  633. if(measureWidget === null){
  634. let measurement = new Measurement({
  635. view:m_view,
  636. type
  637. })
  638. measureWidget = measurement.widget;
  639. }
  640. m_view.ui.add(measureWidget,position);
  641. }
  642. }
  643. function sunshineAnalysis(params){
  644. let status = params.status;
  645. let position = params.position;
  646. if(status === "hide"){
  647. if(sunshineWidget !== null){
  648. m_view.ui.remove(sunshineWidget);
  649. sunshineWidget.destroy();
  650. sunshineWidget = null;
  651. }
  652. return
  653. }
  654. if(status === "show"){
  655. if(sunshineWidget === null){
  656. let sunshineAnalysis = new SunshineAnalysis({
  657. view:m_view
  658. })
  659. sunshineWidget = sunshineAnalysis.widget;
  660. }
  661. m_view.ui.add(sunshineWidget,position);
  662. }
  663. }
  664. function accessFeaturesWithPointEvents(params){
  665. let status = params.status;
  666. let mouse_handle_id = params.mouse_handle_id;
  667. let highlight_handle_id = params.highlight_handle_id;
  668. if(status === "hide"){
  669. if(m_handles.has(mouse_handle_id)){
  670. m_handles.remove(mouse_handle_id);
  671. }
  672. if(m_handles.has(highlight_handle_id)){
  673. m_handles.remove(highlight_handle_id);
  674. }
  675. return
  676. }
  677. if(status === "show"){
  678. let type = params.type;
  679. let mouseTime = params.mouse_time;
  680. let popupTitle = params.popup_title;
  681. if(m_handles.has(mouse_handle_id)){
  682. m_handles.remove(mouse_handle_id);
  683. }
  684. if(m_handles.has(highlight_handle_id)){
  685. m_handles.remove(highlight_handle_id);
  686. }
  687. let addPointEvent = new AddPointEvent({
  688. m_view,
  689. type,
  690. highlightHandleId:highlight_handle_id,
  691. mouseTime,
  692. popupTitle,
  693. callbackFunction:accessFeaturesWithPointEventsReturn
  694. });
  695. m_handles.add(addPointEvent.mouseHandle,mouse_handle_id);
  696. }
  697. }
  698. function accessFeaturesWithPointEventsReturn(screenPoint,handleId,popupTitle){
  699. if(m_handles.has(handleId)){
  700. m_handles.remove(handleId);
  701. }
  702. m_view.hitTest(screenPoint).then((response) =>{
  703. if(response.results.length > 0){
  704. let result = response.results[0];
  705. m_view.whenLayerView(result.graphic.layer).then((lyrView) =>{
  706. let highlightHandle = lyrView.highlight(result.graphic);
  707. m_handles.add(highlightHandle,handleId);
  708. })
  709. let setPopupOptions = new SetPopupOptions({
  710. title:popupTitle,
  711. location:m_view.toMap(screenPoint),
  712. content:result.graphic.attributes
  713. })
  714. m_view.popup.open(setPopupOptions.popupOptions());
  715. }
  716. })
  717. }
  718. function showLayersWithScaleEvents(params){
  719. let status = params.status;
  720. let scale_handle_id = params.scale_handle_id;
  721. if(status === "hide"){
  722. if(scale_handle_id === "scale_handle_cube"){
  723. currentRealPowerShow = false;
  724. getCurrentRealPower({
  725. status:"hide",
  726. id:"power_wj"
  727. })
  728. }else if(scale_handle_id === "scale_handle_tileLayerChange"){
  729. //暂无操作
  730. }else if(scale_handle_id === "scale_handle_sceneLayerLayerChange"){
  731. //暂无操作
  732. }
  733. if(m_handles.has(scale_handle_id)){
  734. m_handles.remove(scale_handle_id);
  735. }
  736. return
  737. }
  738. if(status === "show"){
  739. if(m_handles.has(scale_handle_id)){
  740. m_handles.remove(scale_handle_id);
  741. }
  742. let addScaleEvent;
  743. if(scale_handle_id === "scale_handle_cube"){
  744. currentRealPowerShow = true;
  745. showCubeWithScaleEventsReturn(m_view.scale);
  746. addScaleEvent = new AddScaleEvent({
  747. m_view,
  748. callBackFunction:showCubeWithScaleEventsReturn
  749. });
  750. }else if(scale_handle_id === "scale_handle_tileLayerChange"){
  751. showTileLayersWithScaleEventsReturn(m_view.scale)
  752. addScaleEvent = new AddScaleEvent({
  753. m_view,
  754. callBackFunction:showTileLayersWithScaleEventsReturn
  755. });
  756. }else if(scale_handle_id === "scale_handle_sceneLayerLayerChange"){
  757. showSceneLayersWithScaleEventsReturn(m_view.scale)
  758. addScaleEvent = new AddScaleEvent({
  759. m_view,
  760. callBackFunction:showSceneLayersWithScaleEventsReturn
  761. });
  762. }
  763. m_handles.add(addScaleEvent.scaleHandle,scale_handle_id);
  764. }
  765. }
  766. //不同比例尺加载白膜
  767. function showSceneLayersWithScaleEventsReturn(scaleValue){
  768. let layer = m_map.layers.find(item => item.id === "WhiteMold");
  769. if(scaleValue > 50000){
  770. if(layer){
  771. layer.visible = false;
  772. }
  773. }else{
  774. if(layer){
  775. layer.visible = true;
  776. }
  777. }
  778. }
  779. //不同比例尺加载长三角瓦片
  780. function showTileLayersWithScaleEventsReturn(scaleValue){
  781. let layer = m_map.layers.find(item => item.id === "BaseMapCSJYaoGan");
  782. if(scaleValue < 130000){
  783. if(layer){
  784. layer.visible = false;
  785. }
  786. }else{
  787. if(layer){
  788. layer.visible = true;
  789. }
  790. }
  791. }
  792. //不同比例尺加载网格
  793. function showCubeWithScaleEventsReturn(scaleValue){
  794. switch (true) {
  795. case (scaleValue > 1500000): //15级以上隐藏
  796. getCurrentRealPower({
  797. status:'hide'
  798. })
  799. break;
  800. case (scaleValue <= 1500000 && scaleValue > 300000): //15级
  801. getCurrentRealPower({
  802. status:"show",
  803. id:"power_wj",
  804. fields:["demographics","green","river","road","collision_buffer","no_fly_zone_buffer","clear_zone_buffer"],
  805. center:m_view.center,
  806. radius: (m_view.extent.xmax - m_view.extent.xmin) > (m_view.extent.ymax - m_view.extent.ymin) ? (m_view.extent.xmax - m_view.extent.xmin) : (m_view.extent.ymax - m_view.extent.ymin),
  807. minZ: 0,
  808. maxZ: 1000,
  809. level: 15,
  810. size:{ x: 1582.2726823222256, y: 1856.6079667204758, z: 1724.5956527210265 }
  811. })
  812. break;
  813. case (scaleValue <= 300000 && scaleValue > 150000): //16级
  814. getCurrentRealPower({
  815. status:"show",
  816. id:"power_wj",
  817. fields:["demographics","green","river","road","collision_buffer","no_fly_zone_buffer","clear_zone_buffer"],
  818. center:m_view.center,
  819. radius: (m_view.extent.xmax - m_view.extent.xmin) > (m_view.extent.ymax - m_view.extent.ymin) ? (m_view.extent.xmax - m_view.extent.xmin) : (m_view.extent.ymax - m_view.extent.ymin),
  820. minZ: 0,
  821. maxZ: 500,
  822. level: 16,
  823. size:{ x: 844.8477050379952, y: 990.1345935064928, z: 862.239544684298 }
  824. })
  825. break;
  826. case (scaleValue <= 150000 && scaleValue > 100000): //17级
  827. getCurrentRealPower({
  828. status:"show",
  829. id:"power_wj",
  830. fields:["demographics","green","river","road","collision_buffer","no_fly_zone_buffer","clear_zone_buffer"],
  831. center:m_view.center,
  832. radius: (m_view.extent.xmax - m_view.extent.xmin) > (m_view.extent.ymax - m_view.extent.ymin) ? (m_view.extent.xmax - m_view.extent.xmin) : (m_view.extent.ymax - m_view.extent.ymin),
  833. minZ: 0,
  834. maxZ: 200,
  835. level: 17,
  836. size:{ x: 424.0518521273334, y: 492.09123171765896, z: 431.1052029077298 }
  837. })
  838. break;
  839. case (scaleValue <= 100000 && scaleValue > 40000): //18级
  840. getCurrentRealPower({
  841. status:"show",
  842. id:"power_wj",
  843. fields:["demographics","green","river","road","collision_buffer","no_fly_zone_buffer","clear_zone_buffer"],
  844. center:m_view.center,
  845. radius: (m_view.extent.xmax - m_view.extent.xmin) > (m_view.extent.ymax - m_view.extent.ymin) ? (m_view.extent.xmax - m_view.extent.xmin) : (m_view.extent.ymax - m_view.extent.ymin),
  846. minZ: 0,
  847. maxZ: 100,
  848. level: 18,
  849. size:{ x: 211.66439868324142, y: 246.49964316944533, z: 215.5489592181181 }
  850. })
  851. break;
  852. case (scaleValue <= 40000 && scaleValue > 15000): //19级
  853. getCurrentRealPower({
  854. status:"show",
  855. id:"power_wj",
  856. fields:["demographics","green","river","road","collision_buffer","no_fly_zone_buffer","clear_zone_buffer"],
  857. center:m_view.center,
  858. radius: (m_view.extent.xmax - m_view.extent.xmin) > (m_view.extent.ymax - m_view.extent.ymin) ? (m_view.extent.xmax - m_view.extent.xmin) : (m_view.extent.ymax - m_view.extent.ymin),
  859. minZ: 0,
  860. maxZ: 100,
  861. level: 19,
  862. size:{ x: 105.79869494173579, y: 123.19232219036257, z: 107.77356906534683 }
  863. })
  864. break;
  865. case (scaleValue <= 15000 && scaleValue > 6000): //20级
  866. getCurrentRealPower({
  867. status:"show",
  868. id:"power_wj",
  869. fields:["demographics","green","river","road","collision_buffer","no_fly_zone_buffer","clear_zone_buffer"],
  870. center:m_view.center,
  871. radius: (m_view.extent.xmax - m_view.extent.xmin) > (m_view.extent.ymax - m_view.extent.ymin) ? (m_view.extent.xmax - m_view.extent.xmin) : (m_view.extent.ymax - m_view.extent.ymin),
  872. minZ: 0,
  873. maxZ: 50,
  874. level: 20,
  875. size:{ x: 52.887881893650956, y: 61.627412608112536, z: 53.887012166300096 }
  876. })
  877. break;
  878. case (scaleValue <= 6000 && scaleValue > 3000): //21级
  879. getCurrentRealPower({
  880. status:"show",
  881. id:"power_wj",
  882. fields:["demographics","green","river","road","collision_buffer","no_fly_zone_buffer","clear_zone_buffer"],
  883. center:m_view.center,
  884. radius: (m_view.extent.xmax - m_view.extent.xmin) > (m_view.extent.ymax - m_view.extent.ymin) ? (m_view.extent.xmax - m_view.extent.xmin) : (m_view.extent.ymax - m_view.extent.ymin),
  885. minZ: 0,
  886. maxZ: 20,
  887. level: 21,
  888. size:{ x: 26.44107169853396, y: 30.815525255577086, z: 26.943221541824816 }
  889. })
  890. break;
  891. case (scaleValue <= 3000 && scaleValue > 1500): //22级
  892. getCurrentRealPower({
  893. status:"show",
  894. id:"power_wj",
  895. fields:["demographics","green","river","road","collision_buffer","no_fly_zone_buffer","clear_zone_buffer"],
  896. center:m_view.center,
  897. radius: (m_view.extent.xmax - m_view.extent.xmin) > (m_view.extent.ymax - m_view.extent.ymin) ? (m_view.extent.xmax - m_view.extent.xmin) : (m_view.extent.ymax - m_view.extent.ymin),
  898. minZ: 0,
  899. maxZ: 5,
  900. level: 22,
  901. size:{ x: 13.222978864358083, y: 15.406742669116284, z: 13.471596544164798 }
  902. })
  903. break;
  904. case (scaleValue <= 1500): //23级
  905. getCurrentRealPower({
  906. status:"show",
  907. id:"power_wj",
  908. fields:["demographics","green","river","road","collision_buffer","no_fly_zone_buffer","clear_zone_buffer"],
  909. center:m_view.center,
  910. radius: (m_view.extent.xmax - m_view.extent.xmin) > (m_view.extent.ymax - m_view.extent.ymin) ? (m_view.extent.xmax - m_view.extent.xmin) : (m_view.extent.ymax - m_view.extent.ymin),
  911. minZ: 0,
  912. maxZ: 5,
  913. level: 23,
  914. size:{ x: 6.7358, y: 7.7024, z: 6.6111 }
  915. })
  916. break;
  917. }
  918. }
  919. function showThreeCube(params){
  920. let status = params.status;
  921. if(status === "hide"){
  922. if(addThreeCubeEvent){
  923. addThreeCubeEvent.clear();
  924. addThreeCubeEvent = null;
  925. }
  926. return
  927. }
  928. let size = params.size;
  929. let points = params.points;
  930. // 初始化 AddThreeCubeEvent,暂时不启动
  931. addThreeCubeEvent = new AddThreeCubeEvent({
  932. view: m_view,
  933. points:points,
  934. size,
  935. });
  936. addThreeCubeEvent.init();
  937. }
  938. function showThreeCubeDetail(params){
  939. let status = params.status;
  940. let id = params.id;
  941. let depthTest = params.depthTest;
  942. if(depthTest == undefined){
  943. depthTest = true;
  944. }
  945. if(status === "hide"){
  946. if(addThreeCubeDetailInstance[id]){
  947. addThreeCubeDetailInstance[id].clear();
  948. addThreeCubeDetailInstance[id] = null;
  949. }
  950. return
  951. }
  952. let size = params.size;
  953. if(addThreeCubeDetailInstance[id]){
  954. addThreeCubeDetailInstance[id].add(params.points);
  955. }else{
  956. let addThreeCubeDetailEvent = new AddThreeCubeDetailEvent({
  957. view: m_view,
  958. points:params.points,
  959. size,
  960. bus,
  961. depthTest
  962. });
  963. addThreeCubeDetailEvent.start();
  964. addThreeCubeDetailInstance[id] = addThreeCubeDetailEvent;
  965. }
  966. }
  967. // 递归获取所有建筑点的辅助函数
  968. function getAllPowerPoints(level,scrollId = null) {
  969. getPowerInterface({
  970. x: m_view.camera.position.x,
  971. y: m_view.camera.position.y,
  972. //level: level,
  973. scrollId: scrollId,
  974. }).then(res =>{
  975. if(res.data.data.list?.length >= 10000 && res.data.data.scrollId){
  976. powerDataList = powerDataList.concat(res.data.data.list);
  977. getAllPowerPoints(level,res.data.data.scrollId);
  978. }else{
  979. powerDataList = powerDataList.concat(res.data.data.list);
  980. // 初始化 AddThreeCubeEvent,暂时不启动
  981. powerDataList.forEach((item)=>{
  982. item.color = getColor(item.averageValue, -100, 0);
  983. })
  984. let size = {
  985. x:13.223015683766334,
  986. y:15.404125436905815,
  987. z:13.471596544164798
  988. }
  989. let para = {
  990. id:"1",
  991. status:"show",
  992. size,
  993. points:powerDataList
  994. }
  995. //symbolPointCube(para)
  996. showThreeCubeDetail(para);
  997. }
  998. })
  999. }
  1000. function getColor(value, minValue, maxValue) {
  1001. // 边界处理
  1002. if (value < minValue) value = minValue;
  1003. if (value > maxValue) value = maxValue;
  1004. // 映射到 [0, 1]
  1005. let t = (value - minValue) / (maxValue - minValue);
  1006. // 定义颜色
  1007. let r, g, b;
  1008. if (t <= 0.5) {
  1009. // 从红色到黄色
  1010. r = 1;
  1011. g = t * 2; // 线性插值增加绿色
  1012. b = 0;
  1013. } else {
  1014. // 从黄色到绿色
  1015. r = 2 * (1 - t); // 线性插值减少红色
  1016. g = 1;
  1017. b = 0;
  1018. }
  1019. return [r, g, b];
  1020. }
  1021. function showBuildingThreeCubeByInterface(params){
  1022. let status = params.status;
  1023. let size = params.size;
  1024. if(addThreeCubeEvent){
  1025. addThreeCubeEvent.clear();
  1026. addThreeCubeEvent = null;
  1027. }
  1028. if(status === "hide"){
  1029. return
  1030. }
  1031. let level = params.level;
  1032. // 初始化 AddThreeCubeEvent,暂时不启动
  1033. addThreeCubeEvent = new AddThreeCubeEvent({
  1034. view: m_view,
  1035. size,
  1036. });
  1037. addThreeCubeEvent.start();
  1038. // 获取所有建筑点数据
  1039. getAllBuildingPoints(level);
  1040. }
  1041. function showNoFlyThreeCubeDetailByInterface(params){
  1042. let status = params.status;
  1043. let size = params.size;
  1044. if(addThreeCubeEvent){
  1045. addThreeCubeEvent.clear();
  1046. addThreeCubeEvent = null;
  1047. }
  1048. if(status === "hide"){
  1049. return
  1050. }
  1051. let level = params.level;
  1052. getNoFlyPointInterface({
  1053. x: m_view.camera.position.x,
  1054. y: m_view.camera.position.y,
  1055. level: level,
  1056. scrollId: "",
  1057. }).then(res =>{
  1058. res.data.data.list.forEach(item =>{
  1059. item.color = [1,0,0]
  1060. })
  1061. // 初始化 AddThreeCubeEvent,暂时不启动
  1062. let addThreeCubeDetailEvent = new AddThreeCubeDetailEvent({
  1063. view: m_view,
  1064. points:res.data.data.list,
  1065. size,
  1066. bus
  1067. });
  1068. addThreeCubeDetailEvent.start();
  1069. })
  1070. }
  1071. function showNoFlyThreeCubeByInterface(params){
  1072. let status = params.status;
  1073. let size = params.size;
  1074. if(addThreeCubeEvent){
  1075. addThreeCubeEvent.clear();
  1076. addThreeCubeEvent = null;
  1077. }
  1078. if(status === "hide"){
  1079. return
  1080. }
  1081. let level = params.level;
  1082. // 初始化 AddThreeCubeEvent,暂时不启动
  1083. addThreeCubeEvent = new AddThreeCubeEvent({
  1084. view: m_view,
  1085. size,
  1086. });
  1087. addThreeCubeEvent.start();
  1088. // 获取所有建筑点数据
  1089. getNoFlyPoint(level);
  1090. }
  1091. function showRoadThreeCubeByInterface(params){
  1092. let status = params.status;
  1093. let size = params.size;
  1094. if(addThreeCubeEvent){
  1095. addThreeCubeEvent.clear();
  1096. addThreeCubeEvent = null;
  1097. }
  1098. if(status === "hide"){
  1099. return
  1100. }
  1101. let level = params.level;
  1102. // 初始化 AddThreeCubeEvent,暂时不启动
  1103. addThreeCubeEvent = new AddThreeCubeEvent({
  1104. view: m_view,
  1105. size,
  1106. });
  1107. addThreeCubeEvent.start();
  1108. // 获取所有建筑点数据
  1109. getRoadPoint(level);
  1110. }
  1111. function showRoadThreeCubeDetailByInterface(params){
  1112. let status = params.status;
  1113. let size = params.size;
  1114. if(addThreeCubeEvent){
  1115. addThreeCubeEvent.clear();
  1116. addThreeCubeEvent = null;
  1117. }
  1118. if(status === "hide"){
  1119. return
  1120. }
  1121. let level = params.level;
  1122. getRoadPointInterface({
  1123. x: m_view.camera.position.x,
  1124. y: m_view.camera.position.y,
  1125. level: level,
  1126. scrollId: "",
  1127. }).then(res =>{
  1128. res.data.data.list.forEach(item =>{
  1129. item.color = [0,0,1]
  1130. })
  1131. // 初始化 AddThreeCubeEvent,暂时不启动
  1132. let addThreeCubeDetailEvent = new AddThreeCubeDetailEvent({
  1133. view: m_view,
  1134. points:res.data.data.list,
  1135. size,
  1136. bus
  1137. });
  1138. addThreeCubeDetailEvent.start();
  1139. })
  1140. }
  1141. function showRiverThreeCubeByInterface(params){
  1142. let status = params.status;
  1143. let size = params.size;
  1144. if(addThreeCubeEvent){
  1145. addThreeCubeEvent.clear();
  1146. addThreeCubeEvent = null;
  1147. }
  1148. if(status === "hide"){
  1149. return
  1150. }
  1151. let level = params.level;
  1152. // 初始化 AddThreeCubeEvent,暂时不启动
  1153. addThreeCubeEvent = new AddThreeCubeEvent({
  1154. view: m_view,
  1155. size,
  1156. });
  1157. addThreeCubeEvent.start();
  1158. // 获取所有建筑点数据
  1159. getRiverPoint(level);
  1160. }
  1161. function showRiverThreeCubeDetailByInterface(params){
  1162. let status = params.status;
  1163. let size = params.size;
  1164. if(addThreeCubeEvent){
  1165. addThreeCubeEvent.clear();
  1166. addThreeCubeEvent = null;
  1167. }
  1168. if(status === "hide"){
  1169. return
  1170. }
  1171. let level = params.level;
  1172. getRiverPointInterface({
  1173. x: m_view.camera.position.x,
  1174. y: m_view.camera.position.y,
  1175. level: level,
  1176. scrollId: "",
  1177. }).then(res =>{
  1178. res.data.data.list.forEach(item =>{
  1179. item.color = [1,1,0]
  1180. })
  1181. // 初始化 AddThreeCubeEvent,暂时不启动
  1182. let addThreeCubeDetailEvent = new AddThreeCubeDetailEvent({
  1183. view: m_view,
  1184. points:res.data.data.list,
  1185. size,
  1186. bus
  1187. });
  1188. addThreeCubeDetailEvent.start();
  1189. })
  1190. }
  1191. function showThreeNet(params){
  1192. let status = params.status;
  1193. if(addThreeNetEvent){
  1194. addThreeNetEvent.clear();
  1195. addThreeNetEvent = null;
  1196. }
  1197. if(status === "hide"){
  1198. return
  1199. }
  1200. let size = params.size;
  1201. let origin = params.origin;
  1202. let buffer = params.buffer;
  1203. let maxHeight = params.maxHeight;
  1204. let minHeight = params.minHeight;
  1205. //另一类是网加载(网只根据范围变化)
  1206. addThreeNetEvent = new AddThreeNetEvent({
  1207. view: m_view,
  1208. size,
  1209. origin,
  1210. buffer,
  1211. maxHeight,
  1212. minHeight
  1213. });
  1214. addThreeNetEvent.start();
  1215. }
  1216. // 递归获取所有建筑点的辅助函数
  1217. function getAllBuildingPoints(level,scrollId = null) {
  1218. getBuildingPoint({
  1219. x: m_view.camera.position.x,
  1220. y: m_view.camera.position.y,
  1221. level: level,
  1222. scrollId: scrollId,
  1223. }).then(res =>{
  1224. if(res.data.data.list?.length >= 10000 && res.data.data.scrollId){
  1225. addThreeCubeEvent.addPoints(res.data.data.list);
  1226. getAllBuildingPoints(level,res.data.data.scrollId);
  1227. }else{
  1228. addThreeCubeEvent.addPoints(res.data.data.list);
  1229. }
  1230. })
  1231. }
  1232. // 递归获取所有建筑点的辅助函数
  1233. function getNoFlyPoint(level,scrollId = null) {
  1234. getNoFlyPointInterface({
  1235. x: m_view.camera.position.x,
  1236. y: m_view.camera.position.y,
  1237. level: level,
  1238. scrollId: scrollId,
  1239. }).then(res =>{
  1240. if(res.data.data.list?.length >= 10000 && res.data.data.scrollId){
  1241. addThreeCubeEvent.addPoints(res.data.data.list);
  1242. getNoFlyPoint(level,res.data.data.scrollId);
  1243. }else{
  1244. addThreeCubeEvent.addPoints(res.data.data.list);
  1245. }
  1246. })
  1247. }
  1248. // 递归获取所有道路点的辅助函数
  1249. function getRoadPoint(level,scrollId = null) {
  1250. getRoadPointInterface({
  1251. x: m_view.camera.position.x,
  1252. y: m_view.camera.position.y,
  1253. level: level,
  1254. scrollId: scrollId,
  1255. }).then(res =>{
  1256. if(res.data.data.list?.length >= 10000 && res.data.data.scrollId){
  1257. addThreeCubeEvent.addPoints(res.data.data.list);
  1258. getRoadPoint(level,res.data.data.scrollId);
  1259. }else{
  1260. addThreeCubeEvent.addPoints(res.data.data.list);
  1261. }
  1262. })
  1263. }
  1264. // 递归获取所有河流点的辅助函数
  1265. function getRiverPoint(level,scrollId = null) {
  1266. getRiverPointInterface({
  1267. x: m_view.camera.position.x,
  1268. y: m_view.camera.position.y,
  1269. level: level,
  1270. scrollId: scrollId,
  1271. }).then(res =>{
  1272. if(res.data.data.list?.length >= 10000 && res.data.data.scrollId){
  1273. addThreeCubeEvent.addPoints(res.data.data.list);
  1274. getRiverPoint(level,res.data.data.scrollId);
  1275. }else{
  1276. addThreeCubeEvent.addPoints(res.data.data.list);
  1277. }
  1278. })
  1279. }
  1280. //全市格网自定义分割效果加载
  1281. // function showLayersWithScaleEventsReturn(scaleValue){
  1282. // let eyeExtent = getEyeExtent();
  1283. // if(!eyeExtent){
  1284. // return
  1285. // }
  1286. // let height = m_view.camera.position.z;
  1287. // console.log("height",height,"scale",m_view.scale);
  1288. // let sizeObj = extentGridLimit({
  1289. // eyeExtent,
  1290. // height
  1291. // });
  1292. // let size = sizeObj.size;
  1293. // let opacity = sizeObj.opacity;
  1294. // let layerHeight;
  1295. // if(size > 400){
  1296. // layerHeight = 400;
  1297. // }else{
  1298. // layerHeight = size;
  1299. // }
  1300. // if(addThreeGridEvent){
  1301. // addThreeGridEvent.extent = {minX:eyeExtent.xmin,maxX:eyeExtent.xmax,minY:eyeExtent.ymin,maxY:eyeExtent.ymax};
  1302. // addThreeGridEvent.height = height>1200?1200:height;
  1303. // addThreeGridEvent.size = size;
  1304. // addThreeGridEvent.layerHeight = layerHeight;
  1305. // addThreeGridEvent.gridEnabled = true;
  1306. // addThreeGridEvent.netEnabled = true;
  1307. // addThreeGridEvent.opacity = opacity;
  1308. // addThreeGridEvent.start();
  1309. // }else{
  1310. // addThreeGridEvent = new AddThreeGridEvent({
  1311. // view:m_view,
  1312. // extent: {minX:eyeExtent.xmin,maxX:eyeExtent.xmax,minY:eyeExtent.ymin,maxY:eyeExtent.ymax},
  1313. // height:height>1200?1200:height,
  1314. // size:size,
  1315. // gridEnabled : true,
  1316. // netEnabled : true,
  1317. // opacity:opacity,
  1318. // layerHeight:layerHeight,
  1319. // })
  1320. // addThreeGridEvent.start();
  1321. // }
  1322. //
  1323. // }
  1324. //
  1325. //格网范围限制
  1326. // function extentGridLimit(params){
  1327. // try{
  1328. // //let size = [7.73,61.84,123.69,1850];
  1329. // let size = [
  1330. // {
  1331. // value:7.73,
  1332. // opacity:0.05
  1333. // },
  1334. // {
  1335. // value:61.84,
  1336. // opacity:0.05
  1337. // },
  1338. // {
  1339. // value:123.69,
  1340. // opacity:0.15
  1341. // },
  1342. // {
  1343. // value:1850,
  1344. // opacity:0.3
  1345. // }
  1346. // ]
  1347. // params.eyeExtent = {
  1348. // xmin: params.eyeExtent.xmin < -60000?-60000:params.eyeExtent.xmin,
  1349. // ymin: params.eyeExtent.ymin < -60000?-60000:params.eyeExtent.ymin,
  1350. // xmax: params.eyeExtent.xmax > 60000?60000:params.eyeExtent.xmax,
  1351. // ymax: params.eyeExtent.ymax > 70000?70000:params.eyeExtent.ymax,
  1352. // }
  1353. // params.height = params.height < 1200?params.height:1200;
  1354. // for(let i = 0;i<size.length;i++){
  1355. // let xCount = Math.floor((params.eyeExtent.xmax - params.eyeExtent.xmin) / size[i].value);
  1356. // let yCount = Math.floor((params.eyeExtent.ymax - params.eyeExtent.ymin) / size[i].value);
  1357. // let zCount = Math.floor(params.height / size[i].value);
  1358. // let count = xCount * yCount * zCount;
  1359. // if(count < 200000){
  1360. // return {
  1361. // size: size[i].value,
  1362. // opacity: size[i].opacity
  1363. // }
  1364. // }
  1365. // }
  1366. // }catch(e){
  1367. // console.log("params",params)
  1368. // }
  1369. // }
  1370. // function getEyeExtent() {
  1371. // const screenWidth = m_view.width;
  1372. // const screenHeight = m_view.height;
  1373. //
  1374. // // 四个角的像素坐标
  1375. // const screenCorners = [
  1376. // { x: 0, y: 0 }, // 左上角
  1377. // { x: screenWidth, y: 0 }, // 右上角
  1378. // { x: screenWidth, y: screenHeight }, // 右下角
  1379. // { x: 0, y: screenHeight }, // 左下角
  1380. // ];
  1381. //
  1382. // // 将屏幕角坐标转为地图坐标
  1383. // const mapPoints = screenCorners.map((screenPoint) => m_view.toMap(screenPoint)).filter(p => p);
  1384. //
  1385. // // 添加 camera.position 到 mapPoints
  1386. // const cameraPoint = m_view.camera.position;
  1387. //
  1388. // if (mapPoints.length < 4) {
  1389. // if (cameraPoint) {
  1390. // const bufferDistance = 2000; // 2公里
  1391. // const spatialReference = m_view.spatialReference;
  1392. //
  1393. // const screenExtent = {
  1394. // xmin: cameraPoint.x - bufferDistance,
  1395. // ymin: cameraPoint.y - bufferDistance,
  1396. // xmax: cameraPoint.x + bufferDistance,
  1397. // ymax: cameraPoint.y + bufferDistance,
  1398. // spatialReference: spatialReference,
  1399. // };
  1400. // console.warn("视图范围不足4个有效点,使用摄像机位置生成的2公里范围。");
  1401. // console.log(screenExtent);
  1402. // return screenExtent;
  1403. // } else {
  1404. // console.warn("无法获取摄像机位置,请检查视图状态。");
  1405. // return null;
  1406. // }
  1407. // } else {
  1408. // try {
  1409. // // 获取最小和最大坐标值
  1410. // const xmin = Math.min(...mapPoints.map((p) => p.x));
  1411. // const ymin = Math.min(...mapPoints.map((p) => p.y));
  1412. // const xmax = Math.max(...mapPoints.map((p) => p.x));
  1413. // const ymax = Math.max(...mapPoints.map((p) => p.y));
  1414. //
  1415. // const screenExtent = {
  1416. // xmin: xmin,
  1417. // ymin: ymin,
  1418. // xmax: xmax,
  1419. // ymax: ymax,
  1420. // spatialReference: m_view.spatialReference,
  1421. // };
  1422. // console.log(screenExtent);
  1423. // return screenExtent;
  1424. // } catch (e) {
  1425. // console.error("获取地图范围时出错:", e);
  1426. // return null;
  1427. // }
  1428. // }
  1429. // }
  1430. function viewshedAnalysis(params){
  1431. let status = params.status;
  1432. if(status === "hide"){
  1433. if(viewShedAnalysisWidget !== null){
  1434. viewShedAnalysisWidget.clearAnalysis();
  1435. }
  1436. return
  1437. }
  1438. if(status === "show"){
  1439. if(viewShedAnalysisWidget === null){
  1440. viewShedAnalysisWidget = new ViewShedAnalysisWidget({ view:m_view });
  1441. viewShedAnalysisWidget.startAnalysis();
  1442. }
  1443. }
  1444. }
  1445. function featureLayerThreeDimension(params){
  1446. let status = params.status;
  1447. }
  1448. function addLightBall(params){
  1449. let status = params.status;
  1450. if(addLightBallEvent){
  1451. addLightBallEvent.clear();
  1452. addLightBallEvent = null;
  1453. }
  1454. if(status === "hide"){
  1455. return
  1456. }
  1457. addLightBallEvent = new AddLightBallEvent({
  1458. view:m_view
  1459. })
  1460. addLightBallEvent.start()
  1461. }
  1462. function threeGrid(params){
  1463. let status = params.status;
  1464. if(status === "hide"){
  1465. if(addThreeGridEvent){
  1466. addThreeGridEvent.clear();
  1467. addThreeGridEvent = null;
  1468. }
  1469. return
  1470. }
  1471. let animationEnabled = false;
  1472. if(params.animationEnabled){
  1473. animationEnabled = params.animationEnabled;
  1474. }
  1475. if(addThreeGridEvent){
  1476. addThreeGridEvent.height = params.height;
  1477. addThreeGridEvent.size = params.size;
  1478. addThreeGridEvent.layerHeight = params.layerHeight;
  1479. addThreeGridEvent.animationEnabled = animationEnabled;
  1480. addThreeGridEvent.gridEnabled = true;
  1481. addThreeGridEvent.netEnabled = true;
  1482. addThreeGridEvent.start();
  1483. }else{
  1484. addThreeGridEvent = new AddThreeGridEvent({
  1485. view:m_view,
  1486. extent : {minX:2176,maxX:6048,minY:-1024,maxY:1352},
  1487. height : params.height,
  1488. size : params.size,
  1489. layerHeight :params.layerHeight,
  1490. gridEnabled:true,
  1491. netEnabled:true,
  1492. animationEnabled
  1493. })
  1494. addThreeGridEvent.start();
  1495. }
  1496. }
  1497. function threeGridDetail(params){
  1498. }
  1499. function realPositionGrid(params){
  1500. let status = params.status;
  1501. }
  1502. function limitHeightAnalysis(params){
  1503. let status = params.status;
  1504. if(limitHeightAnalysisEvent){
  1505. limitHeightAnalysisEvent.clear();
  1506. limitHeightAnalysisEvent =null;
  1507. }
  1508. if(status === "hide"){
  1509. return
  1510. }
  1511. limitHeightAnalysisEvent = new LimitHeightAnalysis({
  1512. view:m_view,
  1513. map:m_map,
  1514. layerId:params.layerId,
  1515. limitH:params.limitH,
  1516. maxLimitH:params.maxLimitH,
  1517. rings:params.rings,
  1518. });
  1519. limitHeightAnalysisEvent.start()
  1520. }
  1521. function geometryMeshPrismEffect(params){
  1522. let status = params.status;
  1523. let f_layer = m_map.layers.find(item => item.id === "geometryMeshPrismEffect");
  1524. if (f_layer) {
  1525. m_map.remove(f_layer);
  1526. }
  1527. if(status === "hide"){
  1528. return
  1529. }
  1530. let geometryMeshPrismEffect = new GeometryMeshPrismEffect({
  1531. view:m_view,
  1532. m_map,
  1533. items:params.items,
  1534. startHeight:params.startHeight,
  1535. rings:params.rings
  1536. });
  1537. m_map.add(geometryMeshPrismEffect.graphicsLayer);
  1538. }
  1539. function geometryMeshEffect(params){
  1540. let status = params.status;
  1541. let id = params.id;
  1542. let f_layer = m_map.layers.find(item => item.id === "geometryMeshEffect" + id);
  1543. if (f_layer) {
  1544. m_map.remove(f_layer);
  1545. }
  1546. if(status === "hide"){
  1547. return
  1548. }
  1549. let geometryMeshEffect = new GeometryMeshEffect({
  1550. view:m_view,
  1551. m_map,
  1552. id:params.id,
  1553. data:params.data
  1554. });
  1555. m_map.add(geometryMeshEffect.graphicsLayer);
  1556. }
  1557. // 路径冲突
  1558. function pathConflict(params){
  1559. pathPipe({
  1560. "id": "conflict1",
  1561. "status": "show",
  1562. "paths":Path.path_conflict_1,
  1563. "color": "#438EDB",
  1564. "intensity": 1.2,
  1565. "pipeRadius": 5
  1566. });
  1567. pathPipe({
  1568. "id": "conflict2",
  1569. "status": "show",
  1570. "paths":Path.path_conflict_2,
  1571. "color": "#438EDB",
  1572. "intensity": 1.2,
  1573. "pipeRadius": 5
  1574. });
  1575. getRealFlyPoint({
  1576. flyList:[
  1577. {
  1578. "id": "67513a6e-7ce2-4121-9b11-cd6f1d28e02c",
  1579. "speed":40,
  1580. "uavid": "87066700-f12d-4b3e-ac77-a55a409dd30b"
  1581. },
  1582. {
  1583. "id": "fba073d1-def3-4f85-9326-dff8a1ac6ea6",
  1584. "speed":25,
  1585. "uavid": "9556344a-c055-4156-86d4-bc57930275a2"
  1586. }
  1587. ]
  1588. })
  1589. }
  1590. // 无人机电量预警
  1591. function uavBatteryWarning(params){
  1592. pathPipe({
  1593. "id": "conflict1",
  1594. "status": "show",
  1595. "paths":Path.path_conflict_1,
  1596. "color": "#438EDB",
  1597. "intensity": 1.2,
  1598. "pipeRadius": 10
  1599. });
  1600. getRealFlyPoint({
  1601. flyList:[
  1602. {
  1603. "id": "67513a6e-7ce2-4121-9b11-cd6f1d28e02c",
  1604. "speed":40,
  1605. "uavid": "02d47b30-003c-4e7e-89ec-72255c1ebdaf"
  1606. }
  1607. ]
  1608. })
  1609. }
  1610. //无人机偏航
  1611. function uavYawWarning(params){
  1612. pathPipe({
  1613. "id": "yaw",
  1614. "status": "show",
  1615. "paths":Path.yaw_path,
  1616. "color": "#438EDB",
  1617. "intensity": 1.2,
  1618. "pipeRadius": 10
  1619. });
  1620. getRealFlyPoint({
  1621. flyList:[
  1622. {
  1623. "id": "6fd0fa45-de0b-4008-8d4d-afaaa15064f3",
  1624. "speed":40,
  1625. "uavid": "7e080fe7-dbd4-4be2-aa45-72a28da7f26c"
  1626. }
  1627. ]
  1628. })
  1629. }
  1630. function pathPipe(params){
  1631. let id = params.id;
  1632. let status = params.status;
  1633. if(pathPipeInstance[id]){
  1634. pathPipeInstance[id].clear();
  1635. pathPipeInstance[id] = null;
  1636. }
  1637. if(status === "hide"){
  1638. return
  1639. }
  1640. //优化数据
  1641. //params.paths = Path.paths;
  1642. let pathPipeEvent = new PathPipeEvent({
  1643. view:m_view,
  1644. paths:params.paths,
  1645. color:params.color,
  1646. pipeRadius:params.pipeRadius,
  1647. intensity:params.intensity
  1648. });
  1649. pathPipeEvent.start();
  1650. // 保存实例
  1651. pathPipeInstance[id] = pathPipeEvent;
  1652. }
  1653. function flyGLTF(params){
  1654. let id = params.id;
  1655. let uavid = params.uavid;
  1656. let status = params.status;
  1657. if(status === "hide"){
  1658. if(flyGLTFInstances[uavid]){
  1659. flyGLTFInstances[uavid].clear();
  1660. delete flyGLTFInstances[uavid];
  1661. }
  1662. return
  1663. }
  1664. let point = params.point;
  1665. let duration = params.duration;
  1666. let uavInfo = params.uavInfo;
  1667. if(flyGLTFInstances[uavid]){
  1668. flyGLTFInstances[uavid].updatePath(point,duration);
  1669. if(uavInfo){
  1670. flyGLTFInstances[uavid].updateUavInfo(uavInfo);
  1671. }
  1672. }else{
  1673. let flyGLTFEvent = new FlyGLTFEvent({
  1674. view:m_view,
  1675. uavid,
  1676. bus,
  1677. })
  1678. flyGLTFEvent.start();
  1679. flyGLTFEvent.updatePath(point,duration);
  1680. if(params.uavInfo){
  1681. flyGLTFEvent.updateUavInfo(uavInfo);
  1682. }
  1683. flyGLTFInstances[uavid] = flyGLTFEvent;
  1684. }
  1685. }
  1686. function getVirtualFlyPoint(params){
  1687. let status = params.status;
  1688. const connectVirtualWebSocket = (status) => {
  1689. if(status === "show"){
  1690. if(virtualSocket){
  1691. virtualSocket.send(JSON.stringify(params.flyList));
  1692. }else{
  1693. virtualSocket = new WebSocket('ws://58.34.215.19:8100/simulate/getRouteInfoWebSocket');
  1694. virtualSocket.onopen = () => {
  1695. console.log('WebSocket 连接成功');
  1696. virtualSocket.send(JSON.stringify(params.flyList));
  1697. };
  1698. virtualSocket.onmessage = (messageEvent) => {
  1699. let messages = JSON.parse(messageEvent.data).data;
  1700. messages.forEach(message => {
  1701. flyGLTF({
  1702. id:message.id,
  1703. uavid:message.uavid,
  1704. status:message.routeInfoVO.status == 3?"hide":"show",
  1705. duration:2100,
  1706. //duration:3000,
  1707. point:message.position_cj,
  1708. uavInfo: {
  1709. type:"safe",
  1710. data:message.routeInfoVO,
  1711. origin:message.routeInfoVO
  1712. }
  1713. });
  1714. })
  1715. };
  1716. virtualSocket.onerror = (error) => {
  1717. console.error('WebSocket 出错:', error);
  1718. };
  1719. virtualSocket.onclose = () => {
  1720. console.log('WebSocket 连接已关闭');
  1721. };
  1722. }
  1723. }else{
  1724. if(virtualSocket){
  1725. virtualSocket.close();
  1726. }
  1727. }
  1728. };
  1729. connectVirtualWebSocket(status);
  1730. }
  1731. function getRealFlyPoint(params){
  1732. const connectWebSocket = () => {
  1733. if(socket){
  1734. socket.send(JSON.stringify(params.flyList));
  1735. }else{
  1736. socket = new WebSocket('ws://58.34.215.19:8100/aircraftRouteSpeedWebSocket');
  1737. socket.onopen = () => {
  1738. console.log('WebSocket 连接成功');
  1739. socket.send(JSON.stringify(params.flyList));
  1740. };
  1741. socket.onmessage = (messageEvent) => {
  1742. let messages = JSON.parse(messageEvent.data).data;
  1743. realFlyPointDataQueue.push(messages);
  1744. };
  1745. socket.onerror = (error) => {
  1746. console.error('WebSocket 出错:', error);
  1747. };
  1748. socket.onclose = () => {
  1749. console.log('WebSocket 连接已关闭');
  1750. };
  1751. }
  1752. };
  1753. connectWebSocket();
  1754. processRealFlyPointData();
  1755. }
  1756. //如果是等待,就要设置另一台无人机继续飞行
  1757. function processRealFlyPointData(){
  1758. setInterval(() => {
  1759. if (realFlyPointDataQueue.length > 0) {
  1760. const messages = realFlyPointDataQueue.shift(); // 从队列中取出数据
  1761. //发送消息
  1762. bus.emit('SendMessage',{
  1763. action:"RealTimeUAVList",
  1764. data:{
  1765. "message":messages
  1766. }
  1767. })
  1768. messages.forEach(message => {
  1769. message.routeInfoVO.speed = message.routeInfoVO.speed * 1 +(Math.random() * 2).toFixed(2) * 1
  1770. if(message.overall === "SAFE"){
  1771. addGraphics({
  1772. "id": message.uavid+'_conflict',
  1773. "status": "hide"
  1774. });
  1775. pathPipe({
  1776. "id": message.uavid+'_conflict',
  1777. "status": "hide"
  1778. });
  1779. flyGLTF({
  1780. id:message.id,
  1781. uavid:message.uavid,
  1782. status:message.routeInfoVO.status == 3?"hide":"show",
  1783. //duration:message.time + 100,
  1784. duration:2500,
  1785. point:message.position_cj,
  1786. uavInfo: {
  1787. type:"safe",
  1788. data:message.routeInfoVO,
  1789. origin:message.routeInfoVO
  1790. }
  1791. });
  1792. }else{
  1793. if(message.nearestAircraft.status !="SAFE"){ //碰撞
  1794. flyGLTF({
  1795. id:message.id,
  1796. uavid:message.uavid,
  1797. status:message.routeInfoVO.status == 3?"hide":"show",
  1798. //duration:message.time + 100,
  1799. duration:2500,
  1800. point:message.position_cj,
  1801. uavInfo: {
  1802. type:"conflict",
  1803. action:message.routeInfoVO.avoidanceType,
  1804. data:message.routeInfoVO.avoidanceType == "wait" ?message.nearestAircraft:message.routeInfoVO,
  1805. origin:{
  1806. ...message.nearestAircraft,
  1807. ...message.routeInfoVO
  1808. }
  1809. }
  1810. });
  1811. addGraphics({
  1812. id: message.uavid+'_conflict',
  1813. status:message.routeInfoVO.status == 3?"hide":"show",
  1814. data: {
  1815. "geometry": { "type": "point", "x": message.nearestAircraft.conflictPoint[0], "y": message.nearestAircraft.conflictPoint[1], "z": message.nearestAircraft.conflictPoint[2] },
  1816. "attributes": { "name": "碰撞点位" }
  1817. }
  1818. });
  1819. pathPipe({
  1820. "id": message.uavid+'_conflict',
  1821. "status": message.routeInfoVO.status == 3?"hide":"show",
  1822. "paths":[message.nearestAircraft.conflictPath],
  1823. "color": "#FF0000",
  1824. "intensity": 1.5,
  1825. "pipeRadius": 10
  1826. });
  1827. }else{
  1828. addGraphics({
  1829. "id": message.uavid+'_conflict',
  1830. "status": "hide"
  1831. });
  1832. pathPipe({
  1833. "id": message.uavid+'_conflict',
  1834. "status": "hide"
  1835. });
  1836. // if(message.noFlyZone.status != "SAFE"){
  1837. // console.log("禁飞区预警",message);
  1838. // flyGLTF({
  1839. // id:message.id,
  1840. // uavid:message.uavid,
  1841. // status:message.routeInfoVO.status == 3?"hide":"show",
  1842. // //duration:message.time + 100,
  1843. // duration:2100,
  1844. // point:message.position_cj,
  1845. // uavInfo: {
  1846. // type:"noFlyZone",
  1847. // data:message.routeInfoVO,
  1848. // origin:message.routeInfoVO
  1849. // }
  1850. // });
  1851. // }else
  1852. if(message.routeDeviate.status != "SAFE" && message.routeDeviate.distance * 1 > 14){
  1853. console.log("偏航异常预警",message);
  1854. flyGLTF({
  1855. id:message.id,
  1856. uavid:message.uavid,
  1857. status:message.routeInfoVO.status == 3?"hide":"show",
  1858. //duration:message.time + 100,
  1859. duration:2500,
  1860. point:message.position_cj,
  1861. uavInfo: {
  1862. type:"routeDeviate",
  1863. data:message.routeDeviate,
  1864. index:message.index,
  1865. origin:{
  1866. ...message.routeDeviate,
  1867. ...message.routeInfoVO
  1868. }
  1869. }
  1870. });
  1871. }
  1872. // else if(message.electricityWarning.status != "SAFE"){
  1873. // console.log("电量异常预警",message);
  1874. // flyGLTF({
  1875. // id:message.id,
  1876. // uavid:message.uavid,
  1877. // status:message.routeInfoVO.status == 3?"hide":"show",
  1878. // //duration:message.time + 100,
  1879. // duration:2100,
  1880. // point:message.position_cj,
  1881. // uavInfo: {
  1882. // type:"electricityWarning",
  1883. // data:message.electricityWarning,
  1884. // origin:message.routeInfoVO
  1885. // }
  1886. // });
  1887. // }
  1888. // else if(message.collision.status != "SAFE"){
  1889. // console.log("建筑物过近异常信息",message);
  1890. // flyGLTF({
  1891. // id:message.id,
  1892. // uavid:message.uavid,
  1893. // status:message.routeInfoVO.status == 3?"hide":"show",
  1894. // //duration:message.time + 100,
  1895. // duration:2100,
  1896. // point:message.position_cj,
  1897. // uavInfo: {
  1898. // type:"collision",
  1899. // data:message.collision,
  1900. // origin:message.routeInfoVO
  1901. // }
  1902. // });
  1903. // }
  1904. // else if(message.clearZone.status != "SAFE"){
  1905. // console.log("净空区异常预警",message);
  1906. // flyGLTF({
  1907. // id:message.id,
  1908. // uavid:message.uavid,
  1909. // status:message.routeInfoVO.status == 3?"hide":"show",
  1910. // //duration:message.time + 100,
  1911. // duration:2100,
  1912. // point:message.position_cj,
  1913. // uavInfo: {
  1914. // type:"clearZone",
  1915. // data:message.clearZone,
  1916. // origin:message.routeInfoVO
  1917. // }
  1918. // });
  1919. // }
  1920. else{
  1921. flyGLTF({
  1922. id:message.id,
  1923. uavid:message.uavid,
  1924. status:message.routeInfoVO.status == 3?"hide":"show",
  1925. //duration:message.time + 100,
  1926. duration:2500,
  1927. point:message.position_cj,
  1928. uavInfo: {
  1929. type:"safe",
  1930. data:message.routeInfoVO,
  1931. origin:message.routeInfoVO
  1932. }
  1933. });
  1934. }
  1935. }
  1936. }
  1937. })
  1938. } else {
  1939. console.log("No data to process.");
  1940. }
  1941. }, 2500); // 每3秒处理一次数据
  1942. }
  1943. function conflict_fly(params){
  1944. let uavid = params.uavid;
  1945. let skip_route_id = params.skip_route_id;
  1946. let distance = params.distance;
  1947. getAvoidRoute({
  1948. uavid:uavid,
  1949. skip_route_id:skip_route_id,
  1950. distance:distance
  1951. }).then(res =>{
  1952. console.log("临时路线",res);
  1953. pathPipe({
  1954. "id": uavid+'_change',
  1955. "status": "show",
  1956. "paths":[res.data.data.pathAll],
  1957. "color": "#438EDB",
  1958. "intensity": 1.2,
  1959. "pipeRadius": 5
  1960. });
  1961. getRealFlyPoint({
  1962. flyList:{
  1963. "path": res.data.data.pathAll,
  1964. "avoidanceType":"avoid",
  1965. "uavid": uavid
  1966. }
  1967. })
  1968. })
  1969. }
  1970. function changePointStatus(params){
  1971. flyGLTFInstances[params.uavid].followPath(params.isFollow);
  1972. }
  1973. //ws 推送方法
  1974. function getRealPower(params){
  1975. const connectWebSocket = () => {
  1976. socket = new WebSocket('ws://58.34.215.19:8100/gridSearchWebSocket');
  1977. socket.onopen = () => {
  1978. console.log('WebSocket 连接成功');
  1979. socket.send(JSON.stringify({
  1980. "locationPoint": {
  1981. "mapX": 6454.080981250964,
  1982. "mapY": 5487.978352845347
  1983. },
  1984. "radiusInMeters": 5000,
  1985. "minZ": 1,
  1986. "maxZ": 120,
  1987. "routes": [
  1988. ],
  1989. "fields":["gridCode","x","y","z"],
  1990. "scrollPage": {
  1991. "pageIndex": 1,
  1992. "pageSize": 10000,
  1993. "scrollId": ""
  1994. },
  1995. "level":20,
  1996. "className":"LowAltitudeGrid"
  1997. }));
  1998. };
  1999. socket.onmessage = (messageEvent) => {
  2000. let messages = JSON.parse(messageEvent.data);
  2001. messages.data.list.forEach((point) =>{
  2002. point.color = [0, 1, 1];
  2003. });
  2004. console.log("messages.data.list",messages.data.list)
  2005. let para = {
  2006. "id":"1",
  2007. "status":"show",
  2008. "size":{
  2009. x:46,
  2010. y:54,
  2011. z:53
  2012. },
  2013. "points":messages.data.list,
  2014. }
  2015. showThreeCubeDetail(para);
  2016. };
  2017. socket.onerror = (error) => {
  2018. console.error('WebSocket 出错:', error);
  2019. };
  2020. socket.onclose = () => {
  2021. console.log('WebSocket 连接已关闭');
  2022. };
  2023. };
  2024. connectWebSocket();
  2025. }
  2026. //无极变换
  2027. function getCurrentRealPower(params){
  2028. let id = params.id;
  2029. let lastId = params.lastId;
  2030. let status = params.status;
  2031. let level = params.level;
  2032. let center = params.center;
  2033. let radius = params.radius;
  2034. let minZ = params.minZ;
  2035. let maxZ = params.maxZ;
  2036. let size = params.size;
  2037. let fields = params.fields;
  2038. if(status === "hide"){
  2039. showThreeCubeDetail({
  2040. id:params.id,
  2041. status:"hide"
  2042. });
  2043. return
  2044. }
  2045. getCurrentPowerPoints({
  2046. id,
  2047. lastId,
  2048. "x": center.x,
  2049. "y": center.y,
  2050. status,
  2051. radius,
  2052. size,
  2053. minZ,
  2054. maxZ,
  2055. level,
  2056. fields,
  2057. scrollId:""
  2058. });
  2059. }
  2060. // 无极变化-获取权重数据
  2061. function getCurrentPowerPoints(params) {
  2062. getPowerPoint({
  2063. x: params.x,
  2064. y: params.y,
  2065. radius:params.radius,
  2066. minZ:params.minZ,
  2067. maxZ:params.maxZ,
  2068. level: params.level,
  2069. fields: params.fields,
  2070. scrollId: params.scrollId,
  2071. }).then(res =>{
  2072. showThreeCubeDetail({
  2073. id:params.id,
  2074. status:"hide"
  2075. });
  2076. if(currentRealPowerShow){
  2077. if(res.data.data.list?.length > 0){
  2078. showThreeCubeDetail({
  2079. "id":params.id,
  2080. "status":params.status,
  2081. "size":params.size,
  2082. "points":res.data.data.list,
  2083. })
  2084. }
  2085. }
  2086. })
  2087. }
  2088. //获取当前场景
  2089. function getRealPower2(params){
  2090. let id = params.id;
  2091. let lastId = params.lastId;
  2092. let status = params.status;
  2093. let level = params.level;
  2094. let center = params.center;
  2095. let radius = params.radius;
  2096. let minZ = params.minZ;
  2097. let maxZ = params.maxZ;
  2098. let size = params.size;
  2099. let fields = params.fields;
  2100. if(status === "hide"){
  2101. showThreeCubeDetail({
  2102. id:params.id,
  2103. status:"hide"
  2104. });
  2105. currentShowGridParams = null;
  2106. return
  2107. }
  2108. showThreeCubeDetail({
  2109. id:params.lastId,
  2110. status:"hide"
  2111. });
  2112. currentShowGridParams = id;
  2113. getSixPowerPoints({
  2114. id,
  2115. lastId,
  2116. "x": center.x,
  2117. "y": center.y,
  2118. status,
  2119. radius,
  2120. size,
  2121. minZ,
  2122. maxZ,
  2123. level,
  2124. fields,
  2125. scrollId:""
  2126. });
  2127. }
  2128. // 获取当前场景-递归获取权重数据
  2129. function getSixPowerPoints(params) {
  2130. getPowerPoint({
  2131. x: params.x,
  2132. y: params.y,
  2133. radius:params.radius,
  2134. minZ:params.minZ,
  2135. maxZ:params.maxZ,
  2136. level: params.level,
  2137. fields: params.fields,
  2138. scrollId: params.scrollId,
  2139. }).then(res =>{
  2140. if(currentShowGridParams === params.id){
  2141. if(res.data.data.list?.length >= 100000 && res.data.data.scrollId){
  2142. // res.data.data.list.forEach((point) =>{
  2143. // point.color = [0, 1, 1];
  2144. // });
  2145. // res.data.data.list.forEach((item)=>{
  2146. // item.color = getColor(item.averageValue, -50, 50);
  2147. // })
  2148. showThreeCubeDetail({
  2149. "id":params.id,
  2150. "status":params.status,
  2151. "size":params.size,
  2152. "points":res.data.data.list,
  2153. })
  2154. params.scrollId = res.data.data.scrollId;
  2155. getSixPowerPoints(params);
  2156. }else{
  2157. if(res.data.data.list?.length > 0){
  2158. showThreeCubeDetail({
  2159. "id":params.id,
  2160. "status":params.status,
  2161. "size":params.size,
  2162. "points":res.data.data.list,
  2163. })
  2164. }
  2165. }
  2166. }
  2167. })
  2168. }
  2169. //需要添加初始路径(手动绘制和自动绘制)结果
  2170. function draw(params){
  2171. let id = params.id;
  2172. let geometryType = params.type;
  2173. let status = params.status;
  2174. let path = params.path;
  2175. let hasZ = params.hasZ;
  2176. let symbol = params.symbol;
  2177. let clear = true;
  2178. if(params.clear !== undefined){
  2179. clear = params.clear;
  2180. }
  2181. if(clear){
  2182. if(addDrawEvent){
  2183. addDrawEvent.clear();
  2184. addDrawEvent = null;
  2185. }
  2186. }
  2187. if(status === "hide"){
  2188. return
  2189. }
  2190. if(!addDrawEvent){
  2191. addDrawEvent = new AddDrawEvent({
  2192. view:m_view,
  2193. type:geometryType,
  2194. symbol,
  2195. path:path,
  2196. hasZ
  2197. });
  2198. }
  2199. if(path){
  2200. addDrawEvent.update();
  2201. bus.emit('SendMessage',{
  2202. action:"DrawComplete",
  2203. data:{
  2204. "geometry":{
  2205. type: "polyline",
  2206. paths: [path], // 示例路径坐标
  2207. spatialReference: m_view.spatialReference,
  2208. }
  2209. }
  2210. })
  2211. }else{
  2212. addDrawEvent.start(symbol,geometryType);
  2213. }
  2214. addDrawEvent.createListenerEvent((geometry) =>{
  2215. bus.emit('SendMessage',{
  2216. action:"DrawComplete",
  2217. data:{
  2218. "geometry":geometry
  2219. }
  2220. })
  2221. });
  2222. addDrawEvent.updateListenerEvent((geometry) =>{
  2223. bus.emit('SendMessage',{
  2224. action:"DrawComplete",
  2225. data:{
  2226. "geometry":geometry
  2227. }
  2228. })
  2229. });
  2230. }
  2231. //态势评估
  2232. function situationAssessment(params){
  2233. routeList.list.forEach((item) =>{
  2234. pathPipe({
  2235. id: item.id,
  2236. paths: [item.path],
  2237. color:item.color,
  2238. status: params.status,
  2239. "intensity": 1.2,
  2240. "pipeRadius": 10
  2241. })
  2242. })
  2243. featurePointsPlotting({
  2244. status: params.status,
  2245. data:routeList.points
  2246. });
  2247. routeList.conflictList.forEach((item) =>{
  2248. item.status = params.status =="show"?1:3
  2249. })
  2250. //先加载所有的无人机和航线
  2251. getRealFlyPoint({
  2252. status: params.status,
  2253. flyList:params.status=="show"?routeList.conflictList:routeList.conflictList
  2254. })
  2255. }
  2256. function draw_GeometryMeshPrismEffect(params){
  2257. let geometryType = params.type;
  2258. let status = params.status;
  2259. let startHeight = params.startHeight;
  2260. let items = params.items;
  2261. if(addDrawEvent){
  2262. addDrawEvent.clear();
  2263. addDrawEvent = null;
  2264. }
  2265. if(draw_GeometryMeshPrismEffectEvent){
  2266. draw_GeometryMeshPrismEffectEvent.clear();
  2267. draw_GeometryMeshPrismEffectEvent = null;
  2268. }
  2269. let f_layer = m_map.layers.find(item => item.id === "geometryMeshPrismEffect");
  2270. if (f_layer) {
  2271. m_map.remove(f_layer);
  2272. }
  2273. if(status == "hide"){
  2274. return
  2275. }
  2276. addDrawEvent = new AddDrawEvent({
  2277. view:m_view,
  2278. type:geometryType
  2279. })
  2280. addDrawEvent.start();
  2281. addDrawEvent.createListenerEvent((geometry)=>{
  2282. if(draw_GeometryMeshPrismEffectEvent){
  2283. draw_GeometryMeshPrismEffectEvent.clear();
  2284. draw_GeometryMeshPrismEffectEvent = null;
  2285. }
  2286. draw_GeometryMeshPrismEffectEvent = new GeometryMeshPrismEffect({
  2287. view:m_view,
  2288. m_map,
  2289. items:items,
  2290. startHeight:startHeight,
  2291. rings:geometry.rings
  2292. });
  2293. m_map.add(draw_GeometryMeshPrismEffectEvent.graphicsLayer);
  2294. })
  2295. addDrawEvent.updateListenerEvent((geometry)=>{
  2296. if(draw_GeometryMeshPrismEffectEvent){
  2297. draw_GeometryMeshPrismEffectEvent.clear();
  2298. draw_GeometryMeshPrismEffectEvent = null;
  2299. }
  2300. draw_GeometryMeshPrismEffectEvent = new GeometryMeshPrismEffect({
  2301. view:m_view,
  2302. m_map,
  2303. items:items,
  2304. startHeight:startHeight,
  2305. rings:geometry.rings
  2306. });
  2307. m_map.add(draw_GeometryMeshPrismEffectEvent.graphicsLayer);
  2308. })
  2309. }
  2310. function symbolPathPipe(params){
  2311. let status = params.status;
  2312. let f_layer = m_map.layers.find(item => item.id === "symbolPathPipeEvent");
  2313. if (f_layer) {
  2314. m_map.remove(f_layer);
  2315. }
  2316. if(status === "hide"){
  2317. return
  2318. }
  2319. // params.paths = Path.paths
  2320. symbolPathPipeEvent = new SymbolPathPipeEvent({
  2321. view:m_view,
  2322. paths:params.paths,
  2323. })
  2324. m_map.add(symbolPathPipeEvent.graphicsLayer);
  2325. }
  2326. function symbolPointCube(params){
  2327. let status = params.status;
  2328. let f_layer = m_map.layers.find(item => item.id === "symbolPointCubeEvent");
  2329. if (f_layer) {
  2330. m_map.remove(f_layer);
  2331. }
  2332. if(status === "hide"){
  2333. return
  2334. }
  2335. symbolPointCubeEvent = new SymbolPointCubeEvent({
  2336. view:m_view,
  2337. points:params.points,
  2338. size:params.size,
  2339. })
  2340. m_map.add(symbolPointCubeEvent.graphicsLayer);
  2341. }
  2342. function addGraphics(params){
  2343. let status = params.status;
  2344. let id = params.id;
  2345. if(status === "hide"){
  2346. let idGraphic = m_view.graphics.find(item => item.id === id);
  2347. if(idGraphic){
  2348. m_view.graphics.remove(idGraphic);
  2349. }
  2350. return
  2351. }
  2352. let idGraphic = m_view.graphics.find(item => item.id === id);
  2353. if(idGraphic && JSON.stringify(params.data.geometry) == JSON.stringify(idGraphic.geometry)){
  2354. return
  2355. }else{
  2356. m_view.graphics.remove(idGraphic);
  2357. addGraphicsEvent = new AddGraphicsEvent({
  2358. id,
  2359. view:m_view,
  2360. data:params.data,
  2361. imgType:params.imgType
  2362. })
  2363. }
  2364. }
  2365. function featurePointsPlotting(params){
  2366. let status = params.status;
  2367. let f_layer = m_map.layers.find(item => item.id === "featurePointsPlottingEvent");
  2368. if (f_layer) {
  2369. m_map.remove(f_layer);
  2370. }
  2371. if(status === "hide"){
  2372. return
  2373. }
  2374. //params.data = Path.paths_point;
  2375. featurePointsPlottingEvent = new FeaturePointsPlottingEvent({
  2376. view:m_view,
  2377. data:params.data,
  2378. imgType:params.imgType
  2379. })
  2380. m_map.add(featurePointsPlottingEvent.featureLayer);
  2381. }
  2382. function featurePolygonPlotting(params){
  2383. let status = params.status;
  2384. let id = params.id;
  2385. let p_layer = m_map.layers.find(item => item.id === id+"_polygon");
  2386. if (p_layer) {
  2387. m_map.remove(p_layer);
  2388. }
  2389. let t_layer = m_map.layers.find(item => item.id === id+"_text");
  2390. if (t_layer) {
  2391. m_map.remove(t_layer);
  2392. }
  2393. if(status === "hide"){
  2394. return
  2395. }
  2396. let showText = false;
  2397. if(params.showText){
  2398. showText = params.showText;
  2399. }
  2400. featurePointsPlottingEvent = new FeaturePolygonPlottingEvent({
  2401. id,
  2402. view:m_view,
  2403. data:params.data,
  2404. showText:showText
  2405. });
  2406. }
  2407. function flowPathEffect(params){
  2408. let status = params.status;
  2409. if(addFlowPathEvent){
  2410. addFlowPathEvent.clear();
  2411. addFlowPathEvent = null;
  2412. }
  2413. if(status === "hide"){
  2414. return
  2415. }
  2416. addFlowPathEvent = new AddFlowPathEvent({
  2417. view:m_view,
  2418. paths:params.paths,
  2419. color:params.color,
  2420. pipeRadius:params.pipeRadius
  2421. })
  2422. addFlowPathEvent.start()
  2423. }
  2424. function movePoint(params){
  2425. let status = params.status;
  2426. const connectFlyPointWebSocket = (status) => {
  2427. if(status === "show"){
  2428. if(flyPointSocket){
  2429. flyPointSocket.send(JSON.stringify({
  2430. "flightIdS": ["EFF7AE7B8B044436997F93F327819C20","18207414-c19e-4233-87e2-e6e4743fdea0"],
  2431. "messageCode": 1,
  2432. "isShow": true
  2433. }));
  2434. }else{
  2435. flyPointSocket = new WebSocket('ws://58.34.215.19:8100/flight/data/websocket');
  2436. flyPointSocket.onopen = () => {
  2437. console.log('WebSocket 连接成功');
  2438. };
  2439. flyPointSocket.onmessage = (messageEvent) => {
  2440. showThreeCubeDetail({
  2441. "id":"movePointCube",
  2442. "status":"hide"
  2443. })
  2444. let messages = JSON.parse(messageEvent.data);
  2445. if(movePointEvent){
  2446. movePointEvent.update(messages)
  2447. }else{
  2448. movePointEvent = new MovePointStreamEvent({
  2449. view:m_view,
  2450. map:m_map,
  2451. data:messages
  2452. });
  2453. }
  2454. let data = []
  2455. if(messages.length > 0){
  2456. messages.forEach((item)=>{
  2457. if(item.surroundGrid != null&&item.surroundGrid.length > 0){
  2458. data = data.concat(item.surroundGrid);
  2459. }
  2460. })
  2461. if(data.length > 0){
  2462. showThreeCubeDetail({
  2463. "id":"movePointCube",
  2464. "status":"show",
  2465. "size": {
  2466. x:data[0].boxSize.latLength,
  2467. y:data[0].boxSize.lonLength,
  2468. z:data[0].boxSize.height
  2469. },
  2470. "points":data,
  2471. "depthTest":false
  2472. })
  2473. }
  2474. }
  2475. };
  2476. flyPointSocket.onerror = (error) => {
  2477. console.error('WebSocket 出错:', error);
  2478. };
  2479. flyPointSocket.onclose = () => {
  2480. console.log('WebSocket 连接已关闭');
  2481. };
  2482. }
  2483. }else{
  2484. if(flyPointSocket){
  2485. // if(movePointEvent){
  2486. // movePointEvent.clear();
  2487. // movePointEvent = null;
  2488. // }
  2489. flyPointSocket.close();
  2490. }
  2491. }
  2492. };
  2493. connectFlyPointWebSocket(status);
  2494. }
  2495. //获取当前场景
  2496. function getOccupyCube(params){
  2497. let id = params.id;
  2498. let status = params.status;
  2499. let level = params.level;
  2500. let minZ = params.minZ;
  2501. let maxZ = params.maxZ;
  2502. let rings = params.rings;
  2503. let fields = params.fields;
  2504. let deepShow = params.deepShow;
  2505. if(status === "hide"){
  2506. showThreeCubeDetail({
  2507. id:params.id,
  2508. status:"hide"
  2509. });
  2510. currentShowGridParams = null;
  2511. return
  2512. }
  2513. showThreeCubeDetail({
  2514. id:params.lastId,
  2515. status:"hide"
  2516. });
  2517. currentShowGridParams = {
  2518. id,
  2519. level,
  2520. minZ,
  2521. maxZ,
  2522. rings,
  2523. fields
  2524. };
  2525. getOccupyByPolygon({
  2526. id,
  2527. status,
  2528. minZ,
  2529. maxZ,
  2530. level,
  2531. fields,
  2532. rings,
  2533. deepShow,
  2534. scrollId:""
  2535. });
  2536. }
  2537. // 获取当前场景-递归获取权重数据
  2538. function getOccupyByPolygon(params) {
  2539. getOccupyPointByPolygon({
  2540. minZ:params.minZ,
  2541. maxZ:params.maxZ,
  2542. level: params.level,
  2543. rings: params.rings,
  2544. fields: params.fields,
  2545. scrollId: params.scrollId,
  2546. }).then(res =>{
  2547. if(JSON.stringify(currentShowGridParams) === JSON.stringify({
  2548. id:params.id,
  2549. level:params.level,
  2550. minZ:params.minZ,
  2551. maxZ:params.maxZ,
  2552. rings:params.rings,
  2553. fields:params.fields,
  2554. })){
  2555. if(res.data.data.list?.length >= 100000 && res.data.data.scrollId){
  2556. let size = {
  2557. x:res.data.data.list[0].boxSize.latLength,
  2558. y:res.data.data.list[0].boxSize.lonLength,
  2559. z:res.data.data.list[0].boxSize.height
  2560. }
  2561. showThreeCubeDetail({
  2562. "id":params.id,
  2563. "status":params.status,
  2564. "size":size,
  2565. "points":res.data.data.list,
  2566. "depthTest":params.deepShow?params.deepShow:false
  2567. })
  2568. params.scrollId = res.data.data.scrollId;
  2569. getOccupyByPolygon(params);
  2570. }else{
  2571. if(res.data.data.list?.length > 0){
  2572. let size = {
  2573. x:res.data.data.list[0].boxSize.latLength,
  2574. y:res.data.data.list[0].boxSize.lonLength,
  2575. z:res.data.data.list[0].boxSize.height
  2576. }
  2577. showThreeCubeDetail({
  2578. "id":params.id,
  2579. "status":params.status,
  2580. "size":size,
  2581. "points":res.data.data.list,
  2582. "depthTest":params.deepShow?params.deepShow:false
  2583. })
  2584. }
  2585. }
  2586. }
  2587. })
  2588. }
  2589. //获取当前场景
  2590. function getPowerCube(params){
  2591. let id = params.id;
  2592. let status = params.status;
  2593. let level = params.level;
  2594. let minZ = params.minZ;
  2595. let maxZ = params.maxZ;
  2596. let deepShow = params.deepShow;
  2597. let rings = params.rings;
  2598. let fields = params.fields;
  2599. if(status === "hide"){
  2600. showThreeCubeDetail({
  2601. id:params.id,
  2602. status:"hide"
  2603. });
  2604. currentShowGridParams = null;
  2605. return
  2606. }
  2607. currentShowGridParams = {
  2608. id,
  2609. level,
  2610. minZ,
  2611. maxZ,
  2612. rings,
  2613. fields
  2614. };
  2615. getSixPowerByPolygon({
  2616. id,
  2617. status,
  2618. minZ,
  2619. maxZ,
  2620. level,
  2621. fields,
  2622. rings,
  2623. deepShow,
  2624. scrollId:"",
  2625. });
  2626. }
  2627. // 获取当前场景-递归获取权重数据
  2628. function getSixPowerByPolygon(params) {
  2629. getPowerPointByPolygon({
  2630. minZ:params.minZ,
  2631. maxZ:params.maxZ,
  2632. level: params.level,
  2633. rings: params.rings,
  2634. fields: params.fields,
  2635. scrollId: params.scrollId,
  2636. }).then(res =>{
  2637. if(JSON.stringify(currentShowGridParams) === JSON.stringify({
  2638. id:params.id,
  2639. level:params.level,
  2640. minZ:params.minZ,
  2641. maxZ:params.maxZ,
  2642. rings:params.rings,
  2643. fields:params.fields,
  2644. })){
  2645. if(res.data.data.list?.length >= 100000 && res.data.data.scrollId){
  2646. let size = {
  2647. x:res.data.data.list[0].boxSize.latLength,
  2648. y:res.data.data.list[0].boxSize.lonLength,
  2649. z:res.data.data.list[0].boxSize.height
  2650. }
  2651. showThreeCubeDetail({
  2652. "id":params.id,
  2653. "status":params.status,
  2654. "size":size,
  2655. "points":res.data.data.list,
  2656. "depthTest":params.deepShow?params.deepShow:false
  2657. })
  2658. params.scrollId = res.data.data.scrollId;
  2659. getSixPowerByPolygon(params);
  2660. }else{
  2661. if(res.data.data.list?.length > 0){
  2662. let size = {
  2663. x:res.data.data.list[0].boxSize.latLength,
  2664. y:res.data.data.list[0].boxSize.lonLength,
  2665. z:res.data.data.list[0].boxSize.height
  2666. }
  2667. showThreeCubeDetail({
  2668. "id":params.id,
  2669. "status":params.status,
  2670. "size":size,
  2671. "points":res.data.data.list,
  2672. "depthTest":params.deepShow?params.deepShow:false
  2673. })
  2674. }
  2675. }
  2676. }
  2677. })
  2678. }
  2679. function getFunnelCube(params){
  2680. let id = params.id;
  2681. let lastId = params.lastId;
  2682. let status = params.status;
  2683. let level = params.level;
  2684. let coneHeight = params.coneHeight;
  2685. let cylinderHeight = params.cylinderHeight;
  2686. let topRadius = params.topRadius;
  2687. let bottomRadius = params.bottomRadius;
  2688. let point = params.point;
  2689. if(status === "hide"){
  2690. showThreeCubeDetail({
  2691. id:params.id,
  2692. status:"hide"
  2693. });
  2694. currentShowGridParams = null;
  2695. return
  2696. }
  2697. showThreeCubeDetail({
  2698. id:params.lastId,
  2699. status:"hide"
  2700. });
  2701. currentShowGridParams = id;
  2702. getSixPowerByFunnel({
  2703. id,
  2704. lastId,
  2705. status,
  2706. coneHeight,
  2707. cylinderHeight,
  2708. level,
  2709. topRadius,
  2710. bottomRadius,
  2711. point
  2712. });
  2713. }
  2714. function getSixPowerByFunnel(params){
  2715. getPowerPointByFunnel({
  2716. point:params.point,
  2717. coneHeight:params.coneHeight,
  2718. cylinderHeight:params.cylinderHeight,
  2719. level: params.level,
  2720. topRadius: params.topRadius,
  2721. bottomRadius: params.bottomRadius,
  2722. }).then(res =>{
  2723. let size = {
  2724. x:res.data.data.list[0].boxSize.latLength,
  2725. y:res.data.data.list[0].boxSize.lonLength,
  2726. z:res.data.data.list[0].boxSize.height
  2727. }
  2728. bus.emit('SendMessage',{
  2729. action:"CubeResult",
  2730. data:{
  2731. "message":res.data.data.gridConflict
  2732. }
  2733. })
  2734. showThreeCubeDetail({
  2735. "id":params.id,
  2736. "status":params.status,
  2737. "size":size,
  2738. "points":res.data.data.list,
  2739. "depthTest":false
  2740. })
  2741. })
  2742. }
  2743. function getFrustumConeCube(params){
  2744. let id = params.id;
  2745. let lastId = params.lastId;
  2746. let status = params.status;
  2747. let level = params.level;
  2748. let height = params.height;
  2749. let topRadius = params.topRadius;
  2750. let bottomRadius = params.bottomRadius;
  2751. let point = params.point;
  2752. if(status === "hide"){
  2753. showThreeCubeDetail({
  2754. id:params.id,
  2755. status:"hide"
  2756. });
  2757. currentShowGridParams = null;
  2758. return
  2759. }
  2760. showThreeCubeDetail({
  2761. id:params.lastId,
  2762. status:"hide"
  2763. });
  2764. currentShowGridParams = id;
  2765. getSixPowerByFrustumCone({
  2766. id,
  2767. lastId,
  2768. status,
  2769. height,
  2770. level,
  2771. topRadius,
  2772. bottomRadius,
  2773. point
  2774. });
  2775. }
  2776. function getSixPowerByFrustumCone(params){
  2777. getPowerPointByFrustumCone({
  2778. point:params.point,
  2779. height:params.height,
  2780. level: params.level,
  2781. topRadius: params.topRadius,
  2782. bottomRadius: params.bottomRadius,
  2783. }).then(res =>{
  2784. let size = {
  2785. x:res.data.data.list[0].boxSize.latLength,
  2786. y:res.data.data.list[0].boxSize.lonLength,
  2787. z:res.data.data.list[0].boxSize.height
  2788. }
  2789. bus.emit('SendMessage',{
  2790. action:"CubeResult",
  2791. data:{
  2792. "message":res.data.data.gridConflict
  2793. }
  2794. })
  2795. showThreeCubeDetail({
  2796. "id":params.id,
  2797. "status":params.status,
  2798. "size":size,
  2799. "points":res.data.data.list,
  2800. "depthTest":false
  2801. })
  2802. })
  2803. }
  2804. function getInvertedConeCube(params){
  2805. let id = params.id;
  2806. let lastId = params.lastId;
  2807. let status = params.status;
  2808. let level = params.level;
  2809. let height = params.height;
  2810. let radius = params.radius;
  2811. let point = params.point;
  2812. if(status === "hide"){
  2813. showThreeCubeDetail({
  2814. id:params.id,
  2815. status:"hide"
  2816. });
  2817. currentShowGridParams = null;
  2818. return
  2819. }
  2820. showThreeCubeDetail({
  2821. id:params.lastId,
  2822. status:"hide"
  2823. });
  2824. currentShowGridParams = id;
  2825. getSixPowerByInvertedCone({
  2826. id,
  2827. lastId,
  2828. status,
  2829. height,
  2830. level,
  2831. radius,
  2832. point
  2833. });
  2834. }
  2835. function getSixPowerByInvertedCone(params){
  2836. getPowerPointByInvertedCone({
  2837. point:params.point,
  2838. height:params.height,
  2839. level: params.level,
  2840. radius: params.radius,
  2841. }).then(res =>{
  2842. let size = {
  2843. x:res.data.data.list[0].boxSize.latLength,
  2844. y:res.data.data.list[0].boxSize.lonLength,
  2845. z:res.data.data.list[0].boxSize.height
  2846. }
  2847. bus.emit('SendMessage',{
  2848. action:"CubeResult",
  2849. data:{
  2850. "message":res.data.data.gridConflict
  2851. }
  2852. })
  2853. showThreeCubeDetail({
  2854. "id":params.id,
  2855. "status":params.status,
  2856. "size":size,
  2857. "points":res.data.data.list,
  2858. "depthTest":false
  2859. })
  2860. })
  2861. }
  2862. //查询圆柱体
  2863. function getCylinderCube(params){
  2864. let id = params.id;
  2865. let lastId = params.lastId;
  2866. let status = params.status;
  2867. let level = params.level;
  2868. let height = params.height;
  2869. let rings = params.rings;
  2870. if(status === "hide"){
  2871. showThreeCubeDetail({
  2872. id:params.id,
  2873. status:"hide"
  2874. });
  2875. currentShowGridParams = null;
  2876. return
  2877. }
  2878. showThreeCubeDetail({
  2879. id:params.lastId,
  2880. status:"hide"
  2881. });
  2882. currentShowGridParams = id;
  2883. getSixPowerByPrism({
  2884. id,
  2885. lastId,
  2886. status,
  2887. height,
  2888. level,
  2889. rings
  2890. });
  2891. }
  2892. //查询长方体
  2893. function getCuboidCube(params){
  2894. let id = params.id;
  2895. let lastId = params.lastId;
  2896. let status = params.status;
  2897. let level = params.level;
  2898. let height = params.height;
  2899. let rings = params.rings;
  2900. if(status === "hide"){
  2901. showThreeCubeDetail({
  2902. id:params.id,
  2903. status:"hide"
  2904. });
  2905. currentShowGridParams = null;
  2906. return
  2907. }
  2908. showThreeCubeDetail({
  2909. id:params.lastId,
  2910. status:"hide"
  2911. });
  2912. currentShowGridParams = id;
  2913. getSixPowerByPrism({
  2914. id,
  2915. lastId,
  2916. status,
  2917. height,
  2918. level,
  2919. rings
  2920. });
  2921. }
  2922. //查询棱柱体
  2923. function getPrismCube(params){
  2924. let id = params.id;
  2925. let lastId = params.lastId;
  2926. let status = params.status;
  2927. let level = params.level;
  2928. let height = params.height;
  2929. let rings = params.rings;
  2930. if(status === "hide"){
  2931. showThreeCubeDetail({
  2932. id:params.id,
  2933. status:"hide"
  2934. });
  2935. currentShowGridParams = null;
  2936. return
  2937. }
  2938. showThreeCubeDetail({
  2939. id:params.lastId,
  2940. status:"hide"
  2941. });
  2942. currentShowGridParams = id;
  2943. getSixPowerByPrism({
  2944. id,
  2945. lastId,
  2946. status,
  2947. height,
  2948. level,
  2949. rings
  2950. });
  2951. }
  2952. function getSixPowerByPrism(params){
  2953. getPowerPointByPrism({
  2954. rings:params.rings,
  2955. height:params.height,
  2956. level: params.level
  2957. }).then(res =>{
  2958. let size = {
  2959. x:res.data.data.list[0].boxSize.latLength,
  2960. y:res.data.data.list[0].boxSize.lonLength,
  2961. z:res.data.data.list[0].boxSize.height
  2962. }
  2963. debugger
  2964. bus.emit('SendMessage',{
  2965. action:"CubeResult",
  2966. data:{
  2967. "message":res.data.data.gridConflict
  2968. }
  2969. })
  2970. showThreeCubeDetail({
  2971. "id":params.id,
  2972. "status":params.status,
  2973. "size":size,
  2974. "points":res.data.data.list,
  2975. "depthTest":false
  2976. })
  2977. })
  2978. }
  2979. //查询航线
  2980. function getPathCube(params){
  2981. let id = params.id;
  2982. let lastId = params.lastId;
  2983. let status = params.status;
  2984. let level = params.level;
  2985. let radius = params.radius;
  2986. let originPaths = params.paths;
  2987. if(status === "hide"){
  2988. showThreeCubeDetail({
  2989. id:params.id,
  2990. status:"hide"
  2991. });
  2992. currentShowGridParams = null;
  2993. return
  2994. }
  2995. let paths = [];
  2996. originPaths[0].forEach((item)=>{
  2997. paths.push({
  2998. x:item[0],
  2999. y:item[1],
  3000. z:item[2]
  3001. })
  3002. })
  3003. showThreeCubeDetail({
  3004. id:params.lastId,
  3005. status:"hide"
  3006. });
  3007. currentShowGridParams = id;
  3008. getSixPowerByPath({
  3009. id,
  3010. lastId,
  3011. status,
  3012. radius,
  3013. level,
  3014. paths
  3015. });
  3016. }
  3017. function getSixPowerByPath(params){
  3018. getPowerPointByPath({
  3019. paths:params.paths,
  3020. radius:params.radius,
  3021. level: params.level
  3022. }).then(res =>{
  3023. let size = {
  3024. x:res.data.data.list[0].boxSize.latLength,
  3025. y:res.data.data.list[0].boxSize.lonLength,
  3026. z:res.data.data.list[0].boxSize.height
  3027. }
  3028. bus.emit('SendMessage',{
  3029. action:"CubeResult",
  3030. data:{
  3031. "message":res.data.data.gridConflict
  3032. }
  3033. })
  3034. showThreeCubeDetail({
  3035. "id":params.id,
  3036. "status":params.status,
  3037. "size":size,
  3038. "points":res.data.data.list,
  3039. "depthTest":false
  3040. })
  3041. })
  3042. }
  3043. function getBasePrism(params){
  3044. getPrism({
  3045. paths:params.paths,
  3046. radius:params.radius,
  3047. level: params.level
  3048. }).then(res =>{
  3049. let data = res.data.data;
  3050. let showData = [];
  3051. data.forEach((item)=>{
  3052. let newShape = JSON.parse(item.shape);
  3053. newShape.color = "red"
  3054. showData.push({
  3055. type:item.geoType,
  3056. shape: newShape
  3057. })
  3058. })
  3059. geometryMeshEffect({
  3060. "status": "show",
  3061. "id": "drawOne",
  3062. "data": showData
  3063. })
  3064. })
  3065. }
  3066. function getBasePath(params){
  3067. getPath({
  3068. paths:params.paths,
  3069. radius:params.radius,
  3070. level: params.level
  3071. }).then(res =>{
  3072. let data = res.data.data;
  3073. let showData = [];
  3074. data.forEach((item)=>{
  3075. let newShape = JSON.parse(item.shape);
  3076. newShape.color = "green"
  3077. showData.push({
  3078. type:"polyline",
  3079. shape: newShape
  3080. })
  3081. })
  3082. geometryMeshEffect({
  3083. "status": "show",
  3084. "id": "drawOne",
  3085. "data": showData
  3086. })
  3087. })
  3088. }
  3089. function getBaseQJC(params){
  3090. getQJC({
  3091. paths:params.paths,
  3092. radius:params.radius,
  3093. level: params.level
  3094. }).then(res =>{
  3095. let data = res.data.data;
  3096. let showData = [];
  3097. data.forEach((item)=>{
  3098. let newShape = JSON.parse(item.shape);
  3099. newShape.color = "green"
  3100. showData.push({
  3101. type:item.geoType,
  3102. shape: newShape
  3103. })
  3104. })
  3105. geometryMeshEffect({
  3106. "status": "show",
  3107. "id": "drawOne",
  3108. "data": showData
  3109. })
  3110. })
  3111. }
  3112. })
  3113. }
  3114. }
  3115. </script>
  3116. <style scoped lang="scss">
  3117. #map_jk,#mapDiv,#viewDiv{
  3118. height: 100%;
  3119. }
  3120. :deep(.esri-view-surface--touch-none::after){
  3121. outline: none !important;
  3122. }
  3123. </style>