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

天行健 君子當自強而不息

創建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>
            亚洲国产精品一区二区第一页 | 亚洲美女黄色| 精品福利免费观看| 一区二区视频在线观看| 一区二区亚洲精品| 一区二区三区www| 久久精品噜噜噜成人av农村| 久久九九有精品国产23| 麻豆国产va免费精品高清在线| 另类图片国产| 一区二区不卡在线视频 午夜欧美不卡在| 亚洲精品在线观看视频| 亚洲欧美日韩一区| 欧美男人的天堂| 国精品一区二区| 午夜亚洲性色视频| 亚洲激情二区| 久久久久九九九九| 国产精品老女人精品视频| 在线精品在线| 久久久天天操| 亚洲制服少妇| 欧美激情一区二区三区在线视频观看| 国产日韩在线看| 亚洲人午夜精品| 久久视频在线看| 亚洲午夜伦理| 国产精品入口福利| 香蕉尹人综合在线观看| 亚洲日本欧美天堂| 欧美日韩福利视频| 最新日韩在线视频| 欧美激情一区二区| 欧美—级高清免费播放| 一区二区三区视频在线| 欧美午夜精品久久久| 亚洲天堂黄色| 亚洲欧美偷拍卡通变态| 国产精品一区在线观看| 久久视频一区二区| 麻豆精品视频| 亚洲欧美中文日韩v在线观看| 一本一本久久| 1769国产精品| 日韩亚洲欧美成人一区| 国产精品成人国产乱一区| 亚洲砖区区免费| 久久久无码精品亚洲日韩按摩| 国外成人在线视频网站| 亚洲精品一区二区三区福利| 国产精品海角社区在线观看| 久久精彩视频| 欧美日韩亚洲激情| 久久久久成人精品| 国产精品免费观看视频| 亚洲第一综合天堂另类专| 国产精品久久久久久妇女6080 | 久久综合九色综合欧美就去吻| 国产精品综合色区在线观看| 亚洲女人天堂av| 免费成人av在线看| 午夜亚洲伦理| 欧美三级在线视频| 亚洲激情精品| 亚洲欧洲日本专区| 久久精品国产免费看久久精品| 99pao成人国产永久免费视频| 亚洲女人天堂av| 亚洲欧美综合网| 欧美日韩中国免费专区在线看| 欧美大片91| 亚洲欧洲日本mm| 欧美日韩国产综合视频在线观看中文| 免费亚洲网站| 亚洲靠逼com| 欧美日本一区| 亚洲欧美色婷婷| 久久精品理论片| 1204国产成人精品视频| 欧美电影免费观看网站| 亚洲国产成人午夜在线一区| 亚洲国产日韩欧美在线图片 | 亚洲第一级黄色片| 亚洲高清免费视频| 欧美日韩一区综合| 欧美在线免费| 亚洲国产裸拍裸体视频在线观看乱了 | 99精品福利视频| 亚洲国产精品va在线看黑人动漫| 亚洲特级毛片| 欧美成人一区二区三区在线观看 | 亚洲激情在线| 国产精品国产成人国产三级| 欧美制服丝袜第一页| 亚洲精品综合久久中文字幕| 久久久www成人免费精品| 99伊人成综合| 亚洲欧洲偷拍精品| 亚洲高清资源综合久久精品| 国产精品久久久久久久久| 欧美高清视频| 麻豆成人综合网| 免费h精品视频在线播放| 亚洲欧美日韩中文视频| 一本色道久久加勒比88综合| 亚洲黑丝在线| 欧美顶级少妇做爰| 欧美黄色影院| 亚洲伦理精品| 亚洲免费在线视频| 亚洲欧美日韩精品久久久久| 亚洲自啪免费| 久久人人爽人人爽| 久久久综合激的五月天| 欧美大片一区| 欧美天天影院| 亚洲高清在线观看| 亚洲精品偷拍| 亚洲综合首页| 欧美成人网在线| 日韩视频第一页| 欧美一区二区免费观在线| 性一交一乱一区二区洋洋av| 久久在线观看视频| 欧美日韩免费观看一区 | 性一交一乱一区二区洋洋av| 亚洲视频免费在线观看| 久久精品av麻豆的观看方式| 欧美在线观看日本一区| 蜜臀久久99精品久久久久久9| 欧美精品久久久久久久久老牛影院| 欧美日产一区二区三区在线观看| 国产精品久久午夜夜伦鲁鲁| 亚洲国产欧美日韩精品| 亚洲免费视频成人| 欧美国产视频日韩| 久久久久久久97| 美国成人毛片| 久久国产精彩视频| 国产精品自拍在线| 亚洲欧美日韩国产一区二区三区| 麻豆久久婷婷| 久久夜色精品国产亚洲aⅴ| 欧美丝袜第一区| 西西裸体人体做爰大胆久久久| 亚洲精品久久久久久久久久久| 久久精品免费观看| 韩国精品在线观看| 免费久久99精品国产自| 久久久久久九九九九| 国产一区二区三区在线观看视频 | 欧美日韩视频在线观看一区二区三区| 国产人久久人人人人爽| 久久精品视频亚洲| 欧美在线视频二区| 国内成人自拍视频| 欧美国产精品专区| 国产精品yjizz| 久久国产精品黑丝| 久久久www成人免费无遮挡大片| 国产一区二区在线观看免费播放| 免费的成人av| 免费永久网站黄欧美| 亚洲特级毛片| 久久久国产视频91| 一区免费视频| 亚洲精品午夜| 国产日韩一区| 91久久精品日日躁夜夜躁国产| 国产精品v亚洲精品v日韩精品 | 99精品福利视频| 国产九九精品视频| 亚洲三级性片| 亚洲夫妻自拍| 午夜亚洲福利在线老司机| 亚洲精品中文字幕在线观看| 香蕉精品999视频一区二区| 亚洲国产天堂久久国产91| 亚洲欧美韩国| 午夜久久久久久| 欧美三级网址| 99精品国产福利在线观看免费| 在线免费观看日韩欧美| 欧美一区二区大片| 久久国产精品久久久久久| 国产精品白丝av嫩草影院| 亚洲精品日韩激情在线电影 | 欧美大片免费久久精品三p| 美女视频黄免费的久久| 国产综合欧美| 久久字幕精品一区| 欧美激情中文字幕在线| 91久久国产综合久久91精品网站| 久久久五月天| 亚洲精品女人| 亚洲一区不卡| 韩国在线一区| 欧美日本视频在线| 羞羞视频在线观看欧美| 麻豆成人av|