章节二、three.js开发入门与调试设置02;

一、轨道控制器查看物体;

1、基本概念

     轨道控制器(OrbitControls)可以使得相机围绕目标进行轨道运动;

 2、代码样例

// 七、创建轨道控制器(相机围绕着物体捕捉视角)
const controls = new OrbitControls(camera,renderer.domElement,)function render() {renderer.render(scene , camera);// 请求动画帧:渲染下一帧的时候,会重新执行这个函数requestAnimationFrame(render);
}// 起始动画
render();

二、添加坐标辅助器;

1、基本概念

      用于简单模拟3个坐标轴的对象;红色代表X轴、绿色代表Y轴、蓝色代表Z轴;

2、代码样例

// 八、添加坐标轴辅助器,数字代表轴的线段长度,默认为1
const axesHelper = new THREE.AxesHelper(5);
scene.add(axesHelper);

三、设置物体移动;

1、基本概念

      物体对象的position熟悉,表示对象局部位置的Vector3,默认值为 (0,0,0)  ;

2、代码片段

// 修改物体的位置方法1 (X,Y,Z)
// cube.position.set(5,0,0);// 修改属性改变X轴的位置方法2
cube.position.x = 3;
function render() {// 1.实时移动cube物体位置cube.position.x += 0.01;if(cube.position.x > 5){cube.position.x = 0;} // 2.渲染画面renderer.render(scene , camera);// 请求动画帧:渲染下一帧的时候,会重新执行这个函数requestAnimationFrame(render);
}

四、物体的缩放与旋转;

1、基本概念

       设置物体的缩放属性:scale;

       设置物体的局部旋转属性:rotation,以弧度来表示;属性order值应用于旋转顺序,默认值为'XYZ':意味着先绕X轴旋转,然后是Y轴,最后是Z轴; 

2、代码片段

// 01、设置物体的缩放
cube.scale.set(3,2,1);
cube.scale.x = 5;// 02、设置物体的局部旋转,以弧度来表示;
// 属性order值应用于旋转顺序,默认值为'XYZ':意味着先绕X轴旋转,然后是Y轴,最后是Z轴;
cube.rotation.set(Math.PI / 4, 0 , 0, 'XYZ');
function render() {// 1.实时移动cube物体位置cube.position.x += 0.01;if(cube.position.x > 5){cube.position.x = 0;} // 2.循环旋转cube.rotation.x += 0.01;// 3.渲染画面renderer.render(scene , camera);// 请求动画帧:渲染下一帧的时候,会重新执行这个函数requestAnimationFrame(render);
}

五、应用 requestAnimationFrame 正确处理动画运动;

1、基本概念

      动画运动时快时慢,如何保证其性能?

2、代码片段

function render(time) {// 1.实时移动cube物体位置// cube.position.x += 0.01;// if(cube.position.x > 5){//     cube.position.x = 0;// }// 循环旋转角度// cube.rotation.x += 0.01;// 2.正常的电脑1秒是60帧,每一帧的间隔时间是 1000ms / 60帧 = 16毫秒;// 传入time,表示当前帧的时间,每一帧时间间隔不均匀,导致前进的距离大小不等; // 移动距离 = 速度(速度为1) * 时间;就可以保证物体移动距离均匀,不是时快时慢;let t = (time / 1000) % 5;cube.position.x = t * 1;console.log("time", time);console.log("position", t);// 3.渲染画面renderer.render(scene , camera);// 请求动画帧:渲染下一帧的时候,会重新执行这个函数    requestAnimationFrame(render);
}

六、通过Clock跟踪时间处理动画;

1、基本概念

     该对象用于跟踪时间

2、代码片段

七、Gsap动画库基本使用与原理;

1、基本概念

2、代码片段

八、Gsap控制动画属性与方法;

1、基本概念

2、代码片段

九、根据尺寸变化实现自适应画面;

1、基本概念

2、代码片段

十、调用js接口控制画布全屏 和 退出全屏;

1、基本概念

2、代码片段

十一、应用图形用户界面更改变量;

1、基本概念

2、代码片段

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/714787.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

吴恩达机器学习全课程笔记第五篇

目录 前言 P80-P85 添加数据 迁移学习 机器学习项目的完整周期 公平、偏见与伦理 P86-P95 倾斜数据集的误差指标 决策树模型 测量纯度 选择拆分方式增益 使用分类特征的一种独热编码 连续的有价值特征 回归树 前言 这是吴恩达机器学习笔记的第五篇&#xff0c…

《2023跨境电商投诉大数据报告》发布|亚马逊 天猫国际 考拉海购 敦煌网 阿里巴巴

