lxc 2 years ago
parent
commit
729a641da8
  1. 3622
      app/app.json
  2. 271
      app/app1.json
  3. 3623
      app/app2.json
  4. 3646
      app/app3.json
  5. 3
      app/js/bll/uasbwater.js
  6. 11
      app/js/units/common.js
  7. 38
      app/js/units/css2dlabel.js
  8. 123
      app/js/units/modellabel.js
  9. 3704
      app/ljfs.json
  10. 279
      app/lndexUASB.html
  11. 320
      app/lndexzhsc.html

3622
app/app.json

File diff suppressed because one or more lines are too long

271
app/app1.json

File diff suppressed because one or more lines are too long

3623
app/app2.json

File diff suppressed because one or more lines are too long

3646
app/app3.json

File diff suppressed because one or more lines are too long

3
app/js/bll/uasbwater.js

@ -0,0 +1,3 @@
export default{
}

11
app/js/units/common.js

@ -0,0 +1,11 @@
export default {
guid: function () {
return 'xxxxxxxxxxxx4xxxyxxxxxxxxxxxxxxx'.replace(/[xy]/g, function (c) {
var r = Math.random() * 16 | 0,
v = c == 'x' ? r : (r & 0x3 | 0x8);
return v.toString(16);
});
}
}

38
app/js/units/css2dlabel.js

@ -0,0 +1,38 @@
import { CSS2DRenderer, CSS2DObject } from 'jsm/renderers/CSS2DRenderer.js';
export default {
createButton: function (obj, perent, i) {
const btnDiv = document.createElement('button');
btnDiv.className = 'btn';
btnDiv.identifierName = 'btn';
btnDiv.textContent = 'Btn: Click ...';
btnDiv.style.marginTop = '-1em';
btnDiv.style.zIndex = 1000;
const css2dBtn = new CSS2DObject(btnDiv);
css2dBtn.position.set(obj.x + 2, obj.y, obj.z);
css2dBtn.name = "datalabel" + i;
css2dBtn.userData = { name: "datalable", id: "", url: "" }
// css2DLabelList.add(css2DLabel);
window.scene.add(css2dBtn);
},
//创建标签
createCSSLabel: function (text, x = 0, y = 0, z = 0, className = 'label') {
const labelDiv = document.createElement('div');
labelDiv.className = className;
labelDiv.name = "csslabeldiv"
labelDiv.textContent = text;
labelDiv.style.pointerEvents = 'none';//避免HTML标签遮挡三维场景的鼠标事件
const css2DLabel = new CSS2DObject(labelDiv);
css2DLabel.position.set(x, y, z);
css2DLabel.name = "datalabel"
css2DLabel.userData = { name: "datalable", id: "", url: "" }
return css2DLabel;
}
}

123
app/js/units/modellabel.js

