THREE实战1_代码重构点、线、面

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

THREE.JS的右手坐标系

右手大拇指指向X轴,食指指向Y轴,中指指向Z轴。

酷!

两个知识点补充

知识点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);//添加到场景

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);

监听运行函数

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>

渲染重点:函数不断递归,我理解为回溯。

最后我还是喜欢蓝色的深沉神秘,嘻嘻!


目录
相关文章
基于three.js的牛逼轰轰的3D编辑器nunuStudio!
这是一款基于Three.js的3D编辑器,我之前一直喊错,叫人家"牛牛",因为我觉得它真的好牛,其实人家正确拼音喊“努努”! 可以发布web的运行包,直接可以网页端二次开发,真的不要太方便了!
基于three.js的牛逼轰轰的3D编辑器nunuStudio!
|
存储 NoSQL 关系型数据库
Redis(六)set集合类型
set集合和list列表十分的相似,都可以存储多个字符串。但是list列表可以存储重复值,而set集合中不可重复。
7564 0
Redis(六)set集合类型
|
缓存 对象存储 数据安全/隐私保护
阿里云OSS图片访问出现跨域:Access to image at from origin has been blocked by CORS policy
阿里云OSS图片访问出现跨域:Access to image at from origin has been blocked by CORS policy
3708 0
阿里云OSS图片访问出现跨域:Access to image at from origin has been blocked by CORS policy
|
7月前
|
开发者
云上玩转DeepSeek系列之六:DeepSeek云端加速版发布,具备超高推理性能
作为国内首个千亿级开源 MoE 模型,DeepSeek-R1 凭借其卓越的代码生成与复杂推理能力,已成为开发者构建智能应用的首选。然而,原始模型在产业落地中面临严峻挑战,部署 671B 满血版模型不仅硬件门槛要求很高,同时吞吐效率和响应延迟也受到了制约。PAI 正式推出了优化版 DeepSeek-R1 模型 DeepSeek-R1-PAI-optimized,将大模型推理效率推向了 Next Level。
|
6月前
|
运维 监控 数据可视化
斩获6.1 star,再见Crontab!这款开源定时任务管理系统让运维更高效
Gocron是一款基于Go语言的轻量级定时任务调度系统,替代传统Linux Crontab。它提供可视化Web界面管理,支持秒级调度、任务依赖配置与多节点执行。核心功能包括:1) 可视化管理;2) 精确调度规则;3) 全链路任务控制;4) 多类型任务支持;5) 完善监控通知。适用于自动化运维、系统监控、数据处理及业务自动化等场景。通过三步快速上手:一键部署、添加任务节点、创建定时任务。相比Crontab和Celery,Gocron更直观高效,适合个人与企业使用。项目地址:https://github.com/ouqiang/gocron。
1026 8
|
API 算法框架/工具
【threejs教程】三维物体与三维向量
【8月更文挑战第7天】threejs教程:三维物体与三维向量
316 3
【threejs教程】三维物体与三维向量
|
9月前
|
机器学习/深度学习 人工智能 自然语言处理
YuE:开源AI音乐生成模型,能够将歌词转化为完整的歌曲,支持多种语言和多种音乐风格
YuE 是香港科技大学和 M-A-P 联合开发的开源 AI 音乐生成模型,能够将歌词转化为完整的歌曲,支持多种音乐风格和多语言。
1557 23
YuE:开源AI音乐生成模型,能够将歌词转化为完整的歌曲,支持多种语言和多种音乐风格
|
10月前
|
人工智能 JavaScript 前端开发
一段 JavaScript 代码,集成网站AI语音助手
根据本教程,只需通过白屏化的界面操作,即可快速构建一个专属的AI智能体。
|
图形学
ThreeJs创建管道效果
这篇文章介绍了在Three.js中创建管道(Tube)效果的方法和技术细节。
422 3
ThreeJs创建管道效果
|
机器学习/深度学习 人工智能 自然语言处理
【AI大模型】Transformers大模型库(二):AutoModelForCausalLM
【AI大模型】Transformers大模型库(二):AutoModelForCausalLM
566 1