c++ - 寻找立方体顶点的优雅方式

标签 c++ algorithm opengl cube vertices

几乎每个 OpenGL 教程都会让您实现绘制立方体。因此需要立方体的顶点。在示例代码中,我看到了一个定义每个顶点的长列表。但我想计算立方体的顶点,而不是使用超长的预先计算坐标列表。

一个立方体由八个顶点和十二个三角形组成。顶点由 x、y 和 z 定义。三角形分别由三个顶点的索引定义。

有没有一种优雅的方法来计算顶点和 element多维数据集的索引?

最佳答案

当我“移植”csg.js 时项目到 Java 我发现了一些可爱的代码,可以生成具有选定中心点和半径的立方体。 (我知道这是 JS,但无论如何)

// Construct an axis-aligned solid cuboid. Optional parameters are `center` and
// `radius`, which default to `[0, 0, 0]` and `[1, 1, 1]`. The radius can be
// specified using a single number or a list of three numbers, one for each axis.
// 
// Example code:
// 
//     var cube = CSG.cube({
//       center: [0, 0, 0],
//       radius: 1
//     });
CSG.cube = function(options) {
  options = options || {};
  var c = new CSG.Vector(options.center || [0, 0, 0]);
  var r = !options.radius ? [1, 1, 1] : options.radius.length ?
           options.radius : [options.radius, options.radius, options.radius];
  return CSG.fromPolygons([
    [[0, 4, 6, 2], [-1, 0, 0]],
    [[1, 3, 7, 5], [+1, 0, 0]],
    [[0, 1, 5, 4], [0, -1, 0]],
    [[2, 6, 7, 3], [0, +1, 0]],
    [[0, 2, 3, 1], [0, 0, -1]],
    [[4, 5, 7, 6], [0, 0, +1]]
  ].map(function(info) {
    return new CSG.Polygon(info[0].map(function(i) {
      var pos = new CSG.Vector(
        c.x + r[0] * (2 * !!(i & 1) - 1),
        c.y + r[1] * (2 * !!(i & 2) - 1),
        c.z + r[2] * (2 * !!(i & 4) - 1)
      );
      return new CSG.Vertex(pos, new CSG.Vector(info[1]));
    }));
  }));
};

关于c++ - 寻找立方体顶点的优雅方式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13953476/

相关文章:

java - 快速排序算法一旦第一个枢轴位于数组中的最终位置,下一步是什么?

生成唯一(可能自动递增)ID 的算法

algorithm - 图像移动标定

java - 调用 glTexImage2D 清除数据缓冲区

c++ - 用于序列化的 DOM 或 SAX

C++模板模板

c++ - 如何旋转模型以跟随路径

opengl - 更新统一缓冲区对象会降低性能吗?

c++ - 嵌套 boost::variant 的段错误

c++ - 如何遍历字符串中的每个字符?