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

天行健 君子當自強而不息

2D和3D圖形引擎的混合(1)

 

在圖形技術的應用中,既沒有什么限制,也沒有什么必須遵守的規則。也就是說,沒有限制使用二維圖形或三維圖形,完全可以將它們兩者無損地混合在一起。

 

在三維中繪制二維貼片

需要一個代表游戲層次的三維網格模型,如下圖所示:

一個角色在三維世界里四處移動(通常是沿著一個軸線移動),當角色移動時,攝像機也跟著移動。攝像機需要停留在一個比角色較高的平移位置上,這樣就會產生出全三維的層次效果。不需要別的額外操作,只要加載一個代表層次的網格模型,創建一組代表了物體(例如玩家角色)的二維貼片,并將每件東西正確地排列繪制到每幀中即可。

下載源碼和工程

代碼:

/************************************************************************************
PURPOSE:
     2D in 3D test.
************************************************************************************/


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

#define TILE_SIZE 64

enum DIR { LEFT = 0, RIGHT };

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

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

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

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

        m_level_object.create(&m_level_mesh);

        
// load the 2D texture
        if(! m_2d_object.load("..\\Data\\Tiles.bmp", D3DCOLOR_RGBA(0, 0, 0, 255), D3DFMT_A1R5G5B5))
            
return FALSE;

        
// set player position
        m_x_pos = -900.0f;
        m_y_pos = m_z_pos = 0.0f;        

        
// enable lighting and setup light

        g_d3d_device->SetRenderState(D3DRS_LIGHTING, TRUE);
        set_ambient_light(0, 0, 0);
        g_d3d_device->LightEnable(0, TRUE);        
        
        
// create a directional light to illuminate the scene

        m_light.set_default_state();
        m_light.set_type(D3DLIGHT_DIRECTIONAL);
        m_light.set_diffuse(192, 192, 192);
        m_light.set_ambient(0, 0, 0);
        m_light.point(0.0f, 60.0f, -100.0f, 0.0f, 0.0f, 0.0f);

        m_camera.set_default_state();

        m_font.create("Arial", 16, TRUE, FALSE);
        
        
return TRUE;
    }

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

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

        
// read keyboard data        
        m_keyboard.read();

        
// process input and update everything, ESC quits program.
        if(m_keyboard.get_key_state(KEY_ESC))
            
return FALSE;
        
        
// process movement
        float x_move = 0.0f;

        
if(m_keyboard.get_key_state(KEY_LEFT))
            x_move =  -(
float)(time_elapsed * 0.5f);

        
if(m_keyboard.get_key_state(KEY_RIGHT))
            x_move =  (
float)(time_elapsed * 0.5f);

        uchar red, green, blue;

        m_light.get_diffuse(&red, &green, &blue);

        
if(m_keyboard.get_key_state(KEY_ADD))
        {
            
if(red < 255)
                ++red;

            
if(green < 255)
                ++green;

            
if(blue < 255)
                ++blue;

            m_light.set_diffuse(red, green, blue);
        }

        
if(m_keyboard.get_key_state(KEY_SUBTRACT))
        {
            
if(red > 0)
                --red;

            
if(green > 0)
                --green;

            
if(blue > 0)
                --blue;

            m_light.set_diffuse(red, green, blue);
        }

        
char diffuse_msg[256];
        sprintf(diffuse_msg, "diffuse color: red = %d, green = %d, blue = %d\n", red, green, blue);

        
// check for intersections (allowing climbing as well)

        
float dist, diff;               

        diff = (x_move < 0.0f ? -32.0f : 32.0f);

        D3DXMESH_PTR d3d_mesh = m_level_mesh.get_root_mesh_info()->m_d3d_mesh;

        
if(is_ray_intersect_mesh(d3d_mesh,
                                 m_x_pos + diff,          m_y_pos + m_above_floor, m_z_pos,
                                 m_x_pos + diff + x_move, m_y_pos + m_above_floor, m_z_pos,
                                 &dist))
        {
            x_move = 0.0f;
        }

        
// fix height of player
        m_y_pos = closest_height_below_object(d3d_mesh, m_x_pos + x_move, m_y_pos + m_above_floor, m_z_pos);

        
static float frame = 0.0f;
        
static enum DIR dir = RIGHT;

        
// update animation frame
        if(! float_equal(x_move, 0.0f))
        {
            
// change direction of travel (for aniamtion)
            if(x_move < 0.0f)   // move left
            {
                frame -= (time_elapsed * 0.015f);

                
if(frame < 0.0f)
                    frame = 7.0f;

                dir = LEFT;
            }
            
else    // move right
            {
                frame += (time_elapsed * 0.015f);

                
if(frame >= 8.0f)
                    frame = 0.0f;

                dir = RIGHT;
            }
        }
        
