@d5techs/3dgs-lib 1.4.74 → 1.4.75

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/3dgs-lib.cjs CHANGED
@@ -811,6 +811,7 @@ const _OrbitControls = class _OrbitControls {
811
811
  onKeyDown(e) {
812
812
  var _a2;
813
813
  if (!this.enabled) return;
814
+ if (e.ctrlKey || e.metaKey || e.altKey) return;
814
815
  const tag = (_a2 = e.target) == null ? void 0 : _a2.tagName;
815
816
  if (tag === "INPUT" || tag === "TEXTAREA" || tag === "SELECT") return;
816
817
  const key = e.key.toLowerCase();
@@ -18247,52 +18248,49 @@ class SplatEditor {
18247
18248
  this.editHistory.add(editOp);
18248
18249
  }
18249
18250
  /**
18250
- * 球选择:以点击处最近 splat 为中心,拖拽半径定义世界空间球体
18251
+ * 球选择:在屏幕空间判断 splat 是否在圆形区域内
18251
18252
  */
18252
18253
  selectBySphere(op, centerPx, radiusPx) {
18253
- const pick = this.pickWorldPosition(centerPx.x, centerPx.y);
18254
- if (!pick) return;
18255
- const worldRadius = radiusPx * pick.pixelToWorld;
18256
- const cpuPos = this.gsRenderer.getCPUPositions();
18257
- if (!cpuPos) return;
18258
- const modelMat = this.gsRenderer.getModelMatrix();
18259
- const cx = pick.worldX, cy = pick.worldY, cz = pick.worldZ;
18260
- const r2 = worldRadius * worldRadius;
18254
+ this.ensureProjection();
18255
+ const proj = this.projectedPositions;
18256
+ if (!proj) return;
18257
+ const w = this.container.clientWidth;
18258
+ const h = this.container.clientHeight;
18259
+ const cx = centerPx.x / w;
18260
+ const cy = centerPx.y / h;
18261
+ const rx = radiusPx / w;
18262
+ const ry = radiusPx / h;
18263
+ const rx2 = rx * rx;
18264
+ const ry2 = ry * ry;
18261
18265
  const editOp = new SelectOp(this.splatState, op, (i) => {
18262
- if (this.splatState.data[i] & (State.hidden | State.deleted)) return false;
18263
- const i3 = i * 3;
18264
- const lx = cpuPos[i3], ly = cpuPos[i3 + 1], lz = cpuPos[i3 + 2];
18265
- const wx = modelMat[0] * lx + modelMat[4] * ly + modelMat[8] * lz + modelMat[12];
18266
- const wy = modelMat[1] * lx + modelMat[5] * ly + modelMat[9] * lz + modelMat[13];
18267
- const wz = modelMat[2] * lx + modelMat[6] * ly + modelMat[10] * lz + modelMat[14];
18268
- const dx = wx - cx, dy = wy - cy, dz = wz - cz;
18269
- return dx * dx + dy * dy + dz * dz < r2;
18266
+ const b = i * 3;
18267
+ const sx = proj[b], sy = proj[b + 1], sz = proj[b + 2];
18268
+ if (sz <= 0 || sz >= 1) return false;
18269
+ const dx = sx - cx, dy = sy - cy;
18270
+ return dx * dx / rx2 + dy * dy / ry2 <= 1;
18270
18271
  });
18271
18272
  this.editHistory.add(editOp);
18272
18273
  }
18273
18274
  /**
18274
- * 盒选择:以点击处最近 splat 为中心,拖拽定义世界空间 AABB
18275
- * X/Y 半宽由屏幕拖拽距离转换,Z 半深度取 max(halfW, halfH)
18275
+ * 盒选择:在屏幕空间判断 splat 是否在矩形区域内
18276
18276
  */
18277
18277
  selectByBox(op, centerPx, halfWPx, halfHPx) {
18278
- const pick = this.pickWorldPosition(centerPx.x, centerPx.y);
18279
- if (!pick) return;
18280
- const s = pick.pixelToWorld;
18281
- const hx = halfWPx * s;
18282
- const hy = halfHPx * s;
18283
- const hz = Math.max(hx, hy);
18284
- const cpuPos = this.gsRenderer.getCPUPositions();
18285
- if (!cpuPos) return;
18286
- const modelMat = this.gsRenderer.getModelMatrix();
18287
- const cx = pick.worldX, cy = pick.worldY, cz = pick.worldZ;
18278
+ this.ensureProjection();
18279
+ const proj = this.projectedPositions;
18280
+ if (!proj) return;
18281
+ const w = this.container.clientWidth;
18282
+ const h = this.container.clientHeight;
18283
+ const cx = centerPx.x / w;
18284
+ const cy = centerPx.y / h;
18285
+ const hw = halfWPx / w;
18286
+ const hh = halfHPx / h;
18287
+ const left = cx - hw, right = cx + hw;
18288
+ const top = cy - hh, bottom = cy + hh;
18288
18289
  const editOp = new SelectOp(this.splatState, op, (i) => {
18289
- if (this.splatState.data[i] & (State.hidden | State.deleted)) return false;
18290
- const i3 = i * 3;
18291
- const lx = cpuPos[i3], ly = cpuPos[i3 + 1], lz = cpuPos[i3 + 2];
18292
- const wx = modelMat[0] * lx + modelMat[4] * ly + modelMat[8] * lz + modelMat[12];
18293
- const wy = modelMat[1] * lx + modelMat[5] * ly + modelMat[9] * lz + modelMat[13];
18294
- const wz = modelMat[2] * lx + modelMat[6] * ly + modelMat[10] * lz + modelMat[14];
18295
- return Math.abs(wx - cx) < hx && Math.abs(wy - cy) < hy && Math.abs(wz - cz) < hz;
18290
+ const b = i * 3;
18291
+ const sx = proj[b], sy = proj[b + 1], sz = proj[b + 2];
18292
+ if (sz <= 0 || sz >= 1) return false;
18293
+ return sx >= left && sx <= right && sy >= top && sy <= bottom;
18296
18294
  });
18297
18295
  this.editHistory.add(editOp);
18298
18296
  }