Browse Source

标签OK

master
lxc 2 years ago
parent
commit
436b77219f
  1. 4247
      app/UASB.json
  2. 4247
      app/UASB1.json
  3. 4247
      app/UASB2.json
  4. 304
      app/js/app3d.js
  5. 168
      app/lndexUASB.html
  6. 4
      editor/js/commands/AddLableCommand.js
  7. 58
      editor/js/menus/Menubar.Models.js

4247
app/UASB.json

File diff suppressed because one or more lines are too long

4247
app/UASB1.json

File diff suppressed because one or more lines are too long

4247
app/UASB2.json

File diff suppressed because one or more lines are too long

304
app/js/app3d.js

@ -0,0 +1,304 @@
// import { CSS2DRenderer, CSS2DObject } from '/examples/jsm/renderers/CSS2DRenderer.js';
import { CSS3DRenderer, CSS3DObject } from '/examples/jsm/renderers/CSS3DRenderer.js';
var APP = {
Player: function () {
var renderer = new THREE.WebGLRenderer({ antialias: true });
renderer.setPixelRatio(window.devicePixelRatio); // TODO: Use player.setPixelRatio()
renderer.outputEncoding = THREE.sRGBEncoding;
var css2DRenderer = createCSS2DRenderer()
var loader = new THREE.ObjectLoader();
var camera, scene;
var vrButton = VRButton.createButton(renderer); // eslint-disable-line no-undef
var events = {};
var dom = document.createElement('div');
dom.appendChild(renderer.domElement);
dom.appendChild(css2DRenderer.domElement);
this.dom = dom;
var waters=[];
this.width = 500;
this.height = 500;
function createCSS2DRenderer() {
css2DRenderer = new CSS3DRenderer();
css2DRenderer.setSize(window.innerWidth, window.innerHeight);
css2DRenderer.domElement.style.position = 'absolute';
css2DRenderer.domElement.style.top = '0px';//信息弹窗界面高度一半
css2DRenderer.domElement.style.left = '0px';//信息弹窗界面宽度一半
css2DRenderer.domElement.style.pointerEvents = 'none';
return css2DRenderer;
}
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;
}
this.load = function (json) {
var project = json.project;
if (project.vr !== undefined) renderer.xr.enabled = project.vr;
if (project.shadows !== undefined) renderer.shadowMap.enabled = project.shadows;
if (project.shadowType !== undefined) renderer.shadowMap.type = project.shadowType;
if (project.toneMapping !== undefined) renderer.toneMapping = project.toneMapping;
if (project.toneMappingExposure !== undefined) renderer.toneMappingExposure = project.toneMappingExposure;
if (project.physicallyCorrectLights !== undefined) renderer.physicallyCorrectLights = project.physicallyCorrectLights;
this.setScene(loader.parse(json.scene));
this.setCamera(loader.parse(json.camera));
events = {
init: [],
start: [],
stop: [],
keydown: [],
keyup: [],
pointerdown: [],
pointerup: [],
pointermove: [],
update: []
};
var scriptWrapParams = 'player,renderer,scene,camera';
var scriptWrapResultObj = {};
for (var eventKey in events) {
scriptWrapParams += ',' + eventKey;
scriptWrapResultObj[eventKey] = eventKey;
}
var scriptWrapResult = JSON.stringify(scriptWrapResultObj).replace(/\"/g, '');
for (var uuid in json.scripts) {
var object = scene.getObjectByProperty('uuid', uuid, true);
if (object === undefined) {
console.warn('APP.Player: Script without object.', uuid);
continue;
}
var scripts = json.scripts[uuid];
for (var i = 0; i < scripts.length; i++) {
var script = scripts[i];
var functions = (new Function(scriptWrapParams, script.source + '\nreturn ' + scriptWrapResult + ';').bind(object))(this, renderer, scene, camera);
for (var name in functions) {
if (functions[name] === undefined) continue;
if (events[name] === undefined) {
console.warn('APP.Player: Event type not supported (', name, ')');
continue;
}
events[name].push(functions[name].bind(object));
}
}
}
dispatch(events.init, arguments);
// this.initLable();
};
this.setCamera = function (value) {
camera = value;
camera.aspect = this.width / this.height;
camera.updateProjectionMatrix();
// this.camera = camera;
window.camera = camera;
};
this.setScene = function (value) {
scene = value;
window.scene = scene
};
this.addWater=function(water){
waters.push(water);
}
this.setPixelRatio = function (pixelRatio) {
renderer.setPixelRatio(pixelRatio);
};
this.setSize = function (width, height) {
this.width = width;
this.height = height;
if (camera) {
camera.aspect = this.width / this.height;
camera.updateProjectionMatrix();
}
renderer.setSize(width, height);
};
function dispatch(array, event) {
for (var i = 0, l = array.length; i < l; i++) {
array[i](event);
}
}
var time, startTime, prevTime;
function render(time) {
// dispatch(events.update, { time: time * 1000, delta: 0 /* TODO */ });
renderer.render(scene, camera);
if (css2DRenderer != null) {
css2DRenderer.render(scene, camera);
}
waters.forEach(water => {
// 播放特效
water.material.uniforms['time'].value += 1.0 / 60.0;
});
};
function animate() {
time = performance.now();
try {
dispatch(events.update, { time: time - startTime, delta: time - prevTime });
} catch (e) {
console.error((e.message || e), (e.stack || ''));
}
// renderer.render(scene, camera);
render(time);
prevTime = time;
}
this.play = function () {
if (renderer.xr.enabled) dom.append(vrButton);
startTime = prevTime = performance.now();
document.addEventListener('keydown', onKeyDown);
document.addEventListener('keyup', onKeyUp);
document.addEventListener('pointerdown', onPointerDown);
document.addEventListener('pointerup', onPointerUp);
document.addEventListener('pointermove', onPointerMove);
dispatch(events.start, arguments);
renderer.setAnimationLoop(animate);
};
this.stop = function () {
if (renderer.xr.enabled) vrButton.remove();
document.removeEventListener('keydown', onKeyDown);
document.removeEventListener('keyup', onKeyUp);
document.removeEventListener('pointerdown', onPointerDown);
document.removeEventListener('pointerup', onPointerUp);
document.removeEventListener('pointermove', onPointerMove);
dispatch(events.stop, arguments);
renderer.setAnimationLoop(null);
};
this.dispose = function () {
renderer.dispose();
camera = undefined;
scene = undefined;
};
//
function onKeyDown(event) {
dispatch(events.keydown, event);
}
function onKeyUp(event) {
dispatch(events.keyup, event);
}
function onPointerDown(event) {
dispatch(events.pointerdown, event);
}
function onPointerUp(event) {
dispatch(events.pointerup, event);
}
function onPointerMove(event) {
dispatch(events.pointermove, event);
}
}
};
export { APP };

