THREE实战_代码重构点、线、面(酷)

简介: THREE实战_代码重构点、线、面

THREE.JS的右手坐标系

右手大拇指指向X轴,食指指向Y轴,中指指向Z轴。
酷!
image.png

两个知识点补充

知识点1:渲染器函数

renderer.render(scene, camera);
render( scene, camera, renderTarget, forceClear )
参数变量 类型解释
scene 渲染的场景对象
camera 需要相机视角
renderTarget 渲染目标
forceClear 清除画布canvas对象

知识点2:循环渲染

function render() 
{
   
   
   cube.rotation.x += 0.1; 
   cube.rotation.y += 0.1;
   renderer.render(scene, camera); 
   requestAnimationFrame(render); 
 }

重点
requestAnimationFrame函数让浏览器执行一次参数中的函数,回调render形成游戏循环

绘制点、线、面

case1:绘制点

        var point1=new THREE.Vector3(0,20,0);
        var point2=new THREE.Vector3(20,0,0);
        var point3=new THREE.Vector3(30,0,0);//三维向量

case2:绘制线

        var geometry = new THREE.Geometry();
        //材质
        var materail = new THREE.LineBasicMaterial({
   
   vertexColors:true});//加上渐变色
        var materail1 = new THREE.LineBasicMaterial({
   
   color:0x0000FF});//加上纯色
        var color1 = new THREE.Color(0x00FF00);//颜色里面大小写不敏感
        var color2 = new THREE.Color(0xFF0000);
        //定义的三个能构成三角形的点
        var p1 = new THREE.Vector3(0,20,0);
        var p2 = new THREE.Vector3(20,0,0);
        var p3=new THREE.Vector3(30,0,0);
        //连接点
        geometry.vertices.push(p1);
        geometry.vertices.push(p2);
        geometry.vertices.push(p3);
        geometry.vertices.push(p1);//回到起始点
        geometry.colors.push(color1);
        geometry.colors.push(color2);
        geometry.colors.push(color1);
        var line = new THREE.Line(geometry,materail,THREE.LineSegments);
        scene.add(line);//添加到场景

image.png

case3:绘制面

        var geometry = new THREE.Geometry();
        var materail = new THREE.LineBasicMaterial({
   
   vertexColors:true});//加上渐变色
        var materail1 = new THREE.LineBasicMaterial({
   
   color:0x0000FF});//加上纯色
        var color1 = new THREE.Color(0x00FF00);//颜色里面大小写不敏感,绿色
        var color2 = new THREE.Color(0xFF0000);//红色
        var p1 = new THREE.Vector3(0,20,0);
        var p2 = new THREE.Vector3(20,0,0);
        var p3=new THREE.Vector3(30,0,0);
        geometry.vertices.push(p1);
        geometry.vertices.push(p2);
        geometry.vertices.push(p3);
        geometry.vertices.push(p1);//回到起始点
        geometry.colors.push(color1);
        geometry.colors.push(color2);
        geometry.colors.push(color1);
        //线
        var line = new THREE.Line(geometry,materail,THREE.LineSegments);
        scene.add(line);
        //绘制面
        mesh=new THREE.Mesh(geometry,materail);//点围成的面
        mesh.postion=new THREE.Vector3(0,0,0);//
        scene.add(mesh);

image.png

监听运行函数

html中body的onload 属性在对象已加载时触发。

  • js
    //开始入口
    function threeStart() {
   
   
        initThree();     // 初始化渲染器
        initCamera(); // 照像机设置
        initScene();    // 场景设置
        initLight();      // 灯光设置
        initObject();    // 几何体(物体)设置
        // render();        // 开始渲染
        // animation_camera();//ok!
        animation_model();
    }

    function start(){
   
   
        if (WEBGL.isWebGLAvailable()) {
   
   
            // Initiate function or other initializations here
            threeStart();
        } else {
   
   
            var warning = WEBGL.getWebGLErrorMessage();
            document.getElementById('container').appendChild(warning);
        }
    }
  • html
<body onload="start();">
<div id="container"></div>
<div id="canvas-frame"></div>

渲染重点:函数不断递归,我理解为回溯。
最后我还是喜欢蓝色的深沉神秘,嘻嘻!
image.png

目录
相关文章
|
缓存 JavaScript 前端开发
Vue3 官方文档速通(上)
Vue3 官方文档速通(上)
1408 0
|
设计模式 前端开发 JavaScript
深入探索研究React
【10月更文挑战第5天】
193 4
|
开发工具 git
idea解决git冲突
idea解决git冲突
361 0
|
弹性计算 网络协议 安全
阿里云ECS云服务器安全组配置开放端口方法教程
阿里云ECS云服务器安全组配置开放端口方法教程,阿里云服务器端口怎么打开?云服务器ECS端口在安全组中开启,轻量应用服务器端口在防火墙中打开,阿里云服务器网以80端口为例,来详细说下阿里云服务器端口开放图文教程,其他的端口如8080、3306、443、1433也是同样的方法进行开启端口:
1475 0
|
3天前
|
存储 JavaScript 前端开发
JavaScript基础
本节讲解JavaScript基础核心知识:涵盖值类型与引用类型区别、typeof检测类型及局限性、===与==差异及应用场景、内置函数与对象、原型链五规则、属性查找机制、instanceof原理,以及this指向和箭头函数中this的绑定时机。重点突出类型判断、原型继承与this机制,助力深入理解JS面向对象机制。(238字)
|
2天前
|
云安全 人工智能 安全
阿里云2026云上安全健康体检正式开启
新年启程,来为云上环境做一次“深度体检”
1474 6
|
4天前
|
安全 数据可视化 网络安全
安全无小事|阿里云先知众测,为企业筑牢防线
专为企业打造的漏洞信息收集平台
1310 2
|
3天前
|
缓存 算法 关系型数据库
深入浅出分布式 ID 生成方案:从原理到业界主流实现
本文深入探讨分布式ID的生成原理与主流解决方案,解析百度UidGenerator、滴滴TinyID及美团Leaf的核心设计,涵盖Snowflake算法、号段模式与双Buffer优化,助你掌握高并发下全局唯一ID的实现精髓。
324 160

热门文章

最新文章