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


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

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


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

示例1: TestAABBAABB

 // a and b are not overlapping if they are seperated on any major axis
 bool TestAABBAABB(const AABB& a, const AABB& b)
 {
     if(a.Max().x < b.Min().x || a.Min().x > b.Max().x) return false;
     if(a.Max().z < b.Min().z || a.Min().z > b.Max().z) return false;
     if(a.Max().y < b.Min().y || a.Min().y > b.Max().y) return false;
     return true;
 }
开发者ID:Clever-Boy,项目名称:XLE,代码行数:8,代码来源:CollisionPrimitives.cpp

示例2: IntersectRayAABB

    bool IntersectRayAABB(const Ray& r, const AABB& a, float* out_tmin, float3* out_pos, float3* out_nor)
    {
        const float3& p = r.pos;
        const float3& d = r.direction;
        float tmin = -FLT_MAX;
        float tmax = FLT_MAX;
        float3 minNorm, maxNorm;
        
        // check vs. all three 'slabs' of the aabb
        for(int i = 0; i < 3; ++i)
        {
            if(abs(d[i]) < Epsilon) 
            {   // ray is parallel to slab, no hit if origin not within slab
                if(p[i] < a.Min()[i] || p[i] > a.Max()[i] )
                {
                    return false;
                }
            }
            else
            {
                // compute intersection t values of ray with near and far plane of slab
                float ood = 1.0f / d[i];
                float t1 = (a.Min()[i] - p[i]) * ood;
                float t2 = (a.Max()[i] - p[i]) * ood;
                tmin = maximize(tmin, minimize(t1, t2));
                tmax = minimize(tmax, maximize(t1, t2));

                // exit with no collision as soon as slab intersection becomes empty
                if(tmin > tmax) 
                {
                    return false;
                }
            }
        }
        
        if(tmax < 0.f)
        {
            // entire bounding box is behind us
            return false;
        }
        else if(tmin < 0.f)
        {
            // we are inside the bounding box
            *out_tmin = 0.f;
            *out_pos = p;
            *out_nor = normalize(a.GetCenter() - (*out_pos)); // use 'sphere' type normal calculation to approximate.
            return true;
        }
        else
        {
            // ray intersects all 3 slabs. return point and normal of intersection
            *out_tmin = tmin;
            *out_pos = p + d * tmin;
            *out_nor = normalize(a.GetCenter() - (*out_pos)); // use 'sphere' type normal calculation to approximate.
            return true;
        }
    }
开发者ID:Clever-Boy,项目名称:XLE,代码行数:57,代码来源:CollisionPrimitives.cpp

示例3: UpdateBounds

// ------------------------------------------------------------------------------------------------
void Model::UpdateBounds()
{
    assert(m_constructed==true);
    const GeometryDict& geos = Geometries();
    if(geos.size()==0)
    {
        return;
    }

    float3 min = float3(FLT_MAX, FLT_MAX, FLT_MAX);
    float3 max = float3(-FLT_MAX, -FLT_MAX, -FLT_MAX);
    const NodeDict& nodes = Nodes();
    for(auto nodeIt = nodes.begin(); nodeIt != nodes.end(); ++nodeIt)
    {
        Node* node = nodeIt->second;
        for(auto geoIt = node->geometries.begin(); geoIt != node->geometries.end(); ++geoIt)
        {
            Geometry * geo = (*geoIt);
            AABB bbox = geo->mesh->bounds;
            bbox.Transform(m_nodeTransforms[node->index]);
            min = minimize(min, bbox.Min());
            max = maximize(max, bbox.Max());
        }
    }
    // note: min & max already transformed by entire object world matrix
    m_bounds = AABB(min, max);
}
开发者ID:Clever-Boy,项目名称:XLE,代码行数:28,代码来源:Model.cpp

