Three.js曲线篇 6.雕刻平面大师shape

说shape是平面雕刻大师一点都不为过。shade可以雕刻出各种复杂的平面,包括房子的那种什么c4d设计图纸。然后通过曲线的拉伸,将建筑立体化。

下面这里演示一个简单的使用场景:

完整代码:

javascript 复制代码
import * as THREE from 'three';
import { OrbitControls } from 'three/addons/controls/OrbitControls.js'

export default (domId) => {
    /* ------------------------------初始化三件套--------------------------------- */
    const dom = document.getElementById(domId);
    const { innerHeight, innerWidth } = window

    const scene = new THREE.Scene();

    const camera = new THREE.PerspectiveCamera(45, innerWidth / innerHeight, 1, 2000);
    camera.position.set(100, 100, 100);
    camera.lookAt(scene.position);

    const renderer = new THREE.WebGLRenderer({
        antialias: true,// 抗锯齿
        alpha: false,// 透明度
        powerPreference: 'high-performance',// 性能
        // logarithmicDepthBuffer: true,// 深度缓冲
    })
    renderer.shadowMap.enabled = true;// 开启阴影
    renderer.shadowMap.type = THREE.PCFSoftShadowMap;// 阴影类型
    renderer.outputEncoding = THREE.sRGBEncoding;// 输出编码
    renderer.toneMapping = THREE.ACESFilmicToneMapping;// 色调映射
    renderer.toneMappingExposure = 1;// 色调映射曝光
    renderer.physicallyCorrectLights = true;// 物理正确灯光
    renderer.setPixelRatio(window.devicePixelRatio);// 设置像素比
    renderer.setSize(innerWidth, innerHeight);// 设置渲染器大小
    dom.appendChild(renderer.domElement);

    // 重置大小
    window.addEventListener('resize', () => {
        const { innerHeight, innerWidth } = window
        camera.aspect = innerWidth / innerHeight;
        camera.updateProjectionMatrix();
        renderer.setSize(innerWidth, innerHeight);
    })

    /* ------------------------------初始化工具--------------------------------- */
    const controls = new OrbitControls(camera, renderer.domElement) // 相机轨道控制器
    controls.enableDamping = true // 是否开启阻尼
    controls.dampingFactor = 0.05// 阻尼系数
    controls.panSpeed = -1// 平移速度

    const axesHelper = new THREE.AxesHelper(10);
    scene.add(axesHelper);

    /* ------------------------------正题--------------------------------- */

    // Shape表示一个平面多边形轮廓
    const shape = new THREE.Shape();
    shape.moveTo(10, 0);// 移动到指定点
    shape.lineTo(100, 0);//.currentPoint变为(100, 0)
    shape.lineTo(100, 100);//.currentPoint变为(100, 100)
    shape.lineTo(10, 100);//.currentPoint变为(10, 100)

    // 创建空
    // Shape内孔轮廓
    const path1 = new THREE.Path();// 圆孔1
    path1.absarc(20, 20, 10);
    const path2 = new THREE.Path();// 圆孔2
    path2.absarc(80, 20, 10);
    const path3 = new THREE.Path();// 方形孔
    path3.moveTo(50, 50);
    path3.lineTo(80, 50);
    path3.lineTo(80, 80);
    path3.lineTo(50, 80);

    //三个内孔轮廓分别插入到holes属性中
    shape.holes.push(path1, path2, path3);

    const geometry = new THREE.ExtrudeGeometry(shape, {
        depth: 20,//拉伸长度
        bevelEnabled: false,//禁止倒角
        curveSegments: 50,
    });
    const material = new THREE.MeshBasicMaterial({ color: 0x00ff00 });
    const mesh = new THREE.Mesh(geometry, material);
    scene.add(mesh);
    console.log('currentPoint', shape.currentPoint);


    /* ------------------------------动画函数--------------------------------- */
    const animation = () => {
        controls.update();// 如果不调用,就会很卡
        renderer.render(scene, camera);
        requestAnimationFrame(animation);
    }
    animation();
}
相关推荐
小小怪_下士12 分钟前
Vue3:el-table组件存在多列操作数据,页面渲染导致进入页面卡顿问题优化。
前端·javascript·vue.js
小马超会养兔子18 分钟前
如何画一个网格
前端·vue
m0_7482309425 分钟前
ctfshow-web入门-爆破(web21-web24)
前端·数据库
横冲直撞de40 分钟前
EventSource和WebSocket用法
前端·javascript·网络·websocket·网络协议·vue
m0_748254661 小时前
悬赏任务源码(悬赏发布web+APP+小程序)开发附源码
前端·小程序
大地爱1 小时前
日志平台--graylog-web配置、接入微服务日志
前端·微服务·graylog
codecodegirl2 小时前
ios h5中在fixed元素中的input被focus时,键盘遮挡input (van-popup、van-feild)
前端·vue.js·html5
Li3702349402 小时前
在react中使用组件的标签页写订单管理页面
前端·javascript
Domain-zhuo2 小时前
React的一些主要优点是?
前端·javascript·react.js·webpack·前端框架·es6
杨大东2 小时前
PC端电商网站商品放大效果(附加代码)
javascript·css·html·组件功能