Three.js三维模型几何体旋转、缩放和平移

Three.js三维模型几何体旋转、缩放和平移

创建场景中的三维模型往往需要设置显示大小、位置、角度,three.js提供了一系列网格模型对象的几何变换方法,从WebGL的角度看,旋转、缩放、平移对应的都是模型变换矩阵,关于矩阵变换内容可以观看本人博客发布的原生WebGL课程。

网格模型对象的旋转、缩放、平移等方法或属性可以查找three.js文档的Object3D对象,该对象是网格模型对象、点模型对象、线条模型对象的基类。

缩放

立方体网格模型x轴方向放大2倍,如果连续执行两次该语句,相等于比原来方法4倍

mesh.scale.x = 2.0;//x轴方向放大2倍

立方体网格模型整体缩小0.5倍,相当于xyz三个方向分别缩小0.5倍

mesh.scale.set(0.5,0.5,0.5);//缩小为原来0.5倍

网格模型Mesh的属性scale返回值是一个Vector3对象,查看three.js官方文档你可以知道Vector3对象具有属性x、y、z对于上面的代码而言xyz表示坐标值,xyz数据类型是float,Vector3对象还具有方法set(),set方法有三个表示xyz坐标的参数。

平移

立方体网格模型沿着x轴正方向平移100,可以多次执行该语句,每次执行都是相对上一次的位置进行平移变换

mesh.translateX(100);//沿着x轴正方向平移距离100

网格模型沿着向量(0,1,0)表示的方向平移100

var axis = new THREE.Vector3(0,1,0);//向量axis
mesh.translateOnAxis(axis,100);//沿着axis轴表示方向平移100
translateOnAxis(axis, distance)方法相比.translateX、.translateY、.translateZ更通用,可以实现立方体沿着任何方向旋平移,参数axis表示平移方向,使用对象Vector3表示
旋转

立方体网格模型绕立方体的x轴旋转π/4,可以多次执行该语句,每次执行都是相对上一次的角度进行旋转变化

mesh.rotateX(Math.PI/4);//绕x轴旋转π/4

网格模型绕(0,1,0)向量表示的轴旋转π/8

var axis = new THREE.Vector3(0,1,0);//向量axis
mesh.rotateOnAxis(axis,Math.PI/8);//绕axis轴旋转π/8
rotateOnAxis(axis, angle)方法相比.rotateX、.rotateY、.rotateZ更通用,可以实现立方体绕任何轴旋转,参数axis表示旋转轴,使用对象Vector3表示
位置属性position

立方体网格模型位置坐标(80,2,10)

mesh.position.y = 80;//设置网格模型几何中心y坐标

立方体网格模型几何中心y轴坐标值80

mesh.position.set(80,2,10);//设置网格模型几何中心三维坐标
position属性和平移方法translateX()一样都是设置距离,方法translateX()设置的相对上次位置进行平移,两次执行该方法,距离会叠加,position属性设置的距离是相对坐标系原点位置, 两次执行position属性立方体的会只会更新重新定位,两次的距离参数不是叠加关系,而是替换关系。
角度属性rotation

立方体网格模型位置坐标(80,2,10)

mesh.position.y = 80;//设置网格模型几何中心y坐标

立方体网格模型几何中心y轴坐标值80

mesh.position.set(80,2,10);//设置网格模型几何中心三维坐标

rotation属性和旋转方法rotateX()差异类似position属性和平移方法translateX()的差异,一个是相对坐标系设置角度、位置,一个是相对当前的三维模型的状态设置角度、位置参数。 旋转与平移参考的都是坐标系,不过参考的坐标系稍有不同,平移参考的是世界坐标系或者说三维场景对象Scene的坐标系,和相机对象一样,在整个三维场景中的位置, 三维模型的旋转参考的是模型坐标系,也就是对三维模型本身建立的坐标系。

基类Object3D

点模型Points、线模型Line、精灵模型sprite、组对象Group等threejs模型对象的基类都是Object3D,这些模型对象的角度、位置、缩放属性和旋转、平移、缩放方法都可以查看threejs文档基类Object3D

几何体变换

几何体Geometry和网格模型Mesh一样也就有旋转缩放平移等方法,通过网格模型或几何体的方法都可以对模型进行变换,但是本质是不一样的,网格模型Mesh执行旋转平移缩放变化,并不会改变自身绑定几何体的顶点坐标,会改变模型对应的模型矩阵ModelMatrix,几何体执行旋转缩放平移变换会改变几何体本身包含的顶点位置、法向量等数据。

如果对上面阐述不太理解,建议最好看看本人博客发布的threejs课程中第二章关于几何体顶点的介绍,threejs进阶课程中关于模型矩阵等概念的介绍。

下面的程序是通过一个几何体创建了多个网格模型,网格模型可以共享几何体对象和材质对象都,几何体对象本质上是一组顶点相关数据,每创建一个网格模型, 相当于多次利用显存中的同一组定点相关数据渲染出多个三维模型的效果,几何体顶点虽然是同一组数据,但是可以在GPU着色器中对这组数据进行矩阵变换,来呈现出不同的效果。

/**
 * 创建网格模型1、网格模型2
 */
var box=new THREE.BoxGeometry(50,50,50);//创建一个立方体几何对象
var material=new THREE.MeshLambertMaterial({color:0x0000ff});//材质对象
var mesh1=new THREE.Mesh(box,material);//网格模型对象1
var mesh2=new THREE.Mesh(box,material);//网格模型对象2
mesh1.translateX(-50);//沿着x轴负方向平移距离50
mesh2.translateX(50);//沿着x轴正方向平移距离50
scene.add(mesh1);//网格模型1添加到场景中
scene.add(mesh2);//网格模型2添加到场景中
代码中的网格模型mesh1、网格模型mesh2都是通过同一个几何体对象Geometry创建,默认情况下,几何体对象的顶点位置决定了网格模型在场景中的显示位置, 两个网格模型执行方法translateX()进行平移变换错开显示。网格模型的平移变换方法translateX()会通过three.js引擎转化为WebGL中CPU顶点着色器的矩阵变换程序。