示例4: FrustumAABBIntersect

    //-----------------------------------------------------------------------------
    // AABB vs Frustum test.     
    //
    // Return values: 0 = no intersection, 
    //                1 = intersection, 
    //                2 = box is completely inside frustum    
    //
    //-----------------------------------------------------------------------------
    int FrustumAABBIntersect(const Frustum& frustum, const AABB& box)
    {
        float3 c  = box.GetCenter();
        float3 r  = box.Max() - c;
        bool intersects = false;        
        for(int i = 0; i < 6; ++i)
        {
            const Plane& plane = frustum[i];
            // test plane and AABB intersection.
            float e =  r.x * abs(plane.normal.x) 
                + r.y * abs(plane.normal.y) 
                + r.z * abs(plane.normal.z);
            float s = plane.Eval(c);

           // assert(e > 0);
            // the box is in positive half-space.
            if((s - e) > 0) continue;
            
            // if box is completely in negative side of the plain 
            // then the box is outside frustum.
            if( (s + e) < 0) return 0; // no intersection, early exit.            
            intersects = true;             
        }    
        if(intersects) return 1;
        return 2; // either intersects or completely inside frustum      
    }
开发者ID:Clever-Boy,项目名称:XLE,代码行数:34,代码来源:CollisionPrimitives.cpp

示例5: PlaneAABBIntersection

 //-----------------------------------------------------------------------------
 // Plane vs AABB test.
 //
 // Return values: 
 //              0 = (Front) There is no intersection, and the box is in 
 //                   the positive half-space of the Plane. 
 //                  
 //              1 = (Back) There is no intersection, and the box is in 
 //                  the negative half-space of the Plane.
 //              2 = (Intersecting) the box intersects the plane.
 //-----------------------------------------------------------------------------
 int PlaneAABBIntersection(const Plane& plane, const AABB& box)
 {
     float3 c  = box.GetCenter();
     float3 r  = box.Max() - c;
     float e = r.x * abs(plane.normal.x) 
             + r.y * abs(plane.normal.y) 
             + r.z * abs(plane.normal.z);
     float s = plane.Eval(c);
     if((s - e) > 0)  return 0; // front side
     if((s + e) < 0)  return 1; // back side
     return 2; // Intersecting
 }
开发者ID:Clever-Boy,项目名称:XLE,代码行数:23,代码来源:CollisionPrimitives.cpp

示例6: DrawAABB

void LineRenderer::DrawAABB(const AABB& aabb, const float4& color)
{
    float3 min = aabb.Min();
    float3 max = aabb.Max(); 
    

    // render top quad    
    m_vertsPC.push_back(VertexPC(max,color));      
    m_vertsPC.push_back(VertexPC(float3(min.x,max.y,max.z),color));

    m_vertsPC.push_back(VertexPC(float3(min.x,max.y,max.z),color));
    m_vertsPC.push_back(VertexPC(float3(min.x,max.y,min.z),color));

    m_vertsPC.push_back(VertexPC(float3(min.x,max.y,min.z),color));
    m_vertsPC.push_back(VertexPC(float3(max.x,max.y,min.z),color));

    m_vertsPC.push_back(VertexPC(float3(max.x,max.y,min.z),color));
    m_vertsPC.push_back(VertexPC(max,color));

    // render bottom quad
    m_vertsPC.push_back(VertexPC(float3(max.x,min.y,max.z),color));      
    m_vertsPC.push_back(VertexPC(float3(min.x,min.y,max.z),color));

    m_vertsPC.push_back(VertexPC(float3(min.x,min.y,max.z),color));
    m_vertsPC.push_back(VertexPC(float3(min.x,min.y,min.z),color));

    m_vertsPC.push_back(VertexPC(float3(min.x,min.y,min.z),color));
    m_vertsPC.push_back(VertexPC(float3(max.x,min.y,min.z),color));

    m_vertsPC.push_back(VertexPC(float3(max.x,min.y,min.z),color));
    m_vertsPC.push_back(VertexPC(float3(max.x,min.y,max.z),color));

    // four legs
    m_vertsPC.push_back(VertexPC(max,color));  
    m_vertsPC.push_back(VertexPC(float3(max.x,min.y,max.z),color));      

    m_vertsPC.push_back(VertexPC(float3(min.x,max.y,max.z),color));
    m_vertsPC.push_back(VertexPC(float3(min.x,min.y,max.z),color));

    m_vertsPC.push_back(VertexPC(float3(min.x,max.y,min.z),color));
    m_vertsPC.push_back(VertexPC(float3(min.x,min.y,min.z),color));

    m_vertsPC.push_back(VertexPC(float3(max.x,max.y,min.z),color));
    m_vertsPC.push_back(VertexPC(float3(max.x,min.y,min.z),color));

}
开发者ID:Averroes,项目名称:LevelEditor,代码行数:46,代码来源:LineRenderer.cpp

