当前位置: 首页>>代码示例>>C++>>正文


C++ BBox::extend方法代码示例

本文整理汇总了C++中BBox::extend方法的典型用法代码示例。如果您正苦于以下问题:C++ BBox::extend方法的具体用法?C++ BBox::extend怎么用?C++ BBox::extend使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在BBox的用法示例。


在下文中一共展示了BBox::extend方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1:

BBox LWObject::Face::getBBox() const
{

	BBox ret = BBox::empty();
	ret.extend(m_lwObject->vertices[vert1]);
	ret.extend(m_lwObject->vertices[vert2]);
	ret.extend(m_lwObject->vertices[vert3]);

	return ret;
}
开发者ID:Ollix3112,项目名称:cg1213rc,代码行数:10,代码来源:lwobject_primitive.cpp

示例2: build

//An iterative split in the middle build for BVHs
void BVH::build(const std::vector<Primitive*> &_objects)
{
    std::vector<BBox> objectBBoxes(_objects.size());

    BuildStateStruct curState;
    curState.centroidBBox = BBox::empty();

    std::vector<CentroidWithID> centroids(objectBBoxes.size());

    for(size_t i = 0; i < objectBBoxes.size(); i++)
    {
        objectBBoxes[i] = _objects[i]->getBBox();

        centroids[i].centroid = objectBBoxes[i].min.lerp(objectBBoxes[i].max, 0.5f);
        centroids[i].origIndex = i;
        curState.centroidBBox.extend(centroids[i].centroid);
    }

    curState.segmentStart = 0;
    curState.segmentEnd = objectBBoxes.size();
    curState.nodeIndex = 0;
    m_nodes.resize(1);

    std::stack<BuildStateStruct> buildStack;

    const float _EPS = 0.0000001f;

    for(;;)
    {

        size_t objCnt = curState.segmentEnd - curState.segmentStart;
        Vector boxDiag = curState.centroidBBox.diagonal();

        int splitDim = boxDiag.x > boxDiag.y ? (boxDiag.x > boxDiag.z ? 0 : 2) : (boxDiag.y > boxDiag.z ? 1 : 2);

        if(fabs(boxDiag[splitDim]) < _EPS || objCnt < 3)
        {
            //Create a leaf
            const size_t NODE_TYPE_MASK = ((size_t)1 << Node::LEAF_FLAG_BIT);
            m_nodes[curState.nodeIndex].bbox = BBox::empty();
            m_nodes[curState.nodeIndex].dataIndex = m_leafData.size() | NODE_TYPE_MASK;

            for(size_t i = curState.segmentStart; i < curState.segmentEnd; i++)
            {
                m_nodes[curState.nodeIndex].bbox.extend(objectBBoxes[centroids[i].origIndex]);
                m_leafData.push_back(_objects[centroids[i].origIndex]);
            }

            m_leafData.push_back(NULL);

            if(buildStack.empty())
                break;

            curState = buildStack.top();
            buildStack.pop();

            continue;
        }

        float splitVal = (curState.centroidBBox.min[splitDim] + curState.centroidBBox.max[splitDim]) / 2.f;
        size_t leftPtr = curState.segmentStart, rightPtr = curState.segmentEnd - 1;

        BBox nodeBBox = BBox::empty();
        BuildStateStruct rightState;
        curState.centroidBBox = BBox::empty();
        rightState.centroidBBox = BBox::empty();

        while(leftPtr < rightPtr)
        {
            while(leftPtr < curState.segmentEnd && centroids[leftPtr].centroid[splitDim] <= splitVal)
            {
                curState.centroidBBox.extend(centroids[leftPtr].centroid);
                nodeBBox.extend(objectBBoxes[centroids[leftPtr].origIndex]);
                leftPtr++;
            }

            while(rightPtr >= curState.segmentStart && centroids[rightPtr].centroid[splitDim] > splitVal)
            {
                rightState.centroidBBox.extend(centroids[rightPtr].centroid);
                nodeBBox.extend(objectBBoxes[centroids[rightPtr].origIndex]);
                rightPtr--;
            }

            if(leftPtr >= rightPtr)
                break;

            std::swap(centroids[leftPtr], centroids[rightPtr]);
        }

        m_nodes[curState.nodeIndex].bbox = nodeBBox;
        m_nodes[curState.nodeIndex].dataIndex = m_nodes.size();

        _ASSERT(leftPtr > curState.segmentStart && leftPtr < curState.segmentEnd);
        _ASSERT(leftPtr == rightPtr + 1);

        rightState.segmentStart = leftPtr;
        rightState.segmentEnd = curState.segmentEnd;
        curState.segmentEnd = leftPtr;
        curState.nodeIndex = m_nodes.size();
//.........这里部分代码省略.........
开发者ID:Ollix3112,项目名称:cg1213rc,代码行数:101,代码来源:bvh.cpp


注:本文中的BBox::extend方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。