【threejs】较大物体或shape的贴图较小问题处理方法

问题

有的场景内相对体型差距过大的物体(如山地 海洋等····)由于尺寸问题,加载贴图过于小,同时shader也无法完全展示,如图

我们可以获取物体的uv,进行缩放使得贴图可以完全展开

如果uv是乱的 可以用xyz坐标最大最小值先排布uv再对uv进行缩放

javascript 复制代码
//假设你有一个 mest.geometry(物体网格)
 		let max = { x: 10000, y: 10000, z: 10000 }
        let min = { x: 30000, y: 30000, z: 30000 }
        let positions = geometry.getAttribute('position').array.map((item, index) => {
            let axis = index % 3
            switch (axis) {
                case 0:
                    return item - min.x
                    break;
                case 1:
                    return item - min.y
                    break;
                case 2:
                    return item - min.z
                    break;
                default:
                    break;
            }
        })

        let uv_ = []
        let _X = max.x - min.x
        let _Y = max.y - min.y
        let _Z = max.z - min.z
        for (let i = 0; i < positions.length / 3; i++) {
            let x = positions[i * 3]
            let y = positions[i * 3 + 1]
            let z = positions[i * 3 + 2]
            let _u = x / _X
            let _v = z / _Z
            // 或者你的高度轴是y
            //  _v = y/_Y
            uv_.push(_u, _v)

        }
        let uvs = uv_.map(item=>item*scale)//缩放

        // 只是改原始模型uv比例 
        let uvs = geometry.getAttribute('uv').array.map(item => item / 500)//缩放uv

        // uv传给geometry(网格)
        geometry.setAttribute('uv', new Float32BufferAttribute(uvs, 2))
```

# 效果
```javascript
//我这里只是进行uv缩放
        const mesh = new Mesh(geometry, mat)
        // mesh.position.setZ(-this.lineTick)
        mesh.position.set(startX, startY, - this.lineTick)
        // console.log(geometry);
        let uvs = geometry.getAttribute('uv').array.map(item => item / 500)//缩放
        geometry.setAttribute('uv', new Float32BufferAttribute(uvs, 2))
        mesh.scale.set(scale, scale, 1)
        return mesh
```

![在这里插入图片描述](https://img-blog.csdnimg.cn/direct/d3ddd5998906476bb488d32da7fb56a9.png)
贴图完全展开了
相关推荐
格林威8 小时前
工业视觉检测:提供可视化UI调试工具的实现方式是什么?
开发语言·人工智能·数码相机·ui·计算机视觉·视觉检测·工业相机
We་ct8 小时前
LeetCode 97. 交错字符串:动态规划详解
前端·算法·leetcode·typescript·动态规划
Chengbei118 小时前
轻量化 Web 安全日志分析神器 星川智盾日志威胁检测、地理溯源、MITRE ATT&CK 映射,支持 Windows/macOS/Linux
前端·人工智能·安全·web安全·macos·系统安全·安全架构
风流 少年8 小时前
Python Web框架:FastAPI
前端·python·fastapi
GISer_Jing8 小时前
AI时代面试新常态——从“会用工具”到“深挖原理”的跨越
前端·人工智能·ai编程
IT_陈寒8 小时前
React的useEffect把我坑惨了,这些闭包陷阱真要命
前端·人工智能·后端
前端之虎陈随易8 小时前
有生之年系列,Nodejs进程管理pm2 v7.0发布
前端·typescript·npm·node.js
ayqy贾杰9 小时前
Cursor SDK发布!开发者可直接搬走其内核
前端·vue.js·面试
xinxiangwangzhi_9 小时前
立体匹配--Fast-FoundationStereo
计算机视觉
良木生香9 小时前
【C++初阶】STL——Vector从入门到应用完全指南(1)
开发语言·c++·神经网络·算法·计算机视觉·自然语言处理·数据挖掘