暂替代码

main
wangqiujuan0808 2024-01-08 21:10:22 +08:00
parent f6a7456d77
commit d51445a489
11 changed files with 11897 additions and 449003 deletions

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

View File

@ -9,7 +9,8 @@ const bimStore = defineStore(
activateMenu: { activateMenu: {
name: '建筑信息', name: '建筑信息',
background: '#202a60' background: '#202a60'
} },
checkArr: []
}), }),
actions: { actions: {
// 菜单 // 菜单
@ -35,6 +36,11 @@ const bimStore = defineStore(
// 资产详情num // 资产详情num
setDeviceNum(item) { setDeviceNum(item) {
this.deviceNum = item; this.deviceNum = item;
},
// 巡检列表篇
setCheckArr(item) {
console.log(3,item);
this.checkArr = item;
} }
} }
}) })

View File

@ -0,0 +1,25 @@
<template>
<div>
<el-table :data="checkArr" border style="width: 100%" height="320">
<el-table-column label="序号" width="60" type="index" align="center"></el-table-column>
<el-table-column prop="name" label="设备名称" align="center" />
<el-table-column prop="isPass" label="巡检结果" align="center">
<template #default="scope">
<span :style="{'color': scope.row.isPass? '#0dbc79' : '#e03528'}">{{ scope.row.isPass ? '通过' : '不通过' }}</span>
</template>
</el-table-column>
<el-table-column label="巡检时间" align="center">
<template #default="scope">
{{ scope.row.isPass ? '2023-12-23': '2023-01-11' }}
</template>
</el-table-column>
</el-table>
</div>
</template>
<script setup>
import bimStore from '@/store/modules/bim';
import { computed } from 'vue';
const checkArr = computed(() =>
bimStore().checkArr
);
</script>

View File

