Raycaster光线投射

Raycaster光线投射

3D虚拟工厂在线体验

描述

光线投射Raycaster,用于进行raycasting(光线投射)。 光线投射用于进行鼠标拾取(在三维空间中计算出鼠标移过了什么物体)。

构造器

Raycaster( origin : Vector3, direction : Vector3, near : Float, far : Float )

参数描述
origin光线投射的原点向量
direction向射线提供方向的方向向量,应当被标准化
near返回的所有结果比near远。near不能为负值,其默认值为0
far返回的所有结果都比far近。far不能小于near,其默认值为Infinity(正无穷)

这将创建一个新的raycaster对象。

属性

属性类型描述
.farFloatraycaster的远距离因数(投射远点)。这个值表明哪些对象可以基于该距离而被raycaster所丢弃。这个值不应当为负,并且应当比near属性大
.nearFloatraycaster的近距离因数(投射近点)。这个值表明哪些对象可以基于该距离而被raycaster所丢弃。这个值不应当为负,并且应当比far属性小
.cameraCamera当对依赖于视图的对象(如Sprites等广告牌对象)进行光线投射时使用的相机。可以手动设置,或在调用"setFromCamera"时设置。默认为null
.layersLayers用于在执行相交测试时有选择地忽略3D对象。raycaster.layers.set( 1 );object.layers.enable( 1 );
.paramsObject具有以下属性的对象:{ Mesh: {}, Line: { threshold: 1 }, LOD: {}, Points: { threshold: 1 }, Sprite: {} }。其中threshold是光线投射与对象相交时的精度,以世界单位为单位
.rayRay用于进行光线投射的Ray(射线)

方法

函数名参数描述返回值说明
.setorigin : Vector3光线投射的原点向量undefined使用新的原点和方向更新射线
direction : Vector3标准化方向向量
.setFromCameracoords : Vector2标准化设备坐标中的鼠标二维坐标(X/Y应在-1到1之间)undefined根据相机和屏幕坐标更新射线
camera : Camera射线来源的摄像机
.setFromXRControllercontroller : WebXRController要复制位置和方向的WebXR控制器this从XR控制器更新射线
.intersectObjectobject : Object3D要检测相交的3D对象Array<Intersection>检测射线与单个对象的相交情况
recursive : Boolean是否检测所有后代(默认true)返回相交结果数组,按距离排序
optionalTarget : Array(可选)目标数组容器
.intersectObjectsobjects : Array<Object3D>要检测的3D对象数组Array<Intersection>检测射线与多个对象的相交情况
recursive : Boolean是否检测所有后代(默认true)返回相交结果数组,按距离排序
optionalTarget : Array(可选)目标数组容器

Intersection 类型定义

interface Intersection {distance: number;        // 射线起点到交点的距离point: Vector3;          // 交点世界坐标face: Face3 | null;      // 相交的三角面对象(可能为null)faceIndex: number;       // 相交面的索引号object: Object3D;        // 被相交的3D对象uv: Vector2;             // 交点的UV纹理坐标uv1?: Vector2;           // (可选)交点的第二套UV坐标normal: Vector3;         // 交点处的插值法向量instanceId?: number;     // (可选)InstancedMesh实例的ID
}

I说明

  1. Three.js 通过多态机制(不同对象实现自己的 raycast)实现灵活的相交检测。Raycaster 不会直接计算相交,而是调用每个物体自己的 raycast 方法。不同几何体类型(Mesh/Line/Points)有各自不同的相交检测实现。Mesh 会检测三角面相交,Line 会检测线段邻近点,Points 会检测点云中的点,它们的相交计算逻辑和阈值判断都不同。
  2. 默认情况下,Three.js 只检测射线从正面(法线朝向射线原点的一面)穿过网格面的情况。如果射线从背面(法线背向的一面)穿过,在材质中设置 side: THREE.DoubleSide 可启用双面检测。

代码

