LayerManage.vue 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674
  1. <template>
  2. <div>
  3. <layer-manage-split
  4. :addlayerdata="addlayerdata"
  5. @visibleChange="visibleChange"
  6. @transSliderChange="transSliderChange"
  7. @handleCheckChange="handleCheckChange"
  8. @location="location"
  9. @raise="raise"
  10. @lower="lower"
  11. ></layer-manage-split>
  12. <LayerLegend></LayerLegend>
  13. </div>
  14. </template>
  15. <script>
  16. import { Collect, GetResourceTree, GetMyCollect } from "@/api/map";
  17. import LayerLegend from "./LayerLegend.vue";
  18. import xml2js from "xml2js";
  19. let geoLayers = [];
  20. export default {
  21. name: "LayerManage",
  22. components: { LayerLegend },
  23. data() {
  24. return {
  25. modellayerlist: [],
  26. vectorlayerlist: [],
  27. username: "admin",
  28. // treeSearchText: "",
  29. addlayerdata: [],
  30. sceneLayers: {},
  31. // favoriteLayerList: [],
  32. sharedState: store.state,
  33. // flag: false,
  34. // s3mLen: 0,
  35. // hid: true,
  36. layerparams: {},
  37. // ImgHid: false, //影响图层移动默认不显示
  38. // S3MLayersObj: {
  39. // title: Resource.s3mLayer,
  40. // expand: true,
  41. // checked: true,
  42. // type: "S3M",
  43. // children: [],
  44. // },
  45. // imgLayersObj: {
  46. // title: Resource.imageryLayer,
  47. // expand: true,
  48. // checked: true,
  49. // type: "IMG",
  50. // children: [],
  51. // },
  52. // TerrainLayersObj: {
  53. // title: Resource.terrainLayer,
  54. // expand: true,
  55. // checked: true,
  56. // type: "TERRAIN",
  57. // children: [],
  58. // },
  59. contextData: null,
  60. S3MList: [],
  61. };
  62. },
  63. computed: {
  64. imgLayers: function () {
  65. return this.sharedState.imgLayerManage;
  66. },
  67. terrainLayers: function () {
  68. return this.sharedState.terrainLayerManage;
  69. },
  70. S3MLayers: function () {
  71. return this.sharedState.S3MLayerManage;
  72. },
  73. },
  74. methods: {
  75. toggleVisibility() {
  76. store.setToolBarAction(0);
  77. },
  78. filterNode(value, data) {
  79. if (!value) return true;
  80. return data.label.indexOf(value) !== -1;
  81. },
  82. favorite(data) {
  83. console.log(data);
  84. },
  85. visibleChange(obj, visible, a) {
  86. console.log(obj, visible, a);
  87. switch (obj.type) {
  88. case "S3M": //场景
  89. if (this.sceneLayers[obj.title]) {
  90. for (let i = 0; i < this.sceneLayers[obj.title][0].length; i++) {
  91. this.sceneLayers[obj.title][0][i].visible = visible;
  92. }
  93. }
  94. break;
  95. case "3DTiles": //场景
  96. if (this.sceneLayers[obj.title]) {
  97. this.sceneLayers[obj.title].show = visible;
  98. }
  99. break;
  100. case "S3MDATA": //scp
  101. if (this.sceneLayers[obj.title]) {
  102. this.sceneLayers[obj.title][0][0].visible = visible;
  103. }
  104. break;
  105. case "wms":
  106. case "wmts":
  107. case "IMG": //影像
  108. this.layerparams[obj.id].show = visible;
  109. break;
  110. case "Vector": //矢量
  111. this.layerparams[obj.id].show = visible;
  112. break;
  113. case "Terrain": //地形
  114. if (visible) {
  115. viewer.terrainProvider = new Cesium.CesiumTerrainProvider({
  116. url: obj.url,
  117. isSct: true,
  118. requestVertexNormals: true,
  119. });
  120. } else {
  121. viewer.scene.terrainProvider = new Cesium.EllipsoidTerrainProvider(
  122. {}
  123. );
  124. }
  125. break;
  126. default:
  127. null;
  128. }
  129. },
  130. transSliderChange(obj, v, a) {
  131. if (typeof v == undefined) {
  132. return;
  133. }
  134. let value = v / 100;
  135. let imageryLayers = viewer.imageryLayers;
  136. switch (obj.type) {
  137. case "S3M": //场景
  138. if (this.sceneLayers[obj.title]) {
  139. this.sceneLayers[obj.title][0][0].style3D.fillForeColor =
  140. new Cesium.Color(1.0, 1.0, 1.0, value);
  141. }
  142. break;
  143. case "S3MDATA": //scp
  144. if (this.sceneLayers[obj.title]) {
  145. this.sceneLayers[obj.title][0][0].style3D.fillForeColor =
  146. new Cesium.Color(1.0, 1.0, 1.0, value);
  147. }
  148. break;
  149. case "3DTiles": //tileset
  150. if (this.sceneLayers[obj.title]) {
  151. this.sceneLayers[obj.title].style = new Cesium.Cesium3DTileStyle({
  152. color: "color('rgba(255,255,255," + value + ")')",
  153. });
  154. }
  155. break;
  156. case "wms":
  157. case "wmts":
  158. case "IMG": //影像
  159. case "Vector": //矢量
  160. this.layerparams[obj.id].alpha = value;
  161. // for (let i = 0; i < imageryLayers._layers.length; i++) {
  162. // let element = imageryLayers._layers[i];
  163. // if (element._imageryProvider._name == obj.title) {
  164. // element.alpha = value;
  165. // break;
  166. // }
  167. // }
  168. break;
  169. case "Terrain": //地形
  170. break;
  171. default:
  172. null;
  173. }
  174. },
  175. addS3M(LayerURL) {
  176. let promiseArray = [];
  177. promiseArray.push(viewer.scene.addS3MTilesLayerByScp(LayerURL));
  178. this.promiseWhen(promiseArray, true);
  179. },
  180. addTerrain(LayerURL) {
  181. viewer.terrainProvider = new Cesium.CesiumTerrainProvider({
  182. url: LayerURL,
  183. isSct: true,
  184. requestVertexNormals: true,
  185. });
  186. this.bus.$emit("setDepthAgainst", true);
  187. },
  188. add3DTiles(obj) {
  189. let tileset = new Cesium.Cesium3DTileset({
  190. url: obj.url + "?id=" + obj.id,
  191. skipLevelOfDetail: true,
  192. });
  193. this.sceneLayers[obj.title] = tileset;
  194. store.setSceneLayersList(this.sceneLayers);
  195. let thisLayer = viewer.scene.primitives.add(tileset);
  196. // viewer.flyTo(thisLayer);
  197. },
  198. addImage(LayerURL) {
  199. var layer = viewer.imageryLayers.addImageryProvider(
  200. new Cesium.SuperMapImageryProvider({
  201. url: LayerURL,
  202. })
  203. );
  204. viewer.flyTo(layer);
  205. },
  206. addWMS(obj) {
  207. let layer = viewer.imageryLayers.addImageryProvider(
  208. new Cesium.WebMapServiceImageryProvider({
  209. url: obj.url,
  210. layers: `${obj.fwgzkj}:${obj.fwmc}`, //"demo:Ahtq_czkfbj",
  211. parameters: {
  212. service: obj.type, //"WMS",
  213. format: obj.format,
  214. transparent: true,
  215. // srs: "EPSG:4326", // 坐标参考系统,可以根据需要更改
  216. },
  217. })
  218. );
  219. return layer;
  220. },
  221. addWMTS(obj) {
  222. return viewer.imageryLayers.addImageryProvider(
  223. new Cesium.WebMapTileServiceImageryProvider({
  224. url: obj.url, //'http://192.168.60.52:28085/geoserver/gwc/service/wmts';
  225. layer: `${obj.fwgzkj}:${obj.fwmc}`, //"demo:yzq_czkfbj"
  226. style: "", // 替换为你的WMTS图层风格
  227. tileMatrixSetID: obj.qpfa, // 或者其他的EPSG代码
  228. format: obj.format,
  229. tilingScheme: new Cesium.WebMercatorTilingScheme(), // 当想要加载EPSG:4326瓦片服务时,只需要创建一个GeographicTilingScheme对象即可
  230. maximumLevel: obj.maximumlevel,
  231. minimumlevel: obj.minimumlevel,
  232. })
  233. );
  234. },
  235. addArcGis(obj) {
  236. let layer = viewer.imageryLayers.addImageryProvider(
  237. new Cesium.ArcGisMapServerImageryProvider({
  238. url: "http://192.168.60.20:6080/arcgis/rest/services/150500/DLTB00_2019/MapServer?f=jsapi",
  239. })
  240. );
  241. viewer.flyTo(layer);
  242. },
  243. promiseWhen(promiseArray, sceneName, obj) {
  244. let this_ = this;
  245. Cesium.when.all(
  246. promiseArray,
  247. (layers) => {
  248. console.log(layers, "layerslayers");
  249. this_.sceneLayers[obj.title] = layers;
  250. // if (sceneName) {
  251. // this.flyTo(sceneName);
  252. // }
  253. if (obj.url.indexOf("3D-HeBing8HaoLou") > 0) {
  254. store.setLayerList(layers[0][0]);
  255. layers[0][0].setQueryParameter({
  256. url: "https://www.supermapol.com/realspace/services/data-HeBing8HaoLou/rest/data",
  257. dataSourceName: "Model_8_old",
  258. dataSetName: "属性表",
  259. keyWord: "SmID",
  260. });
  261. } else if (obj.title == "分层分户_白膜") {
  262. store.setLayerList(layers[0][0]);
  263. }
  264. // store.state.S3MList.push(layers[0]);
  265. store.state.tempLatData = layers;
  266. layers[0].forEach((item) => {
  267. item.RGBTOBGR = true;
  268. if (obj.title == "倾斜摄影") {
  269. let style = new Cesium.Style3D();
  270. style.bottomAltitude = window.modelBottomAltitude; //底部高度
  271. item.style3D = style;
  272. item.brightness = 1.2;
  273. item.contrast = 1.2;
  274. item.saturation = 1.2;
  275. item.gamma = 1.1;
  276. }
  277. if (
  278. item.name.indexOf("雨水") > -1 ||
  279. item.name.indexOf("管线") > -1
  280. ) {
  281. item._baseUri.query = obj.id;
  282. }
  283. });
  284. // store.state.tempLatData = layers[0];
  285. store.setSceneLayersList(this_.sceneLayers);
  286. // for (var i = 0; i < layers.length; i++) {
  287. // let style = new Cesium.Style3D();
  288. // style.bottomAltitude = window.modelBottomAltitude; //底部高度
  289. // if (layers[i].length > 0) {
  290. // for (var j = 0; j < layers[i].length; j++) {
  291. // layers[i][j].style3D = style;
  292. // layers[i][j].refresh();
  293. // layers[i][j].isOverlapDisplayed = true; //开启避让
  294. // }
  295. // } else {
  296. // layers[i].style3D = style;
  297. // layers[i].refresh();
  298. // layers[i].isOverlapDisplayed = true; //开启避让
  299. // }
  300. // }
  301. },
  302. function (e) {
  303. if (widget._showRenderLoopErrors) {
  304. let title = Resource.scpUrlErrorMsg;
  305. widget.showErrorPanel(title, undefined, e);
  306. }
  307. }
  308. );
  309. },
  310. handleSelectChange(selectedList, obj) {
  311. obj ? (obj.expand = !obj.expand) : null;
  312. },
  313. // 复选框改变
  314. handleCheckChange(obj, checked) {
  315. // console.log(obj, checked ,);
  316. if (obj.children && obj.children.length > 0) {
  317. for (let i = 0; i < obj.children.length; i++) {
  318. this.handleCheckChange(obj.children[i], checked);
  319. }
  320. } else {
  321. this.checkedChange(obj);
  322. if (checked) store.setCheckedData(obj);
  323. }
  324. store.setVectorLayerList(this.vectorlayerlist);
  325. store.setModelLayerList(this.modellayerlist);
  326. },
  327. //type roller 卷帘 split分屏splitId
  328. checkedChange(obj, type, splitId) {
  329. let imageryLayers = viewer.imageryLayers;
  330. if (obj.checked) {
  331. obj.trans = 100;
  332. obj.visible = true;
  333. this.addlayerdata.unshift(obj); //将最新添加的对象放到第一位
  334. if (obj.serverType == "geoserver") {
  335. switch (obj.type) {
  336. case "wms":
  337. this.vectorlayerlist.push(obj);
  338. this.layerparams[obj.id] = this.addWMS(obj);
  339. store.setlayerparamsList(this.layerparams);
  340. break;
  341. case "wmts":
  342. this.vectorlayerlist.push(obj);
  343. this.layerparams[obj.id] = this.addWMTS(obj);
  344. store.setlayerparamsList(this.layerparams);
  345. break;
  346. }
  347. } else if (obj.serverType == "arcgis") {
  348. } else {
  349. switch (obj.type) {
  350. case "S3M": //场景
  351. let s = viewer.scene.open(obj.url, undefined, {
  352. autoSetView: false, // obj.title != "倾斜摄影",
  353. });
  354. this.vectorlayerlist.push(obj);
  355. this.promiseWhen([s], undefined, obj);
  356. this.bus.$emit("setDepthAgainst", true);
  357. if (
  358. obj.title.indexOf("雨水") > -1 ||
  359. obj.title.indexOf("管线") > -1
  360. ) {
  361. console.log(obj.checked, "obj.checked");
  362. this.bus.$emit("setnUderground", obj.checked);
  363. }
  364. // store.setModelLayerList(this.vectorlayerlist);
  365. // console.log(store.state.modellayerlist,'vvvvv');
  366. // store.state.S3MList.push(obj)
  367. break;
  368. case "S3MDATA": //scp
  369. viewer.scene.addS3MTilesLayerByScp(obj.url, {
  370. name: obj.title,
  371. });
  372. break;
  373. case "3DTiles": //tileset
  374. this.add3DTiles(obj);
  375. this.vectorlayerlist.push(obj);
  376. break;
  377. case "IMG": //影像
  378. let layer = viewer.imageryLayers.addImageryProvider(
  379. new Cesium.SuperMapImageryProvider({
  380. url: obj.url,
  381. name: obj.title,
  382. })
  383. );
  384. this.layerparams[obj.id] = layer;
  385. store.setlayerparamsList(this.layerparams);
  386. if (type == "roller")
  387. this.bus.$emit("setImageryRoller", layer, splitId);
  388. // viewer.flyTo(layer);
  389. break;
  390. case "Vector": //矢量
  391. // let provider = new Cesium.SuperMapImageryProvider({
  392. // url: obj.url,
  393. // name: obj.title,
  394. // })
  395. // let layer2 = viewer.imageryLayers.addImageryProvider(
  396. // provider
  397. // );
  398. // var params = [{
  399. // layerName: 'YJJBNTBHTB@YJJBNTBH',
  400. // isVisible: true,
  401. // displayFilter: "xzqdm='460205000003'"
  402. // }
  403. // ]
  404. // provider.setLayerStatusParameters(params)
  405. // let layer2 = viewer.imageryLayers.addImageryProvider(
  406. // new Cesium.SuperMapImageryProvider({
  407. // url: obj.url,
  408. // name: obj.title,
  409. // })
  410. // );
  411. // var provider = new Cesium.SuperMapImageryProvider({ url: 'http://192.168.60.3:8099/iserver/services/map-GuiHuaDiKuai/rest/maps/GHDK%40%E8%A7%84%E5%88%92%E5%9C%B0%E5%9D%97' });
  412. // var layer2 = viewer.imageryLayers.addImageryProvider(provider);
  413. // var params = [
  414. // {
  415. // layerName: 'GHDK@规划地块',
  416. // isVisible: true,
  417. // displayFilter: "XZQDM LIKE '460203%' and PFSJ < '20190808'"
  418. // }
  419. // ]
  420. // provider.setLayerStatusParameters(params)
  421. let layer2 = viewer.imageryLayers.addImageryProvider(
  422. new Cesium.SuperMapImageryProvider({
  423. url: obj.url,
  424. name: obj.title,
  425. })
  426. );
  427. this.vectorlayerlist.push(obj);
  428. this.layerparams[obj.id] = layer2;
  429. store.setlayerparamsList(this.layerparams);
  430. if (type == "roller")
  431. this.bus.$emit("setImageryRoller", layer2, splitId);
  432. // viewer.flyTo(layer2);
  433. break;
  434. case "Terrain": //地形
  435. this.addTerrain(obj.url);
  436. break;
  437. default:
  438. null;
  439. }
  440. }
  441. if (type == "split") {
  442. this.bus.$emit("setImagerySplit", obj, obj.checked, splitId, true);
  443. } else if (type == "share") {
  444. this.bus.$emit("setShareResources", obj, obj.checked, -2, true);
  445. }
  446. } else {
  447. if (obj.title.indexOf("雨水") > -1 || obj.title.indexOf("管线") > -1) {
  448. console.log(obj.checked, "obj.checked");
  449. this.bus.$emit("setnUderground", obj.checked);
  450. }
  451. for (let i = 0; i < this.addlayerdata.length; i++) {
  452. if (this.addlayerdata[i].title == obj.title) {
  453. this.addlayerdata.splice(i, 1);
  454. break;
  455. }
  456. }
  457. for (let i = 0; i < this.vectorlayerlist.length; i++) {
  458. if (this.vectorlayerlist[i].title == obj.title) {
  459. this.vectorlayerlist.splice(i, 1);
  460. break;
  461. }
  462. }
  463. for (let i = 0; i < this.modellayerlist.length; i++) {
  464. if (this.modellayerlist[i].title == obj.title) {
  465. this.modellayerlist.splice(i, 1);
  466. break;
  467. }
  468. }
  469. switch (obj.type) {
  470. case "S3M": //场景
  471. if (this.sceneLayers[obj.title]) {
  472. for (let i = 0; i < this.sceneLayers[obj.title].length; i++) {
  473. if (this.sceneLayers[obj.title][i].length > 0) {
  474. for (
  475. let u = 0;
  476. u < this.sceneLayers[obj.title][i].length;
  477. u++
  478. ) {
  479. viewer.scene.layers.remove(
  480. this.sceneLayers[obj.title][i][u]._name
  481. );
  482. }
  483. } else {
  484. viewer.scene.layers.remove(
  485. this.sceneLayers[obj.title][i]._name
  486. );
  487. }
  488. }
  489. }
  490. break;
  491. case "S3MDATA": //scp
  492. viewer.scene.layers.remove(obj.title);
  493. break;
  494. case "3DTiles": //tileset
  495. viewer.scene.primitives.remove(this.sceneLayers[obj.title]);
  496. break;
  497. case "wms":
  498. case "wmts":
  499. case "IMG": //影像
  500. case "Vector": //矢量
  501. imageryLayers.remove(this.layerparams[obj.id]);
  502. delete this.layerparams[obj.id];
  503. // for (let i = 0; i < imageryLayers._layers.length; i++) {
  504. // let element = imageryLayers._layers[i];
  505. // if (element._imageryProvider._name == obj.title) {
  506. // imageryLayers.remove(element);
  507. // break;
  508. // }
  509. // }
  510. break;
  511. case "Terrain": //地形
  512. viewer.scene.terrainProvider = new Cesium.EllipsoidTerrainProvider(
  513. {}
  514. );
  515. break;
  516. default:
  517. null;
  518. }
  519. }
  520. },
  521. async getPos() {
  522. let url = "http://192.168.60.52:28085/geoserver/wms";
  523. let params = {
  524. service: "WMS",
  525. version: "1.1.1",
  526. request: "GetCapabilities",
  527. };
  528. let res = await axios.get(url, { params });
  529. new xml2js.Parser().parseString(res.data, (err, result) => {
  530. geoLayers = result.WMT_MS_Capabilities.Capability[0].Layer[0].Layer;
  531. });
  532. },
  533. async flyTogeo(obj) {
  534. if (geoLayers) await this.getPos();
  535. let ser = geoLayers.find((li) => li.Title.indexOf(obj.fwmc) >= 0);
  536. if (ser) {
  537. let pos = ser.LatLonBoundingBox[0]["$"];
  538. viewer.camera.flyTo({
  539. destination: Cesium.Rectangle.fromDegrees(
  540. pos.minx,
  541. pos.miny,
  542. pos.maxx,
  543. pos.maxy
  544. ),
  545. });
  546. }
  547. },
  548. //图层定位
  549. location(obj) {
  550. let imageryLayers = viewer.imageryLayers;
  551. if (obj.serverType == "geoserver") {
  552. switch (obj.type) {
  553. case "wms":
  554. case "wmts":
  555. // console.log("11", this.layerparams[obj.id]);
  556. this.flyTogeo(obj);
  557. break;
  558. }
  559. } else if (obj.serverType == "arcgis") {
  560. } else {
  561. switch (obj.type) {
  562. case "S3M": //场景
  563. if (this.sceneLayers[obj.title]) {
  564. viewer.flyTo(this.sceneLayers[obj.title][0][0]);
  565. }
  566. break;
  567. case "S3MDATA": //scp
  568. viewer.flyTo(this.sceneLayers[obj.title][0][0]);
  569. break;
  570. case "3DTiles": //tileset
  571. viewer.flyTo(this.sceneLayers[obj.title]);
  572. break;
  573. case "IMG": //影像
  574. case "Vector": //矢量
  575. viewer.flyTo(this.layerparams[obj.id]);
  576. // for (let i = 0; i < imageryLayers._layers.length; i++) {
  577. // let element = imageryLayers._layers[i];
  578. // if (element._imageryProvider._name == obj.title) {
  579. // viewer.flyTo(element);
  580. // break;
  581. // }
  582. // }
  583. break;
  584. case "Terrain": //地形
  585. viewer.scene.terrainProvider = new Cesium.EllipsoidTerrainProvider(
  586. {}
  587. );
  588. break;
  589. default:
  590. null;
  591. }
  592. }
  593. },
  594. //影像图层操作
  595. raise(obj) {
  596. viewer.imageryLayers.raise(this.layerparams[obj.id]);
  597. for (let i = 0; i < this.addlayerdata.length; i++) {
  598. if (this.addlayerdata[i].title == obj.title) {
  599. let arr = Array.from(this.addlayerdata);
  600. this.addlayerdata = [];
  601. this.addlayerdata = this.moveUp(arr, i);
  602. break;
  603. }
  604. }
  605. },
  606. lower(obj) {
  607. viewer.imageryLayers.lower(this.layerparams[obj.id]);
  608. for (let i = 0; i < this.addlayerdata.length; i++) {
  609. if (this.addlayerdata[i].title == obj.title) {
  610. let arr = Array.from(this.addlayerdata);
  611. this.addlayerdata = [];
  612. this.addlayerdata = this.moveDown(arr, i);
  613. break;
  614. }
  615. }
  616. },
  617. raiseToTop() {
  618. let imageryLayers = viewer.imageryLayers._layers;
  619. let ly = imageryLayers[this.contextData.id];
  620. viewer.imageryLayers.raiseToTop(ly);
  621. this.updataImgLayers();
  622. },
  623. lowerToBottom() {
  624. let imageryLayers = viewer.imageryLayers._layers;
  625. let ly = imageryLayers[this.contextData.id];
  626. viewer.imageryLayers.lowerToBottom(ly);
  627. this.updataImgLayers();
  628. },
  629. // 上移操作
  630. moveUp(array, index) {
  631. if (index > 0 && index < array.length) {
  632. let temp = array[index];
  633. array[index] = array[index - 1];
  634. array[index - 1] = temp;
  635. }
  636. return array;
  637. },
  638. // 下移操作
  639. moveDown(array, index) {
  640. if (index >= 0 && index < array.length - 1) {
  641. let temp = array[index];
  642. array[index] = array[index + 1];
  643. array[index + 1] = temp;
  644. }
  645. return array;
  646. },
  647. },
  648. mounted() {
  649. this.bus.$on("checkedChange", this.checkedChange);
  650. },
  651. watch: {},
  652. };
  653. </script>
  654. <style lang="scss">
  655. @import "./LayerManage.scss";
  656. </style>