示例7: TestFrustumAABB

    //-----------------------------------------------------------------------------
    // AABB vs frustum test.
    //
    // Return values: false = no intersection, 
    //                true  = either the box intersections or it is fully containt.
    // note: this test is fast but not 100% accurate (it is good for viewfrustum culling)          
    //-----------------------------------------------------------------------------
    bool TestFrustumAABB(const Frustum& frustum, const AABB& box)
	{              
        float3 c  = box.GetCenter();
        float3 r  = box.Max() - c;        
        for(int i = 0; i < 6; ++i)
        {
            const Plane& plane = frustum[i];
            // test plane and AABB intersection.
            float e =  r.x * abs(plane.normal.x) 
                + r.y * abs(plane.normal.y) 
                + r.z * abs(plane.normal.z);
            float s = plane.Eval(c);
            
            // if box is completely in negative side of the plain 
            // then the box is outside frustum.
            if( (s + e) < 0)  return false; // no intersection, early exit.               
        }            
        return true; // either intersects or completely inside frustum         
    }
开发者ID:Clever-Boy,项目名称:XLE,代码行数:26,代码来源:CollisionPrimitives.cpp

示例8: UpdateLightCamera

//---------------------------------------------------------------------------
void ShadowMaps::UpdateLightCamera( ID3D11DeviceContext* dc, const DirLight* light, const AABB& renderedArea )
{
    float3 worldUp(0,1,0);
    float3 lightDir = normalize(light->dir);

    // compute ligtcam params.
    float dt = dot(-lightDir, worldUp);
    float3 center = renderedArea.GetCenter();
    float dim = length(renderedArea.Max() - renderedArea.Min());
    float radi = dim * 0.5f;

    float3 camPos = center - (radi * lightDir);
    float3 up;
    float3 right;

    if ((dt + Epsilon) >= 1)
    {
        up = float3(0, 0, -1);
        right = float3(1, 0, 0);

    }
    else
    {
        right = normalize(cross(lightDir, worldUp));
        up = normalize(cross(right, lightDir));
        right = cross(lightDir, worldUp);
        up = cross(right, lightDir);
    }


    // create view matrix from right, up and look, and position.
     float rp = -dot(right, camPos);
     float upp = -dot(up, camPos);
     float zp = dot(lightDir, camPos);
     Matrix view(
                right.x, up.x, -lightDir.x, 0.0f,
                right.y, up.y, -lightDir.y, 0.0f,
                right.z, up.z, -lightDir.z, 0.0f,
                rp, upp, zp, 1.0f);

    // compute the width, height, near, far by transforming the AABB into view space.
    AABB lbounds = renderedArea;
    lbounds.Transform(view);
    float3 vmin = lbounds.Min();
    float3 vmax = lbounds.Max();
    float width = vmax.x - vmin.x;
    float height = vmax.y - vmin.y;
    float nearz = 0.0f;
    float farz = dim;

    Matrix proj = Matrix::CreateOrthographic(width,height, nearz, farz);
    //Matrix proj = Matrix::CreateOrthographicOffCenter(vmin.x, vmax.x, vmin.y, vmax.y, nearz, farz);
    m_lightCamera.SetViewProj(view, proj);

    // update cb        
    m_cbShadow.Data.texelSize  = ( 1.0f / MapSize() );        

    // udpate constant buffer using lightcamera.
    // transform coords from NDC space to texture space.
    float4x4 ndcToTexSpace(  0.5f,  0.0f, 0.0f, 0.0f,
                             0.0f, -0.5f, 0.0f, 0.0f,
                             0.0f,  0.0f, 1.0f, 0.0f,
                             0.5f,  0.5f, 0.0f, 1.0f);
                                 
    float4x4 shadowViewProjection = (m_lightCamera.View() * m_lightCamera.Proj()) * ndcToTexSpace;
    Matrix::Transpose(shadowViewProjection, m_cbShadow.Data.xform);    
    m_cbShadow.Update(dc);
}
开发者ID:Anters,项目名称:LevelEditor,代码行数:69,代码来源:ShadowMaps.cpp


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