2023年,跨境电商API接口天猫国际、京东国际和抖音全球购以其强大的品牌影响力和市场占有率,稳坐行业前三的位置。同时,各大跨境电商平台消费纠纷问题层出不穷。依据国内知名网络消费纠纷调解平台“电诉宝”(315.100EC.CN&#xff…

javaEE--后端环境变量配置

目录 pre 文件准备 最终运行成功结果 后端运行步骤 1.修改setenv文件 2.运行setenv,设置环境变量 3.查看jdk版本 4.修改mysql文件夹下的my文件 前端运行步骤 1.nodejs环境配置 2.查看node和npm版本 3.下载并运行npm 4.注册登录 pre 文件准备 最终运行…

VR转接器:破解虚拟与现实边界的革命性设备

VR转接器,这一革命性的设备,为虚拟现实体验带来了前所未有的自由度。它巧妙地连接了虚拟与现实,使得用户在享受VR眼镜带来的奇幻世界的同时,也能自由地在现实世界中活动。这一设计的诞生,不仅解决了VR眼镜续航的瓶颈问…

2、云原生安全之可视化界面rancher的部署

文章目录 1、rancher的部署1.1、安装rancher1.2、配置k8s2、部署helm3、容器安全工具neuvector此时已经部署好了k8s,使用rancher来管理 rancher简化了使用k8s的流程,可以图形化管理k8s。 参考: https://blog.51cto.com/u_15343792/5000311https://docs.rancher.cn/docs/ra…

你们团队是否有RocketMQ创建Topic、GID创建规范呢

这里是weihubeats,觉得文章不错可以关注公众号小奏技术 背景 早期在使用RocketMQ的时候,系统和开发人员不算多。所以topic的创建会非常随意,各种千奇百怪的topic 比如: order_topic、ORDER_TOPIC、order-topic 各种奇奇怪怪的风格,用_的&a…

GO结构体

1. 结构体 Go语言可以通过自定义的方式形成新的类型,结构体就是这些类型中的一种复合类型,结构体是由零个或多个任意类型的值聚合成的实体,每个值都可以称为结构体的成员。 结构体成员也可以称为“字段”,这些字段有以下特性&am…

JS清空数组方法

清空数组的方法有多种,以下是几种常见的方式: 1.使用 array.length 属性将数组的长度设为0,这样会移除数组中的所有元素: var arr [1, 3, 5]; arr.length 0; console.log(arr); // [] 2. 使用 array.splice() 方法,…

STM32 | 零基础 STM32 第一天

零基础 STM32 第一天 一、认知STM32 1、STM32概念 STM32:意法半导体基于ARM公司的Cortex-M内核开发的32位的高性能、低功耗单片机。 ST:意法半导体 M:基于ARM公司的Cortex-M内核的高性能、低功耗单片机 32:32位单片机 2、STM32开发的产品 STM32开发的产品&a…

【论文笔记】Improving Language Understanding by Generative Pre-Training

Improving Language Understanding by Generative Pre-Training 文章目录 Improving Language Understanding by Generative Pre-TrainingAbstract1 Introduction2 Related WorkSemi-supervised learning for NLPUnsupervised pre-trainingAuxiliary training objectives 3 Fra…

Java 网络面试题解析

1. Http 协议的状态码有哪些?含义是什么?【重点】 200:OK,客户端请求成功。 301:Moved Permanently(永久移除),请求的URL已移走。Response中应该包含一个Location URL,…

steam++加速问题:出现显示443端口被 vmware-hostd(9860)占用的错误。

目录 前言: 正文: 前言: 使用Steam对GitHub进行加速处理时,建议使用2.8.6版本。 下载地址如下:Release 2.8.6 BeyondDimension/SteamTools GitHub 下载时注意自己的系统位数 正文: 使用GitHub时会使…

NOC2023软件创意编程(学而思赛道)python初中组初赛真题

软件创意编程 一、参赛范围 1.参赛组别:小学低年级组(1-3 年级)、小学高年级组(4-6 年级)、初中组。 2.参赛人数:1 人。 3.指导教师:1 人(可空缺)。 4.每人限参加 1 个赛项。 组别确定:以地方教育行政主管部门(教委、教育厅、教育局) 认定的选手所属学段为准。 二、…

Mybatis-Plus+SpringBoot多数据源注解方式@DS

前言 最近接到一个新需求需要处理多数据源的问题 &#xff0c;今天就来和大家一起学习一下。 一、使用步骤 1.引入库 代码如下&#xff08;示例&#xff09;&#xff1a; <!--配置多数据源--><dependency><groupId>com.baomidou</groupId><artif…

蓝桥杯Java B组历年真题(2013年-2021年)

一、2013年真题 1、世纪末的星期 使用日期类判断就行&#xff0c;这里使用LocalDate&#xff0c;也可以使用Calendar类 答案 2099 使用LocalDate import java.time.LocalDate; import java.time.format.DateTimeFormatter; // 1:无需package // 2: 类名必须Main, 不可修改p…

常见问题和解决方案

OOM overview 发现监控告警 定位日志java.lang.OutOfMemoryError 避免参数配置代码规范 example jvm性能调优实战 -55RPC调用引发的OOM故障-阿里云开发者社区 (aliyun.com) 发现监控告警 定位日志java.lang.OutOfMemoryErrorA rpc BMAT打开堆快照文件分析histogram右击看引…

CentOS7 Hive2.3.8安装

CentOS7 Hive2.3.8 安装 建议从头用我的博客&#xff0c;如果用外教的文件到 一、9)步骤了&#xff0c;就用他的弄完&#xff0c;数据库不一样&#xff0c;在9步骤前还能继续看我的 一、 安装MySQL 0.0&#xff09;查询mariadb,有就去0.1&#xff09;&#xff0c;没有就不管…

python3装饰器

装饰器 它允许你修改函数或类的行为&#xff0c;而不更改其源代码。实质上&#xff0c;装饰器是接受另一个函数作为参数并返回一个包装原始函数的新函数。这样&#xff0c;你可以在不修改原始函数的情况下&#xff0c;添加一些额外的功能或逻辑。 def time_cost(func):"…

排队接水问题

时间限制&#xff1a;1秒 内存限制&#xff1a;128M 题目描述 有n个人在一个水龙头前排队接水&#xff0c;假如每个人接水的时间为Ti&#xff0c;请编程找出这n个人排队的一种顺序&#xff08;若有多种顺序则编号小的在前&#xff09;&#xff0c; 使得n个人的平均时间…

ARCGIS进行视域分析及地形图制作

问题说明 开发商要在本区域建造观景亭,希望在观景亭上能看到优美的景色。根据提供的数据,完成以下要求。 一、 数据说明(见“题目3”文件夹) 1. DEM.tif:研究区域的数据高程模型数据。 2. 观察点.shp:需要建造观景亭的位置。