本文整理汇总了C++中VoxelGrid::numVoxels方法的典型用法代码示例。如果您正苦于以下问题:C++ VoxelGrid::numVoxels方法的具体用法?C++ VoxelGrid::numVoxels怎么用?C++ VoxelGrid::numVoxels使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类VoxelGrid
的用法示例。
在下文中一共展示了VoxelGrid::numVoxels方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: runTest
bool VoxelmapTest::runTest()
{
std::vector<bool> testResults;
{
{
// Basic Test, simple grid.
std::vector<float> boxVert;
std::vector<size_t> boxInd;
makeBoxVertexIndices(Vector3(1.2f), Vector3(0.0f), boxVert, boxInd);
float voxelWidth = 1.0f; // With box size 1.2f, we should have center voxel empty, but immediately surrounded voxels full.
{
VoxelGrid* resultGrid = VoxelGridFactory::generateVoxelGridFromMesh((const float*)&boxVert[0], boxVert.size() / 3, &boxInd[0], boxInd.size() / 3, voxelWidth);
int numVoxels = resultGrid->numVoxels();
bool hasCorrectNumEntries = numVoxels == 26; //27 - 1 [This test is set up so that the central box is empty]
assert(hasCorrectNumEntries);
testResults.push_back(hasCorrectNumEntries);
}
{
// Add another box around 4.0, 4.0, 4.0
makeBoxVertexIndices(Vector3(1.2f), Vector3(4.0f), boxVert, boxInd);
VoxelGrid* resultGrid = VoxelGridFactory::generateVoxelGridFromMesh((const float*)&boxVert[0], boxVert.size() / 3, &boxInd[0], boxInd.size() / 3, voxelWidth);
int numVoxels = resultGrid->numVoxels();
bool hasCorrectNumEntries = numVoxels == 52; //27 - 1 [This test is set up so that the central box is empty]
assert(hasCorrectNumEntries);
testResults.push_back(hasCorrectNumEntries);
}
}
{
// Finer grid test
// Basic Test, simple grid.
std::vector<float> boxVert;
std::vector<size_t> boxInd;
makeBoxVertexIndices(Vector3(1.2f), Vector3(0.0f), boxVert, boxInd);
float voxelWidth = 0.2f; // With box size 1.2f, we should have center voxel empty, but immediately surrounded voxels full.
{
VoxelGrid* resultGrid = VoxelGridFactory::generateVoxelGridFromMesh((const float*)&boxVert[0], boxVert.size() / 3, &boxInd[0], boxInd.size() / 3, voxelWidth);
int numVoxels = resultGrid->numVoxels();
bool hasCorrectNumEntries = numVoxels == 7 * 7 * 7 - 5 * 5 * 5;
assert(hasCorrectNumEntries);
testResults.push_back(hasCorrectNumEntries);
}
}
}
for (auto testResult : testResults)
{
if (!testResult)
{
return false;
}
}
return true;
}