else
        {
            frame = 3.0f;
        }

        
// move player
        m_x_pos += x_move;

        
// position camera by character position
        m_camera.point(m_x_pos, m_y_pos + 200.0f, m_z_pos - 500.0f,
                       m_x_pos, m_y_pos, m_z_pos);
        
        
// set camera
        g_d3d_device->SetTransform(D3DTS_VIEW, m_camera.get_view_matrix());       
        
        
// render everything
        clear_display(0, 1.0f);                       

        
// begin render now
        if(SUCCEEDED(g_d3d_device->BeginScene()))        
        {
            
// render the level mesh
            g_d3d_device->SetRenderState(D3DRS_ZENABLE, D3DZB_TRUE);
            g_d3d_device->SetLight(0, m_light.get_d3d_light());
            m_level_object.render();

            
// render 2D object

            g_d3d_device->SetRenderState(D3DRS_ZENABLE, D3DZB_FALSE);
            enable_alpha_testing();
            
            g_d3d_sprite->Begin(0);

            
ulong tile_index, tile_x, tile_y;

            tile_index = (dir == LEFT ? 1 : 0) * 8 + (
long)frame;

            tile_x = tile_index % 4 * TILE_SIZE;
            tile_y = tile_index / 4 * TILE_SIZE;
            
            m_2d_object.draw(140, 60, tile_x, tile_y, TILE_SIZE, TILE_SIZE, 2.0f, 2.0f, 0xFFFFFFFF);

            g_d3d_sprite->End();

            disable_alpha_testing();

            m_font.draw(diffuse_msg, 0, 0, 0, 0, D3DCOLOR_RGBA(255, 255, 255, 255), DT_LEFT);

            g_d3d_device->EndScene();            
        }

        present_display();

        
return TRUE;
    }

    BOOL shutdown()
    {
        destroy_display();

        
return TRUE;
    }

private:  
    CAMERA          m_camera;
    LIGHT           m_light;
    FONT            m_font;
       
    INPUT           m_input;
    INPUT_DEVICE    m_keyboard; 

    TEXTURE         m_2d_object;

    MESH            m_level_mesh;    
    OBJECT          m_level_object;

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

const float APP::m_above_floor = 84.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;

    DWORD window_style = WS_BORDER | WS_CAPTION | WS_MINIMIZEBOX | WS_SYSMENU;

    
if(! build_window(inst, "2d_in_3d_class", "2D in 3D Test", window_style,
                      x_pos, y_pos, client_width, client_height))
    {
        
return -1;
    }

    APP app;
    app.run();

    
return 0;
}
 

使用+或-改變光源的散射光屬性,左右箭頭鍵控制怪物行走。


截圖:


posted on 2007-10-27 15:38 lovedday 閱讀(663) 評論(1)  編輯 收藏 引用

評論

# re: 2D和3D圖形引擎的混合(1) 2007-10-28 23:29 neoragex2002

這個技法在很多射擊游戲中已經用到了。  回復  更多評論   


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


公告

導航

統計

常用鏈接

