threejs对象拾取

对象拾取

对象拾取也就是要获得鼠标事件发生位置的图形对象。在threejs中,是通过Raycaster 对象来拾取对象的,ray是射线,caster是投射器,从字面上即可理解其工作原理是:从某个方向发射一条射线,穿过鼠标所在的点,则这条射线经过的对象就是鼠标点击的对象。示例如下:

let raycaster = new THREE.Raycaster();
let mouse = new THREE.Vector2();
function pickupObjects(e){//将鼠标点击位置的屏幕坐标转成threejs中的标准坐标mouse.x = (e.clientX/window.innerWidth)*2 -1;mouse.y = -(e.clientY/window.innerHeight)*2 + 1;//从相机发射一条射线,经过鼠标点击位置raycaster.setFromCamera(mouse,camera);//计算射线相机到的对象,可能有多个对象,因此返回的是一个数组,按离相机远近排列let intersects = raycaster.intersectObjects(scene.children);for ( var i = 0; i < intersects.length; i++ ) {intersects[ i ].object.material.color.set( 0x00ff00 );}
}

下面分析一下例子的代码,先看看鼠标点击位置的坐标转换:

mouse.x = (e.clientX/window.innerWidth)*2 -1;
mouse.y = -(e.clientY/window.innerHeight)*2 + 1;

为什么这样就能得到threejs的标准坐标?下面是我写的一个推导过程:

把上面的x1换成e.clientX,把y1换成e.clientY,就可以得到例子中的式子了。所以,当threejs的屏幕宽度并不是window.innerWidth时,也要记得根据实际从新推导。

其它并不复杂,可以参考一下Raycaster对象的文档,看看这些方法的说明。

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

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

相关文章

android webview权限申请_android - 在运行时向摄像机请求WebView权限 - 堆栈内存溢出...

我想在Android WebView的PWA中使用QR码扫描仪。PWA在chrome浏览器上可以正常工作。我确实有在“应用程序”->“应用程序名称”->“权限”下设置摄像机的权限minSdkVersion 26和targetSdkVersion 28在装有Android 9的华为手机上测试问题是似乎没有授予该权限。 另外&#…

threejs指定对象旋转中心

指定对象旋转中心 默认情况下&#xff0c;对象的旋转中心都是自身的中心。对于组对象而言&#xff0c;也是如此。因此&#xff0c;可以利用这个特点&#xff0c;实现对象绕任何点旋转&#xff0c;也就是指定旋转中心。比如我们想要下图的对象绕A点旋转 我们可以添加我们的对…

threejs设置对象层次

设置层次 threejs提供了层次的支持。和相机处于同一层次的对象可见&#xff0c;否则不可见。在threejs中&#xff0c;最多可以设置32层&#xff0c;默认的层次是1。层次在有些系统中很有用&#xff0c;可以将不同的模式的对象设成不同的层次&#xff0c;这样&#xff0c;切换模…

法那科机器人初始化启动_发那科机器人的控制方式和控制柜的启动方式

工业机器人能得到广泛应用&#xff0c;得益于它拥有有多种控制方式&#xff0c;按作业任务的不同&#xff0c;可主要分为点位控制方式、连续轨迹控制方式、力(力矩)控制方式和智能控制方式四种控制方式。1.点位控制方式(PTP)这种控制方式只对工业机器人末端执行器在作业空间中某…

Text段、Data段和BSS段

不同的compiler在编译的过程中对于存储的分配可能略有不同&#xff0c;但基本结构大致相同。 大体上可分为三段&#xff1a;Text段、Data段和BSS段。 text段用于存放代码&#xff0c;通常情况下在内存中被映射为只读&#xff0c;但data和bss是可写的。 数据存放通常分成如下几个…

threejs渲染器剔除模式

渲染器剔除模式 渲染器可以设置成舍弃某些面&#xff0c;如前面、背面等&#xff0c;在【WebGLRenderer Constants】中对此有说明。默认情况下&#xff0c;是剔除掉背面&#xff0c;也就是背对着相机的面。下面看看例子&#xff1a; 首先创建一个正方形&#xff0c;给每个面不…

扫地机器人测评云鲸_云鲸科技,J1测评

云鲸科技&#xff0c;J1测评2020-01-07 16:27:393点赞5收藏11评论9月30日 - 11月10日&#xff0c;能省会花&#xff0c;值友当家&#xff01;参与#我的省钱绝活#征稿活动&#xff0c;分享你的省钱绝活&#xff01;发文就有100金币&#xff0c;千元京东卡等你来拿&#xff01;点…

XVI Open Cup named after E.V. Pankratiev. GP of Eurasia

A. Nanoassembly 首先用叉积判断是否在指定向量右侧&#xff0c;然后解出法线与给定直线的交点&#xff0c;再关于交点对称即可。 #include<bits/stdc.h> using namespace std; const int Maxn300020; typedef long long LL; typedef pair<int,int>pi; struct P{do…