const raycaster = new THREE.Raycaster();
const pointer = new THREE.Vector2();
function onPointerMove( event ) {// 将鼠标位置归一化为设备坐标。x 和 y 方向的取值范围是 (-1 to +1)pointer.x = ( event.clientX / window.innerWidth ) * 2 - 1;pointer.y = - ( event.clientY / window.innerHeight ) * 2 + 1;
}
function render() {// 通过摄像机和鼠标位置更新射线raycaster.setFromCamera( pointer, camera );// 计算物体和射线的焦点const intersects = raycaster.intersectObjects( scene.children );for ( let i = 0; i < intersects.length; i ++ ) {intersects[ i ].object.material.color.set( 0xff0000 );}renderer.render( scene, camera );
}
window.addEventListener( 'pointermove', onPointerMove );
window.requestAnimationFrame(render);

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

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

相关文章

初识Linux —— git三板斧

版本控制器git 为了我们方便管理不同版本的文件&#xff0c;就有了版本控制器&#xff1b; 所谓的版本控制器&#xff0c;就是能够了解到一个文件的历史记录&#xff08;修改记录&#xff09;&#xff1b;简单来说就是记录每一次的改动和版本迭代的一个管理系统&#xff0c;同…

用哈希表封装出unordered_set/_map

前提&#xff1a; ①&#xff1a;本博客是对哈希表(开散列)进行封装&#xff0c;因为闭散列不优秀(与库保持一致) ②&#xff1a;哈希表封装出unordered_set/_map和红黑树封装出ste/map是大同小异的&#xff0c;可以先看下&#xff1a;用红黑树封装出set和map -CSDN博客 ③&…

情绪ABC——AI与思维模型【93】

一、定义 情绪ABC思维模型是一种心理学上的理论&#xff0c;它认为人们的情绪和行为反应&#xff08;C&#xff0c;Consequence&#xff09;并非直接由激发事件&#xff08;A&#xff0c;Activating event&#xff09;引起&#xff0c;而是由个体对激发事件的认知和评价所产生…

Unity URP RenderTexture优化(二):深度图优化

目录 前言&#xff1a; 一、定位深度信息 1.1&#xff1a;k_DepthStencilFormat 1.2&#xff1a;k_DepthBufferBits 1.3&#xff1a;_CameraDepthTexture精度与大小 1.4&#xff1a;_CameraDepthAttachment数量 二、全代码 前言&#xff1a; 在上一篇文章&#xff1a;Un…

【力扣刷题记录】hot100错题本(一)

1. 简单题 我的答案&#xff1a;时间复杂度过高&#xff1a;O(N^3) class Solution:def twoSum(self, nums: List[int], target: int) -> List[int]:for num in nums:if (target - num) in nums:#多余for i in range(len(nums)):if nums[i] num :for j in range(i1,len(nu…

线程池的线程数配置策略

目录 1. CPU密集型任务 2. IO密集型任务 3. 混合型任务 1. CPU密集型任务 特点&#xff1a;任务主要消耗CPU资源&#xff08;如计算、加密、压缩&#xff09;。 推荐线程数&#xff1a; 线程数 ≈ 物理核心数 1 / CPU - 1&#xff08;不知道哪个√&#xff09; 例如&#…

基于开源链动2+1模式AI智能名片S2B2C商城小程序的爆品力构建研究

摘要&#xff1a;在兴趣电商生态中&#xff0c;爆品力已成为品牌实现指数级增长的核心竞争力。本文以开源链动21模式AI智能名片S2B2C商城小程序为技术载体&#xff0c;结合抖音平台的内容传播特性&#xff0c;提出“需求挖掘-技术赋能-内容转化”三位一体的爆品力构建模型。通过…

photoshop学习笔记2

第一章 第01节-界面的重要性(学习方法) 第02节-文件的打开新建及储存 第03节-移动工具(图层概念) 学习目标&#xff1a; 1.了解图层概念 2.认识工具属性 3.掌握工具使用 图层的概念 移动工具 移动工具就是用来移动图层内容的。是否可以用来移动组…

operator 可以根据需要重载 == 运算符进行比较

要将 vector<AppInfo> 类型的 A 和 B 两个容器进行比较&#xff0c;并且当 B 中有 A 中没有的元素时&#xff0c;插入到数据库中&#xff0c;你可以通过以下步骤实现&#xff1a; 比较元素&#xff1a;遍历 vector<B>&#xff0c;检查每个元素是否在 vector<A&…

