青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

天行健 君子當(dāng)自強(qiáng)而不息

創(chuàng)建3D圖形引擎(2)【OO改良版】

 

本篇是創(chuàng)建3D圖形引擎(1)【OO改良版】的續(xù)篇,以創(chuàng)建游戲內(nèi)核【OO改良版】中編寫的代碼為基礎(chǔ)進(jìn)行開發(fā),細(xì)節(jié)說明請參閱創(chuàng)建3D圖形引擎(2

 

接口:

//==============================================================================
// This class encapsulate for frustum, judge whether other object is in frustum.
//==============================================================================
typedef class FRUSTUM
{
public:
    
// Construct the six planes from current view and projection. 
    // Can override the default depth value.
    BOOL create(float z_distance);

    
// The following functions check a single point, cube, rectangle, and sphere if 
    // contained in the frustum. A return value of TRUE means visible, FALSE not visible.
    // When checking cubes or rectangles, you can supply a BOOL variable that determines 
    // if all the points are in the frustum.

    BOOL check_point(
float x_pos, float y_pos, float z_pos);

    BOOL check_cube(
float x_center, float y_center, float z_center,
                    
float radius,
                    BOOL* completely_contained);

    BOOL check_rectangle(
float x_center, float y_center, float z_center,
                         
float x_radius, float y_radius, float z_radius,
                         BOOL* completely_contained);

    BOOL check_sphere(
float x_center, float y_center, float z_center,
                      
float radius);
    
private:
    D3DXPLANE m_planes[6];       
// the frustum planes
} *FRUSTUM_PTR;

實(shí)現(xiàn):

/*************************************************************************
PURPOSE:
    Implement for frustum.
*************************************************************************/


#include "core_common.h"
#include "core_graphics.h"
#include "frustum.h"

//----------------------------------------------------------------------------
// Construct frustum.
//----------------------------------------------------------------------------
BOOL FRUSTUM::create(float z_distance)
{
    D3DXMATRIX matrix, mat_view, mat_proj;

    
// error checking
    if(g_d3d_device == NULL)
        
return FALSE;

    
// calculate FOV data
    g_d3d_device->GetTransform(D3DTS_PROJECTION, &mat_proj);

    
if(! float_equal(z_distance, 0.0f))
    {
        
// Calculate new projection matrix based on distance provided.
        //
        // projection matrix is:
        // 
        // | xScale     0          0               0 |
        // | 0        yScale       0               0 |
        // | 0          0       zf/(zf-zn)         1 |
        // | 0          0       -zn*zf/(zf-zn)     0 |
        //
        // where:
        //      yScale = cot(fovY/2)
        //      xScale = yScale / aspect ratio

        
float z_min = -mat_proj._43 / mat_proj._33;
        
float q = z_distance / (z_distance - z_min);

        mat_proj._33 = q;
        mat_proj._43 = -q * z_min;
    }

    g_d3d_device->GetTransform(D3DTS_VIEW, &mat_view);
    D3DXMatrixMultiply(&matrix, &mat_view, &mat_proj);

    
// calculate the planes
    m_planes[0].a = matrix._14 + matrix._13; // Near
    m_planes[0].b = matrix._24 + matrix._23;
    m_planes[0].c = matrix._34 + matrix._33;
    m_planes[0].d = matrix._44 + matrix._43;
    D3DXPlaneNormalize(&m_planes[0], &m_planes[0]);

    m_planes[1].a = matrix._14 - matrix._13; 
// Far
    m_planes[1].b = matrix._24 - matrix._23;
    m_planes[1].c = matrix._34 - matrix._33;
    m_planes[1].d = matrix._44 - matrix._43;
    D3DXPlaneNormalize(&m_planes[1], &m_planes[1]);

    m_planes[2].a = matrix._14 + matrix._11; 
// Left
    m_planes[2].b = matrix._24 + matrix._21;
    m_planes[2].c = matrix._34 + matrix._31;
    m_planes[2].d = matrix._44 + matrix._41;
    D3DXPlaneNormalize(&m_planes[2], &m_planes[2]);

    m_planes[3].a = matrix._14 - matrix._11; 
// Right
    m_planes[3].b = matrix._24 - matrix._21;
    m_planes[3].c = matrix._34 - matrix._31;
    m_planes[3].d = matrix._44 - matrix._41;
    D3DXPlaneNormalize(&m_planes[3], &m_planes[3]);

    m_planes[4].a = matrix._14 - matrix._12; 
// Top
    m_planes[4].b = matrix._24 - matrix._22;
    m_planes[4].c = matrix._34 - matrix._32;
    m_planes[4].d = matrix._44 - matrix._42;
    D3DXPlaneNormalize(&m_planes[4], &m_planes[4]);

    m_planes[5].a = matrix._14 + matrix._12; 
// Bottom
    m_planes[5].b = matrix._24 + matrix._22;
    m_planes[5].c = matrix._34 + matrix._32;
    m_planes[5].d = matrix._44 + matrix._42;
    D3DXPlaneNormalize(&m_planes[5], &m_planes[5]);

    
return TRUE;
}

//----------------------------------------------------------------------------
// Check one point whether in frustum.
//----------------------------------------------------------------------------
BOOL FRUSTUM::check_point(float x_pos, float y_pos, float z_pos)
{
    
// make sure point is in frustum
    for(short i = 0; i < 6; i++)
    {
        
if(D3DXPlaneDotCoord(&m_planes[i], &D3DXVECTOR3(x_pos, y_pos, z_pos)) < 0.0f)
            
return FALSE;
    }

    
return TRUE;
}

//----------------------------------------------------------------------------
// Check whether a cube in frustum, if total cube in frustum then 
// completely_contained will be set TRUE.
//----------------------------------------------------------------------------
BOOL FRUSTUM::check_cube(float x_center, float y_center, float z_center, 
                         
float radius, 
                         BOOL* completely_contained)
{
    DWORD num_points_in_frustum = 0;

    
// count the number of points inside the frustum
    for(short i = 0; i < 6; i++)
    {
        DWORD count = 8;
        BOOL in_all_planes = TRUE;

        
// test all eight points against plane

        
if(D3DXPlaneDotCoord(&m_planes[i], &D3DXVECTOR3(x_center - radius, y_center - radius, z_center - radius)) < 0.0f)
        {
            in_all_planes = FALSE;
            count--;
        }

        
if(D3DXPlaneDotCoord(&m_planes[i], &D3DXVECTOR3(x_center + radius, y_center - radius, z_center - radius)) < 0.0f) 
        {
          in_all_planes = FALSE;
          count--;
        }

        
if(D3DXPlaneDotCoord(&m_planes[i], &D3DXVECTOR3(x_center - radius, y_center + radius, z_center - radius)) < 0.0f) 
        {
          in_all_planes = FALSE;
          count--;
        }

        
if(D3DXPlaneDotCoord(&m_planes[i], &D3DXVECTOR3(x_center + radius, y_center + radius, z_center - radius)) < 0.0f) 
        {
          in_all_planes = FALSE;
          count--;
        }

        
if(D3DXPlaneDotCoord(&m_planes[i], &D3DXVECTOR3(x_center - radius, y_center - radius, z_center + radius)) < 0.0f) 
        {
          in_all_planes = FALSE;
          count--;
        }

        
if(D3DXPlaneDotCoord(&m_planes[i], &D3DXVECTOR3(x_center + radius, y_center - radius, z_center + radius)) < 0.0f) 
        {
          in_all_planes = FALSE;
          count--;
        }

        
if(D3DXPlaneDotCoord(&m_planes[i], &D3DXVECTOR3(x_center - radius, y_center + radius, z_center + radius)) < 0.0f) 
        {
          in_all_planes = FALSE;
          count--;
        }

        
if(D3DXPlaneDotCoord(&m_planes[i], &D3DXVECTOR3(x_center + radius, y_center + radius, z_center + radius)) < 0.0f) 
        {
          in_all_planes = FALSE;
          count--;
        }

        
// if none contained, return FALSE.
        if(count == 0)
            
return FALSE;

        
// update counter if they were all in front of plane.
        if(in_all_planes)
            ++num_points_in_frustum;
    }

    
// store BOOL flag if completely contained
    if(completely_contained)
        *completely_contained = (num_points_in_frustum == 6);

    
return TRUE;
}

//----------------------------------------------------------------------------
// Check whether a rectangle is in frustum, if total in then completely_contained
// will be set TRUE.
//----------------------------------------------------------------------------
BOOL FRUSTUM::check_rectangle(float x_center, float y_center, float z_center, 
                              
float x_radius, float y_radius, float z_radius, 
                              BOOL* completely_contained)
{
    DWORD num_points_in_frustum = 0;

    
// count the number of points inside the frustum
    for(short i = 0; i < 6; i++) 
    {
        DWORD count = 8;
        BOOL  in_all_planes = TRUE;
        
        
// Test all eight points against plane

        
if(D3DXPlaneDotCoord(&m_planes[i], 
            &D3DXVECTOR3(x_center - x_radius, y_center - y_radius, z_center - z_radius)) < 0.0f) 
        {
          in_all_planes = FALSE;
          count--;
        }

        
if(D3DXPlaneDotCoord(&m_planes[i], 
            &D3DXVECTOR3(x_center + x_radius, y_center - y_radius, z_center - z_radius)) < 0.0f) 
        {
          in_all_planes = FALSE;
          count--;
        }

        
if(D3DXPlaneDotCoord(&m_planes[i], 
            &D3DXVECTOR3(x_center - x_radius, y_center + y_radius, z_center - z_radius)) < 0.0f) 
        {
          in_all_planes = FALSE;
          count--;
        }

        
if(D3DXPlaneDotCoord(&m_planes[i], 
            &D3DXVECTOR3(x_center + x_radius, y_center + y_radius, z_center - z_radius)) < 0.0f) 
        {
          in_all_planes = FALSE;
          count--;
        }

        
if(D3DXPlaneDotCoord(&m_planes[i], 
            &D3DXVECTOR3(x_center - x_radius, y_center - y_radius, z_center + z_radius)) < 0.0f) 
        {
          in_all_planes = FALSE;
          count--;
        }

        
if(D3DXPlaneDotCoord(&m_planes[i], 
            &D3DXVECTOR3(x_center + x_radius, y_center - y_radius, z_center + z_radius)) < 0.0f) 
        {
          in_all_planes = FALSE;
          count--;
        }

        
if(D3DXPlaneDotCoord(&m_planes[i], 
            &D3DXVECTOR3(x_center - x_radius, y_center + y_radius, z_center + z_radius)) < 0.0f) 
        {
          in_all_planes = FALSE;
          count--;
        }

        
if(D3DXPlaneDotCoord(&m_planes[i], 
            &D3DXVECTOR3(x_center + x_radius, y_center + y_radius, z_center + z_radius)) < 0.0f) 
        {
          in_all_planes = FALSE;
          count--;
        }

        
// If none contained, return FALSE
        if(count == 0)
          
return FALSE;

        
// Update counter if they were all in front of plane
        if(in_all_planes)
            ++num_points_in_frustum;
    }

    
// Store BOOL flag if completely contained
    if(completely_contained)
        *completely_contained = (num_points_in_frustum == 6);

    
return TRUE;
}

//----------------------------------------------------------------------------
// Check whether a sphere is in frustum. 
//----------------------------------------------------------------------------
BOOL FRUSTUM::check_sphere(float x_center, float y_center, float z_center, 
                           
float radius)
{
    
// make sure radius is in frustum
    for(short i = 0; i < 6; i++)
    {
        
if(D3DXPlaneDotCoord(&m_planes[i], &D3DXVECTOR3(x_center, y_center, z_center)) < -radius)
            
return FALSE;
    }

    
return TRUE;
}

測試代碼:
/************************************************************************************
PURPOSE:
    frustum test.
************************************************************************************/


#include "core_common.h"
#include "core_framework.h"
#include "core_graphics.h"
#include "core_input.h"
#include "frustum.h"

#define MAX_OBJECTS 256

class APP : public FRAMEWORK
{
public:
    BOOL init()
    {              
        
if(! create_display(g_hwnd, get_client_width(g_hwnd), get_client_height(g_hwnd), 16, TRUE, TRUE))
            
return FALSE;

        set_perspective(D3DX_PI / 4, 1.3333f, 1.0f, 10000.0f);

        
// create font
        m_font.create("Arial", 16, TRUE, FALSE);

        
// initialize input and input device
        m_input.create(g_hwnd, get_window_inst());        
        m_mouse.create(&m_input, MOUSE, TRUE);

        
// load mesh
        if(! m_mesh.load("..\\Data\\Yodan.x", "..\\Data\\"))
            
return FALSE;

        
for(short i = 0; i < MAX_OBJECTS; i++)
        {
            m_objects[i].create(&m_mesh);

            m_objects[i].move((
float) (rand() % 4000) - 2000.0f, 0.0f, (float) (rand() % 4000) - 2000.0f);
        }

        
return TRUE;
    }

    BOOL frame()
    {
        
// read input device data
        m_mouse.read();

        
// position camera and rotate based on mouse position

        m_camera.move(0.0f, 100.0f, 0.0f);

        
// m_mouse.get_y_delta():
        //      get mouse's relative x movement coordinate.
        //
        // m_mouse.get_x_delta():
        //      get mouse's relative y movement coordinate.

        m_camera.rotate_rel(m_mouse.get_y_delta() / 200.0f, m_mouse.get_x_delta() / 200.0f, 0.0f);

        
// set view transform matrix
        g_d3d_device->SetTransform(D3DTS_VIEW, m_camera.get_view_matrix());

        
// render everything
        clear_display(D3DCOLOR_RGBA(0, 64, 128, 255), 1.0f);

        
// begin render now
        if(SUCCEEDED(g_d3d_device->BeginScene()))
        {
            FRUSTUM frustum;
            frustum.create(0.0f);

            
long num_drawn = 0;

            
// render each object in frustum
            for(short i = 0; i < MAX_OBJECTS; i++)\
            {
                
float radius;

                m_objects[i].get_bounds(NULL, NULL, NULL, NULL, NULL, NULL, &radius);

                
if(frustum.check_sphere(m_objects[i].get_x_pos(), m_objects[i].get_y_pos(), m_objects[i].get_z_pos(),
                                        radius))
                {
                    m_objects[i].render();
                    num_drawn++;
                }      
            }               

            
char stats[128];

            
// display statistics
            sprintf(stats, "%lu of 256 objects drawn.", num_drawn);
            m_font.draw(stats, 0, 0, 400, 100, 0xFFFFFFFF, DT_LEFT | DT_TOP);

            g_d3d_device->EndScene();            
        }

        present_display();        

        
return TRUE;
    }

    BOOL shutdown()
    {
        
return TRUE;
    }

private:
    CAMERA          m_camera;
    FONT            m_font;

    INPUT           m_input;    
    INPUT_DEVICE    m_mouse;

    MESH            m_mesh;
    OBJECT          m_objects[MAX_OBJECTS];
};

int WINAPI WinMain(HINSTANCE inst, HINSTANCE, LPSTR cmd_line, int cmd_show)
{
    DWORD client_width  = 640;
    DWORD client_height = 480;
    DWORD x_pos = (get_screen_width()  - client_width) / 2;
    DWORD y_pos = (get_screen_height() - client_height) / 4;

    
if(! build_window(inst, "frustum_class", "frustum test", 
                      WS_BORDER | WS_CAPTION | WS_MINIMIZEBOX | WS_SYSMENU,
                      x_pos, y_pos, client_width, client_height))
    {
        
return -1;
    }

    APP app;
    app.run();

    
return 0;
}
 

posted on 2007-10-19 20:07 lovedday 閱讀(629) 評論(0)  編輯 收藏 引用


只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


公告

導(dǎo)航

統(tǒng)計(jì)

常用鏈接

隨筆分類(178)

3D游戲編程相關(guān)鏈接

搜索

最新評論

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美一区二区三区在线免费观看| 欧美激情1区| 久久久最新网址| 黄色在线成人| 美女露胸一区二区三区| 亚洲第一精品在线| 亚洲伦理自拍| 欧美特黄一级| 久久av一区二区三区| 免费成人激情视频| 99精品国产高清一区二区 | 性久久久久久久久久久久| 久久精品123| 亚洲日本va午夜在线影院| 欧美另类女人| 欧美一区二区三区婷婷月色| 欧美国产日韩二区| 亚洲欧美日产图| 韩国福利一区| 欧美日韩亚洲网| 久久国产免费看| 亚洲精品一区二区三区在线观看| 午夜视频在线观看一区二区三区| 黄色成人在线网站| 欧美日韩精品久久久| 午夜电影亚洲| 亚洲黑丝在线| 久久精品视频va| 99精品视频免费全部在线| 国产精品永久免费视频| 欧美不卡高清| 欧美伊人久久久久久午夜久久久久| 亚洲国产91色在线| 久久久精品国产免费观看同学| 亚洲全部视频| 国内精品久久久久久影视8| 欧美另类变人与禽xxxxx| 欧美一区二区三区男人的天堂| 亚洲精品美女91| 女人天堂亚洲aⅴ在线观看| 亚洲免费视频成人| 日韩视频不卡| 亚洲福利小视频| 国产伦精品一区二区三区视频孕妇| 欧美成人69| 久久蜜桃香蕉精品一区二区三区| 中日韩高清电影网| 最新中文字幕亚洲| 欧美成人中文字幕| 久久免费少妇高潮久久精品99| 亚洲自拍电影| 一本色道久久综合亚洲91 | 亚洲国产成人久久综合一区| 国产日本欧洲亚洲| 国产精品国产三级国产aⅴ无密码 国产精品国产三级国产aⅴ入口 | 中文亚洲免费| 亚洲国内在线| 伊人成综合网伊人222| 国产精品视频九色porn| 欧美日韩在线电影| 欧美日韩伦理在线免费| 欧美成人午夜剧场免费观看| 久久久久综合网| 久久福利资源站| 欧美一区二区女人| 午夜在线成人av| 午夜精品999| 亚洲欧美在线播放| 午夜精品国产更新| 亚洲欧美视频一区| 亚洲欧美日韩专区| 销魂美女一区二区三区视频在线| 亚洲私人黄色宅男| 这里只有精品丝袜| 亚洲一区亚洲二区| 午夜一区不卡| 欧美在线观看视频| 欧美专区在线播放| 久久夜色精品| 欧美黑人在线观看| 欧美日韩国产经典色站一区二区三区| 欧美黄色aa电影| 欧美精品成人| 欧美午夜在线观看| 国产精品色午夜在线观看| 国产精品视频久久久| 国产欧美一区二区精品婷婷| 国产欧美一区二区三区视频 | 久久精品国产第一区二区三区最新章节 | 亚洲国产精品t66y| 亚洲毛片在线看| 亚洲午夜激情在线| 先锋影音久久久| 久久久久一区| 米奇777超碰欧美日韩亚洲| 欧美阿v一级看视频| 欧美精品一区二区在线观看| 欧美午夜免费| 国产亚洲福利社区一区| 亚洲国产精品va在线观看黑人| 亚洲国产高清自拍| 一区二区三区四区国产| 欧美综合77777色婷婷| 狼人天天伊人久久| 亚洲精品欧美日韩| 亚洲综合色婷婷| 久久一综合视频| 欧美日韩国产色视频| 国产精品入口尤物| 亚洲国产精品一区在线观看不卡 | 韩日欧美一区二区| 99热在这里有精品免费| 亚洲综合国产精品| 久久九九全国免费精品观看| 亚洲国产综合91精品麻豆| 亚洲少妇自拍| 美日韩精品视频| 国产精品视频成人| 亚洲毛片av在线| 久久久精品网| 日韩亚洲视频| 乱人伦精品视频在线观看| 国产精品国产精品| 亚洲人成网站777色婷婷| 香蕉精品999视频一区二区| 欧美国产欧美综合| 欧美在线免费观看| 欧美亚洲成人网| 亚洲国产日韩欧美| 欧美在现视频| 日韩亚洲国产欧美| 欧美a级片一区| 国内精品一区二区| 亚洲免费一在线| 91久久精品国产| 久久精品亚洲| 国产欧美日韩精品丝袜高跟鞋| 亚洲美女啪啪| 欧美国产专区| 久久久久久久久久久久久女国产乱 | 亚洲无限av看| 亚洲片国产一区一级在线观看| 欧美在线视频免费观看| 国产精品视频你懂的| 亚洲无线视频| 亚洲精品日产精品乱码不卡| 久久精品一区蜜桃臀影院 | 国产欧美精品日韩精品| 亚洲一区二区三区视频播放| 亚洲国产精品久久久久秋霞蜜臀| 欧美伊人久久| 国产日韩欧美在线观看| 亚洲在线视频网站| 夜夜嗨av一区二区三区| 欧美另类99xxxxx| 99ri日韩精品视频| 亚洲国产欧美日韩| 鲁鲁狠狠狠7777一区二区| 激情久久影院| 久久综合99re88久久爱| 欧美在线一区二区| 国产字幕视频一区二区| 久久久久在线| 欧美在线日韩| 在线不卡中文字幕| 美女精品在线观看| 蜜臀a∨国产成人精品| 亚洲国产精品一区二区第四页av| 免费日韩成人| 欧美www视频在线观看| 日韩午夜在线| 一区二区三区**美女毛片| 国产精品美女999| 欧美一区二区三区男人的天堂| 亚洲综合日本| 一区在线播放视频| 亚洲第一网站免费视频| 欧美日韩国产一区| 亚洲影院污污.| 亚洲欧美日韩天堂| 狠狠爱成人网| 欧美激情乱人伦| 欧美三区在线视频| 久久精品国产96久久久香蕉| 久久久国产精品一区| 亚洲国产电影| 999在线观看精品免费不卡网站| 欧美午夜片欧美片在线观看| 欧美一级午夜免费电影| 久久久久久尹人网香蕉| 99日韩精品| 欧美亚洲免费电影| 亚洲精品网站在线播放gif| 一区二区三区视频免费在线观看 | 在线中文字幕一区| 亚洲影院高清在线| 亚洲第一福利在线观看| 99精品热视频| 极品尤物久久久av免费看| 亚洲青色在线|