摘要:根據(jù)不同的市政建設(shè),管網(wǎng)分供水排污供暖通信電力等多種類別,其廣泛分布遍及地下。隨著城市發(fā)展建設(shè)所衍生出空間分布復(fù)雜,變化大,種類繁多等問題,可視化管理是未來發(fā)展最好的解決方案。
前言
城市管網(wǎng)是城市最重要的公共基礎(chǔ)設(shè)施之一,與城市的發(fā)展和居民日常生活息息相關(guān)。根據(jù)不同的市政建設(shè),管網(wǎng)分供水、排污、供暖、通信、電力等多種類別,其廣泛分布遍及地下。隨著城市發(fā)展建設(shè)所衍生出空間分布復(fù)雜,變化大,種類繁多等問題,可視化管理是未來發(fā)展最好的解決方案。
Demo預(yù)覽
實現(xiàn)
第一步,加載場景
//加載場景代碼 var app = new THING.App({ // 場景地址 "url": "http://www.thingjs.com/./uploads/wechat/S2Vyd2lu/scene/Demo_地下管線", //背景設(shè)置 "skyBox": "BlueSky" });
第二步,創(chuàng)建管線以及創(chuàng)建管線信息面板。這里PolygonLine這種類型我們在之前的Demo中使用過沒看過的同學(xué)可以點進去看一下,當然那篇比較糙還是沒有這篇好看的,可以兩篇對比一下效果,文章地址。這里這個renderOrder屬性劃重點,這里將line的visible屬性設(shè)置為false,當場景加載完成后我們的管線就已經(jīng)創(chuàng)建好了為了能更好的配合我們的面板所以給他先隱藏掉了,等到開關(guān)觸發(fā)再對他進行展示。
function createLine(name, color, points) { var line = null; line = app.create({ type: "PolygonLine", name: name, points: points, style: { color: color, }, }); line.renderOrder = -10000; line.scrollUV = true; line.visible = false; return line; } function createInfo(obj, position) { var panel = new THING.widget.Panel({ template: "default2", width: "120px", cornerType: "polyline" }) var dataObj = { name: obj.name, color: obj.style.color } panel.addString(dataObj, "name").caption("名稱"); panel.addString(dataObj, "color").caption("顏色"); var uiAnchor = app.create({ type: "UIAnchor", parent: obj, element: panel.domElement, position: [position[0], -1, position[2]], pivot: [-0.2, 2.1] }); return uiAnchor; }
第三步,創(chuàng)建功能面板以及創(chuàng)建各種類管線。
//管線的模擬數(shù)據(jù) var dataJson = [{ "id": "BJ002", "starId": "2TAG001", "stopId": "2TAG002", "starDeep": "-1.5", "stopDeep": "-1.5", "material": "ASTNX01", "pressure": "120" }, { "id": "BJ002", "starId": "2TAG001", "stopId": "2TAG002", "starDeep": "-1.5", "stopDeep": "-1.5", "material": "ASTNX01", "pressure": "120" }, { "id": "BJ002", "starId": "2TAG001", "stopId": "2TAG002", "starDeep": "-1.5", "stopDeep": "-1.5", "material": "ASTNX01", "pressure": "120" }];
app.on("load", function () { // init_camera app.camera.flyTo({ "position": [-6.199233956799988, 49.47465259648085, 113.74453304853118], "target": [-4.002967317456267, 26.055382001258867, 37.65111202780902], "time": 2000, }); //創(chuàng)建場景 var controlPanel = new THING.widget.Panel({ titleText: "地下管線Demo", hasTitle: true, // 是否有標題 zIndex: 999, // 設(shè)置層級 }); var data = { totalOpen: false, viewOpen: false, waterOpen: false, blowOffOpen: false, heatOpen: false }; //openTotal按鈕控制 var totalOpen = controlPanel.addBoolean(data, "totalOpen").caption("狀態(tài)切換"); totalOpen.on("change", function (ev) { if (ev) { //將campus下所有的obj的opacity = 0.4,將name = Uncorrelated 的obj的visiable = false app.query("Campus")[0].style.opacity = 0.3; app.query("Uncorrelated")[0].visible = false; } else { //反之初始化 app.query("Campus")[0].style.opacity = 1; app.query("Uncorrelated")[0].visible = true; } }); //viewOpen視角控制 var viewOpen = controlPanel.addBoolean(data, "viewOpen").caption("2D/3D"); viewOpen.on("change", function (ev) { if (ev) { app.camera.viewMode = THING.CameraView.TopView; } else { app.camera.viewMode = THING.CameraView.Normal; app.skyBox = "BlueSky"; } }); //waterOpen供水管線 color #0000FF var waterOpen = controlPanel.addBoolean(data, "waterOpen").caption("供水管線"); var waterLine = []; waterLine.push(createLine("供水管線", "https://thingjs.com/static/images/poly_line_04.png", [[-61.736, -1.5, 10], [74.408, -1.5, 10]])); waterLine.push(createLine("供水管線", "https://thingjs.com/static/images/poly_line_04.png", [[-61.736, -1.50, 8], [-16.126, -1.50, 8], [-16.126, -1.50, -20], [-10.126, -1.50, -20], [-10.126, -1.50, 8], [74.408, -1.5, 8]])); waterLine.push(createLine("供水管線", "https://thingjs.com/static/images/poly_line_04.png", [[-61.736, -1.50, 12], [-45.001, -1.5, 15.755], [-20.736, -1.5, 12], [74.408, -1.5, 12]])); waterLine.push(createLine("供水管線", "https://thingjs.com/static/images/poly_line_04.png", [[4, -1.5, 46], [4, -1.50, 13.809], [4, -2, 13.809], [4, -2, 6], [4, -1.50, 6], [4, -1.5, -34]])); waterLine.push(createLine("供水管線", "https://thingjs.com/static/images/poly_line_04.png", [[6, -1.50, 46], [6, -1.50, 13.809], [6, -2, 13.809], [6, -2, 6], [6, -1.50, 6], [6, -1.5, -34]])); waterLine.push(createLine("供水管線", "https://thingjs.com/static/images/poly_line_04.png", [[8, -1.50, 46], [8, -1.50, 13.809], [8, -2, 13.809], [8, -2, 6], [8, -1.50, 6], [8, -1.5, -34]])); createInfo(waterLine[0], dataJson[0],[-28.847, -1.5, 7.957]); waterOpen.on("change", function (ev) { waterLine.forEach(function (obj) { obj.visible = ev; }) }); //blowOffLine排污管線 color #FFEC8B var blowOffOpen = controlPanel.addBoolean(data, "blowOffOpen").caption("排污管線"); var blowOffLine = []; blowOffLine.push(createLine("排污管線", "https://thingjs.com/static/images/poly_line_03.png", [[-2, -3, 46], [-2, -3, -34]])); blowOffLine.push(createLine("排污管線", "https://thingjs.com/static/images/poly_line_03.png", [[0, -3, 46], [0, -3, -34]])); blowOffLine.push(createLine("排污管線", "https://thingjs.com/static/images/poly_line_03.png", [[-61.736, -3, 4], [74.408, -3, 4]])); blowOffLine.push(createLine("排污管線", "https://thingjs.com/static/images/poly_line_03.png", [[-61.736, -3, 2], [74.408, -3, 2]])); createInfo(blowOffLine[0], dataJson[1],[15.299, -1.5, 1.87]); blowOffOpen.on("change", function (ev) { blowOffLine.forEach(function (obj) { obj.visible = ev; }) }); //heatLine供熱管線 color #FF7F24 var heatOpen = controlPanel.addBoolean(data, "heatOpen").caption("供熱管線"); var heatLine = []; heatLine.push(createLine("供熱管線", "https://thingjs.com/static/images/poly_line_02.png", [[-61.736, -2, 0], [65.736, -2, 0], [74.408, -2, -8]])); heatLine.push(createLine("供熱管線", "https://thingjs.com/static/images/poly_line_02.png", [[-61.736, -2, -2], [65.736, -2, -2], [74.408, -2, -10]])); heatLine.push(createLine("供熱管線", "https://thingjs.com/static/images/poly_line_02.png", [[-4, -2, 46], [-4, -2, -34]])); heatLine.push(createLine("供熱管線", "https://thingjs.com/static/images/poly_line_02.png", [[-6, -2, 46], [-6, -2, -34]])); createInfo(heatLine[0], dataJson[2],[-6.041, -1.817, 8.865]); heatOpen.on("change", function (ev) { heatLine.forEach(function (obj) { obj.visible = ev; }) });
小結(jié)
這個取點坐標的方法在上文中沒有告訴大家,只是因為我原來用的方法就比較傻了,我是自己寫了一個全局的singleclick事件,觸發(fā)之后打印出當前鼠標的pickedPosistion記錄下來再寫進數(shù)組中,這無疑的是很麻煩的操作。
其實ThingJS已經(jīng)給我們寫好了一個工具叫做拾取場景坐標,他的使用方式下面我會給大家貼幾張圖。整個代碼100+行還是比較簡潔了(作者能力有限,已經(jīng)努力精簡了下文可以給作者多提意見,虛心接受)。最后附上完整代碼!
完整代碼
//加載場景代碼 var app = new THING.App({ // 場景地址 "url": "http://www.thingjs.com/./uploads/wechat/S2Vyd2lu/scene/Demo_地下管線", //背景設(shè)置 "skyBox": "BlueSky" }); app.on("load", function () { // init_camera app.camera.flyTo({ "position": [-6.199233956799988, 49.47465259648085, 113.74453304853118], "target": [-4.002967317456267, 26.055382001258867, 37.65111202780902], "time": 2000, }); //創(chuàng)建場景 var controlPanel = new THING.widget.Panel({ titleText: "地下管線Demo", hasTitle: true, // 是否有標題 zIndex: 999, // 設(shè)置層級 }); var data = { totalOpen: false, viewOpen: false, waterOpen: false, blowOffOpen: false, heatOpen: false }; //openTotal按鈕控制 var totalOpen = controlPanel.addBoolean(data, "totalOpen").caption("狀態(tài)切換"); totalOpen.on("change", function (ev) { if (ev) { //將campus下所有的obj的opacity = 0.4,將name = Uncorrelated 的obj的visiable = false app.query("Campus")[0].style.opacity = 0.3; app.query("Uncorrelated")[0].visible = false; } else { //反之初始化 app.query("Campus")[0].style.opacity = 1; app.query("Uncorrelated")[0].visible = true; } }); //viewOpen視角控制 var viewOpen = controlPanel.addBoolean(data, "viewOpen").caption("2D/3D"); viewOpen.on("change", function (ev) { if (ev) { app.camera.viewMode = THING.CameraView.TopView; } else { app.camera.viewMode = THING.CameraView.Normal; app.skyBox = "BlueSky"; } }); //waterOpen供水管線 color #0000FF var waterOpen = controlPanel.addBoolean(data, "waterOpen").caption("供水管線"); var waterLine = []; waterLine.push(createLine("供水管線", "https://thingjs.com/static/images/poly_line_04.png", [[-61.736, -1.5, 10], [74.408, -1.5, 10]])); waterLine.push(createLine("供水管線", "https://thingjs.com/static/images/poly_line_04.png", [[-61.736, -1.50, 8], [-16.126, -1.50, 8], [-16.126, -1.50, -20], [-10.126, -1.50, -20], [-10.126, -1.50, 8], [74.408, -1.5, 8]])); waterLine.push(createLine("供水管線", "https://thingjs.com/static/images/poly_line_04.png", [[-61.736, -1.50, 12], [-45.001, -1.5, 15.755], [-20.736, -1.5, 12], [74.408, -1.5, 12]])); waterLine.push(createLine("供水管線", "https://thingjs.com/static/images/poly_line_04.png", [[4, -1.5, 46], [4, -1.50, 13.809], [4, -2, 13.809], [4, -2, 6], [4, -1.50, 6], [4, -1.5, -34]])); waterLine.push(createLine("供水管線", "https://thingjs.com/static/images/poly_line_04.png", [[6, -1.50, 46], [6, -1.50, 13.809], [6, -2, 13.809], [6, -2, 6], [6, -1.50, 6], [6, -1.5, -34]])); waterLine.push(createLine("供水管線", "https://thingjs.com/static/images/poly_line_04.png", [[8, -1.50, 46], [8, -1.50, 13.809], [8, -2, 13.809], [8, -2, 6], [8, -1.50, 6], [8, -1.5, -34]])); createInfo(waterLine[0], dataJson[0],[-28.847, 0, 7.957]); waterOpen.on("change", function (ev) { waterLine.forEach(function (obj) { obj.visible = ev; }) }); //blowOffLine排污管線 color #FFEC8B var blowOffOpen = controlPanel.addBoolean(data, "blowOffOpen").caption("排污管線"); var blowOffLine = []; blowOffLine.push(createLine("排污管線", "https://thingjs.com/static/images/poly_line_03.png", [[-2, -3, 46], [-2, -3, -34]])); blowOffLine.push(createLine("排污管線", "https://thingjs.com/static/images/poly_line_03.png", [[0, -3, 46], [0, -3, -34]])); blowOffLine.push(createLine("排污管線", "https://thingjs.com/static/images/poly_line_03.png", [[-61.736, -3, 4], [74.408, -3, 4]])); blowOffLine.push(createLine("排污管線", "https://thingjs.com/static/images/poly_line_03.png", [[-61.736, -3, 2], [74.408, -3, 2]])); createInfo(blowOffLine[0], dataJson[1],[15.299, 0, 1.87]); blowOffOpen.on("change", function (ev) { blowOffLine.forEach(function (obj) { obj.visible = ev; }) }); //heatLine供熱管線 color #FF7F24 var heatOpen = controlPanel.addBoolean(data, "heatOpen").caption("供熱管線"); var heatLine = []; heatLine.push(createLine("供熱管線", "https://thingjs.com/static/images/poly_line_02.png", [[-61.736, -2, 0], [65.736, -2, 0], [74.408, -2, -8]])); heatLine.push(createLine("供熱管線", "https://thingjs.com/static/images/poly_line_02.png", [[-61.736, -2, -2], [65.736, -2, -2], [74.408, -2, -10]])); heatLine.push(createLine("供熱管線", "https://thingjs.com/static/images/poly_line_02.png", [[-4, -2, 46], [-4, -2, -34]])); heatLine.push(createLine("供熱管線", "https://thingjs.com/static/images/poly_line_02.png", [[-6, -2, 46], [-6, -2, -34]])); createInfo(heatLine[0], dataJson[2],[-6.041, 0, 8.865]); heatOpen.on("change", function (ev) { heatLine.forEach(function (obj) { obj.visible = ev; }) }); }); function createLine(name, image, points) { var line = null; line = app.create({ type: "PolygonLine", name: name, points: points, image: image }); line.renderOrder = -10000; line.scrollUV = true; line.visible = false; return line; } function createInfo(obj,json, position) { var panel = new THING.widget.Panel({ template: "default2", width: "200px", cornerType: "polyline" }) // panel.zIndex = -10000; panel.renderOrder = -1000; var dataObj = { name: " ", id: json.id, starId: json.starId, stopId: json.stopId, starDeep: json.starDeep, stopDeep: json.stopDeep, material: json.material, pressure: json.pressure, } panel.addString(dataObj, "name").caption(obj.name); panel.addString(dataObj, "id").caption("管線編號"); panel.addString(dataObj, "starId").caption("起點編號"); panel.addString(dataObj, "stopId").caption("終點編號"); panel.addString(dataObj, "starDeep").caption("起點深度"); panel.addString(dataObj, "stopDeep").caption("終點深度"); panel.addString(dataObj, "material").caption("材料"); panel.addString(dataObj, "pressure").caption("壓力"); var uiAnchor = app.create({ type: "UIAnchor", parent: obj, element: panel.domElement, position: [position[0], 0, position[2]], pivot: [-0.2, 2.1] }); return uiAnchor; } var dataJson = [{ "id": "BJ002", "starId": "2TAG001", "stopId": "2TAG002", "starDeep": "-1.5", "stopDeep": "-1.5", "material": "ASTNX01", "pressure": "120" }, { "id": "BJ002", "starId": "2TAG001", "stopId": "2TAG002", "starDeep": "-1.5", "stopDeep": "-1.5", "material": "ASTNX01", "pressure": "120" }, { "id": "BJ002", "starId": "2TAG001", "stopId": "2TAG002", "starDeep": "-1.5", "stopDeep": "-1.5", "material": "ASTNX01", "pressure": "120" }];
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/101439.html
摘要:說起物聯(lián)網(wǎng),大家的第一反應(yīng)就是智慧城市。在物聯(lián)網(wǎng)的幫助下,得以讓我們居住的城市正變得越來越有智慧。作為面向物聯(lián)網(wǎng)的可視化開發(fā)平臺有廣闊的行業(yè)應(yīng)用場景。 隨著科技的發(fā)展,5G網(wǎng)絡(luò)的到來,將開啟萬物即插即慧的新時代。這就是物聯(lián)網(wǎng),當網(wǎng)絡(luò)不再是阻礙,萬物互聯(lián),萬物可視,把數(shù)字世界帶入每個人、每個家庭、每個組織,構(gòu)建萬物互聯(lián)的智能世界。 說起物聯(lián)網(wǎng),大家的第一反應(yīng)就是智慧城市。在物聯(lián)網(wǎng)的幫助下...
摘要:智慧樓宇可視化系統(tǒng)是綜合上述手段打造出的智慧樓宇可查可管可控的一體化可視平臺。智能環(huán)境可視化展示樓宇內(nèi)水電氣冷風(fēng)等的管線含流向及設(shè)備的空間分布。集成停車引導(dǎo)系統(tǒng),高亮展示最佳停車位及到車位的最佳路線。 智慧樓宇大勢所趨,從智能 到智慧,一字之差,它到底有多智慧? 我們可以看一下智慧樓宇3D可視應(yīng)用視頻:https://v.qq.com/x/page/h0767... 基于ThingJS...
摘要:隨著信息化技術(shù)發(fā)展,全國各地開始智慧糧倉的建設(shè),我們可以通過一個視頻看一下使用可視化平臺做的可視應(yīng)用,可視一體化,讓糧倉智慧升級。構(gòu)建糧倉內(nèi)糧情的監(jiān)控預(yù)警診斷分析一體化的可視化平臺。 首先我們先了解一下基于WebGL架構(gòu)的3D可視化平臺——ThingJS是什么? ThingJS是優(yōu)锘科技開發(fā)的一套面向物聯(lián)網(wǎng)應(yīng)用的在線3D可視化應(yīng)用開發(fā)及運營PaaS平臺,以 ThingJS云視PaaS服...
摘要:車輛集中存放管理的場所被人類提出車輛進出的秩序車輛存放的安全性車輛存放管理的有償性等要求。隨著科技的發(fā)展,停車場管理系統(tǒng)也日新月異,目前最為專業(yè)化的停車場系統(tǒng)為免取卡停車場。下面我們就用平臺來搭建一個可視化的停車場管理系統(tǒng)。 隨著社會的發(fā)展,城市中的汽車越來越多。車輛集中存放管理的場所被人類提出車輛進出的秩序、車輛存放的安全性、車輛存放管理的有償性等要求。停車場系統(tǒng)應(yīng)用現(xiàn)代機械電子及通...
摘要:峰會上,阿里云與優(yōu)锘科技聯(lián)合發(fā)布了智慧園區(qū)可視化產(chǎn)品。優(yōu)锘科技受邀參加此次峰會,峰會上,阿里云與優(yōu)锘科技聯(lián)合發(fā)布了智慧園區(qū)可視化產(chǎn)品,并在物聯(lián)網(wǎng)專場論壇構(gòu)建四位一體的數(shù)字園區(qū)運營體系進行了專題分享。 2019年3月21日,2019阿里云峰會在北京國家會議中心如期舉行。峰會上,阿里云與優(yōu)锘科技聯(lián)合發(fā)布了智慧園區(qū)可視化產(chǎn)品。 本次峰會中,圍繞十年再出發(fā)的主題,阿里云首次進行全面戰(zhàn)略解讀,并...
閱讀 926·2021-11-22 13:54
閱讀 2853·2021-09-28 09:36
閱讀 2992·2019-08-30 15:55
閱讀 1960·2019-08-30 15:44
閱讀 554·2019-08-29 12:31
閱讀 2570·2019-08-28 18:18
閱讀 1208·2019-08-26 13:58
閱讀 1394·2019-08-26 13:44