@ -17,7 +17,7 @@ import RealInfo from './RealInfo.vue';
import HistoryInfo from './HistoryInfo.vue'; import HistoryInfo from './HistoryInfo.vue';
import { ElMessage } from 'element-plus'; import { ElMessage } from 'element-plus';
const deviceData = { const deviceData = {
'guan2': { 'T11': {
name: '立仓', name: '立仓',
imgUrl: 'licang', imgUrl: 'licang',
detail: [ detail: [
@ -75,7 +75,7 @@ const deviceData = {
}, },
] ]
}, },
'Circle001': { 'guolvcao': {
name: '过滤槽', name: '过滤槽',
imgUrl: 'guolvcao', imgUrl: 'guolvcao',
detail: [ detail: [

View File

@ -59,28 +59,28 @@ const data = reactive({
{ {
type: '生产设备', type: '生产设备',
name: '立仓', name: '立仓',
num: 'guan2', num: 'T11',
value: 45, value: 45,
id: "echartDiv0" id: "echartDiv0"
}, },
{ {
type: '生产设备', type: '生产设备',
name: '过滤槽', name: '过滤槽',
num: 'Circle001', num: 'guolvcao',
value: 130, value: 130,
id: "echartDiv1" id: "echartDiv1"
}, },
{ {
type: '安防设备', type: '安防设备',
name: '摄像头', name: '摄像头',
num: 'guan2', num: 'T3',
value: 180, value: 180,
id: "echartDiv2" id: "echartDiv2"
}, },
{ {
type: '消防设备', type: '消防设备',
name: '烟感', name: '烟感',
num: 'guan2', num: 'T4',
value: 100, value: 100,
id: "echartDiv3" id: "echartDiv3"
} }
@ -101,28 +101,28 @@ const data = reactive({
{ {
type: '生产设备', type: '生产设备',
name: '立仓', name: '立仓',
num: 'guan2', num: 'T11',
value: 15, value: 15,
id: "echartDiv0" id: "echartDiv0"
}, },
{ {
type: '生产设备', type: '生产设备',
name: '过滤槽', name: '过滤槽',
num: 'set6', num: 'guolvcao',
value: 50, value: 50,
id: "echartDiv1" id: "echartDiv1"
}, },
{ {
type: '安防设备', type: '安防设备',
name: '摄像头', name: '摄像头',
num: 'guan2', num: 'T3',
value: 80, value: 80,
id: "echartDiv2" id: "echartDiv2"
}, },
{ {
type: '消防设备', type: '消防设备',
name: '烟感', name: '烟感',
num: 'guan2', num: 'T4',
value: 50, value: 50,
id: "echartDiv3" id: "echartDiv3"
} }
@ -144,28 +144,28 @@ const data = reactive({
{ {
type: '生产设备', type: '生产设备',
name: '立仓', name: '立仓',
num: 'guan2', num: 'T11',
value: 30, value: 30,
id: "echartDiv0" id: "echartDiv0"
}, },
{ {
type: '生产设备', type: '生产设备',
name: '过滤槽', name: '过滤槽',
num: 'set6', num: 'guolvcao',
value: 80, value: 80,
id: "echartDiv1" id: "echartDiv1"
}, },
{ {
type: '安防设备', type: '安防设备',
name: '摄像头', name: '摄像头',
num: 'guan2', num: 'T4',
value: 100, value: 100,
id: "echartDiv2" id: "echartDiv2"
}, },
{ {
type: '消防设备', type: '消防设备',
name: '烟感', name: '烟感',
num: 'guan2', num: 'T3',
value: 50, value: 50,
id: "echartDiv3" id: "echartDiv3"
} }

View File

@ -45,7 +45,7 @@ const data = reactive({
{ {
label: '立仓', label: '立仓',
id: '0-1', id: '0-1',
clickName: 'guan2', clickName: 'T11',
info: { info: {
name: '立仓', name: '立仓',
type: '生产设备', type: '生产设备',
@ -61,7 +61,7 @@ const data = reactive({
{ {
label: '过滤槽', label: '过滤槽',
id: '0-2', id: '0-2',
clickName: 'Circle001', clickName: 'guolvcao',
info: { info: {
name: '过滤槽', name: '过滤槽',
type: '生产设备', type: '生产设备',
@ -76,7 +76,7 @@ const data = reactive({
{ {
label: '设备二', label: '设备二',
id: '0-3', id: '0-3',
clickName: 'guan3', clickName: 'T3',
info: { info: {
name: '设备二', name: '设备二',
type: '生产设备', type: '生产设备',
@ -90,7 +90,7 @@ const data = reactive({
{ {
label: '设备三', label: '设备三',
id: '0-4', id: '0-4',
clickName: 'guan4', clickName: 'T4',
info: { info: {
name: '设备三', name: '设备三',
type: '空调设备', type: '空调设备',
@ -104,7 +104,7 @@ const data = reactive({
{ {
label: '设备四', label: '设备四',
id: '0-5', id: '0-5',
clickName: 'guan5', clickName: 'T5',
info: { info: {
name: '设备四', name: '设备四',
type: '安防设备', type: '安防设备',
@ -118,7 +118,7 @@ const data = reactive({
{ {
label: '设备五', label: '设备五',
id: '0-6', id: '0-6',
clickName: 'guan6', clickName: 'T6',
info: { info: {
name: '设备五', name: '设备五',
type: '安防设备', type: '安防设备',
@ -132,7 +132,7 @@ const data = reactive({
{ {
label: '设备七', label: '设备七',
id: '0-7', id: '0-7',
clickName: 'guan7', clickName: 'T7',
info: { info: {
name: '设备七', name: '设备七',
type: '安防设备', type: '安防设备',
@ -146,7 +146,7 @@ const data = reactive({
{ {
label: '设备八', label: '设备八',
id: '0-8', id: '0-8',
clickName: 'guan8', clickName: 'T8',
info: { info: {
name: '设备八', name: '设备八',
type: '安防设备', type: '安防设备',

View File

@ -84,16 +84,16 @@ let romeObj = []
let checkArr = []; let checkArr = [];
let checkindex = 0; let checkindex = 0;
//
let isShowWall = false;
let mouse = new THREE.Vector2(); let mouse = new THREE.Vector2();
let labelRenderer = new CSS2DRenderer(); //CSS2DRenderer let labelRenderer = new CSS2DRenderer(); //CSS2DRenderer
const data = reactive({ const data = reactive({
isAddLabel: true, isAddLabel: true,
isRemoveBottom: true isRemoveBottom: true,
isShowWall: false //
}); });
const { isAddLabel, isRemoveBottom } = toRefs(data); const { isAddLabel, isRemoveBottom, isShowWall } = toRefs(data);
// //
Bus.on('clickBuild', (isParent) => { Bus.on('clickBuild', (isParent) => {
// Todo // Todo
@ -242,17 +242,17 @@ const enableGroup = [
'yuanliao_room', 'yuanliao_room',
'tanghua_room', 'tanghua_room',
'touliao_room', 'touliao_room',
'Circle001',// 'guolvcao',//
'guan1', 'T3',
'guan2',// 'T4',
'guan3', 'T5',
'guan4', 'T6',
'guan5', 'T7',
'guan6', 'T8',
'guan7', 'T9',
'guan8', 'T10',
'guan9', 'T11',//
'guan10' 'T12'
] ]
const isSelent = (obj) => { const isSelent = (obj) => {
var o = obj var o = obj
@ -293,7 +293,7 @@ const onMouseMove = (event) => {
} }
} }
} }
const emit = defineEmits(['handleRightClick']) const emit = defineEmits(['handleRightClick', 'checkComplete'])
// //
const onMouseDownRight = (event) => { const onMouseDownRight = (event) => {
var raycaster = new THREE.Raycaster() var raycaster = new THREE.Raycaster()
@ -327,7 +327,7 @@ const onMouseDown = (event) => {
// //
boxLight(selectedObject); boxLight(selectedObject);
// //
console.log(1,clickedObject); console.log(1, clickedObject);
if (bimStore().activateIndex == '0') { if (bimStore().activateIndex == '0') {
// //
Bus.emit('handleTreeClick', clickedObject); Bus.emit('handleTreeClick', clickedObject);
@ -377,7 +377,7 @@ const cleanColor = () => {
} }
// //
const warn = () => { const warn = () => {
['guan1', 'guan2', 'guan3', 'guan4', 'guan5', 'guan6', 'guan7', 'guan8', 'guan9', 'guan10'].forEach(item => { ['T3', 'T4', 'T5', 'T6', 'T7', 'T8', 'T9', 'T10', 'T11', 'T12'].forEach(item => {
warnSets.push(scene.getObjectByName(item)); warnSets.push(scene.getObjectByName(item));
}) })
@ -480,7 +480,7 @@ const toHomeView = () => {
// //
cleanColor(); cleanColor();
// //
isShowWall = false; isShowWall.value = false;
} }
// //
const nearCamera = (floor) => { const nearCamera = (floor) => {
@ -500,7 +500,7 @@ const nearCamera = (floor) => {
// //
const setLabel = () => { const setLabel = () => {
if (isAddLabel.value) { if (isAddLabel.value) {
let obj = scene.getObjectByName('guan2'); let obj = scene.getObjectByName('T11');
addLabel(obj, 'title'); addLabel(obj, 'title');
} else { } else {
removeLabel(); removeLabel();
@ -539,18 +539,24 @@ const createLableObj = (text, t) => {
// //
} else { } else {
laberDiv.className = "laber_state"; laberDiv.className = "laber_state";
laberDiv.innerHTML = `<div class="arrow_state"> let innerHTML = t ? `<div class="arrow_state">
<div>设备名称${text}</div> <div>设备名称${text}</div>
<div> <div>
是否通过 巡检结果巡检通过
<span class="pass" v-if="${t}">
通过,检查下一个
<span>
<span class="nopass" v-else-if="${!t}">
不通过,已记录异常检查下一个
<span>
</div> </div>
</div>` <div>
巡检时间2023-12-23
</div>
</div>`: `<div class="arrow_state1">
<div>设备名称${text}</div>
<div>
巡检结果巡检不通过已记录异常
</div>
<div>
巡检时间2023-01-11
</div>
</div>`;
laberDiv.innerHTML = innerHTML;
} }
let pointLabel = new CSS2DObject(laberDiv); let pointLabel = new CSS2DObject(laberDiv);
return pointLabel; return pointLabel;
@ -602,29 +608,29 @@ const xfadd = (obj, state) => {
} }
// //
const changeMap = (img) => { const changeMap = (img) => {
isShowWall = true; isShowWall.value = true;
// //
model.traverse(e => { model.traverse(e => {
if (['wallnew1', 'wallnew2', 'wallnew3', 'wallnew4'].indexOf(e.name) != -1) { if (['touliao_wall1', 'touliao_wall2', 'touliao_wall3', 'touliao_wall4', 'touliao_wall5', 'touliao_wall6', 'touliao_wall7', 'touliao_wall8'].indexOf(e.name) != -1) {
console.log(e) console.log(e)
e.material = new THREE.MeshBasicMaterial({ e.material = new THREE.MeshBasicMaterial({
transparent: true, transparent: true,
opacity: 0.5, opacity: 0.5,
color: new THREE.Color('rgb( 88,211,247)') color: new THREE.Color('rgb( 88,211,247)')
}); });
} else if (['wall1988_01', 'wall1988_02', 'wall1988_03'].indexOf(e.name) != -1) { } else if (['yuanliao_wall1', 'yuanliao_wall2', 'yuanliao_wall3', 'yuanliao_wall4', 'yuanliao_wall5', 'yuanliao_wall6', 'yuanliao_wall7', 'yuanliao_wall8', 'yuanliao_wall9','yuanliao_wall10'].indexOf(e.name) != -1) {
e.material = new THREE.MeshBasicMaterial({ e.material = new THREE.MeshBasicMaterial({
transparent: true, transparent: true,
opacity: 0.5, opacity: 0.5,
color: new THREE.Color('rgb( 0,128,255)') color: new THREE.Color('rgb( 0,128,255)')
}); });
} else if (['wall2010_01', 'wall2010_02'].indexOf(e.name) != -1) { } else if (['tanghua_wall1', 'tanghua_wall2','tanghua_wall3', 'tanghua_wall4','tanghua_wall5', 'tanghua_wall6','tanghua_wall7', 'tanghua_wall8'].indexOf(e.name) != -1) {
e.material = new THREE.MeshBasicMaterial({ e.material = new THREE.MeshBasicMaterial({
transparent: true, transparent: true,
opacity: 0.5, opacity: 0.5,
color: new THREE.Color('rgb(247,254,46)') color: new THREE.Color('rgb(247,254,46)')
}); });
} else if (['wall2022_01'].indexOf(e.name) != -1) { } else if (['tanghua_wall9', 'tanghua_wall10','tanghua_wall11'].indexOf(e.name) != -1) {
e.material = new THREE.MeshBasicMaterial({ e.material = new THREE.MeshBasicMaterial({
transparent: true, transparent: true,
opacity: 0.5, opacity: 0.5,
@ -632,7 +638,6 @@ const changeMap = (img) => {
}); });
} }
}) })
console.log(123, isShowWall)
} }
// //
const check = () => { const check = () => {
@ -646,9 +651,12 @@ const check = () => {
duration: 10, duration: 10,
ease: 'power1.inOut', ease: 'power1.inOut',
onComplete: () => { onComplete: () => {
if (checkindex == romeObj.length) { //
checkComplete();
}
setTimeout(() => { setTimeout(() => {
check() check()
}, 5000) }, 1000)
} }
}); });
// //
@ -666,12 +674,19 @@ const check = () => {
duration: 10, duration: 10,
ease: "power1.inOut", ease: "power1.inOut",
onComplete: () => { }, onComplete: () => {
},
}); });
checkindex++; checkindex++;
console.log('nextObj', checkindex) console.log('nextObj', checkindex)
} }
} }
//
const checkComplete = () => {
toHomeView();
bimStore().setCheckArr(romeObj);
emit('checkComplete', romeObj);
}
</script> </script>
<style lang='scss'> <style lang='scss'>
@ -695,7 +710,7 @@ const check = () => {
cursor: pointer; cursor: pointer;
// background: #0549a7; // background: #0549a7;
border: 1px solid #3cbfdf; border: 1px solid #3cbfdf;
background: rgba(0,0,0,.8); background: rgba(0, 0, 0, .8);
width: 110px; width: 110px;
height: 40px; height: 40px;
border-radius: 5px; border-radius: 5px;
@ -736,12 +751,32 @@ const check = () => {
.arrow_state { .arrow_state {
display: inline-block; display: inline-block;
width: 200px; // width: 200px;
height: 100px; // height: 100px;
background: rgb(33, 248, 255); padding: 10px;
background: #0dbc79;
color: #fff; color: #fff;
padding: 15px; padding: 15px;
border-radius: 5px;
>div {
line-height: 32px;
}
} }
.arrow_state1 {
display: inline-block;
padding: 10px;
background: #e03528;
color: #fff;
padding: 15px;
border-radius: 5px;
>div {
line-height: 32px;
}
}
.wall_tooltips { .wall_tooltips {
position: absolute; position: absolute;
top: 20px; top: 20px;
@ -752,28 +787,35 @@ const check = () => {
width: 600px; width: 600px;
justify-content: space-around; justify-content: space-around;
align-items: center; align-items: center;
span { span {
display: inline-block; display: inline-block;
width: 16px; width: 16px;
height: 8px; height: 8px;
margin-right: 5px; margin-right: 5px;
&.qing { &.qing {
background:#3cbfdf; background: #3cbfdf;
} }
&.blue { &.blue {
background: #2c68f3; background: #2c68f3;
} }
&.yellow { &.yellow {
background: #dff04e; background: #dff04e;
} }
&.red { &.red {
background: red; background: red;
} }
} }
} }
.pass { .pass {
color: #0caf71; color: #0caf71;
} }
.nopass { .nopass {
color: #fc1818; color: #fc1818;
} }

View File

@ -1,7 +1,8 @@
<template> <template>
<div class="app-container"> <div class="app-container">
<!-- 场景模型 --> <!-- 场景模型 -->
<ThreeView light="0xfffafa" :sceneUrl="sceneUrl" v-if="sceneUrl !== ''" @handleRightClick="handleRightClick"></ThreeView> <ThreeView light="0xfffafa" :sceneUrl="sceneUrl" v-if="sceneUrl !== ''" @handleRightClick="handleRightClick"
@checkComplete="checkComplete"></ThreeView>
<!-- <ThreeModel /> --> <!-- <ThreeModel /> -->
<!-- 底部菜单 --> <!-- 底部菜单 -->
<MenuTab @changeMenu="changeMenu"></MenuTab> <MenuTab @changeMenu="changeMenu"></MenuTab>
@ -35,6 +36,11 @@
append-to-body> append-to-body>
<DeviceDetial></DeviceDetial> <DeviceDetial></DeviceDetial>
</el-dialog> </el-dialog>
<!-- 巡检结果 -->
<el-dialog v-model="dialogVisible3" v-if="dialogVisible3" title="巡检结果" width="1500px" custom-class="bim-dialog"
append-to-body>
<CheckDetial></CheckDetial>
</el-dialog>
</div> </div>
</template> </template>
@ -54,18 +60,20 @@ import ThreeView from './components/ThreeView2.vue';
import DeviceInfoDialog from './components/DeviceInfoDialog.vue'; import DeviceInfoDialog from './components/DeviceInfoDialog.vue';
import RealInfoDialog from './components/RealInfoDialog.vue'; import RealInfoDialog from './components/RealInfoDialog.vue';
import DeviceDetial from './components/DeviceDetial.vue'; import DeviceDetial from './components/DeviceDetial.vue';
import CheckDetial from './components/CheckDetial.vue';
import bimStore from '@/store/modules/bim'; import bimStore from '@/store/modules/bim';
import { computed } from 'vue'; import { computed } from 'vue';
import Bus from '@/utils/bus.js'; import Bus from '@/utils/bus.js';
const data = reactive({ const data = reactive({
sceneUrl: '/jz/glb/scene.gltf', sceneUrl: '/jz/glb/scene.gltf',
equimentInfo: {}, equimentInfo: {}
}); });
const { sceneUrl, equimentInfo } = toRefs(data); const { sceneUrl, equimentInfo } = toRefs(data);
const dialogVisible = ref(false); const dialogVisible = ref(false);
const dialogVisible1 = ref(false); const dialogVisible1 = ref(false);
const dialogVisible2 = ref(false); const dialogVisible2 = ref(false);
const dialogVisible3 = ref(false);
const activateIndex = computed(() => const activateIndex = computed(() =>
bimStore().activateIndex bimStore().activateIndex
@ -80,8 +88,8 @@ const deviceInfo = computed(() =>
); );
Bus.on('viewMore', (title) => { Bus.on('viewMore', (title) => {
// Todo // Todo
title === '资产信息' ? dialogVisible.value = true : dialogVisible1.value = true;; title === '资产信息' ? dialogVisible.value = true : dialogVisible1.value = true;;
}) })
@ -96,13 +104,18 @@ const onProgress = () => {
} }
const handleRightClick = (obj) => { const handleRightClick = (obj) => {
console.log(1,obj.name); console.log(1, obj.name);
bimStore().setDeviceNum(obj.name); bimStore().setDeviceNum(obj.name);
dialogVisible2.value = true; dialogVisible2.value = true;
// viewDetail(); // viewDetail();
} }
const checkComplete = (romeObj) => {
dialogVisible3.value = true;
}
const handleBuildClick = (value, isParent) => { const handleBuildClick = (value, isParent) => {
// / // /
if (isParent) { if (isParent) {