fl-web-component 1.2.9 → 1.2.10

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/README.md CHANGED
@@ -46,6 +46,8 @@ Vue.use(FlWebComponent)
46
46
  欢迎贡献代码和问题反馈。
47
47
 
48
48
  ## 更新日志
49
+ - 1.2.10 2025-06-23
50
+ 1. 修改文字渲染逻辑
49
51
  - 1.2.9 2025-06-19
50
52
  1. fix: matrix 容错
51
53
  - 1.2.8 2025-06-19
@@ -29241,7 +29241,7 @@ if (typeof window !== 'undefined') {
29241
29241
  // Indicate to webpack that this file can be concatenated
29242
29242
  /* harmony default export */ var setPublicPath = (null);
29243
29243
 
29244
- // CONCATENATED MODULE: ./node_modules/cache-loader/dist/cjs.js?{"cacheDirectory":"node_modules/.cache/vue-loader","cacheIdentifier":"b052779e-vue-loader-template"}!./node_modules/cache-loader/dist/cjs.js??ref--12-0!./node_modules/babel-loader/lib!./node_modules/vue-loader/lib/loaders/templateLoader.js??ref--6!./node_modules/cache-loader/dist/cjs.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./packages/components/com-graphics/index.vue?vue&type=template&id=9d23b864&scoped=true
29244
+ // CONCATENATED MODULE: ./node_modules/cache-loader/dist/cjs.js?{"cacheDirectory":"node_modules/.cache/vue-loader","cacheIdentifier":"44287e30-vue-loader-template"}!./node_modules/cache-loader/dist/cjs.js??ref--12-0!./node_modules/babel-loader/lib!./node_modules/vue-loader/lib/loaders/templateLoader.js??ref--6!./node_modules/cache-loader/dist/cjs.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./packages/components/com-graphics/index.vue?vue&type=template&id=9d23b864&scoped=true
29245
29245
  var com_graphicsvue_type_template_id_9d23b864_scoped_true_render = function render() {
29246
29246
  var _vm = this,
29247
29247
  _c = _vm._self._c;
@@ -59479,6 +59479,14 @@ function handleInstancedMeshModel(modelGroup, instances, drawObjs, type, scene,
59479
59479
  // m4.setPosition(new THREE.Vector3(9999999, 9999999, 9999999)); // TODO 临时隐藏方案
59480
59480
  meshMatrix.elements = item.matrix.val;
59481
59481
  geomMatrix.elements = mesh.matrix.val;
59482
+ var points = mesh.points;
59483
+ if (isTextType(mesh.type)) {
59484
+ var positionMatrix = new Matrix4();
59485
+ var alignMatrix = new Matrix4();
59486
+ positionMatrix.identity().makeTranslation(points[0], points[1], points[2]);
59487
+ alignMatrix.identity().makeTranslation(-(mesh.prop.fontsize / 2.5), -(mesh.prop.fontsize / 2.5), 0);
59488
+ geomMatrix.multiply(positionMatrix).multiply(alignMatrix);
59489
+ }
59482
59490
  m4.multiplyMatrices(meshMatrix, geomMatrix);
59483
59491
  model.setMatrixAt(index, m4);
59484
59492
  var copyMatrix = new Matrix4().copy(m4);
@@ -59567,7 +59575,7 @@ function instance_parser_drawModel(geom, instanceName, instanceCount, nColor, nO
59567
59575
  if (geom.type == GEOM_TYPES.geom_2d || geom.type == GEOM_TYPES.geom_2d_others) {
59568
59576
  model = draw2Dmodel(geom, instanceName, instanceCount); // TODO 该类型调试中
59569
59577
  // 处理二维文本类型
59570
- } else if (geom.type == GEOM_TYPES.geom_2d_text || geom.type == GEOM_TYPES.geom_2d_mtext || geom.type == GEOM_TYPES.geom_3d_text || geom.type == GEOM_TYPES.geom_3d_mtext) {
59578
+ } else if (isTextType(geom.type)) {
59571
59579
  model = drawText(geom, instanceName, instanceCount);
59572
59580
  // 处理各种曲线类型(圆形、圆弧、椭圆、椭圆弧)
59573
59581
  } else if (geom.type == GEOM_TYPES.geom_2d_circle || geom.type == GEOM_TYPES.geom_2d_arc || geom.type == GEOM_TYPES.geom_2d_ellipse || geom.type == GEOM_TYPES.geom_2d_ellipseArc) {
@@ -59579,6 +59587,15 @@ function instance_parser_drawModel(geom, instanceName, instanceCount, nColor, nO
59579
59587
  return model;
59580
59588
  }
59581
59589
 
59590
+ /**
59591
+ * 判断几何类型是否为文本类型
59592
+ * @param {number} type - 几何类型枚举值,参考GEOM_TYPES中的定义
59593
+ * @returns {boolean} 是否为文本类型(2D/3D 单行或多行文本)
59594
+ */
59595
+ function isTextType(type) {
59596
+ return type == GEOM_TYPES.geom_2d_text || type == GEOM_TYPES.geom_2d_mtext || type == GEOM_TYPES.geom_3d_text || type == GEOM_TYPES.geom_3d_mtext;
59597
+ }
59598
+
59582
59599
  /**
59583
59600
  * 绘制曲线
59584
59601
  *
@@ -59638,7 +59655,8 @@ function draw3Dmodel(geom, instanceName, instanceCount, nColor, nOpacity) {
59638
59655
  customMaterial = geom.material,
59639
59656
  triangles = geom.triangles,
59640
59657
  points = geom.points,
59641
- normals = geom.normals;
59658
+ normals = geom.normals,
59659
+ prop = geom.prop;
59642
59660
  // 使用自定义几何体或创建新的缓冲几何体
59643
59661
  var geometry = customGeometry || new BufferGeometry();
59644
59662
 
@@ -59658,7 +59676,7 @@ function draw3Dmodel(geom, instanceName, instanceCount, nColor, nOpacity) {
59658
59676
  var normal = new Float32Array(normals);
59659
59677
  geometry.setAttribute('normal', new BufferAttribute(normal, 3));
59660
59678
  }
59661
- var color = geom.prop.color;
59679
+ var color = prop.color;
59662
59680
  var material, mesh, colors, opacity;
59663
59681
  if (Array.isArray(color) && color.length) {
59664
59682
  colors = color;
@@ -59800,10 +59818,10 @@ function drawText(geom, instanceName, instanceCount) {
59800
59818
  }, instanceName, instanceCount);
59801
59819
 
59802
59820
  // 创建平移矩阵并应用
59803
-
59804
- var matrix = new Matrix4();
59805
- matrix.identity().makeTranslation(points[0], points[1], points[2]);
59806
- mesh.applyMatrix4(matrix);
59821
+ // const matrix = new THREE.Matrix4();
59822
+ // matrix.identity().makeTranslation(points[0], points[1], points[2]);
59823
+ // mesh.applyMatrix4(matrix);
59824
+ // points && mesh.position.set(points[0], points[1], points[2]);
59807
59825
 
59808
59826
  // if (stageId == STAGE_MODEL_TYPE.PID) {
59809
59827
  // mesh.translateX(-(fontsize / 2));
@@ -59815,8 +59833,9 @@ function drawText(geom, instanceName, instanceCount) {
59815
59833
  // mesh.rotateY(rotate);
59816
59834
  // }
59817
59835
  // mesh.rotateX(-Math.PI / 2);
59818
- mesh.translateX(-(fontsize / 2.5));
59819
- mesh.translateY(-(fontsize / 2.5));
59836
+ // mesh.translateX(-(fontsize / 2.5));
59837
+ // mesh.translateY(-(fontsize / 2.5));
59838
+
59820
59839
  mesh.userData.instanceName = instanceName;
59821
59840
  return mesh;
59822
59841
  }
@@ -62481,7 +62500,7 @@ var component = normalizeComponent(
62481
62500
  )
62482
62501
 
62483
62502
  /* harmony default export */ var com_graphics = (component.exports);
62484
- // CONCATENATED MODULE: ./node_modules/cache-loader/dist/cjs.js?{"cacheDirectory":"node_modules/.cache/vue-loader","cacheIdentifier":"b052779e-vue-loader-template"}!./node_modules/cache-loader/dist/cjs.js??ref--12-0!./node_modules/babel-loader/lib!./node_modules/vue-loader/lib/loaders/templateLoader.js??ref--6!./node_modules/cache-loader/dist/cjs.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./packages/components/com-flcanvas/index.vue?vue&type=template&id=1eba8e28&scoped=true
62503
+ // CONCATENATED MODULE: ./node_modules/cache-loader/dist/cjs.js?{"cacheDirectory":"node_modules/.cache/vue-loader","cacheIdentifier":"44287e30-vue-loader-template"}!./node_modules/cache-loader/dist/cjs.js??ref--12-0!./node_modules/babel-loader/lib!./node_modules/vue-loader/lib/loaders/templateLoader.js??ref--6!./node_modules/cache-loader/dist/cjs.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./packages/components/com-flcanvas/index.vue?vue&type=template&id=1eba8e28&scoped=true
62485
62504
  var com_flcanvasvue_type_template_id_1eba8e28_scoped_true_render = function render() {
62486
62505
  var _vm = this,
62487
62506
  _c = _vm._self._c;
@@ -65680,7 +65699,7 @@ var com_flcanvas_component = normalizeComponent(
65680
65699
  )
65681
65700
 
65682
65701
  /* harmony default export */ var com_flcanvas = (com_flcanvas_component.exports);
65683
- // CONCATENATED MODULE: ./node_modules/cache-loader/dist/cjs.js?{"cacheDirectory":"node_modules/.cache/vue-loader","cacheIdentifier":"b052779e-vue-loader-template"}!./node_modules/cache-loader/dist/cjs.js??ref--12-0!./node_modules/babel-loader/lib!./node_modules/vue-loader/lib/loaders/templateLoader.js??ref--6!./node_modules/cache-loader/dist/cjs.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./packages/components/com-graphics/per-control.vue?vue&type=template&id=f547d5c6&scoped=true
65702
+ // CONCATENATED MODULE: ./node_modules/cache-loader/dist/cjs.js?{"cacheDirectory":"node_modules/.cache/vue-loader","cacheIdentifier":"44287e30-vue-loader-template"}!./node_modules/cache-loader/dist/cjs.js??ref--12-0!./node_modules/babel-loader/lib!./node_modules/vue-loader/lib/loaders/templateLoader.js??ref--6!./node_modules/cache-loader/dist/cjs.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./packages/components/com-graphics/per-control.vue?vue&type=template&id=f547d5c6&scoped=true
65684
65703
  var per_controlvue_type_template_id_f547d5c6_scoped_true_render = function render() {
65685
65704
  var _vm = this,
65686
65705
  _c = _vm._self._c;
@@ -65788,7 +65807,7 @@ var per_control_component = normalizeComponent(
65788
65807
  )
65789
65808
 
65790
65809
  /* harmony default export */ var per_control = (per_control_component.exports);
65791
- // CONCATENATED MODULE: ./node_modules/cache-loader/dist/cjs.js?{"cacheDirectory":"node_modules/.cache/vue-loader","cacheIdentifier":"b052779e-vue-loader-template"}!./node_modules/cache-loader/dist/cjs.js??ref--12-0!./node_modules/babel-loader/lib!./node_modules/vue-loader/lib/loaders/templateLoader.js??ref--6!./node_modules/cache-loader/dist/cjs.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./packages/components/com-graphics/pid.vue?vue&type=template&id=0ec35ee4&scoped=true
65810
+ // CONCATENATED MODULE: ./node_modules/cache-loader/dist/cjs.js?{"cacheDirectory":"node_modules/.cache/vue-loader","cacheIdentifier":"44287e30-vue-loader-template"}!./node_modules/cache-loader/dist/cjs.js??ref--12-0!./node_modules/babel-loader/lib!./node_modules/vue-loader/lib/loaders/templateLoader.js??ref--6!./node_modules/cache-loader/dist/cjs.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./packages/components/com-graphics/pid.vue?vue&type=template&id=0ec35ee4&scoped=true
65792
65811
  var pidvue_type_template_id_0ec35ee4_scoped_true_render = function render() {
65793
65812
  var _vm = this,
65794
65813
  _c = _vm._self._c;