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

天行健 君子當自強而不息

創建3D圖形引擎(4)【OO改良版】

 

本篇是創建3D圖形引擎(3)【OO改良版】的續篇,以創建游戲內核【OO改良版】中編寫的代碼為基礎進行開發,細節說明請參閱創建3D圖形引擎(4)

 

下載源碼和工程

 

接口:

/*************************************************************************
PURPOSE:
    Interface for sky box.
*************************************************************************/


#ifndef _SKY_BOX_H
#define _SKY_BOX_H

#include "core_common.h"

enum SKY_BOX_SIDES  { TOP = 0, BOTTOM, LEFT, RIGHT, FRONT, BACK };

//=====================================================================================
// This calss encapsulate how to make sky box.
//=====================================================================================
typedef class SKY_BOX
{
private:
    typedef 
struct SKY_BOX_VERTEX
    {
        
float x, y, z;
        
float u, v;
    } *SKY_BOX_VERTEX_PTR;

    
#define SKY_BOX_FVF (D3DFVF_XYZ | D3DFVF_TEX1)

private:    
    TEXTURE         m_textures[6];      
// face texture (0 - 5)
    VERTEX_BUFFER   m_vertex_buffer;    // mesh vertex buffer
    WORLD_POSITION  m_pos;              // sky box position

public:
    SKY_BOX();
    ~SKY_BOX();

    BOOL create();
    
void free();

    
void set_default_state();
    BOOL load_texture(
short side, pcstr filename, D3DCOLOR transparent, D3DFORMAT format);

    
void rotate(float x_rot, float y_rot, float z_rot);
    
void rotate_rel(float x_rot, float y_rot, float z_rot);

    BOOL render(CAMERA_PTR camera, BOOL alpha_blend);
} *SKY_BOX_PTR;

#endif

實現:
 
/*************************************************************************
PURPOSE:
    Implement for sky box.
*************************************************************************/


#include "core_common.h"
#include "core_graphics.h"
#include "sky_box.h"

//----------------------------------------------------------------------------------
// Constructor, initialize member data.
//----------------------------------------------------------------------------------
SKY_BOX::SKY_BOX()
{    
}

//----------------------------------------------------------------------------------
// Destructor, release allocated resource.
//----------------------------------------------------------------------------------
SKY_BOX::~SKY_BOX()
{
    free();
}

//----------------------------------------------------------------------------------
// Release allocated resource.
//----------------------------------------------------------------------------------
void SKY_BOX::free()
{    
    
for(short i = 0; i < 6; i++)
        m_textures[i].free();

    m_vertex_buffer.free();
}

//----------------------------------------------------------------------------------
// Set default state for sky box.
//----------------------------------------------------------------------------------
void SKY_BOX::set_default_state()
{
    m_pos.set_default_state();
}

//----------------------------------------------------------------------------------
// Create a sky box class object.
//----------------------------------------------------------------------------------
BOOL SKY_BOX::create()
{
    SKY_BOX_VERTEX verts[24] = {
        { -10.0f,  10.0f, -10.0f, 0.0f, 0.0f },  
// Top
        {  10.0f,  10.0f, -10.0f, 1.0f, 0.0f },
        { -10.0f,  10.0f,  10.0f, 0.0f, 1.0f },
        {  10.0f,  10.0f,  10.0f, 1.0f, 1.0f },

        { -10.0f, -10.0f,  10.0f, 0.0f, 0.0f },  
// Bottom
        {  10.0f, -10.0f,  10.0f, 1.0f, 0.0f },
        { -10.0f, -10.0f, -10.0f, 0.0f, 1.0f },
        {  10.0f, -10.0f, -10.0f, 1.0f, 1.0f },

        { -10.0f,  10.0f, -10.0f, 0.0f, 0.0f },  
// Left
        { -10.0f,  10.0f,  10.0f, 1.0f, 0.0f },
        { -10.0f, -10.0f, -10.0f, 0.0f, 1.0f },
        { -10.0f, -10.0f,  10.0f, 1.0f, 1.0f },

        {  10.0f,  10.0f,  10.0f, 0.0f, 0.0f },  
// Right
        {  10.0f,  10.0f, -10.0f, 1.0f, 0.0f },
        {  10.0f, -10.0f,  10.0f, 0.0f, 1.0f },
        {  10.0f, -10.0f, -10.0f, 1.0f, 1.0f },

        { -10.0f,  10.0f,  10.0f, 0.0f, 0.0f },  
// Front
        {  10.0f,  10.0f,  10.0f, 1.0f, 0.0f },
        { -10.0f, -10.0f,  10.0f, 0.0f, 1.0f },
        {  10.0f, -10.0f,  10.0f, 1.0f, 1.0f },
        
        {  10.0f,  10.0f, -10.0f, 0.0f, 0.0f },  
// Back
        { -10.0f,  10.0f, -10.0f, 1.0f, 0.0f },
        {  10.0f, -10.0f, -10.0f, 0.0f, 1.0f },
        { -10.0f, -10.0f, -10.0f, 1.0f, 1.0f },
    };

    free();     
// free a prior sky box

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

    
// create the vertex buffer (and copy over sky box vertices)
    if(m_vertex_buffer.create(24, sizeof(SKY_BOX_VERTEX), SKY_BOX_FVF))
        m_vertex_buffer.fill_in(0, 24, (
void*)verts);

    
// rotate the sky box into default orientation
    rotate(0.0f, 0.0f, 0.0f);

    
return TRUE;
}

