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


C++ AABB::calculate方法代码示例

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


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

示例1: wrap

void Batch::Sector::forAllInstancesInAABB(Geometry* geometryLod0, Matrix* instances, AABB* aabb, engine::IBatchCallback callback, void* data)
{
    if( ::intersectionAABBAABB( &boundingBox, aabb ) )
    {
        if( !left && !right )
        {
            AABB instanceAABB;
            Matrix4f instanceMatrix;
            unsigned int index;
            for( unsigned int i=0; i<numIndices; i++ )
            {
                index = indices[i];
                instanceAABB.calculate( geometryLod0->getBoundingBox(), instances + index );
                if( ::intersectionAABBAABB( &instanceAABB, aabb ) )
                {
                    instanceMatrix = wrap( instances[index] );
                    callback( index, &instanceMatrix, data );
                }
            }
        }
        else
        {
            if( left ) static_cast<Sector*>(left)->forAllInstancesInAABB( geometryLod0, instances, aabb, callback, data );
            if( right ) static_cast<Sector*>(right)->forAllInstancesInAABB( geometryLod0, instances, aabb, callback, data );
        }
    }
}
开发者ID:AndreMeijer86,项目名称:base-pro-edition,代码行数:27,代码来源:batch_sector.cpp

示例2: Sector

Batch::Sector* Batch::Sector::createTree(unsigned int leafSize, Geometry* geometryLod0, Matrix* instances, unsigned int numInstances)
{
    DynamicIndices batchIndices;
    for( unsigned int i=0; i<numInstances; i++ ) batchIndices.insert( i );

    AABB batchAABB;
    AABB instanceAABB;
    batchAABB.calculate( geometryLod0->getBoundingBox(), instances );
    for( unsigned int i=1; i<numInstances; i++ )
    {
        instanceAABB.calculate( geometryLod0->getBoundingBox(), instances+i );
        batchAABB.addAABB( &instanceAABB );
    }

    return new Sector( leafSize, geometryLod0, instances, &batchAABB, batchIndices );
}
开发者ID:AndreMeijer86,项目名称:base-pro-edition,代码行数:16,代码来源:batch_sector.cpp

示例3: assert

Batch::Sector::Sector(unsigned int leafSize, Geometry* geometryLod0, Matrix* instances, AABB* aabb, DynamicIndices& parentIndices, float treeProgress, float sectorProgress)
{
    boundingBox = *aabb;
    left = right = NULL;

    // local indices
    DynamicIndices dynamicIndices;

    // show progress
    if( Engine::instance->progressCallback )
    {
        Engine::instance->progressCallback(
            Gui::iLanguage->getUnicodeString(7),
            treeProgress,
            Engine::instance->progressCallbackUserData
        );
    }

    // calculate bounding sphere
    Vector corner[8];
    unsigned int i;
    for( i=0; i<8; i++ ) corner[i] = boundingBox.getCorner( i );    
    boundingSphere.calculate( 8, corner );

    // build list of indices inside AABB of this 
    unsigned int instanceId;
    AABB instanceAABB;
	DynamicIndex index;
    for( index = parentIndices.begin(); 
                      index != parentIndices.end(); 
                      index++ )
    {
        instanceId = (*index);
        instanceAABB.calculate( geometryLod0->getBoundingBox(), instances+instanceId );
        if( ::intersectionAABBAABB( &boundingBox, &instanceAABB ) )
        {
            dynamicIndices.insert( instanceId );
        }
    }

    // remove this indices from parent indices
    DynamicIndex parentIndex;
    for( index = dynamicIndices.begin(); index != dynamicIndices.end(); index++ )
    {
        parentIndex = parentIndices.find( (*index) );
        assert( parentIndex != parentIndices.end() );
        parentIndices.erase( parentIndex );
    }

    // build subsets
    if( dynamicIndices.size() > leafSize )
    {
        AABB leftAABB;
        AABB rightAABB;
        boundingBox.divide( leftAABB, rightAABB, AABB::maxPlane );
        left = new Sector( leafSize, geometryLod0, instances, &leftAABB, dynamicIndices, treeProgress, sectorProgress * 0.5f );
        if( static_cast<Sector*>(left)->getNumInstancesInHierarchy() == 0 )
        {
            delete left;
            left = NULL;
        }
        right = new Sector( leafSize, geometryLod0, instances, &rightAABB, dynamicIndices, treeProgress + sectorProgress * 0.5f, sectorProgress * 0.5f );
        if( static_cast<Sector*>(right)->getNumInstancesInHierarchy() == 0 )
        {
            delete right;
            right = NULL;
        }        
    }

    if( !left && !right )
    {        
        // build static indices
        numIndices = dynamicIndices.size();
        indices = new unsigned int[numIndices];        
        for( index = dynamicIndices.begin(), i = 0; 
             index != dynamicIndices.end(); 
             index++, i++ )
        {
            indices[i] = *index;
        }
        dynamicIndices.clear();
    }
    else
    {
        numIndices = 0;
        indices = NULL;
    }

    // show progress
    if( Engine::instance->progressCallback )
    {
        Engine::instance->progressCallback(
            Gui::iLanguage->getUnicodeString(7),
            treeProgress + sectorProgress,
            Engine::instance->progressCallbackUserData
        );
    }
}
开发者ID:AndreMeijer86,项目名称:base-pro-edition,代码行数:98,代码来源:batch_sector.cpp


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