Three.js在vue中的使用(二)-加载、控制

在 Vue 中使用 Three.js 加载模型、控制视角、添加点击事件是构建 3D 场景的常见需求。下面是一个完整的示例&#xff0c;演示如何在 Vue 单文件组件中实现以下功能&#xff1a; 使用 GLTFLoader 加载 .glb/.gltf 模型添加 OrbitControls 控制视角&#xff08;旋转、缩放、平移…

软件架构之旅(6):浅析ATAM 在软件技术架构评估中的应用

文章目录 一、引言1.1 研究背景1.2 研究目的与意义 二、ATAM 的理论基础2.1 ATAM 的定义与核心思想2.2 ATAM 涉及的质量属性2.3 ATAM 与其他架构评估方法的关系 三、ATAM 的评估流程3.1 准备阶段3.2 场景和需求收集阶段3.3 架构描述阶段3.4 评估阶段3.5 结果报告阶段 四、ATAM …

vue-chat 开源即时聊天系统web本地运行方法

官方文档 https://gitcode.com/gh_mirrors/vuechat7/vue-chat.git npm install 可能需要用 npm 下载两个包 "viewerjs": "^1.9.0", "vue-hot-reload-api": "^2.3.4", src\constant\index.js 改下面两行 export const LOGIN_API …

Rust与C/C++互操作实战指南

目录 1.前言2.动态库调用2.1 动态加载2.2 静态加载3.代码调用4.静态库调用1.前言 本文原文为:Rust与C/C++互操作实战指南 由于rust诞生时间太短,目前生态不够完善,因此大量的功能库都需要依赖于C、C++语言的历史积累。 而本文将要介绍的便是如何实现rust与c乃至c++之间实…

ppt设计美化公司_杰青_长江学者_优青_青年长江学者_万人计划青年拔尖人才答辩ppt模板

WordinPPT / 持续为双一流高校、科研院所、企业等提供PPT制作系统服务。 / 近期PPT美化案例 - 院士增选、科学技术奖、杰青、长江学者特聘教授、校企联聘长江、重点研发、优青、青长、青拔.. 杰青&#xff08;杰出青年科学基金&#xff09; 支持已取得突出成果的45岁以下学…

修复笔记:SkyReels-V2 项目中的 torch.load 警告

#工作记录 一、问题描述 在运行项目时&#xff0c;出现以下警告&#xff1a; FutureWarning: You are using torch.load with weights_onlyFalse (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pic…

GNOME扩展:Bing壁纸

难点 网络请求(Soup) 下载文件(Soup) 读写设置(Gio.Settings) 源码 import GLib from "gi://GLib"; import Gio from gi://Gio; import St from gi://St; import Soup from gi://Soup;import { Extension } from resource:///org/gnome/shell/extensions/extens…

计算机视觉综合实训室解决方案

一、引言 在当今科技飞速发展的时代&#xff0c;计算机视觉作为人工智能领域的核心技术之一&#xff0c;正以前所未有的速度改变着我们的生活和工作方式。从智能手机中的人脸识别解锁&#xff0c;到自动驾驶汽车对道路和障碍物的精准识别&#xff1b;从安防监控系统中的智能视…

C++23 std::tuple与其他元组式对象的兼容 (P2165R4)

文章目录 引言C23 std::tuple概述std::tuple的定义和基本用法std::tuple的特性std::tuple的应用场景 其他元组式对象的特点Python元组的特点Python元组与C std::tuple的对比 P2165R4提案的具体内容提案背景提案主要内容提案的影响 兼容性示例代码总结 引言 在C编程的世界里&am…

Go语言:协程调度器GPM模型深度解析

一、GPM模型概述 Go语言的并发模型是其最强大的特性之一,而这一切的核心就是GPM调度模型。让我们用一个生活中的例子来理解: 想象你经营着一家快递公司: G(Goroutine):就像一个个待配送的包裹P(Processor):就像是你公司的配送站,负责组织配送工作M(Machine):就像…