//----------------------------------------------------------------------------------
// Set a specific side's texture map, allow for transparent and storage format changes.
//----------------------------------------------------------------------------------
BOOL SKY_BOX::load_texture(short side, pcstr filename, D3DCOLOR transparent, D3DFORMAT format)
{
    
// error checking
    if(g_d3d_device == NULL || side < 0 || side > 5)
        
return FALSE;

    m_textures[side].free();    
// free prior texture

    
return m_textures[side].load(filename, transparent, format);
}

//----------------------------------------------------------------------------------
// Rotate box to an absolute rotation.
//----------------------------------------------------------------------------------
void SKY_BOX::rotate(float x_rot, float y_rot, float z_rot)
{
    m_pos.rotate(x_rot, y_rot, z_rot);
}

//----------------------------------------------------------------------------------
// Rotate box to an relative rotation.
//----------------------------------------------------------------------------------
void SKY_BOX::rotate_rel(float x_rot, float y_rot, float z_rot)
{
    m_pos.rotate_rel(x_rot, y_rot, z_rot);
}

//----------------------------------------------------------------------------------
// Render the sky box (using optional alpha-blending) and using current view 
// transformation from camera.
//----------------------------------------------------------------------------------
BOOL SKY_BOX::render(CAMERA_PTR camera, BOOL alpha_blend)
{
    
// error checking
    if(g_d3d_device == NULL || camera == NULL)
        
return FALSE;

    
// position sky box around viewer
    m_pos.move(camera->get_x_pos(), camera->get_y_pos(), camera->get_z_pos());
    g_d3d_device->SetTransform(D3DTS_WORLD, m_pos.get_world_matrix());    

    
// enable alpha testing and alpha blending

    enable_alpha_testing();

    
if(alpha_blend)
        enable_alpha_blending(D3DBLEND_SRCCOLOR, D3DBLEND_DESTCOLOR);

    
// draw each layer
    for(short i = 0; i < 6; i++)
    {
        
if(m_textures[i].is_loaded())
        {
            g_d3d_device->SetTexture(0, m_textures[i].get_d3d_texture());            
            m_vertex_buffer.render(i * 4, 2, D3DPT_TRIANGLESTRIP);
        }
    }

    
// disable alpha testing and alpha blending

   disable_alpha_testing();

    
if(alpha_blend)
        disable_alpha_blending();

    
return TRUE;
}

測試代碼:
/************************************************************************************
PURPOSE:
     node tree mesh test.
************************************************************************************/


#include "core_common.h"
#include "core_framework.h"
#include "core_graphics.h"
#include "core_input.h"
#include "core_sound.h"
#include "frustum.h"
#include "node_tree_mesh.h"
#include "sky_box.h"

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);

        ShowCursor(TRUE);
    
        
// enable lighting and setup light

        g_d3d_device->SetRenderState(D3DRS_LIGHTING, TRUE);
        set_ambient_light(24, 24, 24);
        g_d3d_device->LightEnable(0, TRUE);        
        
        m_light.set_default_state();
        m_light.set_attenuation_0(0.4f);
        m_light.set_range(1000.0f);

        m_camera.set_default_state();

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

        
// load the mesh and create a nodetree mesh from it

        
if(! m_mesh.load("..\\Data\\Level.x", "..\\Data\\"))
            