@ -0,0 +1,123 @@
import * as THREE from 'three';
export default {
//添加模型标签
createRemarkLabel: function (text, x = 0, y = 0, z = 0) {
let labelCanvas = this.getTextCanvas(text);
const labelTexture = new THREE.Texture(labelCanvas);
// labelTexture.magFilter = THREE.LinearFilter;
// labelTexture.minFilter = THREE.LinearFilter;
labelTexture.needsUpdate = true;
const labelMaterial = new THREE.MeshBasicMaterial({
map: labelTexture,
side: THREE.DoubleSide
});
labelMaterial.transparent = true;
const labelPlane = new THREE.PlaneGeometry(labelCanvas.width, labelCanvas.height);
let labelMesh = new THREE.Mesh(labelPlane, labelMaterial);
labelMesh.name = '标签'
labelMesh.position.set(x, y, z);
labelMesh.scale.set(0.005, 0.005, 0.005);
labelMesh.userData = { name: "imaglable", id: "", url: "" }
return labelMesh;
},
getTextCanvas1: function (text) {
var width = text.length * 12, height = 16;
var canvas = document.createElement('canvas');
canvas.width = width;
canvas.height = height;
var ctx = canvas.getContext('2d');
var devicePixelRatio = window.devicePixelRatio || 1;
var backingStoreRatio = ctx.webkitBackingStorePixelRatio ||
ctx.mozBackingStorePixelRatio ||
ctx.msBackingStorePixelRatio ||
ctx.oBackingStorePixelRatio ||
ctx.backingStorePixelRatio || 1;
var ratio = devicePixelRatio / backingStoreRatio;
// debugger
canvas.width = canvas.width * ratio;
canvas.height = canvas.height * ratio;
width = canvas.width;
height = canvas.height;
ctx.scale(ratio, ratio);
ctx.translate(0.5, 0.5);
ctx.lineWidth = 1;
ctx.moveTo(2.5, 2);
ctx.lineTo(98.5, 2);
ctx.lineTo(98.5, 98);
ctx.lineTo(2.5, 98);
ctx.lineTo(2.5, 2);
ctx.stroke();
ctx.fillStyle = '#CfCfC3';
ctx.fillRect(0, 0, width, height);
ctx.font = 10 + 'px " bold ';
ctx.fillStyle = '#000000';
ctx.textAlign = 'center';
ctx.textBaseline = 'middle';
ctx.fillText(text, width / 2 / ratio, height / 2 / ratio);
return canvas;
},
getTextCanvas: function (text) {
var width = text.length * 24, height = 32;
var canvas = document.createElement('canvas');
canvas.width = width;
canvas.height = height;
var ctx = canvas.getContext('2d');
ctx.fillStyle = '#CfCfC3';
ctx.fillRect(0, 0, width, height);
ctx.font = 20 + 'px " bold ';
ctx.fillStyle = '#000000';
ctx.textAlign = 'center';
ctx.textBaseline = 'middle';
ctx.fillText(text, width / 2, height / 2);
return canvas;
},
//普通标签
addLabel: async function (parent, x = 0, y = 0, z = 0, className = 'label') {
console.log("parent.name=", parent.name)
if (!parent.name) {
return;
}
console.log("parent.name2=", parent.name)
let item = await getlabel(parent.name);
console.log("item2=", item)
// debugger
if (!item) return;
console.log("item2=", item)
const labelDiv = document.createElement('div');
labelDiv.className = className;
labelDiv.name = "csslabel";
labelDiv.textContent = item.text;
labelDiv.style.marginTop = '-1em';
labelDiv.style.pointerEvents = 'none';//避免HTML标签遮挡三维场景的鼠标事件
const css2DLabel = new CSS2DObject(labelDiv);
css2DLabel.position.set(x, y, z);
css2DLabel.name = "datalabel"
css2DLabel.userData = { name: "datalable", id: "", url: "" }
// css2DLabelList.add(css2DLabel);
if (parent) {
parent.add(css2DLabel);
} else {
window.scene.add(css2DLabel);
}
}
}

3704
app/ljfs.json

File diff suppressed because one or more lines are too long

279
app/lndexUASB.html

