- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试选择一个 3d 点。我阅读了各种网站,但我的代码不起作用。
鼠标右键点击:
glGetFloatv(GL_MODELVIEW_MATRIX,mv_mat)
glGetFloatv(GL_PROJECTION_MATRIX,p_mat)
ip_mat = np.linalg.inv(mat4(p_mat))
# clip = array[
# (2*x)/window_width-1
# 1-(y*2)/window.height
# -1
# 1
camera_coord = np.dot(ip_mat,clip)
camera_coord = np.array([camera_coord[0,0],camera_coord[0,1],-1,0])
imv_mat = np.linalg.inv(mat4(mv_mat))
ray_world = np.dot(imv_mat,camera_coord)
ray_world = np.array([ray_world[0],ray_world[1],ray_world[2]])
ray_world = ray_world/np.linalg.norm(ray_world)
Intersect_sphere 函数:
v = np.array([model.rx,model.ry,model.rz]) - np.array([-0.5, 0.5, 0])
b = 2 * np.dot(v, ray_world)
c = np.dot(v, v) - 1 * 1
delta = b * b - 4 * c
if (delta > 0):
print('select')
return True
return False
编辑:我发现了一个拼写错误。即使更改代码后仍然无法正常工作。
最佳答案
如果要在窗口中选取一个点,则必须将窗体坐标转换为世界坐标或对象坐标。
要将窗口坐标映射到对象坐标,gluUnProject
可以使用。gluUnProject
的参数属于 GLdouble
类型。
为投影矩阵和 GLdouble
类型的 View 矩阵创建一个数组,为视口(viewport)矩形创建一个 GLint
类型的数组:
self.mv_mat = (GLdouble * 16)()
self.p_mat = (GLdouble * 16)()
self.v_rect = (GLint * 4)()
获取当前投影矩阵、模型 View 矩阵和视口(viewport)矩形:
glGetDoublev(GL_MODELVIEW_MATRIX, self.mv_mat)
glGetDoublev(GL_PROJECTION_MATRIX, self.p_mat)
glGetIntegerv(GL_VIEWPORT, self.v_rect)
在视口(viewport)上绘制了 3 维场景的 2 维(透视)投影。场景是从一个点看的,即摄像机位置。要找到在窗口中“拾取”的对象,您必须找到对象所在的视线。一条射线由 2 个点定义。找到一个靠近相机的点和一个远离场景深度的点,它们位于“拾取”的窗口位置上以定义光线。拾取的对象是距离相机最近的那个对象。在标准化设备空间中,从相机位置看,所有具有相同 x 和 y 坐标的点都在同一条射线上。
一个点在窗口空间中的第一个和第二个坐标是像素中的 x 和 y 坐标,第三个坐标是 [0, 1] 范围内的深度。
因此,从相机附近到远处深度的光线槽坐标 (x,y) 由 2 个点 p0 和 p1 定义,其中:
p0 = (x, y, 0)
p1 = (x, y, 1)
这个点必须通过 gluUnProject
转换 2 个世界空间:
ray_near = [GLdouble() for _ in range(3)]
ray_far = [GLdouble() for _ in range(3)]
gluUnProject(x, y, 0, mv_mat, p_mat, v_rect, *ray_near)
gluUnProject(x, y, 1, mv_mat, p_mat, v_rect, *ray_far)
如果从球体中心点到射线上最近点的距离小于或等于球体半径,则射线与球体相交。
计算射线的归一化方向:
p0 = [v.value for v in ray_near]
p1 = [v.value for v in ray_far]
r_dir = np.subtract(p0, p1)
r_dir = r_dir / np.linalg.norm(r_dir)
计算射线上离球体中心点最近的点:
p0_cpt = np.subtract(p0, cpt)
near_pt = np.subtract(p0, r_dir * np.dot(p0_cpt, r_dir))
计算射线上的点到中心点的距离:
dist = np.linalg.norm(np.subtract(near_pt, cpt))
如果距离小于或等于球体的半径,则光线射中球体:
isIntersecting = dist <= radius
见短PyGlet示例:
from pyglet.gl import *
from pyglet.window import key
import numpy as np
class Window(pyglet.window.Window):
def __init__(self, *args, **kwargs):
super().__init__(*args, **kwargs)
self.sphere = gluNewQuadric()
self.vp_valid = False
self.mouse_pos = (0, 0)
self.mv_mat = (GLdouble * 16)()
self.p_mat = (GLdouble * 16)()
self.v_rect = (GLint * 4)()
def on_resize(self, width, height):
self.vp_valid = False
def isectSphere(self, p0, p1, cpt, radius):
# normalized ray direction
r_dir = np.subtract(p0, p1)
r_dir = r_dir / np.linalg.norm(r_dir)
# nearest point on the ray to the sphere
p0_cpt = np.subtract(p0, cpt)
near_pt = np.subtract(p0, r_dir * np.dot(p0_cpt, r_dir))
# distance to center point
dist = np.linalg.norm(np.subtract(near_pt, cpt))
# intersect if dist less or equal the radius of the sphere
return dist <= radius
def on_draw(self):
if not self.vp_valid:
self.vp_valid = True
glViewport(0, 0, self.width, self.height)
glMatrixMode(GL_PROJECTION)
glLoadIdentity()
gluPerspective(45, self.width/self.height, 0.1, 50.0)
glMatrixMode(GL_MODELVIEW)
glLoadIdentity()
gluLookAt(0, -8, 0, 0, 0, 0, 0, 0, 1)
glGetDoublev(GL_MODELVIEW_MATRIX, self.mv_mat)
glGetDoublev(GL_PROJECTION_MATRIX, self.p_mat)
glGetIntegerv(GL_VIEWPORT, self.v_rect)
temp_val = [GLdouble() for _ in range(3)]
gluUnProject(*self.mouse_pos, 0, self.mv_mat, self.p_mat, self.v_rect, *temp_val)
self.mouse_near = [v.value for v in temp_val]
gluUnProject(*self.mouse_pos, 1, self.mv_mat, self.p_mat, self.v_rect, *temp_val)
self.mouse_far = [v.value for v in temp_val]
isect_a = self.isectSphere(self.mouse_near, self.mouse_far, [-1.5, 0, 0], 1)
isect_b = self.isectSphere(self.mouse_near, self.mouse_far, [1.5, 0, 0], 1)
glEnable(GL_DEPTH_TEST)
glEnable(GL_LIGHTING)
glShadeModel(GL_SMOOTH)
glEnable(GL_COLOR_MATERIAL)
glColorMaterial(GL_FRONT_AND_BACK, GL_AMBIENT_AND_DIFFUSE)
glEnable(GL_LIGHT0)
glLightfv(GL_LIGHT0, GL_AMBIENT, (GLfloat *4)(0.1, 0.1, 0.1, 1))
glLightfv(GL_LIGHT0, GL_DIFFUSE, (GLfloat *4)(1.0, 1.0, 1.0, 1))
glLightfv(GL_LIGHT0, GL_POSITION, (GLfloat *4)(0, -1, 0, 0))
glClear(GL_COLOR_BUFFER_BIT|GL_DEPTH_BUFFER_BIT)
glPushMatrix()
glTranslatef(-1.5, 0, 0)
if isect_a:
glColor4f(1.0, 0.5, 0.5, 1)
else:
glColor4f(0.5, 0.2, 0.2, 1)
gluSphere(self.sphere, 1.0, 32, 16)
glTranslatef(3, 0, 0)
if isect_b:
glColor4f(0.5, 0.5, 1.0, 1)
else:
glColor4f(0.2, 0.2, 0.5, 1)
gluSphere(self.sphere, 1.0, 32, 16)
glPopMatrix()
def on_mouse_motion(self,x,y,dx,dy):
self.mouse_pos = (x, y)
if __name__ == "__main__":
window = Window(width=800, height=600, resizable=True)
pyglet.app.run()
关于python - 射线相交未命中目标,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48722899/
我创建了一个基于命令行可移植脚本的工业化不可知构建系统,可用于快速构建多个依赖项目,而不必依赖特定的 IDE 或构建工厂。它是不可知的,因为它不是基于单个构建引擎。我使用 cmake 创建了第一个版本
我最初使用 Java 目标开发了一个语法(用于 TestRig 支持),然后将其移植到 Python(从 git hub 语法存储库扩展了 Python3 语法,因此需要将操作移植到 Python
我有一个以 iPhone 和 watchOS 为目标的 Xcode 项目。 iPhone 目标使用加速度计,模拟器不支持。我可以只启动 iPhone 应用程序而不启动 watch 目标吗?我从: Ca
您好,我想创建一个批处理文件,用于在 .eml 文件(目标 A)中查找某些关键字,然后删除它们所在的行。之后,我需要批处理文件将"new"文件放入(目标 B)中的单独 .eml 文件中。文件也可以是
当尝试通过 IntelliJ 运行示例 CorDapp (GitHub CorDapp) 时,我收到以下错误: Cannot inline bytecode built with JVM target
我在尝试向我的 kotlin spring 项目添加一些依赖项时遇到问题。我使用 spring boot 初始化程序来运行一个基本项目。 我的问题:如果我取消对 jackson 或 Koin 依赖项的
这是有问题的网站: http://www.onepixelroom.com/londonrefurb 当我点击关于部分后面的多个圆圈时,我希望它更改上面文本中的引号。 到目前为止,我得到它来显示 文本
单击后,我将删除两个元素 $(this) 和 $("#foo")。 目前我的代码如下所示: $(this).remove(); $("#foo").remove(); 如何在不重复自己的情况下优化它?
我有一个小脚本,可将 Markdown 文件编译为 html,并将其与一些样式表和 javascript 一起插入到模板的主体中。我有一个 GNU makefile 来完成这个: output.htm
已关闭。此问题需要 debugging details 。目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and the
一些背景知识: 在android中我们开发了同样的应用,基本上我们先开发了Android应用,现在我们创建了它的IOS版本,所以这个应用有多个客户端。在 android 中,我们实际上是使用 Andr
我想知道是否可以使用 knockout 来更改html中的目标() 我的所有其他信息都在 JavaScript 中,所以这对我来说是一个大问题。这是我的 JavaScript: var library
这个问题在这里已经有了答案: Selecting and manipulating CSS pseudo-elements such as ::before and ::after using j
我在我的有向图中添加了一堆节点和顶点,使用设置 typedef boost::adjacency_list graph; 创建 Node有一个节点名称字符串,Edge它的分数有一个整数。我试图遍历所有
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎与 help center 中定义的范围内的编程无关。 . 关闭 8 年前。 Improve
如何存储我在 NSUserDefaults 中创建的 Goal 类型的对象数组? ( swift ) 代码如下: func saveGoalList ( newGoalList : [Goal] ){
Array.prototype.indexOf 和 Date.now 已在 ES5 中引入。如果我编译存储在文件 test.ts 中的以下代码,为什么 Typescript 不能转译? Date.no
我正在阅读有关属性的内容,并了解到可以使用您的代码将它们应用于不同的目标实体 -(请参阅 Attribute Targets)。 因此,查看我项目中的 AssemblyInfo.cs 文件,我可以看到
给定一个 Makefile: all: build/a build/b build/c # need to change this to all: build/* build/a:
我有一个带有多框架目标的项目- netstandard2.0;net471 . 我想为 netframework 构建解决方案和 netstandard分别。 目前我使用这个 MSBuild 命令:
我是一名优秀的程序员,十分优秀!