threejs向量夹角和夹角方向

计算向量的夹角 计算向量的夹角&#xff1a; v1 new THREE.Vector3(5,0,0); v2 new THREE.Vector3(5,5,0); v1.angleTo(v2); //0.7853981633974484 v2.angleTo(v1); //0.7853981633974484可见&#xff0c;向量的夹角是没有方向的。但是有时候&#xff0c;又需要计算夹角的…

web版本 开源压测工具_siege--Web性能压测工具

-V, --version VERSION, prints the version number.-h, --help HELP, prints this section.-C, --config CONFIGURATION, show the current config.//显示当前的默认装置-v, --verbose VERBOSE, prints notification to screen.//详细通知打印到屏幕&#xff0c;输…

threejs路径

路径 引用百度百科的解释&#xff1a; 路径通常指存在于多种计算机图形设计软件中的以贝塞尔曲线为理论基础的区域绘制方式。路径在Canvas、SVG上都有相关定义&#xff0c;一般用来创建形状。在threejs中&#xff0c;也可以用来创建形状&#xff0c;除此之外&#xff0c;还可…

OpenGL ES 纹理设置

纹理过滤纹理采样最近点采样线性纹理采样MIPMAP纹理纹理过滤 纹理拉伸&#xff1a;重复拉伸和截取拉伸 用于指定纹理坐标超过(00.0,1.0)范围时所发生的行为&#xff0c;使用glTexParameterf函数指定&#xff0c;GL_TEXTURE_WRAP_S 定义 s 坐标超出范围[0.0, 1.0]的情况&#xf…

安装kubernetes dashboard时开发环境,运行gulp local-up-cluster任务一直显示wating for a heapster

问题 按照官方教程搭建dashboard的开发环境&#xff0c;运行“gulp local-up-cluster”任务&#xff0c;一直不断显示“waiting for a heapster…”&#xff0c;日志如下&#xff1a; ... [16:37:22] Finished spawn-cluster after 670 ms ... [16:37:22] Finished wait-for-…

react做h5 例子_使用React写一个网站的心得体会

网站是毕业设计的作品&#xff0c;开发这个网站的目的主要用于记录一些笔记&#xff0c;以及聚合一些资讯信息&#xff0c;也算自己在网络世界中的一块静地吧&#xff0c;可以在这里一些技术上想法的实践。网站最初前端使用vue开发&#xff0c;在前段时间由于项目的开发进度已经…

linux命令小常识

作为一个tester我们必须要会linux,也许你会说不用也可以。那么我想问,你部署测试环境在哪里&#xff0c;你下载war包并部署war包呢&#xff0c;你看日志在哪里&#xff1f; 基于测试需要用到liunx&#xff0c;我这里只针对需要用到的&#xff0c;工作就是不断在探索中学习&…

ubuntu联网不稳定,时断时连问题的解决办法

概览 ubuntu联网不稳定&#xff0c;时断时连问题的解决办法现象网络一会儿连上&#xff0c;过一会又自动断开&#xff0c;再等一会儿又断了。问题原因可能是受ipv6的影响解决办法关闭掉ipv6 详细步骤 1、编辑连接&#xff0c;打开“ipv6 settings”&#xff0c;将method设置…

如何根据原理图画封装_常用原理图封装

原理图常用库文件&#xff1a;Miscellaneous Devices.ddbDallas Microprocessor.ddbIntel Databooks.ddbProtel DOS Schematic Libraries.ddbPCB元件常用库&#xff1a;Advpcb.ddbGeneral IC.ddbMiscellaneous.ddb分立元件库部分 分立元件库元件名称及中英对照AND 与门ANTENNA …

搭建GitLab+Jenkins持续集成环境图文教程

GitLab是一个代码仓库&#xff0c;用来管理代码。Jenkins是一个自动化服务器&#xff0c;可以运行各种自动化构建、测试或部署任务。所以这两者结合起来&#xff0c;就可以实现开发者提交代码到GitLab&#xff0c;Jenkins以一定频率自动运行测试、构建和部署的任务&#xff0c;…

随笔-1031

随笔1030 学习第四天 样式表的样式 一、大小宽度width高度height 二、背景1.background-color 背景色2.background-image 背景图片3.background-repeat&#xff1a;no-repeat 背景图的平铺方式4.background-position 背景图的位置 center等5.background-attachment 背景图是否滚…

exception日志 php_PHP 错误与异常的日志记录

提到 Nginx PHP 服务的错误日志&#xff0c;我们通常能想到的有 Nginx 的 access 日志、error 日志以及 PHP 的 error 日志。虽然看起来是个很简单的问题&#xff0c;但里面其实又牵扯到应用配置以及日志记录位置的问题&#xff0c;如果是在 ubuntu 等系统下使用 apt-get 的方…