Three.js + CSS3DSprite 首帧精灵图模糊问题排查、解决

一、 现象

页面初次加载,浮窗模糊;

用户一旦缩放/旋转/平移,相机矩阵刷新 → 浮窗就清晰。

二、 相关代码

ini 复制代码
        showAreaModel(item, operateModel) {
            // 显示区块浮窗
            const infoDiv = document.getElementById(`operateModel-${item.tenantId}`);
            if (infoDiv) {
                const bbox = new THREE.Box3().setFromObject(operateModel);
                const center = new THREE.Vector3();
                bbox.getCenter(center);

                let sprite = new CSS3DSprite(infoDiv);
                sprite.position.set(center.x, 0.92, center.z);
                sprite.hdType = '区块浮窗';
                // 原尺寸太大,缩小浮窗
                sprite.scale.multiplyScalar(0.0014);

                this.scene.add(sprite);
                sprite.mainModel = operateModel;
                operateModel.blockCardModel = sprite;
            }
        },

三、经过排查、调研, 最终有效方案

核心思路:避免使用threejs的scale缩放,避免直接用 sprite.scale 缩放,改为 DOM 内层缩放。

实现方式:

给浮窗 DOM 加一层 外包装容器(three.js 控制定位)。

内层 DOM 用 transform: scale() 缩放元素。

创建精灵图时 sprite 保持 scale = 1,不再使用 threejs的scale 缩放。

示例:

css 复制代码
<div class="sprite-wrapper">

   <div class="sprite-inner">浮窗文字</div>

</div>

.sprite-wrapper {

   display: inline-block; /* three.js 控制它 */

}

.sprite-inner {

   transform: scale(0.0014) translate(-50%, -50%); ;    /* 再缩小 */

   transform-origin: top left;  /* 保持对齐 */

}

四、 结论

不要使用threejs 极小缩放精灵图,在dom里使用css缩放元素。

相关推荐
2501_9445255441 分钟前
Flutter for OpenHarmony 个人理财管理App实战 - 支出分析页面
android·开发语言·前端·javascript·flutter
李白你好1 小时前
Burp Suite插件用于自动检测Web应用程序中的未授权访问漏洞
前端
刘一说2 小时前
Vue 组件不必要的重新渲染问题解析:为什么子组件总在“无故”刷新?
前端·javascript·vue.js
徐同保3 小时前
React useRef 完全指南:在异步回调中访问最新的 props/state引言
前端·javascript·react.js
刘一说4 小时前
Vue 导航守卫未生效问题解析:为什么路由守卫不执行或逻辑失效?
前端·javascript·vue.js
一周七喜h4 小时前
在Vue3和TypeScripts中使用pinia
前端·javascript·vue.js
weixin_395448914 小时前
main.c_cursor_0202
前端·网络·算法
东东5165 小时前
基于vue的电商购物网站vue +ssm
java·前端·javascript·vue.js·毕业设计·毕设
MediaTea5 小时前
<span class=“js_title_inner“>Python:实例对象</span>
开发语言·前端·javascript·python·ecmascript
梦梦代码精6 小时前
开源、免费、可商用:BuildingAI一站式体验报告
开发语言·前端·数据结构·人工智能·后端·开源·知识图谱