return FALSE;

        m_node_tree_mesh.create(&m_mesh, QUADTREE, 256.0f, 32);

        
// position view at origin
        m_x_pos = m_y_pos = m_z_pos = 0.0f;

        
// setup sky box
        m_sky_box.create();
        m_sky_box.set_default_state();

        
for(short i = 0; i < 6; i++)
            m_sky_box.load_texture(i, "..\\data\\stars.bmp", 0, D3DFMT_UNKNOWN);

        
// initialize the sound system to play with
        m_sound.init(g_hwnd, 22050, 1, 16, DSSCL_PRIORITY);
        m_sound_data.load_wav("..\\data\\cricket.wav");

        
for(short i = 0; i < 3; i++)
            m_sound_channel[i].create(&m_sound, 22050, 1, 16);

        
return TRUE;
    }

    BOOL frame()
    {
        
static DWORD time_now = timeGetTime();

        
// play a random cricket sound
        for(short i = 0; i< 3; i++)
        {
            
if(!m_sound_channel[i].is_playing() && rand()%256 < 16)
                m_sound_channel[i].play(&m_sound_data, 10, 1);
        }

        
// calculate elapsed time (plus speed boost)
        ulong time_elapsed = timeGetTime() - time_now;
        time_now = timeGetTime();

        
// read keyboard and mouse data        
        m_keyboard.read();
        m_mouse.read();

        
// process input and update everything, ESC quits program.

        
if(m_keyboard.get_key_state(KEY_ESC))
            
return FALSE;

        
float x_move, z_move;

        
// process movement
        x_move = z_move = 0.0f;

        
if(m_keyboard.get_key_state(KEY_UP) || m_keyboard.get_key_state(KEY_W))
        {
            x_move = (
float) sin(m_camera.get_y_rotation()) * time_elapsed;
            z_move = (
float) cos(m_camera.get_y_rotation()) * time_elapsed;
        }
        
        
if(m_keyboard.get_key_state(KEY_DOWN) || m_keyboard.get_key_state(KEY_S))
        {
            x_move = (
float) -sin(m_camera.get_y_rotation()) * time_elapsed;
            z_move = (
float) -cos(m_camera.get_y_rotation()) * time_elapsed;
        }

        
if(m_keyboard.get_key_state(KEY_LEFT) || m_keyboard.get_key_state(KEY_A))
        {
            x_move = (
float) sin(m_camera.get_y_rotation() - 1.57f) * time_elapsed;
            z_move = (
float) cos(m_camera.get_y_rotation() - 1.57f) * time_elapsed;
        }

        
if(m_keyboard.get_key_state(KEY_RIGHT) || m_keyboard.get_key_state(KEY_D))
        {
            x_move = (
float) sin(m_camera.get_y_rotation() + 1.57f) * time_elapsed;
            z_move = (
float) cos(m_camera.get_y_rotation() + 1.57f) * time_elapsed;
        }

        
// check for height changes (can step up to 64 units)
        float height = m_node_tree_mesh.closest_height_below_object(m_x_pos, m_y_pos + m_above_floor, m_z_pos);

        
if(m_y_pos > height)
        {
            
// dropping
            if((m_y_pos -= (float)time_elapsed) < height)
                m_y_pos = height;
            
else
                x_move = z_move = 0.0f;
        }
        
else
        {
            
// climbing
            m_y_pos = height;
        }

        
float dist;

        
// check for movement collision - can not walk past anything blocking path.
        if(m_node_tree_mesh.is_ray_intersect_mesh(m_x_pos, m_y_pos + m_above_floor, m_z_pos,
                                                 m_x_pos + x_move, m_y_pos + m_above_floor, m_z_pos + z_move,
                                                 &dist))
        {
            
// adjust coordinates to be exactly 2.5 units away from target

            
float diff = dist - 2.5f;

            D3DXVECTOR2 dir;
            D3DXVec2Normalize(&dir, &D3DXVECTOR2(x_move, z_move));

            dir *= diff;

            x_move = dir.x;
            z_move = dir.y;
        }

        
// update view coordinats
        m_x_pos += x_move;
        m_z_pos += z_move;

        
// position camera and rotate based on mouse position

        m_camera.move(m_x_pos, m_y_pos + 50.0f, m_z_pos);

        
// 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((float) m_mouse.get_y_delta() / 200.0f, (float) m_mouse.get_x_delta() / 200.0f, 0.0f);

        
// position
        m_light.move(m_x_pos, m_y_pos + 60.0f, m_z_pos);
        g_d3d_device->SetLight(0, m_light.get_d3d_light());        

        FRUSTUM frustum;

        
// set camera and calculate frustum    
        g_d3d_device->SetTransform(D3DTS_VIEW, m_camera.get_view_matrix());        
        frustum.create(0.0f);
        
        
// render everything
        clear_display_zbuffer(1.0f);               

        
//clear_display(0, 1.0f);               

        // begin render now
        if(SUCCEEDED(g_d3d_device->BeginScene()))        
        {
            g_d3d_device->SetRenderState(D3DRS_ZENABLE, D3DZB_FALSE);
            g_d3d_device->SetRenderState(D3DRS_LIGHTING, FALSE);            
            m_sky_box.render(&m_camera, FALSE);

            g_d3d_device->SetRenderState(D3DRS_ZENABLE, D3DZB_TRUE);
            g_d3d_device->SetRenderState(D3DRS_LIGHTING, TRUE);            
            m_node_tree_mesh.render(&frustum, 0.0f);

            g_d3d_device->EndScene();            
        }

        present_display();

        
return TRUE;
    }

    BOOL shutdown()
    {
        
return TRUE;
    }

