diff --git a/.github/workflows/publish_package.yml b/.github/workflows/publish_package.yml new file mode 100644 index 000000000..cedde5452 --- /dev/null +++ b/.github/workflows/publish_package.yml @@ -0,0 +1,111 @@ +name: Publish npm package +on: + push: + branches: [package] +jobs: + # 检查版本号 + CheckVersion: + runs-on: ubuntu-latest + outputs: + versionVerified: ${{ steps.versionVerified.outputs.versionVerified }} + distTag: ${{ steps.distTag.outputs.distTag }} + version: ${{ steps.package.outputs.current-version }} + steps: + - uses: actions/checkout@v3 + + - name: Use Node.js + uses: actions/setup-node@v3 + with: + node-version: 20 + + - name: Get package Info + id: package + uses: martinbeentjes/npm-get-version-action@v1.3.1 + + - name: Get Dist Tag Form Version + id: distTag + run: | + if echo ${{ steps.package.outputs.current-version }} | grep -; then + tag=$(echo ${{ steps.package.outputs.current-version }} | cut -d'-' -f2 | cut -d'.' -f1 ) + if grep '^[[:digit:]]*$' <<< $tag; then + exit 0; + else + echo "distTag=$tag" >> $GITHUB_OUTPUT + fi + else + echo "distTag=latest" >> $GITHUB_OUTPUT + fi + + # check whether the version is published + - name: Check version is not published + id: versionVerified + run: | + if npm view @realsee/dnalogel versions | grep "'${{ steps.package.outputs.current-version }}'"; then + echo "Package version is published" + echo "versionVerified=false" >> $GITHUB_OUTPUT + fi + + - name: Output + run: | + echo "version: ${{ steps.package.outputs.current-version }}" + echo "versionVerified: ${{ steps.versionVerified.outputs.versionVerified }}" + echo "distTag: ${{ steps.distTag.outputs.distTag }}" + + Publish: + runs-on: ubuntu-latest + needs: CheckVersion + if: needs.CheckVersion.outputs.versionVerified != 'false' + steps: + - uses: actions/checkout@v3 + + - name: Use Node.js + uses: actions/setup-node@v3 + with: + node-version: 20 + registry-url: 'https://registry.npmjs.org' + + - name: Publish package + env: + NPM_TOKEN: ${{ secrets.NPM_TOKEN_LHZ }} + NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN_LHZ }} + run: | + npm publish --tag ${{ needs.CheckVersion.outputs.distTag }} --ignore-scripts + + QYWeChatPush: + runs-on: ubuntu-latest + needs: [Publish, CheckVersion] + steps: + - uses: actions/checkout@v3 + + - name: Get changelog + id: get_changelog + run: | + changelog_content=$(cat CHANGELOG.md | sed -n -e '/## ${{ needs.CheckVersion.outputs.version }}/,/##/p' | grep -v '##') + echo "changelog<> $GITHUB_OUTPUT + echo "$changelog_content" >> $GITHUB_OUTPUT + echo "EOF" >> $GITHUB_OUTPUT + + echo $(cat $GITHUB_OUTPUT) + + - name: QY WeChat Push + uses: chf007/action-wechat-work@master + env: + WECHAT_WORK_BOT_WEBHOOK: ${{secrets.QY_WECHAT_BOT_HOOK}} + with: + msgtype: markdown + content: "## @realsee/dnalogel@${{ needs.CheckVersion.outputs.version }}\n> ${{ steps.get_changelog.outputs.changelog }}" + + Async_cnpm: + runs-on: ubuntu-latest + needs: Publish + steps: + - uses: actions/checkout@v3 + + - name: Use Node.js + uses: actions/setup-node@v3 + with: + node-version: 20 + + - name: Install dependencies + run: npm install -g cnpm + - run: cnpm sync @realsee/dnalogel diff --git a/.npmrc b/.npmrc new file mode 100644 index 000000000..7991760f7 --- /dev/null +++ b/.npmrc @@ -0,0 +1,2 @@ +strict-peer-dependencies=false +legacy-peer-deps=true \ No newline at end of file diff --git a/CHANGELOG.md b/CHANGELOG.md new file mode 100644 index 000000000..8052ef429 --- /dev/null +++ b/CHANGELOG.md @@ -0,0 +1,2026 @@ +# CHANGELOG + +## 3.59.13 + +- fix(PanoTagPlugin): 修复 enable 在某些特殊情况下没有立即生效的问题。 + +## 3.59.12 + +- chore(PanoTagPlugin): 修复一个报错。 + +## 3.59.11 + +- fix(PanoTagPlugin): 修复虚拟屏幕 创建、修改、销毁过程中的 bug。 + +## 3.59.10 + +- fix(PanoFloorplanRadarPlugin): 还原 hoverEnable 默认值 false。 +- fix(Sculpt): 修复某些特殊情况下,tip 没有展示的问题。 + +## 3.59.9 + +- fix(GuideLinePlugin): 兼容低版本 webgl,修复 ios14 上 fragmentShader 渲染异常的问题。 + +## 3.59.8 + +- fix(PanoTagPlugin): 重构 css3DRender, 修复 five react 切换 work 后,模型广告牌内容可能会消失的问题。 +- fix(PanoTagPlugin): 修复 five react 切换 work 后,模型点击事件不会触发的问题。 +- fix(PanoTagPlugin): 修复 setDataById, setTagById 等方式切换 tag 数据后没有立即更新的问题。 + +## 3.59.7 + +- fix(PanoMeasurePlugin): 修复测面积撤销完所有点后会报错的问题。 + +## 3.59.6 + +- fix(GuideLinePlugin): 修复路线为空时报错的问题。 + +## 3.59.5 + +- fix(\*): zFightting 统一调大至 1mm。 + +## 3.59.4 + +- fix(Util.lookObject): 保证每次转动角度最小。 + +## 3.59.3 + +- fix(ObjectHelper): 修复正交视角下操作不平行于水平面的拖动轴时,结果可能会错误的问题。 + +## 3.59.2 + +- fix(ObjectHelper): 正交视角下,与正交方向一致的移动轴不显示。 +- fix(PointSelector): select 事件现在只有精准点击(500ms 内鼠标按下并在同一个位置抬起)会触发。 +- fix(\*): 修复一个底层错误,该错误可能会导致 拖动、绘制 等操作不正常。 + +## 3.59.1 + +- chore(ModelMakerPlugin): fix type。 + +## 3.59.0 + +- feat(Sculpt): load 时可以指定 defaultAction,选择是否启用默认行为(点击选中等)。默认为 true。 + +## 3.58.7 + +- chore(Sculpt): 缩放操作时,隐藏其他缩放块。 + +## 3.58.6 + +- chore(FloorplanPlugin): 点击事件现在可以获取到点击的房间信息。 + +## 3.58.5 + +- fix(Sculpt): 修复部分 item.setData 结果不正确的问题。 + +## 3.58.4 + +- fix(ModelMakerPlugin): 2D 标注只在指定 panoIndex 上展示。 +- chore(PanoDoorLabelPlugin): 重构,修复 bug。 + +## 3.58.3 + +- change(Sculpt): 当通过 `stopCreate()` 或 `clear()` 主动中断绘制时,createXXX promise 现在会返回 reject。 + +## 3.58.2 + +- fix(Sculpt): 修复绘制矩形时,预览线会显示长度的问题。 + +## 3.58.1 + +- fix(Sculpt): 修复使用 editor 移动物体后,setData 设置数据后物体位置不正确的问题。 +- fix(Sculpt): 修复使用 setData 设置物体位置后 editor 方向不正确的问题。 +- fix(Util.FiveDomEvent): 修复一个代码报错。 + +## 3.58.0 + +- change(PanoTagPlugin): 走点时默认不隐藏标签。 +- fix(PanoTagPlugin): 修复标签闪烁(tag.blink())可能会卡顿的问题。 + +## 3.57.1 + +- fix(FiveDomEvent): 当射线上靠前的物体因为一些配置原因不触发事件时,顺延至后面的物体。 + +## 3.57.0 + +- feat(ModelMakerPlugin): 优化区域标注的标签效果。 +- fix(Sculpt): 移除 item 时,如果在绘制中,停止绘制。 + +## 3.56.1 + +- fix(\*): 修复面的颜色有色差的问题。 + +## 3.56.0 + +- feat(PanoTagPlugin):变更标签的优化策略,以支持低版本浏览器以及 safari。 +- fix(ModelMakerPlugin): 修复部分标注点击后名称没有显示的问题。 + +## 3.55.0 + +- feat(Sculpt): 支持设置边框线的透明度 `lineOpacity`, 默认为 1。 +- fix(Sculpt): 修复 editor 启用时,通过 `setData` 更新物体位置后,editor 位置没有更新的问题。 +- fix(ModelMakerPlugin): 支持多楼层场景,仅在当前楼层展示。 + +## 3.54.2 + +- chore(Sculpt): 优化绘制 `Sculpt` 线的方式。 + +## 3.54.1 + +- fix(Sculpt): 修复凹多边形的绘制问题 + +## 3.54.0 + +- fix(Util.FivePuppet): 兼容 vapor。 +- feat(Sculpt): 添加 `item.setData` 方法,参数为 [SculptData](https://open-platform.realsee.com/developer/docs/dnalogel/Sculpt/#data)。 +- feat(Sculpt): 添加 `item.editor.hooks.on('objectUpdate')`,当 editor 开启时,物体被移动/缩放/旋转时触发。 +- chore(Sculpt): 取消编辑 scale 距离限制;体的绘制高度限制由 10m 改为 100m。 + +## 3.53.4 + +- fix(Sculpt): 关闭 depthWrite,修复不显示被透明面遮挡的线的问题,修复部分面看起来颜色要淡的问题。 +- fix(Sculpt): 物体的 opacity 不再修改边框线的透明度。 + +## 3.53.3 + +- fix(GuideLinePlugin): 修复 `GuideLinePlugin` 在 `hide` 后切换至 `Mapview` 视角时,偶现显示出起点终点标签的问题。 + +## 3.53.2 + +- fix(GuildLinePlugin): 修复 load 后立即获取 item.modelItem 或 item.panoramaItem 的 visible 不正确的问题。 + +## 3.53.1 + +- fix(Util.FivePuppet): 修复 `FivePuppet` 的 `destory` 清除不完全的问题。 + +## 3.53.0 + +- feat(Util): 新增 `Util.FivePuppet` + +## 3.52.3 + +- fix(tag): 没有点的情况下不做碰撞检测。 + +## 3.52.2 + +- fix(ModelMakerPlugin): 修复字号会跟随字符长度变化的问题。 + +## 3.52.1 + +- fix(Sculpt): 修复导出数据不准确的问题。 + +## 3.52.0 + +- fix(ModelMakerPlugin): 修复 hide 后标签没有隐藏的问题(使用 display 代替 visibility)。 +- fix(Object3DHelper): 修复正交相机视角下拉近摄像机时,helper 没有缩放的问题;修复位移操作结束时,helper 没有缩放的问题。 +- feat(Sculpt): + 1. 优化 boxMesh 的 geometry; + 2. 长方体绘制支持锁定平面,支持选择绘制方式,api 同 矩形绘制; + 3. 长方体支持六个面的缩放; + 4. 矩形支持四边的缩放; + 5. 优化缩放块的透视视觉效果; + 6. 撤销快捷键兼容 mac; + 7. 修复先拖动再缩放时,结果不正确的问题; + +## 3.51.0 + +- feat(modelMakerPlugin): 模型标注的标签增加元素间的遮挡检测。 + +## 3.50.16 + +- fix(Util.PointSelector): 支持屏幕支持触摸的 pc 设备。 + +## 3.50.15 + +- chore(Util): 导出工具函数。 + +## 3.50.14 + +- fix(ModelMakerPlugin): 修复碰撞检测计算错误的问题。 + +## 3.50.13 + +- fix(PanoTagPlugin): 修复 load 完后立即 clearTags 时,虚拟屏幕没有被清除的问题。 + +## 3.50.12 + +- chore(Sculpt): fix typo `createline` + +## 3.50.11 + +- fix(PanoTagPlugin): 修复 3.42.0 导致的 hide 后没有隐藏 css3D 渲染的 Dom 的问题。 + +## 3.50.10 + +- chore(floorplan): 修改户型图标尺透明度。 + +## 3.50.9 + +- fix(PointSelector): 修复 disable 时,坐标点外围圆环没有隐藏的问题。 +- fix(CrusePlugin): 进一步修复点位自动漫游中,非常频繁的切换速度时,偶现漫游暂停的问题。 + +## 3.50.8 + +- fix(CrusePlugin): 修复点位自动漫游中,非常频繁的切换速度时,偶现漫游暂停的问题。 + +## 3.50.7 + +- chore(Sculpt): 3.50.6 中的 feature 添加默认参数。 + +## 3.50.6 + +- change(Sculpt): 距离和 tip 颜色默认和 mesh 颜色一致。 + +## 3.50.5 + +- fix(measure): 兼容 five react。 + +## 3.50.4 + +- change(floorplan): 户型图展示/隐藏时,除之前设置 five canvas 透明度的逻辑外,同步设置 five 相关 dom 的透明度(使用 dataset-infive 标识) + +## 3.50.3 + +- fix(ObjectHelper): 修复 helper 起始位置可能错误的问题。 + +## 3.50.2 + +- fix(Sculpt): 修复 `Sculpt` 连续绘制多个平面矩形时,边框长度错误的问题。 +- fix(Sculpt): 修改 `PointMesh` 和 `LineMesh` 的 `visible` 时,tip 或者 长度也会被修改。 + +## 3.50.1 + +- fix(Sculpt): 3.49.11 的 tip 在 ios 设备上支持中文。 + +## 3.50.0 + +- feat(PointSelector): 取消 Hammer 依赖,Hammer 在安卓设备上与 vapor 不兼容。 + +## 3.49.13 + +- fix(Sculpt): 修复 3.49.11 中 point 的 tip 没有在 point 被 remove 时销毁的问题。 + +## 3.49.12 + +- fix(Sculpt): 3.49.11 的 tip 支持中文。 + +## 3.49.11 + +- fix(Sculpt): 绘制点时,实时预览点的位置;点和线 支持设置 tip。 + +## 3.49.10 + +- fix(Sculpt): 优化触摸屏绘制。 + +## 3.49.9 + +- fix(ModelMakerPlugin): 修复页面 resize 后,标签没有更新位置的问题。 + +## 3.49.8 + +- chore(sculpt): 导出工具函数。 + +## 3.49.7 + +- fix(PanoTagPlugin): 修复 360 浏览器 69 版本下标签插件不显示的问题。 +- fix(ModelMakerPlugin): 修复区域标注标签被缩小的问题。 + +## 3.49.6 + +- feat(Sculpt): 支持点击出现删除按钮。 + +## 3.49.5 + +- chore(Sculpt): 优化 `Theme` 类型。 + +## 3.49.4 + +- chore(Sculpt): 修改 `theme` 属性访问权限。 + +## 3.49.3 + +- fix(PanoTagPlugin): 修复插件 hide 的情况下,在页面 resize 后可见状态错误的问题。 + +## 3.49.2 + +- fix(Sculpt): 修复页面 resize 后 距离的 dom 层级问题。 + +## 3.49.1 + +- fix(Sculpt): 修复触摸屏手势操作结束时,有可能触发 five 事件的问题。 +- fix(Sculpt): 修复触摸屏绘制折线时,折线的第一个点没有显示的问题。 +- fix(PanoTagPlugin): 优化 `tag.destroy()` 逻辑。 + +## 3.49.0 + +- feat(ObjectHelper): 支持触摸屏手势操作。 +- feat(Sculpt): 支持触摸屏手势操作。 + +## 3.48.7 + +- fix(PanoMeasurePlugin):修复 `enable({mode: 'View'})` 时 可能会显示不应展示的标尺的问题。 + +## 3.48.6 + +- fix(PanoMeasurePLugin):修复在未来家墙面上测量面积时,偶现无法正常绘制的问题。 +- feat(Sculpt):优化绘制多边形时的实时预览效果。 + +## 3.48.5 + +- fix(PanoTagPlugin): 修复部分场景下,标签无法闪烁的问题。 + +## 3.48.4 + +- fix(PanoTagPlugin): 修复部分标签禁用后再闪烁,闪烁完成后没有消失的问题。 + +## 3.48.3 + +- fix(PanoTagPlugin): 修复 `3.48.0` 导致的图文标签 UI 错误的问题。 + +## 3.48.2 + +- feat(Sculpt): 折线(Polyline)多边形(Polygon)支持撤销/重做。 + +## 3.48.1 + +- feat(Sculpt): 线段(Line)支持撤销/重做。 + +## 3.48.0 + +- feat:(PanoTagPlugin): 带视频的标签,支持 `play` / `pause` + +## 3.47.16 + +- chore(\*): 优化代码。 + +## 3.47.15 + +- fix(\*): 修复一个循环引用问题。 +- fix(PanoTagPlugin): 修复 `requestIdleCallbackId` polyfill 问题。 + +## 3.47.14 + +- fix(Sculpt): 修复移动多边形时,距离/面积 dom 没有跟随移动的问题。 +- fix(Sculpt): 修复清空时,面积没有被删除的问题。 + +## 3.47.13 + +- fix(Sculpt): 修复多次绘制对角线矩形时,距离显示的问题。 + +## 3.47.12 + +- feat(Sculpt): 支持展示面积。 + +## 3.47.11 + +- fix(Sculpt): 修复矩形绘制时的距离不显示的问题。 + +## 3.47.10 + +- fix(Sculpt): 修复 box 绘制;修复距离显示问题。 + +## 3.47.9 + +- fix(Sculpt): 优化矩形绘制代码。 + +## 3.47.8 + +- fix(PanoTagPlugin): 修复 `tag.destroy()` 和 `plugin.clearTags()`。 + +## 3.47.7 + +- fix(Sculpt): 优化点云中的长度标签的碰撞检测。 + +## 3.47.6 + +- fix(Sculpt): 修复长度标签的倾斜角度没有更新的问题。 + +## 3.47.5 + +- fix(Sculpt): 优化点云中的长度标签的碰撞检测;UI 优化。 + +## 3.47.4 + +- chore(\*): 优化放大镜性能。 + +## 3.47.3 + +- fix(Sculpt): 优化垂直绘制方式。 + +## 3.47.2 + +- chore(PanoSelector): 类型优化。 + +## 3.47.1 + +- change(PanoTagPlugin): 移除默认最大距离配置 + +## 3.47.0 + +- feat(PanoMeasurePlugin): 支持通过 `config.pointSelectorConfig.actionIfNoModelUnderMouse` 来配置当鼠标处无模型时的行为。 +- feat(Sculpt): 绘制中遇到鼠标处无模型时的情况时更加智能。 + +## 3.46.1 + +- fix(Sculpt): 修复删除 item 时,距离 dom 没有被删除的问题。 + +## 3.46.0 + +- feat(Sculpt): 支持设置 item 的 `lengthEnable` 来开启距离显示。 + +## 3.45.0 + +- feat(Sculpt): 支持创建线段;支持创建 线段、折线、多边形时,锁定垂直/水平面 + +## 3.44.5 + +- chore(PanoTagPlugin): 开启 `debug` 时,控制台输出函数调用日志。 + +## 3.44.4 + +- fix(PointSelector): 修复缩放 fov 时,放大镜没有更新位置的问题。 +- fix(PointSelector): 修复 `disable` 时,坐标点外围圆环没有隐藏的问题。 + +## 3.44.3 + +- fix(currentPanoImagePlugin): 支持多 work 场景。 + +## 3.44.2 + +- fix(PanoTagPlugin): 修复偶先走点后没有立即显示标签的问题。 + +## 3.44.1 + +- fix(PanoTagPlugin): 标签的模型态入口开启时,在模型态下禁止自动展开。 + +## 3.44.0 + +- feat(PanoMeasurePlugin): 新增一种坐标选择器样式,初始化插件时,可以使用 `config.pointSelectorConfig.helper.pointHelper` 配置来设置坐标选择器的样式。 +- feat(PanoMeasurePlugin): 支持通过 `config.pointSelectorConfig.virtualPoint` 来配置当鼠标处无模型时,是否生成虚拟点。 + +## 3.43.0 + +- feat(PanoTagPlugin): 可通过 `globalConfig.entryFromModel` 启用标签在模型态上的入口,点击后可进入全景态查看标签。 + +## 3.42.0 + +- feat(PanoTagPlugin) + 1. 优化 fov 变化时标签位置的计算。 + 2. 可通过 `globalConfig.simulate3D` 启用模拟 3d 的近大远小的效果,默认关闭。 + 3. 添加 `tag.find()` 方法,移动至适当位置找到此标签。 + 4. 添加 `loaded` 事件,load 完成后触发。 + 5. 添加 `tagsLengthChange` 事件,调用`addTag()`, `clearTags()`, `tag.destroy()` 等方法 使标签数量发生变化时触发。 + 6. 移除方法中的 `withAnimation` 参数,现在默认 `show`, `hide`, `enable` 全部带 fade 动画。 + 7. 展示性能优化,加载速度优化。 +- feat(Util): + 1. `Util.lookObject`,模型态下以最佳视角查看一个物体。 + 2. `Util.lookPoint`: 模型态下以最佳视角查看一个坐标点。 + 3. `Util.reblink`: 修复将 dom 的 opacity 主动设置为 0 时,反向闪烁动画不生效的问题。 +- chore(Object3DHelperPlugin): 优化一些代码。 + +## 3.41.7 + +- chore(\*): update `BasePlugin` + +## 3.41.6 + +- fix(PanoTagPlugin): 修复模型未加载完成时,手动调用 `changeConfig` 会报错的问题。 + +## 3.41.5 + +- fix(GuideLinePlugin): dom 闪烁动画修复 + +## 3.41.4 + +- fix(PanoMeasurePlugin): 修复走点后没有更新放大镜位置的问题。 + +## 3.41.3 + +- fix(\*): 修复众多插件在沙盘 vr 中的碰撞检测的目标错误的问题。 + +## 3.41.2 + +- fix(GuideLinePlugin): dom 闪烁动画修复 + +## 3.41.1 + +- fix(GuideLinePlugin): 闪烁动画修复 +- feat(blink): 支持闪烁 `ShaderMaterial` + +## 3.41.0 + +- feat(GuideLinePlugin): 优化路线转弯处的显示效果 + +## 3.40.4 + +- fix(ModelMakerPlugin): 修复 plugin `disable()` 后,依旧可以点击到物体的偶现问题。 + +## 3.40.3 + +- fix(GuideLinePlugin): 修复一个报错问题 + +## 3.40.2 + +- fix(GuideLinePlugin): 修复初始态为模型态时,路线引导标签不显示的问题。 +- feat(GuideLinePlugin): 没有标签数据时,不生成多余的 PanoTagPlugin 实例。 + +## 3.40.1 + +- 忽略此版本,等同于 3.40.0 + +## 3.40.0 + +- change(blink): 现在返回值为 `animeInstance`,可以通过 `animeInstance.preComplete()` 来提前结束动画。 + +## 3.39.0 + +- feat(GuideLinePlugin): 支持设置 `useAutoDepthTest` 来选择是否动态开启深度测试 + +## 3.38.0 + +- feat(ModelMakerPlugin): 支持通过 `Plugin(five, { occlusionMode?: 'depthTest' | 'translucence' })` 设置当 occlusionVisibility 开启时的显示效果 + +## 3.37.2 + +- fix(ModelMakerPlugin): 修复区域标注 `load` 后 `occlusionVisibility` 可能不立即生效的问题。 + +## 3.37.1 + +- fix(PanoTagPlugin): 修复贴片标签 `disable` 后执行闪烁动画时不生效的问题。 + +## 3.37.0 + +- feat(ModelMakerPlugin): 支持通过 `Plugin(five, { occlusionVisibility?: boolean | Mode[] })` 设置是否展示标注被 five 模型遮挡的部分。 +- fix(ModelMakerPlugin): 修复 区域标注(prism) 少了画一个面的问题。 + +## 3.36.11 + +- fix(PanoTagPlugin): 优化标签 `tag.enable` 性能。 + +## 3.36.10 + +- fix(PanoMeasurePlugin): 修复测量插件在特定条件下 `visibleFiveMode` 不生效的问题。 + +## 3.36.9 + +- fix(PanoMeasurePlugin): 修复沙盘场景下,标尺插件的 dom 部分 第一次加载时的初始位置不正确的问题。 + +## 3.36.8 + +- fix(PanoRulerPlugin): 修复标尺插件在沙盘 vr 中报错的问题。 + +## 3.36.7 + +- fix(PanoMeasurePlugin): 测量插件 view 模式 支持沙盘 VR。 + +## 3.36.6 + +- fix(ModelMakerPlugin): 标注 dom 部分 支持沙盘 VR。 + +## 3.36.5 + +- chore(\*): 一些导出修改 + +## 3.36.4 + +- fix(ModelMakerPlugin): 标注支持沙盘 VR。 + +## 3.36.3 + +- fix(PanoTagPlugin): 模型广告牌(MediaModel)支持沙盘 VR。 + +## 3.36.2 + +- feat(PanoVideoPlugin): 全景视频新增 `click` 事件,使用 `e.preventDefault()` 可以阻止默认点击行为 + +## 3.36.1 + +- fix(PanoTagPlugin) : 修复标签 disable 时,修改标签坐标后再 enable 不会更新标签 visible 的问题。 + +## 3.36.0 + +- feat(PanoTagPlugin): 优化标签性能。 + +## 3.35.2 + +- fix(PanoTagPlugin): 修复 dom 贴片在 disable 后调用 `blink` 不生效的问题。 + +## 3.35.1 + +- fix(PanoVideoPlugin): 修复在视频结束的瞬间调用 `disable` 时有一定概率不生效的问题。 + +## 3.35.0 + +- feat(PanoMeasurePlugin): 每条线可以通过数据中的 `visibleFiveMode: FiveMode[]` 来限制此条线在哪些 FiveMode 下可见 +- feat(PanoVideoPlugin): 新增 `dataLoaded` 事件 + +## 3.34.6 + +- chore(PanoVideoPlugin): 修改 controllerMap 访问权限 + +## 3.34.5 + +- fix(ModelMakerPlugin): 修复插件 disable 后,item 执行 enable 依然生效的问题。 + +## 3.34.4 + +- fix(ModelMakerPlugin): 修复区域标注(prism)高度计算错误的问题。 + +## 3.34.3 + +- fix(PanoTagPlugin): `whyHide` 支持所有场景 +- change(PanoTagPlugin): `__PANOTAGPLUGIN_DEBUG__` 现在会返回标签数最多的插件实例 + +## 3.34.2 + +- fix(ModelMakerPlugin): plugin config 问题修复 + +## 3.34.1 + +- fix(ModelMakerPlugin): 支持设置标签容器的 `zIndex` 属性;修复标签显隐问题。 + +## 3.34.0 + +- feat(PanoTagPlugin): + - 支持设置标签容器的 `zIndex` 属性。 + - 兼容 five react,并回滚 3.29.5 和 3.27.10 中的 five react 兼容方式。此方式可能会引发一些其他问题。 + - 如果遇到浏览器 resize 时标签不可见的问题时,请在插件初始化时设置 zIndex 为大于 0 的值,例: `PanoTagPlugin(five, { containerZIndex: 1 })`,或者使用 `plugin.appendTo(element)` 将插件放入稳定的容器中。 + +## 3.33.0 + +- feat(CSS3DRenderPlugin): 支持设置 wrapper 容器。 + +## 3.32.1 + +- style(PanoTagPlugin): 优化 `Panorama` 标签 UI 效果。 + +## 3.32.0 + +- feat(PanoTagPlugin): 新增 `plugin.appendTo` 方法,支持将标签容器放入到指定的 dom 中,默认与 five canvas dom 同级。 +- fix(PanoTagPlugin): 优化 `clearTags` 方法,现在会一起清除标签容器。 + +## 3.31.1 + +- fix(PanoTagPlugin): 回滚 3.24.0 中引入的标签 filter 缓存 + +## 3.31.0 + +- change(PanoTagPlugin): five 模型更新时,重新计算所有标签状态 + +## 3.30.6 + +- fix(Object3DHelper): 修复 正交相机 下无法正确移动物体的问题 +- fix(FiveDomEvent): 修复 `removeEventListener` 不传事件名时,无法移除所有事件监听的问题 + +## 3.30.5 + +- fix(PanoTagPlugin): 支持闪烁禁用的标签 +- fix(PanoTagPlugin): 优化标签不可见时闪烁的效果 + +## 3.30.4 + +- fix(blink): 修复标签闪烁问题 + +## 3.30.3 + +- doc(blink): 添加 example + +## 3.30.2 + +- doc(blink): 添加注释 + +## 3.30.1 + +- fix(ModelMakerPlugin): typing 优化 + +## 3.30.0 + +- feat(\*): 兼容 five@6.0.0-alpha.74 及大于 74 的版本 + +## 3.29.9 + +- fix(ModelMakerPlugin): 修复 3.28.9 更新导致的 3D 标注(box)的标签位置有可能不准确的问题 + +## 3.29.7 + +- fix(blink): 支持闪烁不可见的物体 + +## 3.29.6 + +- fix(\*): 导出 animejs 类型 + +## 3.29.5 + +- fix(CSS3DRender): 兼容 five/react + +## 3.29.4 + +- fix(PanoTagPlugin): 导出 `tag.blink` 类型 + +## 3.29.3 + +- fix(blink): 修复闪烁函数 blink 在处理一些有透明度的复杂模型时,第二次闪烁异常的问题 + +## 3.29.2 + +- fix(ModelMakerPlugin): 修复 item 的各种事件没有触发的 bug + +## 3.29.1 + +- chore(ModelMakerPlugin): 修改属性访问权限。 + +## 3.29.0 + +- feat(PanoTagPlugin): 支持标签闪烁:`plugin.blinkTagById(id, animeParams)` 和 `tag.blink(animeParams)` + +## 3.28.11 + +- fix(PanoTagPlugin): 修复部分标签无法加载的 bug(我是啥比 + +## 3.28.10 + +- fix(ModelMakerPlugin): 修复区域标注(prism)的 z-fighting 问题 + +## 3.28.9 + +- fix(ModelMakerPlugin): 修复包含旋转数据的 3D 标注(box)加载位置不准确的问题 + +## 3.28.8 + +- fix(PointSelector): 优化点击逻辑 + +## 3.28.7 + +- fix(PanoTagPlugin): 兼容 tag.stickType 没有时标签 config 的计算逻辑。 + +## 3.28.6 + +- fix(PointSelector): 修复 enable 时,一些状态没有重置的问题。 + +## 3.28.5 + +- fix(Object3DHelper): 修复一个 `Cannot read properties of undefined` 的报错 + +## 3.28.4 + +- fix(PanoTagPlugin): 修复 tag 的一些 events 没有触发的问题。 + +## 3.28.3 + +- fix(PanoTagPlugin): 修复 tag.id 改变后,tag 上的方法无法执行的问题 + +## 3.28.2 + +- chore: 发布 CHANGELOG + +## 3.28.1 + +- change(PointSelector): 修改射线碰撞半径 0.01 => 0.02 + +## 3.28.0 + +- feat(PanoTagPlugin): 新增 `plugin.changePositionById(id, position)` 和 `tag.changePosition(position)` + +## 3.27.10 + +- fix(PanoTagPlugin): 兼容 five/react + +## 3.27.9 + +- fix(Sculpt): 修复 `item.off()` 不生效的问题 +- fix(Sculpt): 修复 `plugin.clear()` 清除不干净的问题 +- feat(FiveDomEvents): 支持设置不在场景中的物体不触发事件 + +## 3.27.8 + +- change(PanoMeasurePlugin): 右键不退出测量 + +## 3.27.7 + +- fix(PointSelector): 兼容点云场景 + +## 3.27.6 + +- fix(PanoTagPlugin): 优化&修复标签自动展开时,其他标签被动收起的逻辑。 + +## 3.27.5 + +- fix(PanoTagPlugin): 修复 `destroyTagById` 执行后,视图没有更新的 bug + +## 3.27.4 + +- fix(PanoTagPlugin): 修复 `destroyTagById` 执行后,标签数组缓存没有更新的 bug + +## 3.27.3 + +- fix(PanoTagPlugin): 修复 contentTypeConfig 中,`ModelLike` 和 `Mapview` 等模型态 mode 配置同时存在时,会出现配置相互覆盖而不合并的问题。 + +## 3.27.2 + +- fix(PanoTagPlugin): 回滚 3.27.0 中的第二个 feature + +## 3.27.1 + +- fix(PanoTagPlugin): 修复 3.27.0 中 `initialState` 的 bug + +## 3.27.0 + +- feat(PanoTagPlugin): 支持移动屏幕时自动收起标签 +- feat(PanoTagPlugin): `initialState`支持不同 five mode + +## 3.26.0 + +- change(PanoTagPlugin): contentTypeConfig 移除对自定义标签类型的 Mixin-[type] 支持,直接使用 type 作为 key 即可 + +## 3.25.10 + +- fix(PanoTagPlugin): contentTypeConfig 支持任意自定义标签。 + +## 3.25.9 + +- fix(PanoTagPlugin): 修复 `changeConfig`, `changeContentTypeConfig` 修改影响标签展示的配置时,可能不会立即生效的问题。 +- fix(ObjectHelper): `ScaleController` 添加 `setScale` 方法。 + +## 3.25.8 + +- fix(PanoTagPlugin): 兼容 tailwind + +## 3.25.7 + +- fix(PanoVideoPlugin): shader 修复 +- chore(PanoTagPlugin): `Tag` 类型优化 + +## 3.25.6 + +- chore(PanoTagPlugin): 导出 `ContentTypeMapInterface` 类型 + +## 3.25.5 + +- chore(Sculpt): 优化 `Sculpt` ts 类型 + +## 3.25.4 + +- fix(Object3DHelper): 修复模型位移组件在特殊边界条件下位移不准确的问题。 + +## 3.25.3 + +- fix(\*): 修复插件 `load()` 时,数据校验检测不准确的问题。 + +## 3.25.2 + +- chore(Sculpt): 导出 type `SculptData` + +## 3.25.1 + +- chore(Sculpt): 导出 SculptPlugin + +## 3.25.0 + +- feat(MovePlugin): 模型漫游插件支持 `show()` `hide()` 路线 +- fix(ModelMakerPlugin): `load()`后立即应用当前`state` +- fix(ModelMakerPlugin): 修复`clear()`没有清除干净的 bug + +## 3.24.3 + +- fix(ModelMakerPlugin): 修复区域标注 prism 在特殊情况下走点后 标签会隐藏的问题 + +## 3.24.2 + +- fix(ModelMakerPlugin): 修复模型隐藏时,仍然可以点击的问题 + +## 3.24.1 + +- fix(ModelMakerPlugin): 修复 Box 名称无法显示的问题 以及 没有 name 字段时会显示 undefined 的问题 + +## 3.24.0 + +- feat(PanoTagPlugin): 滑动屏幕时的性能优化,当前点位不可能看到的标签不会有任何多余的计算。 +- fix(PanoTagPlugin): 修复 3.23.3 中手贱引入的 bug。 +- fix(ModelMakerPlugin): 修复 disable 函数报错问题。 + +## 3.23.3 + +- fix(ModelMakerPlugin): 修复循环引用的问题。 +- feat(ModelMakerPlugin): 添加函数`getItemById()`用来获取模型 Item。 + +## 3.23.2 + +- fix(ModelMakerPlugin): 多边形支持 hover 态。 +- fix(FiveDomEvent): 修复 unHover 不会触发的问题。 + +## 3.23.1 + +- fix(ModelMakerPlugin): 模型态标注标签支持碰撞检测。 + +## 3.23.0 + +- feat(ModelMakerPlugin): 新增默认 UI, 使用 `plugin.registerTagRenderer` 可自定义 UI。 + +## 3.22.0 + +- feat: add `ModelMakerPlugin` + +## 3.21.2 + +- fix(PanoMeasurePlugin): 修复`disable()`后仍能点击的问题。 + +## 3.21.1 + +- fix(\*): audio.js 支持 SSR + +## 3.21.0 + +- feat: 新增 `Sculpt`, [文档](../plugins/src/Sculpt/README.md) + +## 3.20.7 + +- fix(PanoMeasurePlugin): 彻底修复插件在序列化时会报错的问题 [相关 issue](https://github.com/mrdoob/three.js/issues/26598)。 + +## 3.20.6 + +- fix(PanoMeasurePlugin): 修复插件`disable`后,再次`enable`时,新手引导不展示的问题。 +- fix(PanoMeasurePlugin): 修复插件在序列化时会报错的问题 [相关 issue](https://github.com/mrdoob/three.js/issues/26598)。 +- chore(PanoMeasurePlugin): 移除废弃的类型声明。 + +## 3.20.5 + +- fix(GuideLinePlugin): 修复数据中没有 id 时,无法生成多条路线的 bug +- change(GuideLinePlugin): dispose 后可以正常调用 load 函数 +- feat(GuideLinePlugin): 内置默认箭头图片 + +## 3.20.4 + +- feat(MovePlugin): load 参数 data.path 支持传入坐标点数组。 + +## 3.20.3 + +- fix(PanoTagPlugin): 修复部分手机(oppo reno 9)的火狐浏览器中,视频贴片黑屏的问题 + +## 3.20.2 + +- fix(PanoTagPlugin): 修复一些特殊情况下,走点后标签点可见性判断错误的问题 + +## 3.20.1 + +- fix(PanoTagPlugin): 之前由于性能问题,去除了标签的 zIndex 策略。现在使展开后的标签的 zIndex 生效,以解决展开后的标签被其他标签遮挡的问题。 + +## 3.20.0 + +- feat(floorplan): 添加 `roomDimensionEnable` 参数, 控制是否展示分间长宽。用`getRoomDimensionText`自定义分间尺寸文案 + +## 3.19.1 + +- fix(PanoTagPlugin): 移除视频贴片不可见时的多余逻辑 + +## 3.19.0 + +- feat(PanoVideoPlugin): 添加 `unmuteByRenderID(id: string)` 方法来取消静音。 + +## 3.18.0 + +- feat(ObjectHelperPLugin): `moveController.moveByMouse()`参数`useFaceNormal`开启时,新增 `fixedFaceNormal` 参数用来设置修正后的用来做重合的 face 法向量 + +## 3.17.1 + +- feat(ObjectHelperPLugin): `moveController.moveByMouse()`参数`useFaceNormal`开启时,新增 `alignmentVector` 参数用来设置需要和面片法向重合的物体本地向量,默认使用 Y 轴重合。 + +## 3.17.0 + +- feat(ObjectHelperPLugin): `moveController.moveByMouse()` 新增 `{ useFaceNormal?: boolean }` 参数用来控制物体放置时,是否考虑面片的法线方向,默认为 `false` +- update(ObjectHelperPLugin): BoundingBox 边框线关闭 `depthTest` +- fix(ObjectHelperPLugin): 修复 controller 是否启用的判断逻辑错误的问题 + +## 3.16.2 + +- fix(ObjectHelperPLugin): 修复关闭 rotateHelper 时,放置物体会触发走点的问题 + +## 3.16.1 + +- fix(GuildLinePlugin): `skip_group` 配置移动到 `panorama_style` 中 + +## 3.16.0 + +- feat(GuildLinePlugin): 支持设置 `skip_group: boolean` 来选择是否跳过全景点位,默认为 `true` + +## 3.15.0 + +- feat(ObjectHelperPLugin): 支持设置 `moveHelper` x/y/z 轴是否开启 + +## 3.14.2 + +- chore(ObjectHelperPLugin): 优化`addObject3DHelper`方法的返回类型 + +## 3.14.1 + +- fix(GuildLinePlugin): 修复路线箭头颜色混合不正确的问题 + +## 3.14.0 + +- feat(GuildLinePlugin): 支持修改 `backgroundClip`,默认为 `border-box` + +## 3.13.0 + +- feat(GuildLinePlugin): 支持修改边框宽度 +- fix(GuildLinePlugin): 修复箭头黑边问题 + +## 3.12.7 + +- fix(PanoTagPlugin): 修复低版本浏览器非透明图片的黑屏问题 + +## 3.12.6 + +- revert: 回滚 svelte 版本 + +## 3.12.5 + +- fix(PanoTagPlugin): 修复商品标签性能问题 + +## 3.12.4 + +- fix(PanoTagPlugin): 修复一个内存泄漏的问题 + +## 3.12.3 + +- fix(AreaMaker): 优化 `tagShow` / `tagHide` 触发时机 + +## 3.12.2 + +- fix(ModalFloorplanPlugin): 修复模型户型图插件实例化时可能会错过设置 wrapper 时机的问题 + +## 3.12.1 + +- fix(FloorplanRanderPlugin): 修复户型雷达图多次调用 `appendTo` 时不生效的 bug + +## 3.12.0 + +- feat(CruisePlugin): 支持 `five@6.0` 多 work 数据 +- feat(GuildPlugin): 支持 `five@6.0` 多 work 数据 +- feat(GuildPlugin): 路线默认图片支持低版本浏览器 +- feat(PanoTagPlugin): 提供 debug 方法来关闭碰撞检测: `plugin.debugUtil.closeIntersectRaycaster()` +- fix(PanoTagPlugin): 修复 `changeGlobalConfig` 后 config 计算错误的 bug + +## 3.11.0 + +- feat(AreaMakerPlugin): item 新增事件 `tagShow` / `tagHide`,在标注标签被模型遮挡/不遮挡时触发 + +## 3.10.3 + +- fix(CruisePlugin): 修复续播问题 + +## 3.10.2 + +- chore(AreaMakerPlugin): resize 使用 `resizeObserver` 的实现方案替代 `iframe` 的实现方案 + +## 3.10.1 + +- chore: 兼容 five@6.0.0-alpha.56 + +## 3.10.0 + +- feat(AreaMakerPlugin): object_data 新增 `{ visible?: boolean }` 属性,用于控制模型的可见性,默认为 true + +## 3.9.0 + +- feat(PanoVideoPlugin): 添加渐现效果 + +## 3.8.11 + +- fix(PanoTagPlugin): 提升在点云场景下的性能 + +## 3.8.10 + +- fix(PanoTagPlugin): 兼容 Five 5.x 版本 + +## 3.8.9 + +- fix(AreaMakerPlugin): load 时之前的数据没有销毁干净的问题 + +## 3.8.8 + +- chore(PanoTagPlugin): 修改默认配置 + +## 3.8.7 + +- fix(AreaMakerPlugin): 修复 load 可能不生效的问题 + +## 3.8.6 + +- fix(MovePlugin): 修复不能重复播放的问题 + +## 3.8.5 + +- fix(PanoTagPlugin): 修复 usePoint 影响到了非自定义标签的问题 + +## 3.8.4 + +- fix(PanoTagPlugin): 修复标签在初始化过程中就妄图拿到初始化结果的问题,会导致一些设置了 visibleFiveMode 的标签无法按照预期显示 + +## 3.8.3 + +- fix(MovePlugin): 修复一些 hook 没有正常触发的问题;修复 开始播放/续播 时有延迟的的问题 + +## 3.8.2 + +- fix(CruisePlugin): 修复 CruisePlugin 和 MovePlugin 初始化参数无法设置的问题 + +## 3.8.1 + +- fix(Object3DHelperPlugin): 修复 MoveHelper 没有销毁的问题,更改 boundingBox 计算的逻辑 + +## 3.8.0 + +- feat(PanoTagPlugin): registerRenderer 新增 usePoint 参数,用于设置自定义标签是否使用标签点 + +## 3.7.0 + +- feat(MovePlugin): 新增 MovePlugin,支持按照指定的路径移动相机 + +## 3.6.0 + +- feat(AreaMakerPlugin): 支持通过设置`itemRenderer`属性来自定义标签渲染器 + +## 3.5.1 + +- fix(PanoTagPlugin): 修复修改标签 position 后没有重新计算标签可见性的问题 + +## 3.5.0 + +- feat(PanoTagPlugin): 添加 `bindRenderer(currentCententType: string, targetContentType: TagContentType)` 方法,当标签的 ContentType 为 currentCententType 时,会使用 targetContentType 的渲染器来渲染标签 +- fix(PanoTagPlugin): 修复 tag.config 在处理多种 five mode 时 config 会被覆盖的问题 + +## 3.4.1 + +- style(PanoTagPlugin): 标签样式修复 + +## 3.4.0 + +- feat(PanoTagPlugin): 添加全景标签 + +## 3.3.6 + +- fix(PanoTagPlugin): 修复走点时可能报错的问题 + +## 3.3.5 + +- feat(PanoTagPlugin): 2d 标签按需加载 dom,优化性能问题 + +## 3.3.4 + +- fix(Floorplan): 复户型图在少数情况下,第一次从模型态展示户型图时展示失败。 + +## 3.3.3 + +- fix(PanoTagPlugin): 修复 3.3.2 中可能会出现报错的问题 + +## 3.3.2 + +- fix(PanoTagPlugin): 如果 config keep 值存在,强制修改 initialState + +## 3.3.1 + +- fix(PanoTagPlugin): 修复报错 + +## 3.3.0 + +- feat(PanoTagPlugin): 标签在`Mapview`态时,支持按距离显示。 +- feat(PanoTagPlugin): 标签位置计算支持多 Work 场景下的标签位置偏移量。 +- fix(PanoTagPlugin): 修复了标签在消失动画过程中时不会更新位置的问题。 +- fix(PanoTagPlugin): 图片贴片兼容低版本 Chrome。 + +## 3.2.4 + +- fix(CurrentPanoImage): texture.minFilter 改为 THREE.LinearFilter,用于修复在部分设备下渲染图片异常。 + +## 3.2.3 + +- fix(GuideLinePlugin): 修复设置 tag 为空时再修改别的属性报错。 + +## 3.2.2 + +- fix(GuideLinePlugin): 修复 tag.data 为 null 时报错。 + +## 3.2.1 + +- fix(GuideLinePlugin): 修复配置路线引导位移时标签没有变化。 + +## 3.2.0 + +- feat(GuideLinePlugin): 路线引导支持配置位移。 + +## 3.1.3 + +- fix(PanoTagPlugin): 修复带帧动画的标签在低版本浏览器中显示异常的问题。 + +## 3.1.2 + +- fix(PanoTagPlugin): 视频贴片 autoplay 为 true 时,在微信场景下允许一直尝试自动播放。 + +## 3.1.1 + +- fix(floorplan-radar): 修复雷达图参数为空时报错的问题。 + +## 3.1.0 + +- feat(floorplan): 户型图支持缺失楼层配置。可以配置一张占位图片和文字。 +- feat(floorplan): 雷达图图支持缺失楼层配置占位图。 + +## 3.0.1 + +- fix(PanoTagPlugin): 修复 safari 中模型态标签 hide 时,opacity 不会立即生效的问题 + +## 3.0.0 + +- feat(\*): 插件支持 Five 6.x 版本 +- fix(CSS3DRenderPlugin): 嵌套 object 的 show/hide 修复 +- fix(PanoTagPlugin): 修复 renderType 为 Mesh 时,MediaPlane 标签 无法正常显示 gif 的问题 +- fix(PanoTagPlugin): 修复 changeConfig 性能问题;其他 bug 修复 +- fix(PanoMeasurePlugin): 设置放大镜容器为传入的 container 而不是 body +- fix(PanoMeasurePlugin): 修复 Five 不为全屏时,测量时的辅助坐标点计算错误的问题 +- chore(floorplan): 兼容 five changeMode 时, 传入 0, 得到的可能是 Math.PI \* 2 的问题 +- 优化 FiveDomEvents 性能 + +## 2.31.0 + +- PanoTagPlugin: + - feat: 更好的支持`2D标签`在模型态下的展示,内置模型态标签的相关配置 + - feat: visibleMode 支持 `Mode | Mode[] | 'PanoramaLike' | 'ModelLike' | 'all' | function`; 默认值为 `tag.fiveState?.mode ?? 'Panorama'` + - feat: `plugin.config.contentTypeConfig` 支持设置标签在不同 FiveMode 下的展示行为。 具体值参照 `type ContentTypeConfigKey` + - feat: 使用 2.27.3 相似方式 优化 `tag.contentType` 的类型推断 + - fix: 修复部分情况下标签的渐显动画失效的问题 + - fix: 修复`2D标签`远近距离判断错误的问题 + - fix: 使用 `five.model.uuid` 代替 `five.work.workCode` 作为标签点位缓存的 key, 修复加载其他 five 后,缓存依然生效的问题 + - chore: `FiveDomEvents` 代码优化 + +## 2.30.3 + +- fix(MapviewFloorplanPlugin): 修复移动端缩放失效。 + +## 2.30.2 + +- fix(AreaMakerPlugin): 修复 initialState 不生效。 + +## 2.30.1 + +- fix(CurrentPanoImagePlugin): 修复 five initialState.mode 不为 Panorama 且 Plugin initialState.enabled 为 false 时,先 changeMode 到 Panorama 再调用 Plugin.enable() 在首点位模型没有正常展示的问题。 +- feat(CurrentPanoImagePlugin): 提供 \_\_whyCantSeeMesh 方法,用于 debug 时查找为什么无法看到模型。 + +## 2.30.0 + +- feat(CurrentPanoImagePlugin): 新增 CurrentPanoImagePlugin。 + +## 2.29.0 + +- feat(PanoTagPlugin): 添加函数 `tag.whyHide(tagId)`,会告诉你为什么看不到标签 +- fix(PanoTagPlugin): 重构物体点击判断逻辑,修复 bug;减少射线检测次数,提升性能 + +## 2.28.6 + +- fix(CruisePlugin): 后置 load 函数中的 `clearPauseData()` 调用时机,修复 play 过程中执行 load 导致暂停的情况下,记录了暂停数据的问题 + +## 2.28.5 + +- fix(PanoCompassPlugin): 支持配置 logoURL + +## 2.28.4 + +- fix(PipelinePLugin): typo +- update github action + +## 2.28.3 + +- fix(AreaMakerPlugin): 修复屏幕 Resize 时,标签位置错误。 + +## 2.28.2 + +- fix(AreaMakerPlugin): 修复调用 plugin.hide 时,标注标签没有隐藏。 +- fix(AreaMakerPlugin): 修复 Five 初始状态不是全景时,没有正确加载。 +- fix(AreaMakerPlugin): 修复插件参数没有正确传入。 + +## 2.28.1 + +- fix(PanoTagPlugin): 修复透明图片贴片的黑边问题 + +## 2.28.0 + +- feat(AreaMakerPlugin): 添加 AreaMakerPlugin。 + +## 2.27.4 + +- fix(PanoTagPlugin): 修复安卓小程序中,视频贴片无法自动播放的问题 + +## 2.27.3 + +- feat(PanoTagPlugin): 优化 tag.data 的类型 + 1. 对于未知类型的 tag 如 `tag: Tag`,现在可以使用 tag.data.my_any_property 而不报 ts 错误, 而之前版本需要使用`tag: Tag` + 2. 对于已知类型的 tag 如 `tag: Tag<'Text'>`, 现在可以使用 tag.data.my_any_other_property 而不报 ts 错误 + +## 2.27.2 + +- fix(PanoTagPlugin): 修复 tag 没有处理模型标签的 clickable。 + +## 2.27.1 + +- fix(PanoTagPlugin): 修复在部分 IOS 微信场景中,虚拟视频自动播放时播放按钮没有消失的 bug + +## 2.27.0 + +- feat(PanoTagPlugin): 碰撞检测支持更精细的检测配置,默认检测所有 tag.position,默认任意一点检测通过则视为碰撞检测通过 +- fix(PanoTagPlugin): 修复 MediaPlane 标签的 `tag.disable()` / `tag.enable()` 方法不生效的 bug +- fix(PanoTagPlugin): MediaPlane visible 状态变化为 false 时,立即销毁图片资源 +- fix(PanoTagPlugin): TextTag 支持换行符 + +## 2.26.2 + +- fix(PanoTagPlugin): 修复模型 loaded 判断。 + +## 2.26.1 + +- fix(MeasurePlugin): 修复测量撤销时线段删除有问题 & 修复报错。 + +## 2.26.0 + +- fix(Floorplan): 修复户型图插件连续调用两次 show() 展示失败。 +- feat(Pipeline): 添加 Pipeline 插件。 + +## 2.25.0 + +- feat(MapviewFloorplanPlugin): Mapview Floorplan 支持惯性滚动。 + +## 2.24.2 + +- fix(PanoTagPlugin): fix ImagePlane z-fighting + +## 2.24.1 + +- fix(PanoMeasurePlugin): 测面积支持自定义单位转换,使用方法 `changeConfigs(getAreaText: (area: number) => string` + +## 2.24.0 + +- feat(PanoTagPlugin): MediaPlane visible 状态变化为 false 时,立即销毁视频资源 + +## 2.23.1 + +- fix(PanoCompassPlugin): 支持 i18n 函数 + +## 2.23.0 + +- feat(PanoTagPlugin): textTag 的 plane 样式下新增 data.titleMaxRows 和 data.descriptionMaxRows,用于控制最大显示行数,默认显示全部 +- fix(PanoTagPlugin): 修复 textTag.data.edit 的 placeholder 为空字符串时不显示插入符的问题 + +## 2.22.0 + +- feat(PanoMeasurePlugin): 新增测面积功能,使用 editParams.allowMeasureType: ['line', 'area'] 开启 + +## 2.21.1 + +- fix(PanoCompassPlugin): 修复 config.staticPrefix 不生效的问题 + +## 2.21.0 + +- fix(MeasurePlugin): 为了优化性能,测量插件去除「吸附」功能,将不会在模型初始化时计算模型边界。 +- fix(ModelChassisCompassPlugin): 修复模型底盘在模型改变时,没有更新位置。 + +## 2.20.9 + +- chore(\*): 插件图片转为 base64 或支持 staticPrefix 参数 + +## 2.20.8 + +- fix(GuideLinePlugin): 路线标签距离使用 Math.round。 + +## 2.20.7 + +- fix(GuideLinePlugin): 更改路线标签线条宽度。 + +## 2.20.6 + +- fix(GuideLinePlugin): 修复路线标签样式。 + +## 2.20.5 + +- feat(GuideLinePlugin): 标签展示路线长度。 + +## 2.20.4 + +- fix(PanoTagPlugin): 修复图片贴片没有根据 config.clickable 来设置点击事件的问题 + +## 2.20.3 + +- fix(\*): fix Lint。 +- fix(FloorplanRadarPlugin): 修复鼠标 hover 报错。 +- feat(GuideLinePlugin): 支持距离计算。 + +## 2.20.2 + +- fix(GuideLinePlugin): 修复旧版本数据无法展示。 + +## 2.20.0 + +- feat(PanoTagPlugin): + + - Typescript 类型优化 + - 新增方法 `tag.changeData(data: PartialObjectDeep): void`,用于修改标签的 `data` + - 新增方法 `registerRenderer(contentType: string, renderer: ElementRenderer): void`,插件会按照传入的 `renderer` 来渲染相应的 `ContentType` + +- fix(PanoTagPlugin): 使用 `PartialObjectDeep` 代替 `PartialDeep`, 修复复杂场景下的类型推断问题 +- fix(\*): 修复 eslint 失效问题 + +- chore(\*): 修改 load 日志级别为 `Verbose` + +## 2.19.3 + +- fix(PanoTagPlugin): 使用 z-index 代替 dom 排序,解决标签数量较多时的卡顿问题 + +## 2.19.2 + +- fix(PanoTagPlugin): 修复多媒体标签没有自动轮播的问题。 + +## 2.19.1 + +- fix(PanoMeasure): 修复移动端测量工具没有触发 editedPolylineChange。 + +## 2.19.0 + +- feat(PanoTagPlugin): 添加 Model 类型。 +- feat(PanoTagPlugin): 允许自动转向。 +- feat(PanoTagPlugin): 添加 MediaModel 和 Model 的点击行为。 +- fix(PanoTagPlugin): 修复标签插件初始化时合并 config 没有深度合并。 +- fix(PanoTagPlugin): 修复 MediaModel renderType 不为 Mesh 时,非 Panorama 态展示异常。 +- fix(PanoMeasure): 修复移动端删除测量线段报错。 + +## 2.18.5 + +- fix(PanoTagPlugin): 修复标签 style.point 报错。 + +## 2.18.4 + +- fix(GuideLinePlugin): 修复历史数据默认展示逻辑。 + +## 2.18.3 + +- fix(GuideLinePlugin): 修复标签控制判断。 + +## 2.18.2 + +- feat(GuideLinePlugin): 允许通过传入空值动态删除标签。 + +## 2.18.1 + +- fix(GuideLinePlugin): 加载标签插件时,不使用 followModelVisibility。修复自定义标签楼层显示错误。 + +## 2.18.0 + +- feat(GuideLinePlugin): 路线引导插件支持自定义路径。 + - 支持添加模型 & 全景两种不同的路线。 + - 支持配置路径背景、贴图颜色、边框、缩放。 + - 支持模型态时添加起点、终点标签。 + - 支持路径闪烁动画。 + - 支持路径流动动画。 +- refactor(\*): 优化打包: + - 支持 CJS 库的引用。 + - 优化 ESLint,在引用 TS 声明时,需要显示表明 import type。 + +## 2.17.1 + +- fix(PanoTagPlugin): 修复微信场景中的视频贴片不能自动播放的问题 +- change(PanoTagPlugin): 修复一个拼写错误, autoUnfoldWhenHide -> autoFoldWhenHide + +## 2.17.0 + +- feat(PanoTagPlugin): tag config 新增 initialData 字段,可以设置标签中的 data 的初始值。tag.mergeConfig.initialData 会深度合并入 tag.data 中 +- feat(PanoTagPlugin): tag config 新增 followModelVisibility 字段,用于控制当标签在 Floorplan、MapView 可见时,是否仅在当前高亮的楼层显示。默认值为 false +- feat(PanoTagPlugin): 视频贴片支持通过 `tag.config.initialData.autoplayConfig.autoplayVideo` 或 `tag.data.autoplayConfig.autoplayVideo` 设置默认是否播放,默认值为 false +- fix(PanoTagPlugin): 修复以 Mesh 形式渲染的图片贴片没有 emit 点击事件的 bug +- fix(PanoTagPlugin): 修复以 Mesh 形式渲染的贴片的 ObjectFit 没有生效的 bug +- fix(PanoTagPlugin): 将 five.panoIndex 改为 five.getCurrentState().panoIndex,保证 panoIndex 不为 undefined + +## 2.16.1 + +- fix(PanoTagPlugin): 视频贴片隐藏/禁用时,不再监听播放按钮 Mesh 的点击事件 +- fix(PanoTagPlugin): 修复视频被动播放时封面图的展示逻辑 + +## 2.16.0 + +- feat(PanoTagPlugin): 视频贴片支持以 Mesh 方式渲染 +- feat(PanoTagPlugin): 优化 Five 焦点环在不透明图片贴片上的效果 +- fix(PanoTagPlugin): 修复 getRenderType 有可能返回 undefined 的 bug,这个 bug 会导致部分含有 mediadata 的 3DPoint 标签无法显示 +- fix(PanoTagPlugin): 修复广告牌中的图片以 css3d behind 模式渲染时, 调用 disable 时没有删除 css3dObject.opacityMesh 的问题 +- fix(PanoTagPlugin): 修复广告牌中的图片以 css3d behind 模式渲染时, 调用 enable 时没有同步 css3dObject 的 matrix 的问题 + +## 2.15.0 + +- change(PanoTagPlugin): 单张的视频贴片不再支持以 behindDom 模式渲染,因为目前会有黑边问题;后续会直接使用 Mesh 实现 +- change(threex): 监听到 touch 相关事件后不再执行 preventDefault() +- feat(PanoTagPlugin): 自定义标签(customTag)取消了展开/收起时的默认样式 +- feat(PanoTagPlugin): 标签添加 className 属性,可以在标签的父元素上添加自定义的 className +- fix(PanoTagPlugin): 修复视频贴片播放时没有声音的问题 +- fix(PanoTagPlugin): 修复视频贴片以 Dom 形式渲染时无法播放的问题 + +## 2.14.3 + +- fix(PanoTagPlugin): 虚拟屏幕标签存在多张图片的时候不以 behind 模式渲染 +- fix(PanoTagPlugin): 单张的视频贴片支持以 behind 模式渲染 +- fix(CruisePlugin): 修复 CruisePlugin 解析数据时可能计算出错误 longitude/latitude 的问题 + +## 2.14.2 + +- fix(PanoFloorplanRadarPlugin): 修复 PanoFloorplanRadarPlugin 配置 hoverEnable 为 true 报错的问题 + +## 2.14.1 + +- fix(ModelChassisCompassPlugin): 替换模型底盘文件使用的贴图宽高为 2 的整数次幂 + +## 2.14.0 + +- feat(PanoTagPlugin): MediaModel(虚拟广告牌)新增 `config.renderType: 'Mesh' | 'Dom'` 配置,默认值为`Dom` +- chore(\*): 通过 loadTexture 函数加载的 texture 的 wrapS/wrapT 默认值设置为 ClampToEdgeWrapping + +## 2.13.2 + +- refactor(floor & tag & roomLabel): 更改 dom resize 监听。从 iframe 改成了 resizeObserver。 + +## 2.13.1 + +- fix(\*): 修复 ios16.4 上 texture 使用默认 mipmap 的方式插值时导致 texture 变黑的问题 + +## 2.13.0 + +- feat(PanoTagPlugin): 三维图片标签(贴片标签)新增 `config.renderType: 'Mesh' | 'Dom'` 配置,默认值为`Dom`,当数据中只有一张图片时,可以选择 Mesh 或 CSS3DRender 形式渲染。 + +## 2.12.0 + +- feat(PanoMeasurePlugin): 支持国际化配置。 + +## 2.11.2 + +- feat(TopviewFloorplanPlugin ModelFloorplanPlugin MapviewFloorplanPlugin): 支持 highlight 高亮 支持 去掉 Camera + +## 2.11.1 + +- feat(ModelRoomLabelPlugin): 支持 Mapview 模式。 + +## 2.11.0 + +- fix(PanoTagPlugin): 修复无法被展开/收起的标签可以通过 changeUnfoldedById 方法强制展开/收起的 bug +- feat(\*): BasePlugin 添加 `readonly VERSION: string` 属性,默认值取自 package.json 中的 version 字段 +- feat(PanoTagPlugin): + - 优化帧动画组件,减少不必要的 Dom 和计算 + - 标签点支持帧动画 + - 不再建议通过 size 设置标签点大小,而是通过 ratio 指定输入图片为几倍图,默认为三倍图 + +## 2.10.8 + +- fix(panoTagPlugin): 修复当`音频标签A`播放结束后,播放其他`音频标签B`时,`音频标签A`的播放动画会触发的问题。 +- fix(PanoTagPlugin): 修复音频标签无法在部分 iPhone `(>= ios 15)` 中播放第二次的问题。 +- 相关文档: + - [github issus](https://github.com/aws/amazon-chime-sdk-js/issues/2394) + - [webkit bugs](https://bugs.webkit.org/show_bug.cgi?id=241152) + - [Auto-Play Policy Changes for macOS](https://webkit.org/blog/7734/auto-play-policy-changes-for-macos/) + +## 2.10.7 + +- fix(PanoTagPlugin): 修复 hide 未隐藏 MR 标签。 + +## 2.10.6 + +- fix(PanoVideoPlugin): 修复 video 事件监听丢失。 + +## 2.10.5 + +- fix(PanoVideoPlugin): 修复看向模型时视角错误。 +- perf(PanoVideoPlugin): 优化视频添加时机。 + +## 2.10.4 + +- fix(PanoVideoPlugin): 修复 load 导致的 enable 失效。 + +## 2.10.3 + +- fix(PanoTagPlugin): 修复音频标签在部分 iPhone `(<= ios 15)`上续播失败的问题。原因是浏览器中的 HTMLAudioElement 在设置 currentTime 时,会根据 metadata 信息做校验,所以在 onloadeddata 事件触发前无法成功设置 currentTime。 +- 相关文档: + - [MDN]('https://developer.mozilla.org/en-US/docs/Web/API/HTMLMediaElement/currentTime') + +## 2.10.2 + +- fix(PanoVideoPlugin): 点位视频支持点击播放时,判断视频 Mesh 是否在场景中。 + +## 2.10.1 + +- feat(PanoVideoPlugin): 点位视频支持点击播放。 +- feat(PanoVideoPlugin): 点位视频支持点击看向某个视频元素。 + +## 2.10.0 + +- feat(PanoVideoPlugin): 添加点位视频融合插件。 + +## 2.9.2 + +- fix(PanoTagPlugin): 修复音频标签第二次播放时,点击播放按钮无反应的问题。 + +## 2.9.1 + +- feat(PanoMeasurePlugin): 测量工具 DistanceDOM 不再判断端点是否超出屏幕。 + +## 2.9.0 + +- feat(PanoTagPlugin): MarketingTag 新增黑色主题: `theme: 'light' | 'dark'`, 默认为 `light`。 +- feat(PanoTagPlugin): Media 组件优化,一张图片/视频时不放入轮播组件中。 +- fix(PanoTagPlugin): 修复 disable() 无法完全禁用 MediaModelTag 的问题 + +## 2.8.6 + +- feat(PanoTagPlugin): 添加 ContentType 为 Sticker 的 Tag +- fix(PanoTagPlugin): 修复 LinkTag 动画帧数为 1 时不显示文字的问题 + +## 2.8.4 + +- fix(Object3DHelper): 修复初始化时的一个报错 + +## 2.8.3 + +- fix(Object3DHelper): 重构优化部分旋转逻辑,修复绕旋转 z 中心旋转时的 bug + +## 2.8.2 + +- fix(PanoTagPlugin): 修复 MediaModelTag loading 计算错误。 + +## 2.8.1 + +- fix(PanoTagPlugin): 修复 MediaModelTag 射线检测。 + +## 2.8.0 + +- feat(floorplan): 户型图插件添加配置 + - 分间面积是否展示:roomAreaEnable + - 分间名称是否展示:roomNameEnable + +## 2.7.3 + +- fix(PanoTagPlugin): 修复部分标签 content 无法点击的问题 + +## 2.7.2 + +- fix(Object3DHelperPlugin): 修复 Object3DHelperPlugin 的 CSS3DScaleHelper 的操作框位置错误的问题 + +## 2.7.1 + +- fix(PanoTagPlugin): 修复 disable -> load -> enable 路径 MediaModelTag media content 不展示。 + +## 2.7.0 + +- feat(PanoTagPlugin): 添加 ContentType 为 MediaModel 的 Tag。 + + - 允许加载外部 GLTF 模型。 + - 允许通过 4 个点和多媒体信息,配置模型上应该展示的多媒体。 + - TagConfig 添加 visibleFiveMode,允许配置在哪个模态下展示标签。 + - 允许动态更改 Tag css3D mode。 + +- feat(Object3DHelper): + + - 新增 BoundingBoxHelper,默认关闭 + - 新增配置可以控制三条旋转轴的显示/隐藏 + - 修复一些 bug + +- change(PanoTagPlugin): + - 使用 svelte-carousel 代替 swiper + - 标签的 tag.data.objectFit 默认值改为 fill + +## 2.6.6 + +- fix(TagPanoPlugin): 修复 config `clickable` 未生效的情况 +- change(TagPanoPlugin): 移除文字 word-break: break-all 的 css 属性 + +## 2.6.5 + +- fix(TagPanoPlugin): videoTag disable picture-in-picture + +## 2.6.4 + +- feat(GuidePlugin): fix dispose function + +## 2.6.3 + +- feat(PanoTagPlugin): [changelog: 2.0.8](https://github.com/realsee-developer/dnalogel/blob/main/plugins/src/PanoTagPlugin/Archive/CHANGELOG.md) + +## 2.6.2 + +- fix(CruisePlugin): 漫游插件(CruisePlugin)支持设置路线插件(GuideLinePlugin)的贴图等参数。 + +## 2.6.1 + +- fix(PanoMeasurePlugin): 修复先 load 数据再 changeMode:View 时,没有应用 panoIndexes 的问题。 + +## 2.5.4 + +- fix(PanoTagPlugin): 修复一个比较严重的报错 + +## 2.5.3 + +- fix(PanoTagPlugin): 修复模型状态下仍然可以点击标签点的问题 + +## 2.5.2 + +- fix(PanoMeasurePlugin): 修复 View 模式 load 数据时没有应用 visiblePanoIndexes。 + +## 2.5.1 + +- fix(PanoTagPlugin): tag-container 添加 `transform: translate3d(0,0,0)`,解决 iPhone13 上标签闪烁的问题,以及可能会影响其他 Dom 元素正常渲染的问题。 + +## 2.5.0 + +- feat(PanoTagPlugin): 标签插件升级。 [changelog: 1.2.7 -> 2.0.5](https://github.com/realsee-developer/dnalogel/blob/main/plugins/src/PanoTagPlugin/Archive/CHANGELOG.md) + +## 2.4.0 + +- 1. feat(MeasurePlugin): 测量工具支持标尺功能。 + +## 2.3.8 + +- 1. feat(PanoTagPlugin): tag dom 添加 `data-content-type={tag.contentType}` 用来标识标签的 contentType + +## 2.3.6 + +- 1. feat(CruisePlugin): load 添加参数 moveToFirstPanoDuration,可指定移动到漫游初始点时的速度。 + +## 2.3.5 + +- 1. feat(model-view-plugin): 支持动态 enable 和 disable。 + +## 2.3.4 + +- 1. fix(pano-tag-plugin): 修复空格不展示。 + +## 2.3.2 + +- 1. feat(pano-measure-plugin): 支持传入自定义 UI 文案 + +## 2.2.7 + +- 1. fix(build:libs): 修复 libs 构建产物异常的问题。 + +## 2.2.6 + +- 1. feat(entry-door): 入户门插件支持配置 name。 + +## 2.2.1 + +- 1. fix(floorplan-radar): 修复在 panoArrived 之后 loadData 时初始展示楼层只会是一层的问题。 + +## 2.2.0 + +- 1. refactor: 开发/构建流程优化 + +## 2.1.1 + +- 1. feat: PointHelper 和 PointDomHelper 直径改成 0.4m。 + +## 2.1.0 + +- 1. feat: CSS3DRenderPlugin API 支持插件 3.0 标准 +- 2. refactor: CSS3DRenderPlugin 重构,提供不依赖 Five 的内部类 +- 3. fix: CSS3DRenderPlugin 修复在部分情况下,CSS3DDom 最终渲染结果与传入的四个点的朝向可能不一致的情况 +- 4. feat: ModelTVVideoPlugin 视频点击行为由 「静音播放/不静音播放」 改为 「播放/暂停」,且在暂停时显示播放按钮 +- 5. feat: 导出 Util + +## 2.0.4 + +- 1. 构建工具优化 + +## 2.0.3 + +- 1. fix: ModelRoomLabelPlugin 修复在 Five 模型切换动画过程中改变楼层,没有触发刷新的问题。 +- 2. fix: ModelRoomLabelPlugin 修复切换楼层时,没有触发立即刷新的问题。 +- 3. refactor: ModelViewPlugin 支持配置锁定视角和点位。 + +## 2.0.2 + +- 1. feat: FloorplanPlugin 支持动态修改房间面积展示和房间标尺展示 +- 2. feat: PanoRulerPlugin 支持动态修改距离展示 +- 3. feat: PanoMeasurePlugin 支持动态修改距离展示 +- 4. refactor: FloorplanPlugin 允许 `setState` 传入 `Partial` 而不是 `Config` + +## 2.0.0 + +- 1. fix: `ModelViewPlugin` 修复模型部分材质不展示的问题 +- 2. feat: CruisePlugin 漫游插件 +- 3. feat: GuideLinePlugin 地面路线引导插件 + +## 2.0.0-alpha.57 + +- 1.fix: PanoRulerPlugin 部分数据情况下 element 未 display: none 问题。 + +## 2.0.0-alpha.56 + +- 1.fix: PanoRulerPlugin off 全量事件监听。 + +## 2.0.0-alpha.55 + +- 1.fix: PanoRulerPlugin 异常 Dom。 +- 2.51 ~ 54 版本为测试阶段,主版本无异常变更。 + +## 2.0.0-alpha.50 + +- 1.feat: MapviewFloorplanPlugin: 添加大空间户型图插件 + +## 2.0.0-alpha.49 + +- 1.fix: ModelTVVideoPlugin 多点位视频播放。 + +## 2.0.0-alpha.43 + +- 1.fix: PanoCompassPluginData 导出 + +## 2.0.0-alpha.42 + +- 1.fix: PanoCompassPlugin 未完全 dispose 导致切换 VR 重新加载数据出现异常。 +- 2.fix: PanoCompassPlugin 在 five 切换全景与模型,入户门与分间指向错位的问题。 + +## 2.0.0-alpha.41 + +- 1.feat: 40 版本漏发。 + +## 2.0.0-alpha.40 + +- 1.refactor: PanoMeasurePlugin: 添加 View Mode,支持用户仅预览和点击高亮。 + +## 2.0.0-alpha.39 + +- 1.feat: 更新 ItemLabelPlugin 策略,仅在全景模态下展示。 + +## 2.0.0-alpha.38 + +- 1.feat: 新增 PanoRulerProPlugin。 + +## 2.0.0-alpha.37 + +- 1.feat: 参考 plugins/src/floorplan/CHANGELOG.md v1.0.1 + +## 2.0.0-alpha.36 + +- 1.style: PanoMeasurePlugin pc 端 UI 优化 +- 2.style: PanoMeasurePlugin 准心优化,支持是否展示法向量和小球颜色可配置 +- 3.fix: 修复 ResizeObserver 使用。 +- 4.refactor: 参考 plugins/src/floorplan/CHANGELOG.md v1.0.0 + +## 2.0.0-beta.36 + +- 1.refactor: 户型图相关插件改造,详情参考 floorplan/CHANGELOGE.md。 + +## 2.0.0-alpha.35 + +- 1.style: PanoSpatialTagPlugin 标签样式兼容, 标签阴影背景自适应; +- 2.feat: PanoSpatialTagPlugin 开放可见距离配置参数,此功能不保证最佳 UI 效果); +- 3.refactor: PanoSpatialTagPlugin 更新中心点位置及事件监听。 + +## 2.0.0-alpha.34 + +- 1.feat: 新增 PaintBrush 组件,此版本为实验版,请谨慎使用。 + +## 2.0.0-alpha.33 + +- 1.fix: Floorplan Plugins Compass & ModelChassisCompassPlugin 修复对 north_rad 为 0 的处理 +- 2.fix: panospatialtagplugin 兼容 nextjs 出现的 text 样式问题 + +## 2.0.0-alpha.32 + +- 1.feat: PanoRulerPlugin 修改标尺隐藏策略,线长小于 0.3m 隐藏; +- 2.fix: TopViewFloorplanPlugin & ModelFloorplanPlugin wrapper pointer-events: none。 + +## 2.0.0-alpha.31 + +- 1.fix: 修复 ?? 语法在 svelte 中不编译的问题。 + +## 2.0.0-alpha.30 + +- 1.feat: PanoMeasurePlugin 新增移动端 UI 交互模式 +- 2.feat: PanoMeasurePlugin 点线、标签气泡、删除按钮、三维坐标系 UI 交互优化 +- 3.feat: PanoMeasurePlugin 优化放大镜功能,支持可拖拽,新增放大镜开放参数 +- 4.fix: TopviewFloorplanPlugin 兼容全局 text-align 使用 +- 5.fix: 新增 ItemLabelPlugin 内测版 + +## 2.0.0-alpha.29 + +- 1.chore: 删除 react 依赖. + +## 2.0.0-alpha.28 + +- 1.chore: 优化打包输出路径. + +## 2.0.0-alpha.27 + +- 1.feat: PanoSpatialTagPlugin 兼容 bvh 为 false 模式. + +## 2.0.0-alpha.26 + +- 1.fix: ModelRoomLabelPlugin - 修复渲染区域大小改变时,标签位置没有更新 +- 2.pref: ModelRoomLabelPlugin - 优化渲染逻辑 + +## 2.0.0-alpha.25 + +- 1.refactor: 恢复发版 + +## 2.0.0-alpha.24 + +- 1.feat: PanoRulerPlugin 支持数据 reload。 + +## 2.0.0-alpha.23 + +- 1.fix: 修复 PanoFloorplanRadarPlugin reload 数据时报错 +- 2.fix: 修复 PanoFloorplanRadarPlugin reload 户型图数据后雷达图标位置没有适配 + +## 2.0.0-alpha.22 + +- 1.fix: 修复 PanoMeasurePlugin disable 状态下仍有背景色占位问题。 + +## 2.0.0-alpha.21 + +- 1.fix: 修复 PanoMeasurePlugin 仅初始化 UI 面板仍占位为题。 + +## 2.0.0-alpha.20 + +- 1.fix: 修复 PanoMeasurePlugin hide 时 UI 面板仍占位为题。 + +## 2.0.0-alpha.19 + +- 1.fix: 修复在模型中切换全部楼层,切换回户型图,展示的是上一次展示时的楼层; +- 2.fix: 修复户型图界面切换楼层时,图片与 SVG 渲染有时间差导致闪烁的问题; +- 3.feat: TopviewFloorplanPlugin 插件支持放大缩小; +- 4.feat: ModelFloorplanPlugin 插件,autoShowEnable 和 hoverEnable 能同时支持; +- 5.chore: 设置 tsconfig.json importsNotUsedAsValues 为 error,在引用类型时,必须显示写为 import type。 + +## 2.0.0-alpha.18 + +- 1.fix: 修复 PanoMeasurePlugin 使用时 hammerjs 报错问题。 + +## 2.0.0-alpha.17 + +- 1.fix: 修复构建输出 px2rem 失效问题。 + +## 2.0.0-alpha.16 + +- 1.fix: 修复 z-index 问题; +- 2.fix: 修复 ModelItemLabelPlugin 事件监听问题。 + +## 2.0.0-alpha.15 + +- 1.refactor: 优化 ModelItemLabelPlugin 在调用 five.setState() 时的动画显示。 + +## 2.0.0-alpha.14 + +- 1.feat: 新增 ModelTVVideoPlugin 插件; +- 2.fix: 修复 ModelItemLabelPlugin disable & enable 方法逻辑; +- 3.refactor: 增加 ModelItemLabelPlugin 类型导出。 + +## 2.0.0-alpha.13 + +- 1.chore: 修改 tsconfig.json target 配置项为 es6。 + +## 2.0.0-alpha.12 + +- 1.feat: 新增 ModelItemLabelPlugin + +## 2.0.0-alpha.11 + +- 1.fix: 修复 ModelRoomLabelPlugin 未监听多楼层切换 rerender 问题。 +- 2.feat: ModelFloorplanPlugin & TopviewFloorplanPlugin 新增 `northDesc?: string` 配置项,支持用户修改指北针名称。 + +## 2.0.0-alpha.10 + +- 1.feat: 新增空间三维标签插件 PanoSpatialTagPlugin +- 2.feat: 新增轻量 ejs 渲染模板函数 shared-utils/tinyEJSrender.js + +## 2.0.0-alpha.9 + +- 1.refactor: 增加插件独立 js 输出及对 svelte 的编译。 + +## 2.0.0-alpha.8 + +- 1.fix: 修复 ModelViewPlugin 实景 VR 模型不居中问题; +- 2.fix: 修复 ModelRoomLabelPlugin fov 更新未 rerender 问题; +- 2.fix: 修复 ModelRoomLabelPlugin enable 判断问题; +- 4.fix: 修改 ModelFloorplanPlugin 在全景态满足户型图的俯仰角时会自动切换户型图问题。 + +## 2.0.0-alpha.7 + +- 1.fix: PanoCompassPlugin 向下兼容; +- 2.feat: 新增 PC 全景测量插件:PanoMeasurePlugin; +- 3.docs: 修改 README.md; + +## 2.0.0-alpha.6 + +- 1.fix: 标尺插件 PanoRulerPlugin 所有标尺仅展示一次问题; +- 2.fix: TopviewFloorplanPlugin && ModelFloorplanPlugin 插件小雷达位置显示不正确问题; +- 3.feat: 为 TopviewFloorplanPlugin && ModelFloorplanPlugin 插件新增线框图吸附位置配置选项。 + - 可选地板、天花板、模型中心,默认吸附选项为模型中心。 + +## 2.0.0-alpha.5 + +1.修复全景指南针插件 PanoCompassPlugin 默认导出 name + +## 2.0.0-alpha.4 + +1.新增全景标尺插件 PanoRulerPlugin + +## 2.0.0-alpha.3 + +1.新增全景指南针插件 PanoCompassPlugin diff --git a/README.md b/README.md new file mode 100644 index 000000000..41329545f --- /dev/null +++ b/README.md @@ -0,0 +1,116 @@ +