隨筆分類(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视频精品全部免费在线| 国产亚洲人成a一在线v站| 久久国产精品一区二区| 在线成人性视频| 欧美网站大全在线观看| 欧美激情va永久在线播放| 欧美一区激情视频在线观看| 91久久亚洲| 久久影院午夜片一区| 欧美亚洲网站| 久久精品综合网| 欧美成人午夜77777| 欧美成人一区二区三区| 欧美激情精品久久久久久免费印度 | 午夜日韩在线观看| 亚洲网友自拍| 久久嫩草精品久久久久| 亚洲风情在线资源站| 亚洲最新视频在线播放| 亚洲欧美日韩一区| 欧美v亚洲v综合ⅴ国产v| 国产精品久久久久久久久婷婷| 欧美激情视频一区二区三区免费 | 在线观看一区| 日韩午夜av| 老色批av在线精品| 亚洲一区二区三区视频| 欧美超级免费视 在线| 国产欧美一区二区白浆黑人| **欧美日韩vr在线| 久久精品亚洲乱码伦伦中文| 亚洲黄色免费网站| 久久久精品一区| 国产亚洲精品久久久| 亚洲欧美国产精品桃花| 最新高清无码专区| 欧美.日韩.国产.一区.二区| 激情综合色综合久久| 久久久久国产精品厨房| 午夜免费电影一区在线观看| 欧美日韩中文字幕| 亚洲午夜日本在线观看| av成人毛片| 国产精品丝袜久久久久久app| 亚洲欧美国产精品桃花| 亚洲一区国产精品| 国产日本欧美一区二区| 欧美成人中文字幕在线| 欧美国产日韩二区| 亚洲一区二区三区高清| 欧美一区二区三区啪啪| 亚洲国产精品一区二区www在线 | 久久精品中文字幕一区二区三区| 国产精品久久久久久久久| 久久久久久久一区| 欧美不卡在线| 午夜电影亚洲| 美国成人毛片| 欧美一级专区| 久久综合久久综合久久综合| 中日韩高清电影网| 噜噜噜91成人网| 欧美一级二级三级蜜桃| 欧美高清日韩| 久久综合网络一区二区| 欧美日韩国产一级片| 免费中文字幕日韩欧美| 国产精品一区二区三区观看| 亚洲黄色一区二区三区| 亚洲电影在线播放| 久久久一二三| 老色鬼精品视频在线观看播放| 国产乱理伦片在线观看夜一区| 亚洲国产视频直播| 最新日韩av| 欧美大尺度在线| 免费日本视频一区| 尤物在线观看一区| 噜噜噜91成人网| 亚洲精品国产品国语在线app| 一本色道久久综合亚洲精品高清 | 在线亚洲美日韩| 亚洲午夜视频| 国产日韩欧美亚洲一区| 欧美一区二区国产| 国产女主播一区二区| 香蕉亚洲视频| 女女同性精品视频| 日韩视频在线一区二区| 国产精品久久久久久久久久久久久 | 欧美一区国产二区| 麻豆成人综合网| 一区二区三区 在线观看视频| 欧美日韩不卡一区| 久久99在线观看| 亚洲国产精品一区制服丝袜| 午夜国产不卡在线观看视频| 韩日视频一区| 欧美性片在线观看| 久久久久久网| 亚洲一区视频在线| 亚洲国产日本| 欧美成人午夜激情在线| 久久久久欧美精品| 久久国产精品99精品国产| 在线观看视频欧美| 国产欧美日韩中文字幕在线| 免费高清在线视频一区·| 亚洲天堂网站在线观看视频| 亚洲成人在线视频播放| 久久成年人视频| 久久国产日韩| 久久国产婷婷国产香蕉| 亚洲欧美乱综合| 亚洲一区二区不卡免费| 日韩一二三在线视频播| 99国产精品视频免费观看一公开 | 麻豆成人91精品二区三区| 亚洲女ⅴideoshd黑人| 亚洲一区二区三区四区视频| 亚洲久久视频| 亚洲婷婷综合久久一本伊一区| 日韩午夜av| 性欧美xxxx大乳国产app| 亚洲在线播放| 欧美影院成年免费版| 久久久亚洲高清| 亚洲国产精选| 亚洲一二三区视频在线观看| 欧美一二三视频| 久久精品三级| 欧美美女日韩| 伊甸园精品99久久久久久| 亚洲激情不卡| 欧美在线高清视频| 欧美成人69av| 亚洲深夜激情| 久久午夜色播影院免费高清| 欧美日韩专区| **网站欧美大片在线观看| 亚洲欧美不卡| 亚洲三级免费| 久久综合伊人77777蜜臀| 欧美日韩一区二区欧美激情 | 亚洲欧美日韩天堂| 免费h精品视频在线播放| 国产乱码精品一区二区三区五月婷| 一区二区亚洲精品| 欧美一区二区三区另类| 最新国产精品拍自在线播放| 欧美专区亚洲专区| 国产精品久久久对白| 午夜精品久久| 亚洲一区二区三区高清| 欧美电影免费观看高清完整版| 国产精品久久久久久久电影| 欧美人与性动交cc0o| 久久成人一区二区| 欧美日韩hd| 亚洲一区二区三区免费观看 | 精品99一区二区三区| 亚洲欧美影音先锋| 亚洲一区在线播放| 国产欧美日韩亚洲| 久久成人资源| 亚洲三级国产| 国产精品久久77777| 久久精品午夜| 男男成人高潮片免费网站| 91久久亚洲| 亚洲视频1区| 久久久久久999| 亚洲综合视频一区| 欧美一区二区视频在线观看2020| 亚洲第一精品夜夜躁人人躁| 亚洲黄色av| 娇妻被交换粗又大又硬视频欧美| 免费永久网站黄欧美| 中文亚洲免费| 亚洲国产激情| 欧美中文字幕视频| 亚洲一级网站| 欧美色道久久88综合亚洲精品| 久久久综合激的五月天| 亚洲欧美另类久久久精品2019| 亚洲福利一区| 欧美一区日本一区韩国一区| 亚洲天堂男人| 欧美日韩国产精品| 欧美福利精品| 悠悠资源网久久精品| 午夜精品理论片| 亚洲欧美日韩久久精品| 欧美成人69av| 91久久午夜| 亚洲视频电影在线| 欧美jizz19性欧美| 亚洲国产成人在线| 免费不卡在线视频| 欧美国产另类|