gl-draw 0.11.40 → 0.11.41
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/BaseObject.js +1 -1
- package/dist/BaseObject.module.js +29 -28
- package/dist/core/BaseObject.d.ts +1 -0
- package/package.json +1 -1
package/dist/BaseObject.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";const u=require("three"),b=require("esus-lite"),p=require("three/examples/jsm/renderers/CSS2DRenderer"),d=require("three/examples/jsm/renderers/CSS3DRenderer"),n=require("./disposeMesh.js");require("idb-keyval");require("d3-geo");require("d3-geo-projection");function j(o){const e=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(o){for(const t in o)if(t!=="default"){const i=Object.getOwnPropertyDescriptor(o,t);Object.defineProperty(e,t,i.get?i:{enumerable:!0,get:()=>o[t]})}}return e.default=o,Object.freeze(e)}const r=j(u);class f{constructor(){this.objectType="BaseObject",this.userData={},this.prefab=!1,this.isInstantiate=!1,this.pm=b.makePromiseCreator(),this.materialList={},this.useMaterialType="origin",this.onPointerIndex=[]}get parent(){const e=this.object3d.parent;return e?this.drawController.objMap.get(e)||this.pencil.scene:null}get children(){return this.object3d.children.map(e=>this.drawController.objMap.get(e)).filter(e=>!!e)}get position(){var e;return(e=this.object3d)==null?void 0:e.position}get rotation(){var e;return(e=this.object3d)==null?void 0:e.rotation}get scale(){var e;return(e=this.object3d)==null?void 0:e.scale}get add(){var e;return(e=this.object3d)==null?void 0:e.add.bind(this.object3d)}get remove(){var e;return(e=this.object3d)==null?void 0:e.remove.bind(this.object3d)}get visible(){return this.object3d?this.object3d.visible:!1}create(){}render(){}update(e,t){}resize(e,t){}show(){return this.object3d&&(this.object3d.visible=!0),this}hide(){return this.object3d&&(this.object3d.visible=!1),this}createMesh(...e){return this.object3d=new r.Mesh(...e),this}createGroup(){return this.object3d=new r.Group,this}createPoints(...e){return this.object3d=new r.Points(...e),this}createCSS2DObject(e){return this.object3d=new p.CSS2DObject(e),this}createCSS3DObject(e){return this.object3d=new d.CSS3DObject(e),this}createCSS3DSprite(e){return this.object3d=new d.CSS3DSprite(e),this}createSprite(e){return this.object3d=new r.Sprite(e),this}attach(...e){return[...e].forEach(t=>{this.object3d.attach(t.object3d),this.drawController!==t.drawController&&(t.drawController.objects.delete(t.key),this.drawController.objects.set(t.key,t))}),this}getSize(){const e=new r.Box3().setFromObject(this.object3d);return{min:e.min,max:e.max,size:e.getSize(new r.Vector3)}}traverse(e){e(this),this.children.forEach(t=>{t.traverse(e)})}clone(){return this.instantiate()}instantiate(e){return this.drawController.instantiate(this,{create:t=>{var i;if(this.object3d){if(this.object3d instanceof r.Sprite&&typeof e=="number"){const{size:s}=this.getSize(),a=new r.MeshBasicMaterial,c=["color","map","alphaMap","transparent","opacity","alphaTest","blending","side","depthTest","depthWrite"];for(const h of c){const l=this.object3d.material[h];l!==null&&(a[h]=l)}t.object3d=new r.Mesh(new r.PlaneGeometry(s.x,s.y,2,2),a)}else t.object3d=this.object3d.clone(!0);typeof e=="number"&&(t.object3d=new r.InstancedMesh(t.object3d.geometry,t.object3d.material,e),t.object3d.instanceMatrix.setUsage(r.DynamicDrawUsage)),t.position.set(0,0,0),t.rotation.set(0,0,0),t.setMaterialList("instantiate","clone"),t.useMaterial("instantiate"),t.object3d.userData.bloom&&((i=this.pencil.composerController)==null||i.toggleBloomSelection(t.object3d,!0)),t.object3d.userData.prefab&&(t.object3d.userData.prefab=!1)}}})}setInstancedMatrix(e){this.object3d instanceof r.InstancedMesh&&(Object.keys(e).forEach(t=>{this.object3d.setMatrixAt(Number(t),e[t])}),this.object3d.instanceMatrix.needsUpdate=!0,this.object3d.computeBoundingSphere())}erase(){this.drawController.erase(this)}cloneMaterial(){const e=this.object3d;if(!e||!e.material)return;const t=e.material;if(Array.isArray(t))return t.map(i=>{const s=i.userData;i.userData={};const a=i.clone();return i.userData=s,a});{const i=t.userData;t.userData={};const s=t.clone();return t.userData=i,s}}setMaterialList(e,t,i=!0){const s=this.object3d;if(!s||!s.material)return;if(this.materialList.origin||(this.materialList.origin=s.material),this.materialList[e])if(i){const c=this.materialList[e];n.disposeMesh({material:c})}else return this.materialList[e];const a=t==="clone"?this.cloneMaterial():t;return this.materialList[e]=a,a}useMaterial(e){const t=this.object3d;!t||!t.material||this.useMaterialType===e||!this.materialList[e]||(this.useMaterialType=e,t.material=this.materialList[e])}setTop(e){this.object3d&&(this.object3d.renderOrder=e)}onPointerEvent(e,t){const i=this.drawController.handlePick([this],e,t);this.onPointerIndex.push(i)}dispose(){this.onPointerIndex.forEach(e=>{this.drawController.removePick(e)}),this.object3d&&n.disposeMesh(this.object3d),Object.keys(this.materialList).forEach(e=>{if(e!==this.useMaterialType){if(this.isInstantiate&&e==="origin")return;n.disposeMesh({material:this.materialList[e]})}})}disposeWithOutMaterial(){this.onPointerIndex.forEach(e=>{this.drawController.removePick(e)}),this.object3d&&n.disposeMesh(this.object3d,!1)}}exports.BaseObject=f;
|
|
1
|
+
"use strict";const u=require("three"),b=require("esus-lite"),p=require("three/examples/jsm/renderers/CSS2DRenderer"),d=require("three/examples/jsm/renderers/CSS3DRenderer"),n=require("./disposeMesh.js");require("idb-keyval");require("d3-geo");require("d3-geo-projection");function j(o){const e=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(o){for(const t in o)if(t!=="default"){const i=Object.getOwnPropertyDescriptor(o,t);Object.defineProperty(e,t,i.get?i:{enumerable:!0,get:()=>o[t]})}}return e.default=o,Object.freeze(e)}const r=j(u);class f{constructor(){this.objectType="BaseObject",this.userData={},this.prefab=!1,this.isInstantiate=!1,this.pm=b.makePromiseCreator(),this.materialList={},this.useMaterialType="origin",this.onPointerIndex=[]}get parent(){const e=this.object3d.parent;return e?this.drawController.objMap.get(e)||this.pencil.scene:null}get children(){return this.object3d.children.map(e=>this.drawController.objMap.get(e)).filter(e=>!!e)}get position(){var e;return(e=this.object3d)==null?void 0:e.position}get rotation(){var e;return(e=this.object3d)==null?void 0:e.rotation}get scale(){var e;return(e=this.object3d)==null?void 0:e.scale}get add(){var e;return(e=this.object3d)==null?void 0:e.add.bind(this.object3d)}get remove(){var e;return(e=this.object3d)==null?void 0:e.remove.bind(this.object3d)}get visible(){return this.object3d?this.object3d.visible:!1}create(){}render(){}update(e,t){}resize(e,t){}show(){return this.object3d&&(this.object3d.visible=!0),this}hide(){return this.object3d&&(this.object3d.visible=!1),this}createMesh(...e){return this.object3d=new r.Mesh(...e),this}createGroup(){return this.object3d=new r.Group,this}createPoints(...e){return this.object3d=new r.Points(...e),this}createCSS2DObject(e){return this.object3d=new p.CSS2DObject(e),this}createCSS3DObject(e){return this.object3d=new d.CSS3DObject(e),this}createCSS3DSprite(e){return this.object3d=new d.CSS3DSprite(e),this}createSprite(e){return this.object3d=new r.Sprite(e),this}attach(...e){return[...e].forEach(t=>{this.object3d.attach(t.object3d),this.drawController!==t.drawController&&(t.drawController.objects.delete(t.key),this.drawController.objects.set(t.key,t))}),this}getSize(){const e=new r.Box3().setFromObject(this.object3d);return{min:e.min,max:e.max,size:e.getSize(new r.Vector3),center:e.getCenter(new r.Vector3)}}traverse(e){e(this),this.children.forEach(t=>{t.traverse(e)})}clone(){return this.instantiate()}instantiate(e){return this.drawController.instantiate(this,{create:t=>{var i;if(this.object3d){if(this.object3d instanceof r.Sprite&&typeof e=="number"){const{size:s}=this.getSize(),a=new r.MeshBasicMaterial,c=["color","map","alphaMap","transparent","opacity","alphaTest","blending","side","depthTest","depthWrite"];for(const h of c){const l=this.object3d.material[h];l!==null&&(a[h]=l)}t.object3d=new r.Mesh(new r.PlaneGeometry(s.x,s.y,2,2),a)}else t.object3d=this.object3d.clone(!0);typeof e=="number"&&(t.object3d=new r.InstancedMesh(t.object3d.geometry,t.object3d.material,e),t.object3d.instanceMatrix.setUsage(r.DynamicDrawUsage)),t.position.set(0,0,0),t.rotation.set(0,0,0),t.setMaterialList("instantiate","clone"),t.useMaterial("instantiate"),t.object3d.userData.bloom&&((i=this.pencil.composerController)==null||i.toggleBloomSelection(t.object3d,!0)),t.object3d.userData.prefab&&(t.object3d.userData.prefab=!1)}}})}setInstancedMatrix(e){this.object3d instanceof r.InstancedMesh&&(Object.keys(e).forEach(t=>{this.object3d.setMatrixAt(Number(t),e[t])}),this.object3d.instanceMatrix.needsUpdate=!0,this.object3d.computeBoundingSphere())}erase(){this.drawController.erase(this)}cloneMaterial(){const e=this.object3d;if(!e||!e.material)return;const t=e.material;if(Array.isArray(t))return t.map(i=>{const s=i.userData;i.userData={};const a=i.clone();return i.userData=s,a});{const i=t.userData;t.userData={};const s=t.clone();return t.userData=i,s}}setMaterialList(e,t,i=!0){const s=this.object3d;if(!s||!s.material)return;if(this.materialList.origin||(this.materialList.origin=s.material),this.materialList[e])if(i){const c=this.materialList[e];n.disposeMesh({material:c})}else return this.materialList[e];const a=t==="clone"?this.cloneMaterial():t;return this.materialList[e]=a,a}useMaterial(e){const t=this.object3d;!t||!t.material||this.useMaterialType===e||!this.materialList[e]||(this.useMaterialType=e,t.material=this.materialList[e])}setTop(e){this.object3d&&(this.object3d.renderOrder=e)}onPointerEvent(e,t){const i=this.drawController.handlePick([this],e,t);this.onPointerIndex.push(i)}dispose(){this.onPointerIndex.forEach(e=>{this.drawController.removePick(e)}),this.object3d&&n.disposeMesh(this.object3d),Object.keys(this.materialList).forEach(e=>{if(e!==this.useMaterialType){if(this.isInstantiate&&e==="origin")return;n.disposeMesh({material:this.materialList[e]})}})}disposeWithOutMaterial(){this.onPointerIndex.forEach(e=>{this.drawController.removePick(e)}),this.object3d&&n.disposeMesh(this.object3d,!1)}}exports.BaseObject=f;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import * as
|
|
1
|
+
import * as i from "three";
|
|
2
2
|
import { makePromiseCreator as l } from "esus-lite";
|
|
3
3
|
import { CSS2DObject as d } from "three/examples/jsm/renderers/CSS2DRenderer";
|
|
4
4
|
import { CSS3DObject as b, CSS3DSprite as u } from "three/examples/jsm/renderers/CSS3DRenderer";
|
|
@@ -6,7 +6,7 @@ import { d as o } from "./disposeMesh.module.js";
|
|
|
6
6
|
import "idb-keyval";
|
|
7
7
|
import "d3-geo";
|
|
8
8
|
import "d3-geo-projection";
|
|
9
|
-
class
|
|
9
|
+
class C {
|
|
10
10
|
constructor() {
|
|
11
11
|
this.objectType = "BaseObject", this.userData = {}, this.prefab = !1, this.isInstantiate = !1, this.pm = l(), this.materialList = {}, this.useMaterialType = "origin", this.onPointerIndex = [];
|
|
12
12
|
}
|
|
@@ -55,13 +55,13 @@ class D {
|
|
|
55
55
|
return this.object3d && (this.object3d.visible = !1), this;
|
|
56
56
|
}
|
|
57
57
|
createMesh(...t) {
|
|
58
|
-
return this.object3d = new
|
|
58
|
+
return this.object3d = new i.Mesh(...t), this;
|
|
59
59
|
}
|
|
60
60
|
createGroup() {
|
|
61
|
-
return this.object3d = new
|
|
61
|
+
return this.object3d = new i.Group(), this;
|
|
62
62
|
}
|
|
63
63
|
createPoints(...t) {
|
|
64
|
-
return this.object3d = new
|
|
64
|
+
return this.object3d = new i.Points(...t), this;
|
|
65
65
|
}
|
|
66
66
|
createCSS2DObject(t) {
|
|
67
67
|
return this.object3d = new d(t), this;
|
|
@@ -73,7 +73,7 @@ class D {
|
|
|
73
73
|
return this.object3d = new u(t), this;
|
|
74
74
|
}
|
|
75
75
|
createSprite(t) {
|
|
76
|
-
return this.object3d = new
|
|
76
|
+
return this.object3d = new i.Sprite(t), this;
|
|
77
77
|
}
|
|
78
78
|
attach(...t) {
|
|
79
79
|
return [...t].forEach((e) => {
|
|
@@ -81,11 +81,12 @@ class D {
|
|
|
81
81
|
}), this;
|
|
82
82
|
}
|
|
83
83
|
getSize() {
|
|
84
|
-
const t = new
|
|
84
|
+
const t = new i.Box3().setFromObject(this.object3d);
|
|
85
85
|
return {
|
|
86
86
|
min: t.min,
|
|
87
87
|
max: t.max,
|
|
88
|
-
size: t.getSize(new
|
|
88
|
+
size: t.getSize(new i.Vector3()),
|
|
89
|
+
center: t.getCenter(new i.Vector3())
|
|
89
90
|
};
|
|
90
91
|
}
|
|
91
92
|
traverse(t) {
|
|
@@ -99,10 +100,10 @@ class D {
|
|
|
99
100
|
instantiate(t) {
|
|
100
101
|
return this.drawController.instantiate(this, {
|
|
101
102
|
create: (e) => {
|
|
102
|
-
var
|
|
103
|
+
var r;
|
|
103
104
|
if (this.object3d) {
|
|
104
|
-
if (this.object3d instanceof
|
|
105
|
-
const { size: s } = this.getSize(), a = new
|
|
105
|
+
if (this.object3d instanceof i.Sprite && typeof t == "number") {
|
|
106
|
+
const { size: s } = this.getSize(), a = new i.MeshBasicMaterial(), n = [
|
|
106
107
|
"color",
|
|
107
108
|
"map",
|
|
108
109
|
"alphaMap",
|
|
@@ -118,17 +119,17 @@ class D {
|
|
|
118
119
|
const h = this.object3d.material[c];
|
|
119
120
|
h !== null && (a[c] = h);
|
|
120
121
|
}
|
|
121
|
-
e.object3d = new
|
|
122
|
-
new
|
|
122
|
+
e.object3d = new i.Mesh(
|
|
123
|
+
new i.PlaneGeometry(s.x, s.y, 2, 2),
|
|
123
124
|
a
|
|
124
125
|
);
|
|
125
126
|
} else
|
|
126
127
|
e.object3d = this.object3d.clone(!0);
|
|
127
|
-
typeof t == "number" && (e.object3d = new
|
|
128
|
+
typeof t == "number" && (e.object3d = new i.InstancedMesh(
|
|
128
129
|
e.object3d.geometry,
|
|
129
130
|
e.object3d.material,
|
|
130
131
|
t
|
|
131
|
-
), e.object3d.instanceMatrix.setUsage(
|
|
132
|
+
), e.object3d.instanceMatrix.setUsage(i.DynamicDrawUsage)), e.position.set(0, 0, 0), e.rotation.set(0, 0, 0), e.setMaterialList("instantiate", "clone"), e.useMaterial("instantiate"), e.object3d.userData.bloom && ((r = this.pencil.composerController) == null || r.toggleBloomSelection(
|
|
132
133
|
e.object3d,
|
|
133
134
|
!0
|
|
134
135
|
)), e.object3d.userData.prefab && (e.object3d.userData.prefab = !1);
|
|
@@ -137,7 +138,7 @@ class D {
|
|
|
137
138
|
});
|
|
138
139
|
}
|
|
139
140
|
setInstancedMatrix(t) {
|
|
140
|
-
this.object3d instanceof
|
|
141
|
+
this.object3d instanceof i.InstancedMesh && (Object.keys(t).forEach((e) => {
|
|
141
142
|
this.object3d.setMatrixAt(
|
|
142
143
|
Number(e),
|
|
143
144
|
t[e]
|
|
@@ -153,25 +154,25 @@ class D {
|
|
|
153
154
|
return;
|
|
154
155
|
const e = t.material;
|
|
155
156
|
if (Array.isArray(e))
|
|
156
|
-
return e.map((
|
|
157
|
-
const s =
|
|
158
|
-
|
|
159
|
-
const a =
|
|
160
|
-
return
|
|
157
|
+
return e.map((r) => {
|
|
158
|
+
const s = r.userData;
|
|
159
|
+
r.userData = {};
|
|
160
|
+
const a = r.clone();
|
|
161
|
+
return r.userData = s, a;
|
|
161
162
|
});
|
|
162
163
|
{
|
|
163
|
-
const
|
|
164
|
+
const r = e.userData;
|
|
164
165
|
e.userData = {};
|
|
165
166
|
const s = e.clone();
|
|
166
|
-
return e.userData =
|
|
167
|
+
return e.userData = r, s;
|
|
167
168
|
}
|
|
168
169
|
}
|
|
169
|
-
setMaterialList(t, e,
|
|
170
|
+
setMaterialList(t, e, r = !0) {
|
|
170
171
|
const s = this.object3d;
|
|
171
172
|
if (!s || !s.material)
|
|
172
173
|
return;
|
|
173
174
|
if (this.materialList.origin || (this.materialList.origin = s.material), this.materialList[t])
|
|
174
|
-
if (
|
|
175
|
+
if (r) {
|
|
175
176
|
const n = this.materialList[t];
|
|
176
177
|
o({
|
|
177
178
|
material: n
|
|
@@ -189,8 +190,8 @@ class D {
|
|
|
189
190
|
this.object3d && (this.object3d.renderOrder = t);
|
|
190
191
|
}
|
|
191
192
|
onPointerEvent(t, e) {
|
|
192
|
-
const
|
|
193
|
-
this.onPointerIndex.push(
|
|
193
|
+
const r = this.drawController.handlePick([this], t, e);
|
|
194
|
+
this.onPointerIndex.push(r);
|
|
194
195
|
}
|
|
195
196
|
dispose() {
|
|
196
197
|
this.onPointerIndex.forEach((t) => {
|
|
@@ -212,5 +213,5 @@ class D {
|
|
|
212
213
|
}
|
|
213
214
|
}
|
|
214
215
|
export {
|
|
215
|
-
|
|
216
|
+
C as B
|
|
216
217
|
};
|