+ +

+ + +

+ + npm version + + + install size + + + license + +

+ +

@realsee/dnalogel

+ +# 👀 Overview + +@realsee/dnalogel 将 [如视(realsee.com)](https://realsee.com) **VR 空间交互** 常用能力沉淀,并以 `Five Plugins` 形式进行抽象。 +结合[如视三维空间重建渲染引擎 Five](https://open-platform.realsee.com/developer/docs/five/intro/) +与 [如视开放 API](https://open-platform.realsee.com/developer/openapi/?id=1001) ,可以制作出丰富多彩的三维空间应用。不论是经过线上环境千锤百炼的刚需功能,还是灵感一现的炫酷尝试,所有已经落地的功能我们均毫无保留的开源至github [realsee-developer/dnalogel](https://github.com/realsee-developer/dnalogel) 。 + +# 🔨 Usage + +**1、安装** + +```bash +npm install @realsee/dnalogel +``` + +```bash +yarn add @realsee/dnalogel +``` + +**2、插件注册** + +```js +import { Five } from '@realsee/five' +import { Plugin } from '@realsee/dnalogel' +const five = new Five({ + plugins: [[Plugin, 'PluginName', initOptions]], +}) +``` + +**3、插件方法使用** + +```js +// 不同插件提供的方法可能存在差异,请参考各插件 API 文档 +five.plugins.PluginName.load(data) +five.plugins.PluginName.enable() +five.plugins.PluginName.disable() +five.plugins.PluginName.dispose() +``` + +**4、插件依赖数据获取** + +您可以通过 [open API](https://open-platform.realsee.com/developer/open/api#/) 查看数据获取方式及相关 open API 。 + +# 📖 Documents + +- [说明文档](https://open-platform.realsee.com/developer/docs/dnalogel/intro/) +- [API 文档](https://open-platform.realsee.com/developer/openapi/?id=1001) +- [demo 源码](https://github.com/realsee-developer/dnalogel) +- [数据依赖来源:open API](https://open-platform.realsee.com/developer/openapi/?id=1001) + +# 💡 Preview + +我们为每个插件书写了简单的效果示例,您可点击预览: +[@realsee/dnalogel showcase](https://realsee-developer.github.io/dnalogel/) + +# 🧾 Lists + +- 🔌 ModelViewPlugin:模型小窗插件 +- 🔌 PanoFloorplanRadarPlugin:全景户型雷达图插件 +- 🔌 ModelRoomLabelPlugin:模型态房屋标签插件 +- 🔌 TopviewFloorplanPlugin:俯视模型户型图插件 +- 🔌 ModelChassisCompassPlugin:模型底盘指南针插件 +- 🔌 ModelEntryDoorGuidePlugin:模型入户门引导插件 +- 🔌 CSS3DRenderPlugin:CSS3D渲染插件 +- 🔌 CameraMovementPlugin:相机运镜插件 +- 🔌 ModelFloorplanPlugin:模型户型图插件 +- 🔌 PanoRulerPlugin:全景标尺插件 +- 🔌 PanoCompassPlugin:全景指南针插件 +- 其他插件持续更新中... + +# 可能遇到的问题 + +1. webpack打包出现以下错误 + +```bash +Module not found: Error: Can't resolve '@realsee/five/line' in 'xxx/node_modules/@realsee/dnalogel/libs' +Did you mean 'index.js'? +BREAKING CHANGE: The request '@realsee/five/line' failed to resolve only because it was resolved as fully specified +(probably because the origin is strict EcmaScript Module, e. g. a module with javascript mimetype, a '*.mjs' file, or a '*.js' file where the package.json contains '"type": "module"'). +The extension in the request is mandatory for it to be fully specified. +Add the extension to the request. +``` + +解决方案:在webpack配置里加以下rule +参考:[resolvefullyspecified](https://webpack.js.org/configuration/module/#resolvefullyspecified) + +```js +{ + test: /\.m?js$/, + resolve: { + fullySpecified: false, // disable the behaviour + }, +}, +``` + +# License + +[TERMS](https://github.com/realsee-developer/dnalogel/blob/main/TERMS.txt) diff --git a/TERMS.txt b/TERMS.txt new file mode 100644 index 000000000..3ff44af46 --- /dev/null +++ b/TERMS.txt @@ -0,0 +1,56 @@ +Realsee SDK License Agreement + +Update: July 28, 2021 + +THIS LICENSE AGREEMENT BETWEEN YOU AND 【BEIKE REALSEE TECHNOLOGY (HK) LIMITED】(“Realsee”) FORMS A LEGALLY BINDING CONTRACT BETWEEN YOU AND REALSEE IN RELATION TO YOUR USE OF THE SDK. This License Agreement accompanies the Realsee Software Development Kit(s) for the software and related explanatory materials (the "SDK") and includes any upgrades, modified versions, updates, additions, and copies of the SDK licensed to You by Realsee. +BY DOWNLOADING, INSTALLING, OR OTHERWISE ACCESSING OR USING THE SDK, YOU AGREE THAT YOU HAVE READ, UNDERSTOOD, AND AGREE TO BE BOUND BY THIS AGREEMENT. YOU ARE AGREEING ON YOUR OWN BEHALF AND/OR ON BEHALF OF YOUR COMPANY OR ORGANIZATION TO THE TERMS AND CONDITIONS STATED BELOW. +This Agreement applies to Your use of the SDK in the country in which You legally install it (“Territory”) and is subject to the laws of such Territory and further subject to Section 12 below. Different terms, conditions, and limitations may apply to the use of the SDK in any additional countries. +1. DEFINITIONS. +“Agreement” means this Realsee SDK License Agreement. +“Developer”, “You” and “Your” means the person(s) or entity acquiring or using the SDK or otherwise exercising rights under the terms of this Agreement. +“Documentation” means the technical or other specifications or documentation that Realsee may provide to You for use in connection with the SDK. +“Integrated Product” means any software, website, or on-line service developed by You based on or using the SDK (collectively, the “Integrated Product”). +“Intellectual Property” means any patents, patent rights, trademarks, service marks, registered and unregistered designs, applications for any of the foregoing, copyright, and any other similar protected rights in any country and to the extent recognised by any relevant jurisdiction as intellectual property, trade secrets, know-how and confidential information. Realsee reserves all rights not expressly granted to You. +“Realsee” means [Beike Realsee Technology (HK) Limited, a company incorporated and validly existing under the laws of Hong Kong]. +“SDK” means the Realsee-proprietary Software Development Kits (SDK) provided hereunder, includes all development tools (including any compiler and debugger), application programming interfaces (“APIs”), libraries, binary utilities, header files, Documentation, content, data, code samples, and other materials provided to You in connection with this Agreement, whether delivered through a download, or any other media or form, and is licensed, not sold, to You by Realsee for use only under the terms of this Agreement. The terms of this Agreement will govern any updates provided by Realsee that replace and/or supplement the original SDK delivered to You, unless such update is accompanied by a separate license, in which case the terms of such license will govern. +2. LICENSED USES AND RESTRICTIONS. +2.1 Subject to the restrictions contained in this Section 2, Realsee grants to You during the term, a limited, non-exclusive, revocable, non-sublicensable, non-transferable license to install and use the SDK within the Territory only for the purpose of internal development. +2.2 Restrictions. You acknowledge and agree that, You shall not, and shall ensure that Your affiliates, employees, agents, representatives, officers, representatives, and subcontractors do not (directly or indirectly): +2.2.1 decompile, reverse engineer, disassemble or attempt to derive the source code of, those components of the SDK provided in object code form, or any part thereof; +2.2.2 remove, alter, or obscure any copyright notice or other proprietary rights notice on any part of the SDK; +2.2.3 sell, assign, pledge, rent, lease, lend, upload to or host on any website or server for use by any third party except You, redistribute, or sublicense the SDK (or any part thereof), or operate the SDK (or any part thereof) in the capacity of a service bureau or other hosted services provider, in whole or in part, nor may You enable others to do so; +2.2.4 or alter, modify, customize or improve the SDK, or any part thereof; +2.2.5 use the SDK (or any part thereof) for any illegal purpose, in any manner that is inconsistent with the terms of this Agreement, or to engage in any illegal activity; +2.2.6 use the SDK (or any part thereof) in any manner that may damage the operation of Realsee’s products or services; or +2.2.7 use the SDK or any information contained therein or otherwise provided by Realsee for the purpose of developing, or having developed, any product competitive with any Realsee product or service, as determined by Realsee in its sole discretion; +2.2.8 include any portion of the SDK in Your Developer products. +2.3 Realsee has the right to impose reasonable conditions such as a reasonable fee for use of the SDK in Integrated Product in the future. +2.4 You may make a limited number of copies of the SDK to be used by Your employees or consultants as provided herein, and not for general business purposes, and such employees or consultants shall be subject to the obligations and restrictions in this Agreement. +2.5 All licenses not expressly granted in this Agreement are reserved and no other licenses, immunity, or rights, express or implied, are granted by Realsee, by implication, estoppel, or otherwise. +3. CONFIDENTIALITY. +The SDK and all source code, Documentation, specifications, engineering details, and related information pertaining to the SDK, whether in oral, written, graphic, or electronic form, are and shall remain the confidential and proprietary information of Realsee or its licensors (collectively, the “Confidential Information”). You shall (i) disclose Confidential Information to only those directors and employees (collectively, “Affiliates”) whose duties justify their need to know such information and who have been clearly informed of their obligation to maintain the confidential, proprietary, and/or trade secret status of such Confidential Information; and (ii) use Confidential Information solely in accordance with the license granted hereunder. In any event, You and Your Affiliates shall treat Confidential Information as strictly confidential and shall use the same care to prevent disclosure of such information as You use with respect to Your own similar confidential and/or proprietary information, which shall not be less than the care a reasonable person would use under similar circumstances. All Confidential Information, and any copies thereof, shall be returned promptly to Realsee upon request. You shall ensure that Your Affiliates comply with the provisions of this Section 3, and You shall be liable for any breach of this Section 3 resulting from the act or omission of any of Your Affiliates. You shall not disclose Confidential Information to any third party, including, without limitation, any of Your subcontractors. +4. PROPRIETARY RIGHTS. +4.1 As between You and Realsee, Realsee and/or its licensors retain ownership of all right, title, and interest in, to, and under the SDK, including, without limitation, all patents, copyrights, trade secrets, trademarks and other intellectual property and other proprietary rights therein, and reserve all rights not expressly granted to You. +4.2 The items contained in the SDK are the intellectual property of Realsee and its licensors and are protected by PRC copyright and patent law, international treaty provisions and applicable laws of the country in which it is being used. You agree to protect all copyright and other ownership interests of Realsee and/or its licensors in all items in the SDK supplied under this License Agreement. You agree that all copies of the items in the SDK, reproduced for any reason by You, contain the same copyright notices, and other proprietary notices as appropriate, as appear on or in the original items delivered by Realsee in the SDK. Realsee and/or its licensors retain title and ownership of the items in the SDK, the media on which it is loaded, and all subsequent copies, regardless of the form or media in or on which the original and other copies may exist. Except as stated above, this Agreement does not grant You any rights to patents, copyrights, trade secrets, trademarks or any other rights in respect to the items in the SDK. +5. TERM AND TERMINATION. +5.1 This Agreement is effective until terminated. Realsee has the right to terminate this Agreement immediately, without judicial intervention, if You fail to comply with any term herein. Upon any such termination You must remove all full and partial copies of the items in the SDK from Your computer and discontinue the use of the items in the SDK. +5.2 Realsee may at any time, terminate the Agreement with You if: (A) You have breached any provision of the Agreement; or (B) Realsee is required to do so by law; or (C) Realsee decides to no longer provide the SDK or certain parts of the SDK to users in the country in which You are resident or from which You use the service, or the provision of the SDK or certain SDK services to You by Realsee is, in Realsee's sole discretion, no longer legally or commercially viable. +5.3 When the Agreement comes to an end, all of the legal rights, obligations and liabilities that You and Realsee have benefited from, been subject to (or which have accrued over time whilst the Agreement has been in force) or which are expressed to continue indefinitely, shall be unaffected by this cessation, and the provisions of Section 3, 4, 6, 7 and 8 shall continue to apply to such rights, obligations and liabilities indefinitely. +6. DISCLAIMER OF WARRANTY. +YOU EXPRESSLY ACKNOWLEDGE AND AGREE THAT, TO THE EXTENT PERMITTED BY APPLICABLE LAW, USE OF THE SDK (OR ANY PART THEREOF) IS AT YOUR SOLE RISK AND THAT THE ENTIRE RISK AS TO SATISFACTORY QUALITY, PERFORMANCE, ACCURACY, AND EFFORT IS WITH YOU. REALSEE LICENSES THE SDK TO YOU ONLY ON AN "AS-IS" BASIS. REALSEE MAKES NO REPRESENTATION WITH RESPECT TO THE ADEQUACY OF ANY ITEMS IN THE SDK, WHETHER OR NOT USED BY YOU IN THE DEVELOPMENT OF INTEGRATED PRODUCT, FOR ANY PARTICULAR PURPOSE OR WITH RESPECT TO THEIR ADEQUACY TO PRODUCE ANY PARTICULAR RESULT. REALSEE AND ITS LICENSORS SHALL NOT BE LIABLE FOR LOSS OR DAMAGE ARISING OUT OF THIS AGREEMENT OR FROM THE DISTRIBUTION OR USE OF INTEGRATED PRODUCT CONTAINING PORTIONS OF THE SDK. REALSEE AND ITS LICENSORS DISCLAIM ALL WARRANTIES, EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO IMPLIED CONDITIONS OR WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE OR NONINFRINGEMENT OF ANY THIRD PARTY RIGHT IN RESPECT OF THE ITEMS IN THE SDK OR ANY SERVICES RELATED TO THE SDK. +REALSEE IS UNDER NO OBLIGATION TO PROVIDE ANY SUPPORT UNDER THIS LICENSE AGREEMENT, INCLUDING UPGRADES OR FUTURE VERSIONS OF THE SDK OR ANY PORTIONS THEREOF, TO YOU, END USER OR TO ANY OTHER PARTY. +7. LIMITATION OF LIABILITY. +TO THE EXTENT NOT PROHIBITED BY APPLICABLE LAW, IN NO EVENT WILL REALSEE OR ITS LICENSORS BE LIABLE FOR ANY DIRECT, INCIDENTAL, SPECIAL, INDIRECT, OR CONSEQUENTIAL DAMAGES, INCLUDING, WITHOUT LIMITATION, DAMAGES FOR LOSS OF USE, LOSS OF BUSINESS, REVENUE, OR PROFITS, LOSS OF OPPORTUNITY (WHETHER DIRECT OR INDIRECT), CORRUPTION OR LOSS OF DATA, LOSS OF REPUTATION OR SAVINGS, DOWNTIME, OR DAMAGE TO, LOSS OF OR REPLACEMENT OF DATA OR TRANSACTIONS, COST OF PROCUREMENT OF SUBSTITUTE SERVICES, BUSINESS INTERRUPTION, OR ANY OTHER COMMERCIAL DAMAGES OR LOSSES, ARISING OUT OF OR RELATED TO YOUR USE OR INABILITY TO USE THE SDK (OR ANY PART THEREOF), ANY INTEGRATED PRODUCT, OR ANY THIRD PARTY SOFTWARE, APPLICATIONS, OR SERVICES IN CONJUNCTION WITH THE SDK (OR ANY PART THEREOF), HOWEVER CAUSED, REGARDLESS OF THE THEORY OF LIABILITY (CONTRACT, TORT, OR OTHERWISE) AND EVEN IF REALSEE HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. IN NO EVENT WILL REALSEE’S TOTAL LIABILITY TO YOU FOR ALL DAMAGES EXCEED ONE HUNDRED DOLLARS ($100.00). THE FOREGOING LIMITATIONS WILL APPLY EVEN IF THE ABOVE STATED REMEDY FAILS OF ITS ESSENTIAL PURPOSE. THE LIMITATIONS CONTAINED IN SECTIONS 6 AND THIS SECTION 7 ARE A FUNDAMENTAL PART OF THE BASIS OF REALSEE’S BARGAIN HEREUNDER, AND REALSEE WOULD NOT ENTER INTO THIS AGREEMENT OR PROVIDE YOU WITH ACCESS TO THE SDK ABSENT SUCH LIMITATIONS. +8. INDEMNIFICATION. +To the extent permitted by applicable law, You agree to indemnify, defend and hold harmless Realsee, its affiliates and each of their directors, officers, employees, independent contractors, and agents (each a “Realsee Indemnified Party”) from any and all claims, losses, liabilities, damages, expenses, and costs (including without limitation attorneys’ fees and court costs) incurred by a Realsee Indemnified Party as a result of: (i) Your non-compliance with any terms of this Agreement; (ii) Your use of the SDK (or any part thereof); or (iii) Your use of any Integrated Product, including any claim that Integrated Product infringes the copyright, trademark, trade secret or other intellectual property right of a third party. +9. ACKNOWLEDGEMENTS. +Portions of the SDK may utilize or include third party software and other copyrighted material. Acknowledgments, licensing terms, and disclaimers for such material are contained in Documentation for the SDK or may otherwise accompany such material, and Your use of such materials governed by their respective terms. In the event of conflict between the terms of this Agreement and an applicable open source or third party agreement, the open source or third party agreement will control solely with respect to the open source software or third party software. Moreover, You shall not subject any items (including not limited to source code, object code, and any software) included in the SDK to any open source license. +10. NON-BLOCKING OF REALSEE DEVELOPMENT. +You acknowledge that Realsee is currently developing or may develop technologies and products in the future that have or may have design and/or functionality similar to Integrated Product that You may develop based on Your license herein. Nothing in this Agreement shall impair, limit or curtail Realsee's right to continue with its development, maintenance and/or distribution of Realsee's technology or products. +11. GENERAL. +11.1 Export Control. You may not use or otherwise export or re-export the SDK (or any part thereof) except as authorized by United States law and the laws of the jurisdiction(s) in which the SDK (or any part thereof) was obtained. In particular, but without limitation, the SDK may not be exported or re-exported (i) into any U.S. embargoed countries or (ii) to anyone on the U.S. Treasury Department's list of Specially Designated Nationals or the U.S. Department of Commerce Denied Person's List or Entity List. By using the SDK (or any part thereof), You represent and warrant that You are not located in any such country or on any such list. +11.2 Governing Law. This Agreement and the rights of the parties hereunder shall be governed by and construed in accordance with the laws of People’s Republic of China (for purpose of this Agreement, excluding Hong Kong, Taiwan, and Macau), without reference to its conflict of laws principles. Any dispute, controversy or claim arising from or in connection with this Agreement, or the breach, termination or invalidity thereof, shall be submitted to China International Economic and Trade Arbitration Commission (“CIETAC”) for arbitration in Beijing which shall be conducted in accordance with the CIETAC's arbitration rules in effect at the time of applying for arbitration. The arbitral award is final and binding upon both parties. +11.3 Severability. If any provision of this Agreement is held by a court of competent jurisdiction to be unenforceable for any reason, the remaining provisions hereof will be unaffected and remain in full force and effect. +11.4. Modifications. Realsee reserves the right, from time to time, with or without notice to You, to make revisions to this Agreement in our sole and absolute discretion. The most current version of this Agreement will supersede all previous versions and shall be made available on the website where the SDK is made available, or by such other means as Realsee may determine in its discretion. Any modified versions of this Agreement hereto shall take effect from the time that it is made available. You shall be responsible for regularly checking for notice of any such modifications. You agree that Your continued use of the SDK constitutes Your agreement to the modified Agreement. +11.5 Relationship of the Parties. This Agreement will not be construed as creating an agency, partnership, joint venture, fiduciary duty, or any other form of legal association between You and Realsee, and You will not represent to the contrary, whether expressly, by implication, appearance, or otherwise. +11.6 Entire Agreement; Governing Language. This Agreement constitutes the entire agreement between You and Realsee with respect to the use of the SDK licensed hereunder and supersedes all prior understandings regarding such subject matter. No amendment to or modification of this Agreement will be binding unless in writing and signed by Realsee. You and Realsee hereto confirm that this Agreement and all related documents shall be drafted in English. diff --git a/components/index.js b/components/index.js new file mode 100644 index 000000000..6846a1d84 --- /dev/null +++ b/components/index.js @@ -0,0 +1,994 @@ +var z = Object.defineProperty; +var Z = (t, i, e) => i in t ? z(t, i, { enumerable: !0, configurable: !0, writable: !0, value: e }) : t[i] = e; +var C = (t, i, e) => (Z(t, typeof i != "symbol" ? i + "" : i, e), e); +function m() { +} +const B = () => Promise.resolve(), k = { + __queue: Promise.resolve() +}; +function G(t = B) { + k.__queue = k.__queue.then(t).catch(B); +} +function T(t, i, e) { + const n = t.x, s = t.y, r = Math.floor(n / i * 1e4) / 1e4, a = Math.floor(s / e * 1e4) / 1e4; + return { x: r, y: a }; +} +function L(t, i, e) { + const { x: n, y: s } = t, r = n * i, a = s * e; + return { x: r, y: a }; +} +function j(t) { + if (t.length < 2) + return {}; + const i = t.slice(-2), e = i[0], n = { + x: (i[0].x + i[1].x) / 2, + y: (i[0].y + i[1].y) / 2 + }; + return { control: e, end: n }; +} +function U(t, i, e = m) { + new Promise((n) => { + setTimeout(() => { + e(), n(!0); + }, i * t); + }); +} +const W = window, R = window.requestAnimationFrame || W.webkitRequestAnimationFrame || ((t) => setTimeout(t, 16)); +function P(t, i = 0) { + i <= 0 ? R(t) : R(() => P(t, i - 1)); +} +var b = Object.freeze({ + Linear: Object.freeze({ + None: function(t) { + return t; + }, + In: function(t) { + return this.None(t); + }, + Out: function(t) { + return this.None(t); + }, + InOut: function(t) { + return this.None(t); + } + }), + Quadratic: Object.freeze({ + In: function(t) { + return t * t; + }, + Out: function(t) { + return t * (2 - t); + }, + InOut: function(t) { + return (t *= 2) < 1 ? 0.5 * t * t : -0.5 * (--t * (t - 2) - 1); + } + }), + Cubic: Object.freeze({ + In: function(t) { + return t * t * t; + }, + Out: function(t) { + return --t * t * t + 1; + }, + InOut: function(t) { + return (t *= 2) < 1 ? 0.5 * t * t * t : 0.5 * ((t -= 2) * t * t + 2); + } + }), + Quartic: Object.freeze({ + In: function(t) { + return t * t * t * t; + }, + Out: function(t) { + return 1 - --t * t * t * t; + }, + InOut: function(t) { + return (t *= 2) < 1 ? 0.5 * t * t * t * t : -0.5 * ((t -= 2) * t * t * t - 2); + } + }), + Quintic: Object.freeze({ + In: function(t) { + return t * t * t * t * t; + }, + Out: function(t) { + return --t * t * t * t * t + 1; + }, + InOut: function(t) { + return (t *= 2) < 1 ? 0.5 * t * t * t * t * t : 0.5 * ((t -= 2) * t * t * t * t + 2); + } + }), + Sinusoidal: Object.freeze({ + In: function(t) { + return 1 - Math.sin((1 - t) * Math.PI / 2); + }, + Out: function(t) { + return Math.sin(t * Math.PI / 2); + }, + InOut: function(t) { + return 0.5 * (1 - Math.sin(Math.PI * (0.5 - t))); + } + }), + Exponential: Object.freeze({ + In: function(t) { + return t === 0 ? 0 : Math.pow(1024, t - 1); + }, + Out: function(t) { + return t === 1 ? 1 : 1 - Math.pow(2, -10 * t); + }, + InOut: function(t) { + return t === 0 ? 0 : t === 1 ? 1 : (t *= 2) < 1 ? 0.5 * Math.pow(1024, t - 1) : 0.5 * (-Math.pow(2, -10 * (t - 1)) + 2); + } + }), + Circular: Object.freeze({ + In: function(t) { + return 1 - Math.sqrt(1 - t * t); + }, + Out: function(t) { + return Math.sqrt(1 - --t * t); + }, + InOut: function(t) { + return (t *= 2) < 1 ? -0.5 * (Math.sqrt(1 - t * t) - 1) : 0.5 * (Math.sqrt(1 - (t -= 2) * t) + 1); + } + }), + Elastic: Object.freeze({ + In: function(t) { + return t === 0 ? 0 : t === 1 ? 1 : -Math.pow(2, 10 * (t - 1)) * Math.sin((t - 1.1) * 5 * Math.PI); + }, + Out: function(t) { + return t === 0 ? 0 : t === 1 ? 1 : Math.pow(2, -10 * t) * Math.sin((t - 0.1) * 5 * Math.PI) + 1; + }, + InOut: function(t) { + return t === 0 ? 0 : t === 1 ? 1 : (t *= 2, t < 1 ? -0.5 * Math.pow(2, 10 * (t - 1)) * Math.sin((t - 1.1) * 5 * Math.PI) : 0.5 * Math.pow(2, -10 * (t - 1)) * Math.sin((t - 1.1) * 5 * Math.PI) + 1); + } + }), + Back: Object.freeze({ + In: function(t) { + var i = 1.70158; + return t === 1 ? 1 : t * t * ((i + 1) * t - i); + }, + Out: function(t) { + var i = 1.70158; + return t === 0 ? 0 : --t * t * ((i + 1) * t + i) + 1; + }, + InOut: function(t) { + var i = 2.5949095; + return (t *= 2) < 1 ? 0.5 * (t * t * ((i + 1) * t - i)) : 0.5 * ((t -= 2) * t * ((i + 1) * t + i) + 2); + } + }), + Bounce: Object.freeze({ + In: function(t) { + return 1 - b.Bounce.Out(1 - t); + }, + Out: function(t) { + return t < 1 / 2.75 ? 7.5625 * t * t : t < 2 / 2.75 ? 7.5625 * (t -= 1.5 / 2.75) * t + 0.75 : t < 2.5 / 2.75 ? 7.5625 * (t -= 2.25 / 2.75) * t + 0.9375 : 7.5625 * (t -= 2.625 / 2.75) * t + 0.984375; + }, + InOut: function(t) { + return t < 0.5 ? b.Bounce.In(t * 2) * 0.5 : b.Bounce.Out(t * 2 - 1) * 0.5 + 0.5; + } + }), + generatePow: function(t) { + return t === void 0 && (t = 4), t = t < Number.EPSILON ? Number.EPSILON : t, t = t > 1e4 ? 1e4 : t, { + In: function(i) { + return Math.pow(i, t); + }, + Out: function(i) { + return 1 - Math.pow(1 - i, t); + }, + InOut: function(i) { + return i < 0.5 ? Math.pow(i * 2, t) / 2 : (1 - Math.pow(2 - i * 2, t)) / 2 + 0.5; + } + }; + } +}), N = function() { + return performance.now(); +}, Y = ( + /** @class */ + function() { + function t() { + this._tweens = {}, this._tweensAddedDuringUpdate = {}; + } + return t.prototype.getAll = function() { + var i = this; + return Object.keys(this._tweens).map(function(e) { + return i._tweens[e]; + }); + }, t.prototype.removeAll = function() { + this._tweens = {}; + }, t.prototype.add = function(i) { + this._tweens[i.getId()] = i, this._tweensAddedDuringUpdate[i.getId()] = i; + }, t.prototype.remove = function(i) { + delete this._tweens[i.getId()], delete this._tweensAddedDuringUpdate[i.getId()]; + }, t.prototype.update = function(i, e) { + i === void 0 && (i = N()), e === void 0 && (e = !1); + var n = Object.keys(this._tweens); + if (n.length === 0) + return !1; + for (; n.length > 0; ) { + this._tweensAddedDuringUpdate = {}; + for (var s = 0; s < n.length; s++) { + var r = this._tweens[n[s]], a = !e; + r && r.update(i, a) === !1 && !e && delete this._tweens[n[s]]; + } + n = Object.keys(this._tweensAddedDuringUpdate); + } + return !0; + }, t; + }() +), w = { + Linear: function(t, i) { + var e = t.length - 1, n = e * i, s = Math.floor(n), r = w.Utils.Linear; + return i < 0 ? r(t[0], t[1], n) : i > 1 ? r(t[e], t[e - 1], e - n) : r(t[s], t[s + 1 > e ? e : s + 1], n - s); + }, + Bezier: function(t, i) { + for (var e = 0, n = t.length - 1, s = Math.pow, r = w.Utils.Bernstein, a = 0; a <= n; a++) + e += s(1 - i, n - a) * s(i, a) * t[a] * r(n, a); + return e; + }, + CatmullRom: function(t, i) { + var e = t.length - 1, n = e * i, s = Math.floor(n), r = w.Utils.CatmullRom; + return t[0] === t[e] ? (i < 0 && (s = Math.floor(n = e * (1 + i))), r(t[(s - 1 + e) % e], t[s], t[(s + 1) % e], t[(s + 2) % e], n - s)) : i < 0 ? t[0] - (r(t[0], t[0], t[1], t[1], -n) - t[0]) : i > 1 ? t[e] - (r(t[e], t[e], t[e - 1], t[e - 1], n - e) - t[e]) : r(t[s ? s - 1 : 0], t[s], t[e < s + 1 ? e : s + 1], t[e < s + 2 ? e : s + 2], n - s); + }, + Utils: { + Linear: function(t, i, e) { + return (i - t) * e + t; + }, + Bernstein: function(t, i) { + var e = w.Utils.Factorial; + return e(t) / e(i) / e(t - i); + }, + Factorial: function() { + var t = [1]; + return function(i) { + var e = 1; + if (t[i]) + return t[i]; + for (var n = i; n > 1; n--) + e *= n; + return t[i] = e, e; + }; + }(), + CatmullRom: function(t, i, e, n, s) { + var r = (e - t) * 0.5, a = (n - i) * 0.5, o = s * s, c = s * o; + return (2 * i - 2 * e + r + a) * c + (-3 * i + 3 * e - 2 * r - a) * o + r * s + i; + } + } +}, H = ( + /** @class */ + function() { + function t() { + } + return t.nextId = function() { + return t._nextId++; + }, t._nextId = 0, t; + }() +), E = new Y(), Q = ( + /** @class */ + function() { + function t(i, e) { + e === void 0 && (e = E), this._object = i, this._group = e, this._isPaused = !1, this._pauseStart = 0, this._valuesStart = {}, this._valuesEnd = {}, this._valuesStartRepeat = {}, this._duration = 1e3, this._isDynamic = !1, this._initialRepeat = 0, this._repeat = 0, this._yoyo = !1, this._isPlaying = !1, this._reversed = !1, this._delayTime = 0, this._startTime = 0, this._easingFunction = b.Linear.None, this._interpolationFunction = w.Linear, this._chainedTweens = [], this._onStartCallbackFired = !1, this._onEveryStartCallbackFired = !1, this._id = H.nextId(), this._isChainStopped = !1, this._propertiesAreSetUp = !1, this._goToEnd = !1; + } + return t.prototype.getId = function() { + return this._id; + }, t.prototype.isPlaying = function() { + return this._isPlaying; + }, t.prototype.isPaused = function() { + return this._isPaused; + }, t.prototype.getDuration = function() { + return this._duration; + }, t.prototype.to = function(i, e) { + if (e === void 0 && (e = 1e3), this._isPlaying) + throw new Error("Can not call Tween.to() while Tween is already started or paused. Stop the Tween first."); + return this._valuesEnd = i, this._propertiesAreSetUp = !1, this._duration = e < 0 ? 0 : e, this; + }, t.prototype.duration = function(i) { + return i === void 0 && (i = 1e3), this._duration = i < 0 ? 0 : i, this; + }, t.prototype.dynamic = function(i) { + return i === void 0 && (i = !1), this._isDynamic = i, this; + }, t.prototype.start = function(i, e) { + if (i === void 0 && (i = N()), e === void 0 && (e = !1), this._isPlaying) + return this; + if (this._group && this._group.add(this), this._repeat = this._initialRepeat, this._reversed) { + this._reversed = !1; + for (var n in this._valuesStartRepeat) + this._swapEndStartRepeatValues(n), this._valuesStart[n] = this._valuesStartRepeat[n]; + } + if (this._isPlaying = !0, this._isPaused = !1, this._onStartCallbackFired = !1, this._onEveryStartCallbackFired = !1, this._isChainStopped = !1, this._startTime = i, this._startTime += this._delayTime, !this._propertiesAreSetUp || e) { + if (this._propertiesAreSetUp = !0, !this._isDynamic) { + var s = {}; + for (var r in this._valuesEnd) + s[r] = this._valuesEnd[r]; + this._valuesEnd = s; + } + this._setupProperties(this._object, this._valuesStart, this._valuesEnd, this._valuesStartRepeat, e); + } + return this; + }, t.prototype.startFromCurrentValues = function(i) { + return this.start(i, !0); + }, t.prototype._setupProperties = function(i, e, n, s, r) { + for (var a in n) { + var o = i[a], c = Array.isArray(o), d = c ? "array" : typeof o, I = !c && Array.isArray(n[a]); + if (!(d === "undefined" || d === "function")) { + if (I) { + var u = n[a]; + if (u.length === 0) + continue; + for (var l = [o], h = 0, g = u.length; h < g; h += 1) { + var f = this._handleRelativeValue(o, u[h]); + if (isNaN(f)) { + I = !1, console.warn("Found invalid interpolation list. Skipping."); + break; + } + l.push(f); + } + I && (n[a] = l); + } + if ((d === "object" || c) && o && !I) { + e[a] = c ? [] : {}; + var p = o; + for (var A in p) + e[a][A] = p[A]; + s[a] = c ? [] : {}; + var u = n[a]; + if (!this._isDynamic) { + var v = {}; + for (var A in u) + v[A] = u[A]; + n[a] = u = v; + } + this._setupProperties(p, e[a], u, s[a], r); + } else + (typeof e[a] == "undefined" || r) && (e[a] = o), c || (e[a] *= 1), I ? s[a] = n[a].slice().reverse() : s[a] = e[a] || 0; + } + } + }, t.prototype.stop = function() { + return this._isChainStopped || (this._isChainStopped = !0, this.stopChainedTweens()), this._isPlaying ? (this._group && this._group.remove(this), this._isPlaying = !1, this._isPaused = !1, this._onStopCallback && this._onStopCallback(this._object), this) : this; + }, t.prototype.end = function() { + return this._goToEnd = !0, this.update(1 / 0), this; + }, t.prototype.pause = function(i) { + return i === void 0 && (i = N()), this._isPaused || !this._isPlaying ? this : (this._isPaused = !0, this._pauseStart = i, this._group && this._group.remove(this), this); + }, t.prototype.resume = function(i) { + return i === void 0 && (i = N()), !this._isPaused || !this._isPlaying ? this : (this._isPaused = !1, this._startTime += i - this._pauseStart, this._pauseStart = 0, this._group && this._group.add(this), this); + }, t.prototype.stopChainedTweens = function() { + for (var i = 0, e = this._chainedTweens.length; i < e; i++) + this._chainedTweens[i].stop(); + return this; + }, t.prototype.group = function(i) { + return i === void 0 && (i = E), this._group = i, this; + }, t.prototype.delay = function(i) { + return i === void 0 && (i = 0), this._delayTime = i, this; + }, t.prototype.repeat = function(i) { + return i === void 0 && (i = 0), this._initialRepeat = i, this._repeat = i, this; + }, t.prototype.repeatDelay = function(i) { + return this._repeatDelayTime = i, this; + }, t.prototype.yoyo = function(i) { + return i === void 0 && (i = !1), this._yoyo = i, this; + }, t.prototype.easing = function(i) { + return i === void 0 && (i = b.Linear.None), this._easingFunction = i, this; + }, t.prototype.interpolation = function(i) { + return i === void 0 && (i = w.Linear), this._interpolationFunction = i, this; + }, t.prototype.chain = function() { + for (var i = [], e = 0; e < arguments.length; e++) + i[e] = arguments[e]; + return this._chainedTweens = i, this; + }, t.prototype.onStart = function(i) { + return this._onStartCallback = i, this; + }, t.prototype.onEveryStart = function(i) { + return this._onEveryStartCallback = i, this; + }, t.prototype.onUpdate = function(i) { + return this._onUpdateCallback = i, this; + }, t.prototype.onRepeat = function(i) { + return this._onRepeatCallback = i, this; + }, t.prototype.onComplete = function(i) { + return this._onCompleteCallback = i, this; + }, t.prototype.onStop = function(i) { + return this._onStopCallback = i, this; + }, t.prototype.update = function(i, e) { + var n = this, s; + if (i === void 0 && (i = N()), e === void 0 && (e = !0), this._isPaused) + return !0; + var r, a = this._startTime + this._duration; + if (!this._goToEnd && !this._isPlaying) { + if (i > a) + return !1; + e && this.start(i, !0); + } + if (this._goToEnd = !1, i < this._startTime) + return !0; + this._onStartCallbackFired === !1 && (this._onStartCallback && this._onStartCallback(this._object), this._onStartCallbackFired = !0), this._onEveryStartCallbackFired === !1 && (this._onEveryStartCallback && this._onEveryStartCallback(this._object), this._onEveryStartCallbackFired = !0); + var o = i - this._startTime, c = this._duration + ((s = this._repeatDelayTime) !== null && s !== void 0 ? s : this._delayTime), d = this._duration + this._repeat * c, I = function() { + if (n._duration === 0 || o > d) + return 1; + var p = Math.trunc(o / c), A = o - p * c, v = Math.min(A / n._duration, 1); + return v === 0 && o === n._duration ? 1 : v; + }, u = I(), l = this._easingFunction(u); + if (this._updateProperties(this._object, this._valuesStart, this._valuesEnd, l), this._onUpdateCallback && this._onUpdateCallback(this._object, u), this._duration === 0 || o >= this._duration) + if (this._repeat > 0) { + var h = Math.min(Math.trunc((o - this._duration) / c) + 1, this._repeat); + isFinite(this._repeat) && (this._repeat -= h); + for (r in this._valuesStartRepeat) + !this._yoyo && typeof this._valuesEnd[r] == "string" && (this._valuesStartRepeat[r] = // eslint-disable-next-line + // @ts-ignore FIXME? + this._valuesStartRepeat[r] + parseFloat(this._valuesEnd[r])), this._yoyo && this._swapEndStartRepeatValues(r), this._valuesStart[r] = this._valuesStartRepeat[r]; + return this._yoyo && (this._reversed = !this._reversed), this._startTime += c * h, this._onRepeatCallback && this._onRepeatCallback(this._object), this._onEveryStartCallbackFired = !1, !0; + } else { + this._onCompleteCallback && this._onCompleteCallback(this._object); + for (var g = 0, f = this._chainedTweens.length; g < f; g++) + this._chainedTweens[g].start(this._startTime + this._duration, !1); + return this._isPlaying = !1, !1; + } + return !0; + }, t.prototype._updateProperties = function(i, e, n, s) { + for (var r in n) + if (e[r] !== void 0) { + var a = e[r] || 0, o = n[r], c = Array.isArray(i[r]), d = Array.isArray(o), I = !c && d; + I ? i[r] = this._interpolationFunction(o, s) : typeof o == "object" && o ? this._updateProperties(i[r], a, o, s) : (o = this._handleRelativeValue(a, o), typeof o == "number" && (i[r] = a + (o - a) * s)); + } + }, t.prototype._handleRelativeValue = function(i, e) { + return typeof e != "string" ? e : e.charAt(0) === "+" || e.charAt(0) === "-" ? i + parseFloat(e) : parseFloat(e); + }, t.prototype._swapEndStartRepeatValues = function(i) { + var e = this._valuesStartRepeat[i], n = this._valuesEnd[i]; + typeof n == "string" ? this._valuesStartRepeat[i] = this._valuesStartRepeat[i] + parseFloat(n) : this._valuesStartRepeat[i] = this._valuesEnd[i], this._valuesEnd[i] = e; + }, t; + }() +), _ = E; +_.getAll.bind(_); +_.removeAll.bind(_); +_.add.bind(_); +_.remove.bind(_); +_.update.bind(_); +function F(t, i, e, n = b.Linear.None) { + const s = new Q(t).to(i, e).easing(n).start(); + function r(a) { + s.update(a) && requestAnimationFrame(r); + } + return requestAnimationFrame(r), s; +} +var y = /* @__PURE__ */ ((t) => (t.Drawline = "Drawline", t.Undo = "Undo", t.Exit = "Exit", t))(y || {}); +const x = Symbol("$$PAINT_BRUSH_EVENT$$"); +function S(t) { + return t[x] || (t[x] = {}), t[x]; +} +function J(t) { + t[x] || delete t[x]; +} +class K { + /** + * 判断是否注册了事件 + * @param name 事件类型 + */ + hasListener(i) { + const e = S(this); + return e && e[i] && e[i].length > 0; + } + /** + * 注册事件 + * @param name 事件类型 + * @param callback 事件回调函数 + * @param once 是否只执行一次 + * @returns 解除事件 + * @template K 预设的监听事件名称 + * @template C 回调函数函数上下文 + */ + on(i, e, n) { + const s = S(this); + return s[i] || (s[i] = []), s[i].push([e, n || !1]), () => this.off(i, e); + } + /** + * 注册事件(是否只执行一次) + * @param name 事件类型 + * @param callback 事件回调函数 + * @returns 解除事件 + * @template K 预设的监听事件名称 + * @template C 回调函数函数上下文 + */ + once(i, e) { + return this.on(i, e, !0); + } + /** + * 解除事件 + * + * 如果 name 不传的话解除对应所有事件 + * 如果 name, callback 不传的话解除所有name的所有事件 + * @param name 事件类型 + * @param callback 事件回调函数 + * @template K 预设的监听事件名称 + */ + off(i, e) { + if (i === void 0) { + J(this); + return; + } + const n = S(this); + if (n[i] || (n[i] = []), e === void 0) { + n[i].length = 0; + return; + } + let s = 0; + for (; s < n[i].length && n[i][s][0] !== e; s++) + ; + s < n[i].length && n[i].splice(s, 1); + } + /** + * 触发事件 + * @param name 事件类型 + * @param data 触发事件的数据 + * @returns canceled 是否被触发取消 + * @template K 预设的监听事件名称 + */ + emit(i, ...e) { + let n = !1; + const r = S(this)[i] || []; + for (let a of r.slice()) { + const [o, c = !1] = a, d = o(...e); + c && this.off(i, o), d === !1 && (n = !0); + } + return n; + } +} +function M() { + return ((1 + Math.random()) * 65536 | 0).toString(16).substring(1); +} +function X() { + return (M() + M() + "-" + M() + "-4" + M().substr(0, 3) + "-" + M() + "-" + M() + M() + M()).toLowerCase(); +} +const V = ` + +`; +class q extends K { + constructor(e) { + super(); + C(this, "configs"); + C(this, "clientWidth"); + C(this, "clientHeight"); + C(this, "ready", !1); + C(this, "uuid", X()); + C(this, "tween"); + C(this, "tweening", !1); + C(this, "container"); + C(this, "canvas"); + C(this, "data", {}); + C(this, "tempLine", {}); + this.configs = e, this.clientWidth = document.body.clientWidth, this.clientHeight = document.body.clientHeight, this.container = this.ifInsertToDOM(), this.canvas = {}, this.initCtrl(); + } + get color() { + return this.configs.currentColor; + } + get state() { + return this.data; + } + get dpr() { + return this.configs.DPR || 1; + } + ifInsertToDOM() { + if (this.container) + return this.container; + if (this.configs.container) + this.configs.container.id = "_gl_paintBrush", this.container = this.configs.container; + else if (document.getElementById("_gl_paintBrush")) + this.container = document.getElementById("_gl_paintBrush"); + else { + const e = document.createElement("div"); + e.id = "_gl_paintBrush", document.body.appendChild(e), this.container = e; + } + return this.container.innerHTML = V, this.container; + } + /** + * + * @param className 初始化画板 + * @returns + */ + initCanvas(e) { + const n = document.createElement("canvas"); + n.className = e, n.width = this.clientWidth, n.height = this.clientHeight; + const s = n.getContext("2d"); + if (s) + return s.lineWidth = 5 * this.dpr, s.lineCap = "round", s.lineJoin = "round", this.container.appendChild(n), n; + } + /** + * 初始化操作面板 + * @returns + */ + initCtrl() { + const e = document.createElement("div"); + e.className = "_paintBrush-ctrl"; + const n = document.createElement("div"); + n.className = "_paintBrush-ctrlinner"; + const s = document.createElement("a"); + s.className = "_paintBrush-ctrlitem _paintBrush-ctrlitem--undo", s.addEventListener("click", (o) => { + var l; + if (o.stopPropagation(), this.configs.onClickUndo && this.configs.onClickUndo(), !this.canvas[this.uuid] || !this.data[this.uuid] || this.data[this.uuid].length === 0) + return; + const c = this.data[this.uuid].pop(); + c && this.emitStateChange({ + type: y.Undo, + color: this.color, + ready: this.ready, + state: c, + uuid: this.uuid + }); + const d = (l = this.canvas[this.uuid]) == null ? void 0 : l.getContext("2d"); + if (!this.canvas[this.uuid]) + return; + const { width: I, height: u } = this.canvas[this.uuid]; + d && d.clearRect(0, 0, I, u), this.data[this.uuid].forEach((h) => this.handleDrawLine(this.uuid, h, { withUndo: !0 })); + }); + const r = document.createElement("a"); + return r.className = "_paintBrush-ctrlitem _paintBrush-ctrlitem--close", r.addEventListener("click", (o) => { + o.stopPropagation(), this.closeBrush(), this.configs.onClickClose && this.configs.onClickClose(); + }), [s, r].forEach((o) => { + const c = document.createElement("i"); + c.className = "brush-icon"; + const d = document.createElement("span"); + d.className = "brush-txt", d.innerText = o.className.endsWith("undo") ? this.configs.onUndoText : this.configs.onExitText, o.appendChild(c), o.appendChild(d); + }), n.appendChild(s), n.appendChild(r), e.appendChild(n), this.container.appendChild(e), e; + } + openBrush() { + if (this.ready) + return; + this.canvas[this.uuid] || (this.canvas[this.uuid] = this.initCanvas("_paintBrush-canvas")), this.container.className = "brushing"; + const e = this.canvas[this.uuid]; + e.getContext("2d").clearRect(0, 0, e.width, e.height), this.openBrushHandle(), this.ready = !0, this.emit("readyChange", !0); + } + closeBrush() { + this.ready && (this.container.className = "", this.data = {}, this.tempLine = {}, Object.keys(this.canvas).forEach((e) => { + this.canvas[e].ontouchstart = () => !1, this.canvas[e].ontouchmove = () => !1, this.canvas[e].ontouchend = () => !1, this.canvas[e].ontouchcancel = () => !1; + const n = this.canvas[e].getContext("2d"); + n && n.clearRect(0, 0, this.canvas[e].width, this.canvas[e].height); + }), this.ready = !1, this.emit("readyChange", !1), this.emitStateChange({ + type: y.Exit, + color: this.color, + ready: !1, + uuid: this.uuid + })); + } + updateCurrentColor(e) { + const n = this.canvas[this.uuid]; + if (!n) + return; + const s = n.getContext("2d"); + s && (this.configs.currentColor = e, s.strokeStyle = e); + } + openBrushHandle() { + const e = this.canvas[this.uuid]; + if (!e) + return; + const n = e.getContext("2d"); + if (!n) + return; + const s = this.color || "#6D92FF"; + n.strokeStyle = s; + let r = null, a = [], o, c = [], d = 0; + const I = (u, l, h) => { + const g = this.color || "#ff0000"; + n.strokeStyle = g, n.beginPath(), n.moveTo(u.x, u.y), n.quadraticCurveTo(l.x, l.y, h.x, h.y), n.stroke(); + }; + e.onmousedown = (u) => { + u.preventDefault(), d = Date.now(); + const l = u.clientX, h = u.clientY; + a = [], a.push({ x: l, y: h }), r = { x: l, y: h }, o = T({ x: l, y: h }, this.clientWidth, this.clientHeight), c = []; + }, e.onmousemove = (u) => { + if (u.preventDefault(), !r) + return; + const l = Number(u.clientX), h = Number(u.clientY); + if (Math.abs(l - r.x) < 5 && Math.abs(h - r.y) < 5 || (a.push({ x: l, y: h }), c.push(T({ x: l, y: h }, this.clientWidth, this.clientHeight)), a.length < 3)) + return; + const { control: g, end: f } = j(a); + !g || !f || (I(r, g, f), r = f); + }, e.onmouseup = (u) => { + if (u.preventDefault(), r = null, a.length < 3) + return; + this.data[this.uuid] || (this.data[this.uuid] = []); + const l = Date.now() - d, h = { + move: Object.assign({}, o), + uuid: this.uuid, + line: [...c], + color: this.color, + duration: l < 1280 ? l : l < 2e3 ? 1280 : 0 + // 单次笔迹时长超过2000ms不加动画 + }; + this.data[this.uuid].push(h), P(() => { + this.emitStateChange({ + type: y.Drawline, + color: this.color, + ready: this.ready, + state: h, + uuid: this.uuid + }); + }); + }, e.ontouchstart = (u) => { + u.preventDefault(), d = Date.now(); + const l = u.touches[0].clientX, h = u.touches[0].clientY; + a = [], a.push({ x: l, y: h }), r = { x: l, y: h }, o = T({ x: l, y: h }, this.clientWidth, this.clientHeight), c = []; + }, e.ontouchmove = (u) => { + if (u.preventDefault(), !r) + return; + const l = Number(u.touches[0].clientX), h = Number(u.touches[0].clientY); + if (Math.abs(l - r.x) < 5 && Math.abs(h - r.y) < 5 || (a.push({ x: l, y: h }), c.push(T({ x: l, y: h }, this.clientWidth, this.clientHeight)), a.length < 3)) + return; + const { control: g, end: f } = j(a); + !g || !f || (I(r, g, f), r = f); + }, e.ontouchend = e.ontouchcancel = (u) => { + if (u.preventDefault(), r = null, a.length < 3) + return; + this.data[this.uuid] || (this.data[this.uuid] = []); + const l = Date.now() - d, h = { + move: Object.assign({}, o), + line: [...c], + uuid: this.uuid, + color: this.color, + duration: l < 1280 ? l : l < 2e3 ? 1280 : 0 + // 单次笔迹时长超过2000ms不加动画 + }; + this.data[this.uuid].push(h), P(() => { + this.emitStateChange({ + type: y.Drawline, + color: this.color, + ready: this.ready, + state: h, + uuid: this.uuid + }); + }); + }; + } + emitStateChange(e, n = !0) { + if (e.type !== y.Drawline) { + this.emit("stateChange", e, n); + return; + } + const s = Date.now(), r = e.state; + if (!r || !r.line) + return; + const a = Math.ceil(r.line.length / 100); + for (let o = 0; o < a; o++) { + const c = { + uuid: this.uuid, + color: this.color, + ready: this.ready, + type: e.type, + state: { + uuid: this.uuid, + move: r.move, + duration: r.duration, + color: this.color, + line: r.line.slice(o * 100, (o + 1) * 100) + }, + timestamp: s, + end: o === a - 1 + }; + U(o, 20, () => { + this.emit("stateChange", c, n); + }); + } + } + action(e) { + const { ready: n, type: s, uuid: r } = e; + if (!n && this.ready) { + this.closeBrush(); + return; + } + if (n && !this.ready) { + this.openBrush(); + return; + } + if (this.ready) + switch (s) { + case y.Drawline: + const { state: a, timestamp: o, end: c } = e; + if (!o || !a) + return; + this.tempLine[o] = [].concat(this.tempLine[o] || [], a.line), c && (Object.assign(a, { line: this.tempLine[o] }), this.handleDrawLine(r, a, {}, () => delete this.tempLine[o])); + break; + case y.Undo: + this.handleUndo(r); + break; + } + } + handleDrawLine(e, n, { withUndo: s = !1 }, r = m) { + !n || Object.prototype.toString.call(n) != "[object Object]" || Object.keys(n).length === 0 || G(() => new Promise((a) => { + if (s || (this.canvas[e] || (this.canvas[e] = this.initCanvas("_paintBrush-canvas--sync")), this.data[e] || (this.data[e] = []), this.data[e].push(n)), !this.canvas[e]) + return; + const o = this.canvas[e].getContext("2d"); + if (!o) + return; + const { line: c = [], color: d = "black", duration: I = 0, uuid: u } = n, l = L(n.move || {}, this.clientWidth, this.clientHeight); + let h = [l]; + if (o.strokeStyle = d, o.beginPath(), o.moveTo(l.x, l.y), I && !s) { + let g = []; + const f = this; + f.tween = F({ step: 0 }, { step: c.length - 1 }, I).onUpdate(({ step: p }) => { + var v; + if (f.tweening = !0, !f.ready) + return o.clearRect(0, 0, f.canvas[u].width, f.canvas[u].height), (v = f.tween) == null ? void 0 : v.stop(); + const A = Math.floor(p); + if (!g.find((D) => D === A)) { + if (g.push(A), h.push(L(c[A], f.clientWidth, f.clientHeight)), h.length < 3) + return; + const { control: D, end: O } = j(h); + if (!D || !O) + return; + o.quadraticCurveTo(D.x, D.y, O.x, O.y), o.stroke(); + } + }).onComplete((p) => { + f.tween = void 0, f.tweening = !1, g = [], h = [], r && r(), a(); + }); + } else { + for (let g = 0; g < c.length; g++) { + if (h.push(L(c[g], this.clientWidth, this.clientHeight)), h.length < 3) + continue; + const { control: f, end: p } = j(h); + !f || !p || o.quadraticCurveTo(f.x, f.y, p.x, p.y); + } + o.stroke(), h = [], r && r(), a(); + } + })); + } + handleUndo(e) { + if (!this.canvas[e] || !this.data[e] || this.data[e].length === 0) + return; + this.data[e].pop(); + const n = () => { + var r; + const s = (r = this.canvas[e]) == null ? void 0 : r.getContext("2d"); + s && s.clearRect(0, 0, this.canvas[e].width, this.canvas[e].height), this.data[e].forEach((a) => this.handleDrawLine(e, a, { withUndo: !0 })); + }; + if (this.tween && this.tweening) { + this.tween.stop(), P(n, 60); + return; + } + n(); + } + destroyBrush() { + this.closeBrush(), this.ready = !1, this.emit("readyChange", !0); + } +} +class tt { + constructor(i = {}) { + C(this, "controller"); + const e = Object.assign({ + currentColor: "#f44336", + onUndoText: "回退", + onExitText: "关闭" + }, i); + this.controller = new q(e); + } + on(i, e) { + this.controller.on(i, e); + } + off(i, e) { + this.controller.off(i, e); + } + once(i, e) { + this.controller.once(i, e); + } + /** + * 显示画笔。 + */ + show() { + this.controller.openBrush(); + } + action(i) { + this.controller.action(i); + } + /** + * 获取画笔状态。 + */ + get state() { + return this.controller.state; + } + get configs() { + return this.controller.configs; + } + /** + * 销毁。 + * + * @deprecated + * + * @description 画笔应该维护一个 **全局单例**,重复利用。 + */ + dispose() { + return this.controller.destroyBrush(); + } + setCurrentColor(i) { + this.controller.updateCurrentColor(i); + } +} +export { + tt as PaintBrush, + y as PaintBrushTypeEnum +}; diff --git a/dist/AreaMakerPlugin/Controller.d.ts b/dist/AreaMakerPlugin/Controller.d.ts new file mode 100644 index 000000000..d122c5eda --- /dev/null +++ b/dist/AreaMakerPlugin/Controller.d.ts @@ -0,0 +1,96 @@ +import * as THREE from 'three'; +import type { Five } from '@realsee/five'; +import * as BasePlugin from '../base/BasePluginWithData'; +import { AreaMakerItem } from './utils/Item'; +import type * as PluginType from './typing'; +export declare class Controller extends BasePlugin.Controller { + /** 插件当前状态 */ + state: PluginType.State; + /** 标注模型 { id: item } 的映射表 */ + itemMap: Map; + /** 自定义 DOM */ + itemRenderer?: PluginType.ItemRenderer; + /** 标注模型容器 */ + modelGroup: THREE.Group; + /** 当前使用的数据 */ + data?: PluginType.PluginData; + /** tag 容器 */ + tagDomContainer: HTMLDivElement; + /** 插件配置项 */ + get config(): { + modelDepthTest: boolean; + }; + /** 是否已经被销毁 */ + get disposed(): boolean; + /** 查询问题使用的调试对象 */ + checkMsg: { + childrenMountedState: string; + }; + /** 是否在 Five Change Mode 动画中 */ + private isInFiveChangeModeAnime; + /** 子组件是否挂载 */ + private childrenMountedState; + /** config 的原始值 */ + private _config; + /** disposed 的原始值 */ + private _disposed; + /** AreaMakerPlugin + * @param `five` `` Five 实例 + * @param `params` ` | ` 插件初始化参数 + * @param `params.initialState` ` | ` 插件初始化后,使用的状态 + */ + constructor(five: Five, params?: PluginType.Params); + /** 加载数据,重复调用会使用新数据覆盖旧数据 */ + load(data: PluginType.ServerData): Promise; + /** 将插件的 DOM 容器添加到指定的 DOM 元素上 */ + appendTo(wrapper: Element): void; + /** 启用插件 + * @param `options` `