@ -72,21 +72,15 @@
import { CSS2DRenderer, CSS2DObject } from 'jsm/renderers/CSS2DRenderer.js';
import { Water } from 'jsm/objects/Water.js';
import modellabel from './js/units/modellabel.js'
import css2dlabel from './js/units/css2dlabel.js'
const type = 1;
window.THREE = THREE; // Used by APP Scripts.
window.VRButton = VRButton; // Used by APP Scripts.
//水泵列表
//水泵列表
let pumpModelArr = []
//红色标签
const labArr = [{ name: "水泵M_1", text: "水泵1" }, { name: "水泵M_2", text: "水泵002" }
, { name: "水泵M_3", text: "水泵003" }, { name: "水泵M_4", text: "水泵4" }, { name: "水泵M_5", text: "水泵5" }
, { name: "OilTank001", text: "油桶1" }, { name: "OilTank002", text: "油桶2" }, { name: "OilTank003", text: "油桶3" },
]
//黑色标签
const remarkLabArr = [{ name: "221", text: "USAB进水", x: 2.0501311208405713, y: -0.7778027560129786, z: -5.377062185399511, ry: 9.4 }
, { name: "211", text: "USAB进水", x: 0.1740166304621844, y: -0.7760432883855322, z: -5.667636935767586, ry: 9.4 },
{ name: "491", text: "至污泥浓缩池", x: -2.105188770141037, y: -0.7901334936138524, z: -5.4669334625207435, ry: 9.4 }]
var loader = new THREE.FileLoader();
@ -113,24 +107,7 @@
});
function addButton(obj, perent, i) {
const btnDiv = document.createElement('button');
btnDiv.className = 'btn';
btnDiv.identifierName = 'btn';
btnDiv.textContent = 'Btn: Click ...';
btnDiv.style.marginTop = '-1em';
btnDiv.style.zIndex = 1000;
const css2dBtn = new CSS2DObject(btnDiv);
css2dBtn.position.set(obj.x + 2, obj.y, obj.z);
css2dBtn.name = "datalabel" + i;
css2dBtn.userData = { name: "datalable", id: "", url: "" }
// css2DLabelList.add(css2DLabel);
window.scene.add(css2dBtn);
}
@ -171,13 +148,7 @@
// }
// }
// }
// function guid() {
// return 'xxxxxxxxxxxx4xxxyxxxxxxxxxxxxxxx'.replace(/[xy]/g, function (c) {
// var r = Math.random() * 16 | 0,
// v = c == 'x' ? r : (r & 0x3 | 0x8);
// return v.toString(16);
// });
// }
function onDBMouseClick(event) {
@ -202,14 +173,14 @@
let tmpobj = obj.object;
console.log(tmpobj)
//输出 增加标签 位置
console.log('{name:"' + tmpobj.name + '1",text:"' + tmpobj.name + '",x:' + obj.point.x + ',y:' + obj.point.y + ',z:' + obj.point.z + ',rx:0}');
console.log('{name:"' + tmpobj.name + '1",text:"' + tmpobj.name + '",x:' + obj.point.x.toFixed(2) + ',y:' + obj.point.y.toFixed(2) + ',z:' + obj.point.z.toFixed(2) + ',rx:0,ry:0,rz:0}');
if (tmpobj.name.indexOf('水泵M_') > -1) { // 水泵
openDialog(tmpobj)
//alert(tmpobj.name, "双击");
}
break;
}
}
}
@ -230,147 +201,132 @@
}
});
}
//创建标签
function createCSSLabel(text, parent) {
const labelDiv = document.createElement('div');
labelDiv.className = 'label';
labelDiv.name = "csslabeldiv"
labelDiv.textContent = text;
labelDiv.style.pointerEvents = 'none';//避免HTML标签遮挡三维场景的鼠标事件
const moonLabel = new CSS2DObject(labelDiv);
moonLabel.position.set(1, 2, 0);
moonLabel.name = "datalabel"
moonLabel.userData = { name: "datalable", id: "", url: "" }
return moonLabel;
// 设置标签
function setModel(scene, player) {
scene.castShadow = true; // 开启阴影
scene.receiveShadow = true; // 接受阴影
scene.children.forEach((item, index) => {
// console.log("--------item ==", index);
// console.log("name=", item.name)
// console.log("type=", item.type)
if (item.name.indexOf('OilTank00') > -1) {
addLabel(item, 0, 0.4, 0)
}
else if (item.name.indexOf('水泵M_') > -1) { // 水泵
pumpModelArr.push(item);
//debugger
if (item.name === '水泵001') {
item.material.color.set(0xff0000);
} else {
item.material.color.set(0x006600);
}
addStateLabel(item, 0, 3, 0)
}
if (item.type === 'Object3D' || item.type === 'Group') { // 有下一级
setModel(item, player);
}
})
console.log('pumpModelArr=', pumpModelArr)
}
//模型标签
const remarkLabArr = [{ name: "221", text: "USAB进水", x: 2.0501311208405713, y: -0.7778027560129786, z: -5.4, ry:360 }
, { name: "211", text: "USAB进水", x: 0.1740166304621844, y: -0.7760432883855322, z: -5.4, ry: 360 },
{ name: "491", text: "至污泥浓缩池", x: -2.105188770141037, y: -0.7901334936138524, z: -5.4, ry: 360 }]
//添加 模型标签
function addRemarkLabels() {
remarkLabArr.forEach((item, index) => {
let labelMesh = modellabel.createRemarkLabel(item.text, item.x, item.y, item.z);
labelMesh.rotation.y = Math.PI*(item.ry/360);
labelMesh.rotation.x = Math.PI * (30 / 360);;
// labelMesh.rotation.x= rz;
window.scene.add(labelMesh);
})
}
//红色标签
const labArr = [{ name: "水泵M_1", text: "水泵1" }, { name: "水泵M_2", text: "水泵002" }
, { name: "水泵M_3", text: "水泵003" }, { name: "水泵M_4", text: "水泵4" }, { name: "水泵M_5", text: "水泵5" }
, { name: "OilTank001", text: "PT桶1" }, { name: "OilTank002", text: "PT桶2" }, { name: "OilTank003", text: "PT桶3" },
//通过 模型名称获取标签名称
]
//通过 模型名称获取标签名称
async function getlabel(name) {
let result;
labArr.forEach((item, index) => {
if (item.name === name) {
result = item;
return null;
}
})
return result
}
//普通标签
async function addLabel(parent, x = 0, y = 0, z = 0, className = 'label') {
console.log("parent.name=", parent.name)
if (!parent.name) {
return;
}
console.log("parent.name2=", parent.name)
let item = await getlabel(parent.name);
console.log("item2=", item)
// debugger
if (!item) return;
console.log("item2=", item)
const labelDiv = document.createElement('div');
labelDiv.className = className;
labelDiv.name = "csslabel";
labelDiv.textContent = item.text;
labelDiv.style.marginTop = '-1em';
labelDiv.style.pointerEvents = 'none';//避免HTML标签遮挡三维场景的鼠标事件
const css2DLabel = new CSS2DObject(labelDiv);
css2DLabel.position.set(x, y, z);
css2DLabel.name = "datalabel"
css2DLabel.userData = { name: "datalable", id: "", url: "" }
// css2DLabelList.add(css2DLabel);
if (parent) {
parent.add(css2DLabel);
} else {
window.scene.add(css2DLabel);
if (item) {
let css2DLabel = css2dlabel.createCSSLabel(item.text, x, y, z, className);
if (parent) {
parent.add(css2DLabel);
} else {
window.scene.add(css2DLabel);
}
}
}
//添加模型标签
async function addRemarkLabel(parent, text, x = 0, y = 0, z = 0, ry = 9.5) {
let labelCanvas = getTextCanvas(text);
const labelTexture = new THREE.Texture(labelCanvas);
labelTexture.magFilter = THREE.LinearFilter;
labelTexture.minFilter = THREE.LinearFilter;
labelTexture.needsUpdate = true;
const labelMaterial = new THREE.MeshBasicMaterial({
map: labelTexture,
side: THREE.DoubleSide
});
labelMaterial.transparent = true;
const labelPlane = new THREE.PlaneGeometry(labelCanvas.width, labelCanvas.height);
let labelMesh = new THREE.Mesh(labelPlane, labelMaterial);
labelMesh.name = '标签'
labelMesh.position.set(x, y, z);
labelMesh.scale.set(0.01, 0.01, 0.01);
labelMesh.userData = { name: "imaglable", id: "", url: "" }
labelMesh.rotation.y = ry;
// labelMesh.rotation.x = rx;
// labelMesh.rotation.x= rz;
if (parent) {
parent.add(labelMesh);
} else {
window.scene.add(labelMesh);
}
}
function getTextCanvas(text) {
var width = text.length * 26, height = 22;
var canvas = document.createElement('canvas');
canvas.width = width;
canvas.height = height;
var ctx = canvas.getContext('2d');
ctx.fillStyle = 'rgba( 233, 233, 233, 0.8 )';// '#CfCfC3';
ctx.fillRect(0, 0, width, height);
ctx.font = 14 + 'px " bold ';
ctx.fillStyle = '#000';
ctx.textAlign = 'center';
ctx.textBaseline = 'middle';
ctx.fillText(text, width / 2, height / 2);
return canvas;
}
//状态标签
async function addStateLabel(parent, x = 0, y = 0, z = 0, className = 'label') {
console.log("parent.name=", parent.name)
if (!parent.name) {
return;
}
console.log("parent.name2=", parent.name)
let item = await getlabel(parent.name);
console.log("item2=", item)
// debugger
if (!item) return;
console.log("item2=", item)
const labelDiv = document.createElement('div');
labelDiv.className = className;
labelDiv.name = "csslabel";
labelDiv.textContent = '●' + item.text;
labelDiv.style.marginTop = '-1em';
labelDiv.style.pointerEvents = 'none';//避免HTML标签遮挡三维场景的鼠标事件
const css2DLabel = new CSS2DObject(labelDiv);
css2DLabel.position.set(x, y, z);
css2DLabel.name = "datalabel"
css2DLabel.userData = { name: "datalable", id: "", url: "" }
// css2DLabelList.add(css2DLabel);
parent.add(css2DLabel);
if (item) {
let css2DLabel = css2dlabel.createCSSLabel('●' + item.text, x, y, z, className);
if (parent) {
parent.add(css2DLabel);
} else {
window.scene.add(css2DLabel);
}
}
}
//添加动态水
@ -411,55 +367,8 @@
scene.add(waterobj);
player.addWater(waterobj);
}
// 设置标签
function setModel(scene, player) {
scene.castShadow = true; // 开启阴影
scene.receiveShadow = true; // 接受阴影
scene.children.forEach((item, index) => {
// console.log("--------item ==", index);
// console.log("name=", item.name)
// console.log("type=", item.type)
if (item.name.indexOf('OilTank00') > -1) {
addLabel(item, 0, 0.4, 0)
}
else if (item.name.indexOf('水泵M_') > -1) { // 水泵
pumpModelArr.push(item);
//debugger
if (item.name === '水泵001') {
item.material.color.set(0xff0000);
} else {
item.material.color.set(0x006600);
}
addStateLabel(item, 0, 3, 0)
}
if (item.type === 'Object3D' || item.type === 'Group') { // 有下一级
setModel(item, player);
}
})
console.log('pumpModelArr=', pumpModelArr)
}
//添加 模型标签
function addRemarkLabels() {
remarkLabArr.forEach((item, index) => {
addRemarkLabel(null, item.text, item.x, item.y, item.z, item.ry)
})
}
//测试用
let clickindex = false;
//全开全关 测试
window.btnclick = function () {

320
app/lndexzhsc.html

@ -37,10 +37,19 @@
color: #ff000f;
font-family: sans-serif;
padding: 2px;
/* background: rgba(0, 0, 0, .6); */
}
.label1 {
color: #ffffff;
font-family: sans-serif;
padding: 2px;
background: rgba(0, 0, 0, .6);
}
</style>
<script async src="/app/bin/layui/layui.js"></script>
<script type="importmap">
{
"imports": {
@ -52,7 +61,7 @@
</head>
<body ontouchstart="">
<div class="info">2D数据表格显示 不旋转 综合水池</div>
<div class="info">2D数据表格显示 不旋转 厌氧系统 <button onclick="btnclick()">全开</button></div>
<script type="module">
import * as THREE from 'three';
@ -62,9 +71,17 @@
import { OrbitControls } from 'jsm/controls/OrbitControls.js';
import { CSS2DRenderer, CSS2DObject } from 'jsm/renderers/CSS2DRenderer.js';
import { Water } from 'jsm/objects/Water.js';
import modellabel from './js/units/modellabel.js'
import css2dlabel from './js/units/css2dlabel.js'
const type = 1;
window.THREE = THREE; // Used by APP Scripts.
window.VRButton = VRButton; // Used by APP Scripts.
//水泵列表
let pumpModelArr = []
console.log('Math.PI=',Math.PI);
var loader = new THREE.FileLoader();
loader.load('zhsc.json', function (text) {
@ -82,42 +99,59 @@
});
var orbitControls = new OrbitControls(window.camera, player.dom);
initLable();
// initLable();
// setModel(window.scene, player);
// AddWaters(player);
addRemarkLabels();
});
function initLable() {
const labobjarr = [{ text: "测试标签1", x: -1, y: 0, z: 1 }, { text: "测试标签2", x: 1, y: 1, z: 1 }]
for (var i = 0, length = labobjarr.length; i < length; i++) {
addLabel(labobjarr[i], scene, i);
}
}
function addLabel(obj, scene, i) {
const labelDiv = document.createElement('div');
labelDiv.className = 'label';
labelDiv.name = "label" + i;
labelDiv.textContent = obj.text;
labelDiv.style.pointerEvents = 'none';//避免HTML标签遮挡三维场景的鼠标事件
const css2DLabel = new CSS2DObject(labelDiv);
css2DLabel.position.set(obj.x, obj.y, obj.z);
css2DLabel.name = "datalabel" + i;
css2DLabel.userData = { name: "datalable", id: "", url: "" }
// css2DLabelList.add(css2DLabel);
window.scene.add(css2DLabel);
}
//添加这个就可以用鼠标拖动
var raycaster = new THREE.Raycaster()
var mouse = new THREE.Vector2()
//点击模型
window.addEventListener('click', onMouseClick);
// window.addEventListener('click', onMouseClick);
window.addEventListener('dblclick', onDBMouseClick);
// function onMouseClick(event) {
// //将鼠标点击位置的屏幕坐标转换成threejs中的标准坐标
// mouse.x = (event.clientX / window.innerWidth) * 2 - 1
// mouse.y = -((event.clientY / window.innerHeight) * 2 - 1)
// //console.log("mouse:"+mouse.x+","+mouse.y)
// // 通过鼠标点的位置和当前相机的矩阵计算出raycaster
// raycaster.setFromCamera(mouse, window.camera);
// // 获取raycaster直线和所有模型相交的数组集合
// var intersects = raycaster.intersectObjects(scene.children);
// console.log(intersects);
// //debugger
// //将所有的相交的模型的颜色设置为红色
// for (var i = 0; i < intersects.length; i++) {
// let obj = intersects[i];
// if (obj.object) {
// // if (obj.object.name == "视频监控1") {
// // obj.object.material.color.set(0xff6666);
// // alert("视频");
// // } else {
// // obj.object.material.color.set(0xff0000);
// // }
// }
// }
// }
function onMouseClick(event) {
function onDBMouseClick(event) {
//将鼠标点击位置的屏幕坐标转换成threejs中的标准坐标
mouse.x = (event.clientX / window.innerWidth) * 2 - 1
@ -130,39 +164,243 @@
// 获取raycaster直线和所有模型相交的数组集合
var intersects = raycaster.intersectObjects(scene.children);
console.log(intersects);
//debugger
//将所有的相交的模型的颜色设置为红色
for (var i = 0; i < intersects.length; i++) {
let obj = intersects[i];
if (obj.object) {
let tmpobj = obj.object;
console.log(tmpobj)
//输出 增加标签 位置
console.log('{name:"' + tmpobj.name + '1",text:"' + tmpobj.name + '",x:' + obj.point.x.toFixed(2) + ',y:' + obj.point.y.toFixed(2) + ',z:' + obj.point.z.toFixed(2) + ',rx:-180,ry:0,rz:160}');
if (tmpobj.name.indexOf('水泵M_') > -1) { // 水泵
openDialog(tmpobj)
//alert(tmpobj.name, "双击");
}
break;
}
}
}
//打开对话框
function openDialog(tmpobj) {
layer.open({
type: 1
, offset: type //具体配置参考:http://doc/modules/layer.html#offset
, id: 'layerDemo' + type //防止重复弹出
, content: '<div style="padding: 20px 100px;">' + tmpobj.name + '</div>'
, btn: '关闭'
, btnAlign: 'c' //按钮居中
, shade: 0 //不显示遮罩
, yes: function () {
layer.closeAll();
}
});
}
if (obj.object.name == "视频监控1") {
obj.object.material[0].color.set(0xff6666);
alert("视频");
// 设置标签
function setModel(scene, player) {
scene.castShadow = true; // 开启阴影
scene.receiveShadow = true; // 接受阴影
scene.children.forEach((item, index) => {
// console.log("--------item ==", index);
// console.log("name=", item.name)
// console.log("type=", item.type)
if (item.name.indexOf('OilTank00') > -1) {
addLabel(item, 0, 0.4, 0)
}
else if (item.name.indexOf('水泵M_') > -1) { // 水泵
pumpModelArr.push(item);
//debugger
if (item.name === '水泵001') {
item.material.color.set(0xff0000);
} else {
obj.object.material[0].color.set(0xff0000);
item.material.color.set(0x006600);
}
addStateLabel(item, 0, 3, 0)
}
if (item.type === 'Object3D' || item.type === 'Group') { // 有下一级
setModel(item, player);
}
})
console.log('pumpModelArr=', pumpModelArr)
}
//模型标签
const remarkLabArr = [{ name: "水管301", text: "至板式换热器", x: 2.588, y: 0.031, z: -1.6, rx:-180 ,ry: 0 ,rz:160}
, { name: "水管291", text: "水管29", x: 2.33, y: 0.031, z: -1.46, rx: -180, ry: 0, rz: 160 }
,{ name: "水管281", text: "水管28", x: 1.980, y: 0.031, z: -1.46, rx: -180, ry: 0, rz: 160 }
, { name: "水管271", text: "水管27", x: 1.729, y: 0.031, z: -1.46, rx: -180, ry: 0, rz: 160 }
, { name: "水管251", text: "水管25", x: -0.084, y: 0.031, z: -1.46, rx: -180, ry: 0, rz: 160 }
,{ name: "水管221", text: "水管22", x: -0.594, y: 0.031, z: -1.46, rx: -180, ry: 0, rz: 160 }
, { name: "水管211", text: "水管21", x: -1.450, y: 0.031, z: -1.46, rx: -180, ry: 0, rz: 160 }
, { name: "水管61", text: "水管6", x: -2.062, y: 0.031, z: -1.46, rx: -180, ry: 0, rz: 160 }
, { name: "水管51", text: "水管5", x: -2.324, y: 0.031, z: -1.46, rx: -180, ry: 0, rz: 160 }
, { name: "水管41", text: "水管4", x: -2.560, y: 0.031, z: -1.46, rx: -180, ry: 0, rz: 160 }
, { name: "水管31", text: "水管3", x: -2.824, y: 0.031, z: -1.46, rx: -180, ry: 0, rz: 160 }
, { name: "水管21", text: "水管2", x: -3.072, y: 0.031, z: -1.46, rx: -180, ry: 0, rz: 160 }
, { name: "水管11", text: "水管1", x: -3.317, y: 0.031, z: -1.46, rx: -180, ry: 0, rz: 160 }
]
//添加 模型标签
function addRemarkLabels() {
remarkLabArr.forEach((item, index) => {
let labelMesh = modellabel.createRemarkLabel(item.text, item.x, item.y, item.z);
labelMesh.rotation.x = Math.PI*(item.rx/360);
labelMesh.rotation.z = Math.PI * (item.rz/360);
labelMesh.rotation.y= 0;
window.scene.add(labelMesh);
})
}
//红色标签
const labArr = [{ name: "水泵M_1", text: "水泵1" }, { name: "水泵M_2", text: "水泵002" }
, { name: "OilTank001", text: "PT桶1" }, { name: "OilTank002", text: "PT桶2" }, { name: "OilTank003", text: "PT桶3" },
]
//通过 模型名称获取标签名称
async function getlabel(name) {
let result;
labArr.forEach((item, index) => {
if (item.name === name) {
result = item;
return null;
}
})
return result
}
//普通标签
async function addLabel(parent, x = 0, y = 0, z = 0, className = 'label') {
if (!parent.name) {
return;
}
console.log("parent.name2=", parent.name)
let item = await getlabel(parent.name);
// debugger
if (item) {
let css2DLabel = css2dlabel.createCSSLabel(item.text, x, y, z, className);
if (parent) {
parent.add(css2DLabel);
} else {
window.scene.add(css2DLabel);
}
}
}
//状态标签
async function addStateLabel(parent, x = 0, y = 0, z = 0, className = 'label') {
if (!parent.name) {
return;
}
console.log("parent.name2=", parent.name)
let item = await getlabel(parent.name);
if (item) {
let css2DLabel = css2dlabel.createCSSLabel('●' + item.text, x, y, z, className);
if (parent) {
parent.add(css2DLabel);
} else {
window.scene.add(css2DLabel);
}
}
}
//添加动态水
function AddWaters(player) {
let water1 = {}
water1.position = { x: 0, y: 1, z: 0 }
water1.scale = { x: 4, y: 2.6 }
AddWater(water1, player)
let water2 = {}
water2.position = { x: 0, y: 1, z: 5 }
water2.scale = { x: 7.5, y: 8 }
AddWater(water2, player)
}
function AddWater(water, player) {
const waterGeometry = new THREE.PlaneGeometry(water.scale.x, water.scale.y);
let waterobj = new Water(
waterGeometry,
{
textureWidth: 255,
textureHeight: 255,
waterNormals: new THREE.TextureLoader().load('./img/waternormals.jpg', function (texture) {
texture.wrapS = texture.wrapT = THREE.RepeatWrapping;
}),
sunDirection: new THREE.Vector3(),
sunColor: 0xffffff,
waterColor: 0x3498DB,
distortionScale: 0.5,//波浪大小
fog: true// scene.fog !== undefined
}
);
waterobj.position.set(water.position.x, water.position.y, water.position.z)
waterobj.rotation.x = - Math.PI / 2;
scene.add(waterobj);
player.addWater(waterobj);
}
//测试用
let clickindex = false;
//全开全关 测试
window.btnclick = function () {
function createCSSLabel(text, parent) {
pumpModelArr.forEach((item, index) => {
if (clickindex) {
item.material.color.set(0x00ff00);
const labelDiv = document.createElement('div');
labelDiv.className = 'label';
labelDiv.name = "csslabeldiv"
labelDiv.textContent = text;
} else {
item.material.color.set(0x666666);
labelDiv.style.pointerEvents = 'none';//避免HTML标签遮挡三维场景的鼠标事件
const moonLabel = new CSS2DObject(labelDiv);
moonLabel.position.set(1, 2, 0);
moonLabel.name = "datalabel"
moonLabel.userData = { name: "datalable", id: "", url: "" }
return moonLabel;
}
clickindex = !clickindex;
})
}
</script>
<!-- Code injected by live-server -->
<script>
// <![CDATA[ <-- For SVG support
@ -201,6 +439,10 @@
}
// ]]>
</script>
<script>
</script>
</body>
</html>

Loading…
Cancel
Save