168
app/lndexUASB.html

@ -39,12 +39,14 @@
padding: 2px; padding: 2px;
/* background: rgba(0, 0, 0, .6); */ /* background: rgba(0, 0, 0, .6); */
} }
.label1 {
.label1 {
color: #ffffff; color: #ffffff;
font-family: sans-serif; font-family: sans-serif;
padding: 2px; padding: 2px;
background: rgba(0, 0, 0, .6); background: rgba(0, 0, 0, .6);
} }
</style> </style>
<script async src="/app/bin/layui/layui.js"></script> <script async src="/app/bin/layui/layui.js"></script>
@ -73,6 +75,19 @@
const type = 1; const type = 1;
window.THREE = THREE; // Used by APP Scripts. window.THREE = THREE; // Used by APP Scripts.
window.VRButton = VRButton; // 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(); var loader = new THREE.FileLoader();
loader.load('UASB3.json', function (text) { loader.load('UASB3.json', function (text) {
@ -127,35 +142,35 @@
//点击模型 //点击模型
// window.addEventListener('click', onMouseClick); // window.addEventListener('click', onMouseClick);
window.addEventListener('dblclick', onDBMouseClick); window.addEventListener('dblclick', onDBMouseClick);
function onMouseClick(event) { // function onMouseClick(event) {
//将鼠标点击位置的屏幕坐标转换成threejs中的标准坐标 // //将鼠标点击位置的屏幕坐标转换成threejs中的标准坐标
mouse.x = (event.clientX / window.innerWidth) * 2 - 1 // mouse.x = (event.clientX / window.innerWidth) * 2 - 1
mouse.y = -((event.clientY / window.innerHeight) * 2 - 1) // mouse.y = -((event.clientY / window.innerHeight) * 2 - 1)
//console.log("mouse:"+mouse.x+","+mouse.y) // //console.log("mouse:"+mouse.x+","+mouse.y)
// 通过鼠标点的位置和当前相机的矩阵计算出raycaster // // 通过鼠标点的位置和当前相机的矩阵计算出raycaster
raycaster.setFromCamera(mouse, window.camera); // raycaster.setFromCamera(mouse, window.camera);
// 获取raycaster直线和所有模型相交的数组集合 // // 获取raycaster直线和所有模型相交的数组集合
var intersects = raycaster.intersectObjects(scene.children); // var intersects = raycaster.intersectObjects(scene.children);
console.log(intersects); // console.log(intersects);
//debugger // //debugger
//将所有的相交的模型的颜色设置为红色 // //将所有的相交的模型的颜色设置为红色
for (var i = 0; i < intersects.length; i++) { // for (var i = 0; i < intersects.length; i++) {
let obj = intersects[i]; // let obj = intersects[i];
if (obj.object) { // if (obj.object) {
// if (obj.object.name == "视频监控1") { // // if (obj.object.name == "视频监控1") {
// obj.object.material.color.set(0xff6666); // // obj.object.material.color.set(0xff6666);
// alert("视频"); // // alert("视频");
// } else { // // } else {
// obj.object.material.color.set(0xff0000); // // obj.object.material.color.set(0xff0000);
// // }
// }
// }
// } // }
}
}
}
// function guid() { // function guid() {
// return 'xxxxxxxxxxxx4xxxyxxxxxxxxxxxxxxx'.replace(/[xy]/g, function (c) { // return 'xxxxxxxxxxxx4xxxyxxxxxxxxxxxxxxx'.replace(/[xy]/g, function (c) {
// var r = Math.random() * 16 | 0, // var r = Math.random() * 16 | 0,
@ -186,20 +201,15 @@
if (obj.object) { if (obj.object) {
let tmpobj = obj.object; let tmpobj = obj.object;
console.log(tmpobj) console.log(tmpobj)
console.log('{name:"' + tmpobj.name +'1",text:"'+ tmpobj.name +'",x:' + obj.point.x +',y:' + obj.point.y +',z:'+ obj.point.z+'}'); //输出 增加标签 位置
console.log('{name:"' + tmpobj.name + '1",text:"' + tmpobj.name + '",x:' + obj.point.x + ',y:' + obj.point.y + ',z:' + obj.point.z + ',rx:0}');
if (tmpobj.name.indexOf('水泵M_') > -1) { // 水泵 if (tmpobj.name.indexOf('水泵M_') > -1) { // 水泵
openDialog(tmpobj) openDialog(tmpobj)
//alert(tmpobj.name, "双击"); //alert(tmpobj.name, "双击");
} }
break; break;
// let mondeojb = {}
// mondeojb.id = guid();
// mondeojb.text = "新标签";
// mondeojb.position = tmpobj.position;
// mondeojb.rotation = tmpobj.rotation;
// var json = JSON.stringify(mondeojb);
// console.log(json);
} }
} }
} }
@ -220,6 +230,7 @@
} }
}); });
} }
//创建标签
function createCSSLabel(text, parent) { function createCSSLabel(text, parent) {
const labelDiv = document.createElement('div'); const labelDiv = document.createElement('div');
@ -235,17 +246,9 @@
return moonLabel; return moonLabel;
} }
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: "22", x: 2.0501311208405713, y: -0.9778027560129786, z: -5.377062185399511 }, { name: "211", text: "21", x: 0.1740166304621844, y: -0.9760432883855322, z: -5.667636935767586 },
{ name: "491", text: "49", x: -2.105188770141037, y: -0.9901334936138524, z: -5.4669334625207435 }]
//通过 模型名称获取标签名称
async function getlabel(name) { async function getlabel(name) {
let result; let result;
@ -285,37 +288,62 @@
css2DLabel.name = "datalabel" css2DLabel.name = "datalabel"
css2DLabel.userData = { name: "datalable", id: "", url: "" } css2DLabel.userData = { name: "datalable", id: "", url: "" }
// css2DLabelList.add(css2DLabel); // css2DLabelList.add(css2DLabel);
if(parent){ if (parent) {
parent.add(css2DLabel); parent.add(css2DLabel);
}else{ } else {
window.scene.add(css2DLabel); window.scene.add(css2DLabel);
} }
} }
async function addRemarkLabel(parent,text, x = 0, y = 0, z = 0, className = 'label') { //添加模型标签
async function addRemarkLabel(parent, text, x = 0, y = 0, z = 0, ry = 9.5) {
const labelDiv = document.createElement('div');
labelDiv.className = className;
labelDiv.name = "csslabel";
labelDiv.textContent = text;
labelDiv.style.marginTop = '-1em';
labelDiv.style.pointerEvents = 'none';//避免HTML标签遮挡三维场景的鼠标事件 let labelCanvas = getTextCanvas(text);
const css2DLabel = new CSS2DObject(labelDiv); const labelTexture = new THREE.Texture(labelCanvas);
css2DLabel.position.set(x, y, z); labelTexture.magFilter = THREE.LinearFilter;
css2DLabel.name = "datalabel" labelTexture.minFilter = THREE.LinearFilter;
css2DLabel.userData = { name: "datalable", id: "", url: "" } labelTexture.needsUpdate = true;
// css2DLabelList.add(css2DLabel);
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) { if (parent) {
parent.add(css2DLabel); parent.add(labelMesh);
} else { } else {
window.scene.add(css2DLabel); 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') { async function addStateLabel(parent, x = 0, y = 0, z = 0, className = 'label') {
@ -345,6 +373,7 @@
parent.add(css2DLabel); parent.add(css2DLabel);
} }
//添加动态水
function AddWaters(player) { function AddWaters(player) {
let water1 = {} let water1 = {}
water1.position = { x: 0, y: 1, z: 0 } water1.position = { x: 0, y: 1, z: 0 }
@ -423,19 +452,16 @@
}) })
console.log('pumpModelArr=', pumpModelArr) console.log('pumpModelArr=', pumpModelArr)
} }
function addRemarkLabels(){ //添加 模型标签
function addRemarkLabels() {
remarkLabArr.forEach((item, index) => { remarkLabArr.forEach((item, index) => {
addRemarkLabel(null,item.text,item.x,item.y,item.z,'label1') addRemarkLabel(null, item.text, item.x, item.y, item.z, item.ry)
}) })
} }
function addDBclick(item) {
item.ondbclick = pumpDBClick
}
function pumpDBClick(event) {
alert("ddd111111");
}
let clickindex = false; let clickindex = false;
//全开全关 测试
window.btnclick = function () { window.btnclick = function () {
pumpModelArr.forEach((item, index) => { pumpModelArr.forEach((item, index) => {

4
editor/js/commands/AddLableCommand.js

@ -25,9 +25,9 @@ class AddLableCommand extends Command {
execute() { execute() {
//this.editor.addObject( this.object ); this.editor.addObject( this.object );
this.editor.addLable(this.object); this.editor.addLable(this.object);
//this.editor.select( this.object ); this.editor.select( this.object );
} }

58
editor/js/menus/Menubar.Models.js

@ -120,15 +120,15 @@ function MenubarModels(editor) {
option.setTextContent(strings.getKey('menubar/models/addlable')); option.setTextContent(strings.getKey('menubar/models/addlable'));
option.onClick(function () { option.onClick(function () {
// debugger
// return; // return;
let selectobj = editor.selected; let selectobj = editor.selected;
if (!!!selectobj) { // if (!!!selectobj) {
alert("none"); // alert("none");
return; // return;
} // }
add2dlable("中国"); add2dlable(selectobj, "abc");
// selectobj.layers.enableAll(); // selectobj.layers.enableAll();
// debugger // debugger
// const moonDiv = document.createElement('div'); // const moonDiv = document.createElement('div');
@ -158,14 +158,14 @@ function MenubarModels(editor) {
//create a blue LineBasicMaterial //create a blue LineBasicMaterial
const csslable= AddCSSLabel(); const csslable = AddCSSLabel();
editor.execute(new AddObjectCommand(editor, csslable)); editor.execute(new AddObjectCommand(editor, csslable));
}); });
options.add(option) options.add(option)
options.add(option); // options.add(option);
// option = new UIRow(); // option = new UIRow();
@ -190,26 +190,19 @@ function MenubarModels(editor) {
// editor.execute(new AddObjectCommand(editor, line)); // editor.execute(new AddObjectCommand(editor, line));
// }); // });
options.add(option) // options.add(option)
return container; return container;
} }
function add2dlable(text) {
let labelCanvas = document.createElement('canvas'); function add2dlable(parent, text) {
const context = labelCanvas.getContext('2d'); let labelCanvas = getTextCanvas(text);
context.font = 'Bold 20px Arial';
const labelWidth = context.measureText(text).width;
labelCanvas.width = labelWidth;
labelCanvas.height = 25; //25 to account for g, p, etc.
context.font = 'Bold 20px Arial';
context.fillStyle = 'rgba( 255, 0, 0, 1 )';
context.fillText(text, 0, 20);
const labelTexture = new THREE.Texture(labelCanvas); const labelTexture = new THREE.Texture(labelCanvas);
labelTexture.magFilter = THREE.LinearFilter; labelTexture.magFilter = THREE.LinearFilter;
labelTexture.minFilter = THREE.LinearFilter; labelTexture.minFilter = THREE.LinearFilter;
labelTexture.needsUpdate = true; labelTexture.needsUpdate = true;
const labelMaterial = new THREE.MeshBasicMaterial({ const labelMaterial = new THREE.MeshBasicMaterial({
map: labelTexture, map: labelTexture,
side: THREE.DoubleSide side: THREE.DoubleSide
@ -219,7 +212,28 @@ function add2dlable(text) {
let labelMesh = new THREE.Mesh(labelPlane, labelMaterial); let labelMesh = new THREE.Mesh(labelPlane, labelMaterial);
labelMesh.name = '标签' labelMesh.name = '标签'
labelMesh.scale.set(0.01, 0.01, 0.01);
if (parent) {
parent.add(labelMesh)
} else {
editor.execute(new AddLableCommand(editor, labelMesh)); editor.execute(new AddLableCommand(editor, labelMesh));
}
}
function getTextCanvas(text, fontcolor = 'rgba( 0, 0, 0, 1 )') {
var width = text.length*26, height = 22;
var canvas = document.createElement('canvas');
canvas.width = width;
canvas.height = height;
var ctx = canvas.getContext('2d');
ctx.font = 20 + 'px " bold ';
ctx.fillStyle = fontcolor
ctx.textAlign = 'center';
ctx.textBaseline = 'middle';
ctx.fillText(text, width/2 , height/2);
return canvas;
} }
function AddCSSLabel() { function AddCSSLabel() {
@ -232,8 +246,8 @@ function AddCSSLabel() {
labelDiv.style.pointerEvents = 'none';//避免HTML标签遮挡三维场景的鼠标事件 labelDiv.style.pointerEvents = 'none';//避免HTML标签遮挡三维场景的鼠标事件
const moonLabel = new CSS2DObject(labelDiv); const moonLabel = new CSS2DObject(labelDiv);
moonLabel.position.set(0, 1, 0); moonLabel.position.set(0, 1, 0);
moonLabel.name="datalabel" moonLabel.name = "datalabel"
moonLabel.userData={name:"datalable",id:"",url:""} moonLabel.userData = { name: "datalable", id: "", url: "" }
return moonLabel; return moonLabel;
} }

Loading…
Cancel
Save