更改上面的程序,插入下面一段代码,放大其中一个网格模型,可以看到另外外一个网格模型的显示大小并不受影响。

mesh2.scale.y = 2.0;//y轴方向放大2倍

网格模型对象可以进行缩放平移旋转变换,几何体对象也拥有相关的几何变换方法和属性,几何体进行几何变换,本质上更改的是显存中的顶点相关数据, 网格模型进行几何变换,不会更改显存中的顶点数据,顶点数据的变换是在GPU渲染管线的顶点着色器处理单元中借助程序逐顶点执行矩阵乘法运算。

几何体对象执行方法scale(),尺寸缩小为原来的0.5倍,刷新浏览器你会看到两个网格模型代表的立方体都缩小了,对比上面的程序可以看出更改几何体的参数,与之相关的网格模型都会变化。 这很好理解,网格模型的几何变换更改的是要与顶点数据进行乘法运算的模型矩阵,几何体对象进行变换更累刷新的是显存上的顶点相关数据,每次渲染出一个网格模型, 都会从网格模型构造函数指定的顶点对象获取顶点数据。

var box=new THREE.BoxGeometry(50,50,50);//创建一个立方体几何对象
box.scale(0.5,0.5,0.5);//几何体缩小为原来0.5倍

几何体对象可以进行上面程序中的缩放变换,自然也有平移、缩放变换的相关方法,具体使用方法可以参考three.js文档的Geometry对象,立方体、球体等几何体的构造函数返回的结果都是Geometry对象, 这些构造函数返回的对象都会继承Geometry对象的属性和方法。

  • 3
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
自动控制节水灌溉技术的高低代表着农业现代化的发展状况,灌溉系统自动化水平较低是制约我国高效农业发展的主要原因。本文就此问题研究了单片机控制的滴灌节水灌溉系统,该系统可对不同土壤的湿度进行监控,并按照作物对土壤湿度的要求进行适时、适量灌水,其核心是单片机和PC机构成的控制部分,主要对土壤湿度与灌水量之间的关系、灌溉控制技术及设备系统的硬件、软件编程各个部分进行了深入的研究。 单片机控制部分采用上下位机的形式。下位机硬件部分选用AT89C51单片机为核心,主要由土壤湿度传感器,信号处理电路,显示电路,输出控制电路,故障报警电路等组成,软件选用汇编语言编程。上位机选用586型以上PC机,通过MAX232芯片实现同下位机的电平转换功能,上下位机之间通过串行通信方式进行数据的双向传输,软件选用VB高级编程语言以建立友好的人机界面。系统主要具有以下功能:可在PC机提供的人机对话界面上设置作物要求的土壤湿度相关参数;单片机可将土壤湿度传感器检测到的土壤湿度模拟量转换成数字量,显示于LED显示器上,同时单片机可采用串行通信方式将此湿度值传输到PC机上;PC机通过其内设程序计算出所需的灌水量和灌水时间,且显示于界面上,并将有关的灌水信息反馈给单片机,若需灌水,则单片机系统启动鸣音报警,发出灌水信号,并经大驱动设备,开启电磁阀进行倒计时定时灌水,若不需灌水,即PC机上显示的灌水量和灌水时间均为0,系统不进行灌水。
智慧农业是一种结合了现代信息技术,包括物联网、大数据、云计算等,对农业生产过程进行智能化管理和监控的新模式。它通过各种传感器和设备采集农业生产中的关键数据,如大气、土壤和水质参数,以及生物生长状态等,实现远程诊断和精准调控。智慧农业的核心价值在于提高农业生产效率,保障食品安全,实现资源的可持续利用,并为农业产业的转型升级提供支持。 智慧农业的实现依赖于多个子系统,包括但不限于设施蔬菜精细化种植管理系统、农业技术资料库、数据采集系统、防伪防串货系统、食品安全与质量追溯系统、应急追溯系统、灾情疫情防控系统、农业工作管理系统、远程诊断系统、监控中心、环境监测系统、智能环境控制系统等。这些系统共同构成了一个综合的信息管理和服务平台,使得农业生产者能够基于数据做出更加科学的决策。 数据采集是智慧农业的基础。通过手工录入、传感器自动采集、移动端录入、条码/RFID扫描录入、拍照录入以及GPS和遥感技术等多种方式,智慧农业系统能够全面收集农业生产过程中的各种数据。这些数据不仅包括环境参数,还涵盖了生长状态、加工保存、检验检疫等环节,为农业生产提供了全面的数据支持。 智慧农业的应用前景广阔,它不仅能够提升农业生产的管理水平,还能够通过各种应用系统,如库房管理、无公害监控、物资管理、成本控制等,为农业生产者提供全面的服务。此外,智慧农业还能够支持政府监管,通过发病报告、投入品报告、死亡报告等,加强农业产品的安全管理和质量控制。 面对智慧农业的建设和发展,存在一些挑战,如投资成本高、生产过程标准化难度大、数据采集和监测的技术难题等。为了克服这些挑战,需要政府、企业和相关机构的共同努力,通过政策支持、技术创新和教育培训等手段,推动智慧农业的健康发展。智慧农业的建设需要明确建设目的,选择合适的系统模块,并制定合理的设备布署方案,以实现农业生产的智能化、精准化和高效化。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值