private:  
    CAMERA          m_camera;
    LIGHT           m_light;

    SOUND           m_sound;
    SOUND_DATA      m_sound_data;
    SOUND_CHANNEL   m_sound_channel[3];

    SKY_BOX         m_sky_box;

    INPUT           m_input;
    INPUT_DEVICE    m_keyboard;
    INPUT_DEVICE    m_mouse;    

    MESH            m_mesh;
    NODE_TREE_MESH  m_node_tree_mesh;

    
float           m_x_pos, m_y_pos, m_z_pos;
    
    
static const float m_above_floor;
};

const float APP::m_above_floor = 64.0f;

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, "node_tree_mesh_class", "node tree mesh 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-25 15:07 lovedday 閱讀(362) 評論(0)  編輯 收藏 引用

公告

導航

統計

常用鏈接

隨筆分類(178)

3D游戲編程相關鏈接

搜索

最新評論

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲精品国精品久久99热一| 欧美激情精品久久久六区热门| 欧美日本在线视频| 亚洲精品一区在线| 亚洲激情国产| 欧美新色视频| 久久久噜噜噜久久| 美腿丝袜亚洲色图| 99精品99久久久久久宅男| 亚洲精品老司机| 国产精品久久久久国产a级| 午夜欧美视频| 麻豆久久婷婷| 亚洲欧美国产日韩中文字幕| 午夜在线电影亚洲一区| 91久久精品www人人做人人爽| 91久久精品国产91久久| 国产精品伦理| 老司机精品视频网站| 欧美日韩黄色一区二区| 欧美在线观看你懂的| 欧美成人蜜桃| 久久精品国产99| 欧美精品久久久久久久久老牛影院| 亚洲男同1069视频| 免费观看亚洲视频大全| 亚洲欧美视频在线观看视频| 美女黄毛**国产精品啪啪| 亚洲午夜三级在线| 麻豆成人精品| 久久成人免费电影| 欧美日韩国产麻豆| 欧美成人精品福利| 国产欧美一区二区三区另类精品| 亚洲国产精品福利| 韩国欧美国产1区| 国产精品99久久久久久宅男 | 欧美亚洲成人精品| 麻豆久久久9性大片| 国产精品视频1区| 亚洲日本精品国产第一区| 国内成+人亚洲| 亚洲欧美电影在线观看| 在线亚洲+欧美+日本专区| 久久久久欧美精品| 久久久视频精品| 国产精品婷婷午夜在线观看| 日韩一级在线| 日韩午夜激情电影| 免费的成人av| 免费欧美电影| 韩国一区二区三区在线观看| 亚洲视频在线免费观看| 一区二区日本视频| 欧美精品免费播放| 亚洲国产日韩精品| 亚洲精品久久久蜜桃| 鲁大师成人一区二区三区| 久久综合狠狠| 伊人久久婷婷| 久久夜色精品国产| 欧美国内亚洲| 亚洲人线精品午夜| 欧美黄色一区| 亚洲片在线资源| 99riav久久精品riav| 欧美精品一卡二卡| 一二三区精品福利视频| 亚洲欧美日韩精品一区二区 | 欧美性大战久久久久久久蜜臀| 亚洲精品免费在线播放| 一片黄亚洲嫩模| 欧美午夜a级限制福利片| 在线中文字幕一区| 欧美在线视频观看免费网站| 国产日本亚洲高清| 久久精品91| 亚洲大片在线观看| 99精品视频一区| 国产精品美女久久久久久免费| 亚洲一区日韩| 久久亚洲欧美| 日韩视频一区| 国产精品亚洲网站| 久久野战av| 一区二区精品在线观看| 久久久国产精彩视频美女艺术照福利 | 亚洲精品少妇30p| 午夜精品视频网站| 曰韩精品一区二区| 欧美日韩免费高清| 久久精品国产亚洲一区二区| 亚洲大胆av| 亚洲欧美中文另类| 在线免费观看成人网| 欧美日韩三区四区| 欧美一区二区在线免费播放| 欧美韩国在线| 欧美一区二区三区男人的天堂| 精品成人在线观看| 欧美视频在线观看| 久久综合九色综合欧美狠狠| 一区二区三区高清视频在线观看| 久久全国免费视频| 亚洲主播在线| 亚洲第一精品夜夜躁人人爽| 欧美天堂亚洲电影院在线播放| 久久精品二区亚洲w码| 亚洲免费高清| 欧美大片免费观看| 欧美在线一二三区| 99国产精品一区| 在线播放精品| 国产亚洲欧美一级| 国产精品电影在线观看| 免费成人高清视频| 欧美一区亚洲一区| 一本综合精品| 亚洲黄色性网站| 欧美成人精品高清在线播放| 欧美一区二区三区免费观看视频| 99精品99久久久久久宅男| 精品二区视频| 国产美女扒开尿口久久久| 欧美日韩久久久久久| 免费久久99精品国产自在现线| 欧美在线看片| 翔田千里一区二区| 亚洲自拍另类| 亚洲欧美日韩国产中文在线| 一本不卡影院| 一本色道久久综合亚洲精品高清| 亚洲二区三区四区| 欧美国产日本韩| 欧美wwwwww| 欧美高清视频一区二区| 乱中年女人伦av一区二区| 久久精品视频免费播放| 欧美一区二视频| 欧美一二区视频| 午夜宅男久久久| 亚洲欧美日韩成人高清在线一区| 一区二区欧美日韩视频| 亚洲小视频在线| 亚洲欧美成人一区二区三区| 亚洲视频碰碰| 亚洲欧美日韩中文在线制服| 中文一区字幕| 亚洲综合社区| 欧美一区日本一区韩国一区| 欧美一区二区三区在线观看视频| 欧美一区免费视频| 久久久久久久久伊人| 免费不卡在线观看av| 亚洲国产成人porn| 亚洲精品无人区| 中日韩男男gay无套 | 美女免费视频一区| 亚洲电影欧美电影有声小说| 亚洲国产婷婷香蕉久久久久久| 亚洲人成免费| 亚洲午夜三级在线| 久久久99国产精品免费| 欧美va日韩va| 国产精品国产自产拍高清av王其 | 欧美精品免费在线| 国产精品亚洲综合久久| 精品96久久久久久中文字幕无| 亚洲精品久久视频| 午夜影院日韩| 欧美激情精品久久久久久免费印度| 欧美黄色日本| 亚洲午夜av在线| 久久久久国产一区二区| 欧美区一区二区三区| 国产伦精品一区二区三区| 亚洲国产精品成人久久综合一区| 夜夜爽99久久国产综合精品女不卡| 翔田千里一区二区| 亚洲黑丝一区二区| 欧美在线免费视屏| 欧美日一区二区在线观看| 国内精品国产成人| 一区二区三区高清不卡| 久久久久久色| 一区二区三区www| 久久欧美肥婆一二区| 国产精品毛片va一区二区三区| 亚洲高清视频的网址| 亚洲欧美日韩综合| 亚洲精品国精品久久99热| 久久成人综合视频| 国产精品久久久久久久午夜| 亚洲国产一区二区三区a毛片| 欧美一区二区高清在线观看| 亚洲精品自在在线观看| 久久亚洲春色中文字幕| 国产乱码精品一区二区三区不卡| 日韩一区二区高清| 欧美激情第1页|