- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用从激光雷达收到的 3D 点云进行研究。我将大量点(最多 10 - 1 亿个)分割成立方体,研究它们的位置并使用 Axes3D.voxels
方法在单独的体素中显示结果。但是,在多次使用此方法后,我在设置 Axes3D
的适当限制时遇到了一些问题。
我定义了add_voxels
函数,以便立即从输入的立方体位置的np.array
中显示体素:
import numpy as np
import matplotlib.pyplot as plt
from mpl_toolkits.mplot3d import Axes3D
import itertools
def add_voxels(true_ids, ax):
shape_of_filled = true_ids.max(axis=0) + 1 # shape of building
filled = np.zeros(shape_of_filled)
for n in true_ids:
filled[n] = 1
x, y, z = np.indices(np.array(shape_of_filled) + 1)
return ax.voxels(x,y,z, filled)```
Then use it to plot my two clouds of cubes:
fig = plt.gcf() # get a reference to the current figure instance
ax = fig.gca(projection='3d') # get a reference to the current axes instance
cubecloud1 = np.array(list(itertools.product(range(2,4), range(2,4), range(2,4))))
cubecloud2 = np.array(list(itertools.product(range(4,7), range(4,7), range(4,7))))
add_voxels(cubecloud2, ax)
add_voxels(cubecloud1, ax)
plt.show()
这会导致体素位置的显示出现错误的限制:
我希望所有组件都显示在正确的边界框中,如下所示:
或者,至少,这个(假设边界框也包含不可见的体素):
最佳答案
我只能通过明确设置轴限制来完成这项工作:
# [...]
faces2 = add_voxels(cubecloud2, ax)
faces1 = add_voxels(cubecloud1, ax)
points = list(faces1.keys()) + list(faces2.keys())
data = list(zip(*points))
xmin = min(data[0])
xmax = max(data[0])
ymin = min(data[1])
ymax = max(data[1])
zmin = min(data[2])
zmax = max(data[2])
ax.set_xlim3d(xmin, xmax)
ax.set_ylim3d(ymin, ymax)
ax.set_zlim3d(zmin, zmax)
plt.show()
关于python - 如何在 python 中多次使用 ax.voxels 方法后修复限制,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57527709/
我正在尝试为我的体素游戏生成 10*10*10 block block ,渲染 1 block 完全没问题,但是当我使用 for 循环时,它会变得困惑,以下正确吗?: final int ch
我正在尝试使用 matplotlib 来显示一些 3d 柏林噪音。我读过 Axes3DSubplot 中的 voxels 方法可用于简单地显示值。但是,当我尝试调用 ax.voxels(voxels,
有一个关于我的体素引擎的问题。从现在开始,我基本上是在最大限度地发挥我的发动机的性能,它已经变得非常出色,有时能够达到600fps,但有一个问题,我已经被困了一周,这有点糟糕。。所以就像我之前说的那样
我正在学习 JavaScript,因为我最终想制作体素游戏(如《我的世界》类型风格)。有人告诉我要使用 WebGL,但我见过很多使用 voxel.js 的 Minecraft 类型游戏的示例。 那么我
我正在使用从激光雷达收到的 3D 点云进行研究。我将大量点(最多 10 - 1 亿个)分割成立方体,研究它们的位置并使用 Axes3D.voxels 方法在单独的体素中显示结果。但是,在多次使用此方法
我正在尝试实现本文中解释的算法,用于按照直线顺序遍历网格单元,这对光线追踪很有用: http://www.cse.yorku.ca/~amana/research/grid.pdf 论文将算法描述为两
我是一名优秀的程序员,十分优秀!