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

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

游戲中物件的定義與使用(7)

 

本篇是游戲中物件的定義與使用(6)的續(xù)篇。

 

下載源碼和工程

 

cMapIcs類(lèi)的測(cè)試代碼:


 

創(chuàng)建游戲內(nèi)核【OO改良版】創(chuàng)建3D圖形引擎【OO改良版】的代碼為基礎(chǔ)進(jìn)行開(kāi)發(fā)。


 

/************************************************************************************
PURPOSE:
     map ics 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 "map_ics.h"
#include "mil.h"

#define MAX_ITEMS   1024

class cApp : public cFramework
{
private:  
    cCamera          m_camera;
    cLight           m_light;
    cFont            m_font;

    cInput           m_input;
    cInputDevice     m_keyboard;
    cInputDevice     m_mouse;    

    cMesh            m_scene_mesh;
    cNodeTreeMesh    m_node_tree_mesh;

    sItem            m_items[MAX_ITEMS];

    cMapIcs          m_map_ics;

    cMesh            m_item_mesh;
    cObject          m_item_object;

    cMesh            m_target_mesh;
    cObject          m_target_object;

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

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

        m_font.create("Arial", 16, TRUE, FALSE);
    
        
// enable lighting and setup light

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

        m_camera.build_view_matrix();        

        
// 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_scene_mesh.load("..\\Data\\Map.x", "..\\Data\\"))
            
return FALSE;

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

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

        
if(! m_map_ics.load("..\\Data\\MapItems.mi"))
            
return FALSE;
       
        
// load a generic item mesh and targeting mesh and setup their objects

        
if(! m_item_mesh.load("..\\Data\\Item.x", "..\\Data\\"))
            
return FALSE;
        m_item_object.create(&m_item_mesh);

        
if(! m_target_mesh.load("..\\Data\\Target.x", "..\\Data\\"))
            
return FALSE;
        m_target_object.create(&m_target_mesh);

        
// load in mil list

        ZeroMemory(m_items, 
sizeof(m_items));

        FILE* fp;

        
if((fp = fopen("..\\Data\\Default.mil", "rb")) != NULL)
        {
            fread(&m_items, 1, 
sizeof(m_items), fp);
            fclose(fp);
        }

        
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 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 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,
                                                  NULL))
        {
            x_move = 0.0f;
        }

        
if(m_node_tree_mesh.is_ray_intersect_mesh(m_x_pos, m_y_pos + m_above_floor, m_z_pos,
                                                  m_x_pos, m_y_pos + m_above_floor, m_z_pos + z_move,
                                                  NULL))
        {
            z_move = 0.0f;
        }

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

        
long item_index;

        
if(m_mouse.get_button_state(MOUSE_RBUTTON))
        {
            
// Lock it, so press down right mouse button will not drop item all along.
            m_mouse.set_lock(MOUSE_RBUTTON, TRUE);  

            
// drop an item - pick a random one
            while(1)
            {
                item_index = rand() % MAX_ITEMS;

                
if(m_items[item_index].name[0]) // found a valid item
                    break;
            }

            m_map_ics.add(item_index, 1,
                          m_x_pos + (
float)sin(m_camera.get_y_rotation()) * 200.0f,
                          m_y_pos,
                          m_z_pos + (
float)cos(m_camera.get_y_rotation()) * 200.0f,
                          NULL);
        }

        
// position camera and rotate based on mouse position

        m_camera.move(m_x_pos, m_y_pos + 100.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 light
        m_light.move(m_x_pos, m_y_pos + 100.0f, m_z_pos);
        g_d3d_device->SetLight(0, m_light.get_d3d_light());        

        cFrustum 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(0, 1.0f);     

        sMapItemPtr closest_item = NULL;

        
// begin render now
        if(SUCCEEDED(g_d3d_device->BeginScene()))        
        {            
            g_d3d_device->SetRenderState(D3DRS_ZENABLE, D3DZB_TRUE);
            g_d3d_device->SetRenderState(D3DRS_LIGHTING, TRUE);            

            
// render scene
            m_node_tree_mesh.render(&frustum, 0.0f);

            
// draw all items, scanning for closest one to viewer.

            sMapItemPtr item;
            
float closest;

            
for(item = m_map_ics.get_root_item(); item != NULL; item = item->next)
            {
                
// do not bother with child objects
                if(item->parent)
                    
continue;

                
// get the radius of the generic item object
                float radius;
                m_item_object.get_bounds(NULL, NULL, NULL, NULL, NULL, NULL, &radius);
        
                
// frustum check and draw it if visible
                if(! frustum.is_sphere_in(item->x_pos, item->y_pos, item->z_pos, radius))
                    
continue;

                m_item_object.move(item->x_pos, item->y_pos, item->z_pos);
                m_item_object.render();

                
// figure if current item is closest to viewer

                
float x_diff = (float) fabs(item->x_pos - m_x_pos);
                
float z_diff = (float) fabs(item->z_pos - m_z_pos);
                
float dist = x_diff * x_diff + z_diff * z_diff;

                
if(dist >= 100000.0f)
                    
continue;

                
if(closest_item == NULL || dist < closest)
                {
                    closest_item = item;
                    closest = dist;
                }                
            }

            
// rotate target and move into position
            if(closest_item)
            {
                m_target_object.rotate_rel(0.0f, (
float) time_elapsed * 0.01f, 0.0f);
                m_target_object.move(closest_item->x_pos, closest_item->y_pos + 50.0f, closest_item->z_pos);
                m_target_object.render();

                
// print item name

                
char text[256];

                sprintf(text, "index:%lu, name:%s, quantity:%lu",
                        closest_item->item_index, m_items[closest_item->item_index].name, closest_item->quantity);

                m_font.draw(text, 0, 0, 0, 0, 0xFFFFFFFF, DT_LEFT);
            }

            g_d3d_device->EndScene();            
        }

        present_display();

        
// check for picking up item, put here to make easier for clostet item.
        if(m_mouse.get_button_state(MOUSE_LBUTTON))
        {
            m_mouse.set_lock(MOUSE_LBUTTON, TRUE);

            
// pick up closest item
            if(closest_item)
                m_map_ics.remove(closest_item);
        }

        
return TRUE;
    }

    
bool shutdown()
    {
        m_map_ics.save("..\\Data\\MapItems.mi");

        
return TRUE;
    }
};

const float cApp::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, "map_ics_class", "map ics test", 
                      WS_BORDER | WS_CAPTION | WS_MINIMIZEBOX | WS_SYSMENU,
                      x_pos, y_pos, client_width, client_height))
    {
        
return -1;
    }

    cApp app;
    app.run();

    
return 0;
}
 

posted on 2007-11-07 19:44 lovedday 閱讀(393) 評(píng)論(0)  編輯 收藏 引用


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


公告

導(dǎo)航

統(tǒng)計(jì)

常用鏈接

隨筆分類(lèi)(178)

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

搜索

最新評(píng)論

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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区2区3区| 91久久香蕉国产日韩欧美9色| 久久久久久久久久久一区 | 欧美精品在线免费播放| 激情六月综合| 久久综合久色欧美综合狠狠| 欧美中文字幕第一页| 国产精品午夜视频| 午夜激情一区| 亚洲欧美日韩专区| 国产精品任我爽爆在线播放| 亚洲欧美国产高清| 亚洲一区二区四区| 国产一区二区三区黄视频| 亚洲自拍电影| 亚洲欧美激情精品一区二区| 欧美色视频在线| 99热免费精品| 欧美成人一品| 欧美国产另类| 亚洲欧美国产精品专区久久| 亚洲欧美日韩精品久久奇米色影视 | 欧美精品一区二区三区在线播放| 亚洲精品一区二区三区在线观看| 亚洲乱码一区二区| 国产精品欧美一区喷水 | 欧美性视频网站| 欧美一区=区| 久久男女视频| 在线视频免费在线观看一区二区| 亚洲一品av免费观看| 伊人久久综合| 亚洲人成在线观看| 国产精品一二一区| 你懂的国产精品| 毛片av中文字幕一区二区| 亚洲第一黄色网| 一片黄亚洲嫩模| 国内精品国产成人| 亚洲精选在线观看| 国产婷婷色一区二区三区四区 | 激情自拍一区| 99视频一区二区三区| 国产日韩欧美亚洲一区| 亚洲福利视频网| 国产欧美日韩视频一区二区三区| 欧美激情精品久久久久久变态| 欧美少妇一区| 老司机67194精品线观看| 欧美日韩成人综合天天影院| 亚洲欧美日韩精品久久| 欧美不卡三区| 久久久免费观看视频| 欧美伦理影院| 模特精品裸拍一区| 国产精品视频yy9099| 亚洲区欧美区| 国外成人在线视频网站| 亚洲少妇中出一区| 亚洲国产1区| 欧美一区二区黄色| 日韩亚洲国产精品| 久久一区二区三区国产精品| 亚洲免费在线观看视频| 欧美岛国激情| 午夜在线电影亚洲一区| 欧美日韩在线直播| 亚洲精品国偷自产在线99热| 亚洲二区免费| 久久久久国产一区二区| 欧美一区二区三区视频| 国产精品高清一区二区三区| 亚洲人成欧美中文字幕| 亚洲国产欧美日韩精品| 久久久久九九视频| 欧美一区二区三区在线观看视频| 欧美日韩日日夜夜| 最近看过的日韩成人| aa级大片欧美三级| 欧美激情一区二区三级高清视频| 欧美激情亚洲自拍| 亚洲韩国日本中文字幕| 免费看亚洲片| 亚洲高清视频的网址| 日韩视频免费观看| 美日韩精品免费观看视频| 欧美成人一二三| 国产精品www色诱视频| 亚洲国产精品成人一区二区 | 夜夜嗨av一区二区三区网站四季av| 国产亚洲成年网址在线观看| 亚洲视频999| 久久精品国产精品亚洲精品| 国产日韩欧美在线观看| 久久精品日韩一区二区三区| 久久午夜激情| 亚洲激情视频网站| 欧美日韩二区三区| 一区二区三区产品免费精品久久75| 亚洲综合激情| 国产主播一区| 欧美成人有码| 这里是久久伊人| 久久精品国产免费观看| 在线观看国产日韩| 欧美黄色一区| 亚洲欧美日本精品| 久久久久免费| 夜夜夜久久久| 国产精品久久久亚洲一区| 亚洲午夜视频在线观看| 久久男女视频| 一区二区三区欧美在线| 国产精品永久在线| 久久综合九色综合网站| 在线亚洲高清视频| 久久亚洲国产精品一区二区| 亚洲毛片播放| 国产视频一区免费看| 欧美刺激性大交免费视频| 一区二区三区高清不卡| 噜噜噜久久亚洲精品国产品小说| 日韩图片一区| 国产亚洲一区精品| 欧美日韩免费在线观看| 久久色在线播放| 一区二区不卡在线视频 午夜欧美不卡在| 欧美专区18| 亚洲国产专区| 国模精品一区二区三区色天香| 欧美刺激午夜性久久久久久久| 亚洲欧美日韩精品久久久| 欧美激情视频一区二区三区在线播放 | 麻豆国产精品va在线观看不卡| 在线性视频日韩欧美| 狠狠爱成人网| 国产精品色一区二区三区| 欧美sm视频| 久久国产精品久久久久久久久久| 日韩视频免费大全中文字幕| 欧美福利在线| 猛男gaygay欧美视频| 欧美伊人久久久久久久久影院| 一区二区欧美亚洲| 亚洲精品国产精品久久清纯直播| 欧美日韩亚洲视频一区| 久久久久久久999精品视频| 亚洲在线观看视频网站| 亚洲日本va午夜在线电影| 暖暖成人免费视频| 久久久久久成人| 欧美一区观看| 性欧美大战久久久久久久免费观看| 99精品国产高清一区二区| 91久久精品视频| 1000部国产精品成人观看| 国模精品一区二区三区色天香| 国产麻豆日韩| 国产精品自拍小视频| 国产精品theporn| 欧美激情视频一区二区三区不卡| 免费成人毛片| 欧美激情视频一区二区三区免费| 欧美成人精品| 欧美日本高清| 欧美黄色小视频| 国产精品久久久久久亚洲调教| 国产一区二区三区在线观看视频 | 国产精品色婷婷久久58| 国内精品一区二区| 日韩亚洲综合在线| 欧美综合77777色婷婷| 欧美国产日韩在线观看| 在线一区二区日韩| 久久久久网址| 国产精品黄色| 亚洲国产精品99久久久久久久久| 一区二区三欧美| 久久久久一本一区二区青青蜜月| 亚洲激精日韩激精欧美精品| 亚洲一区二区久久| 美女精品网站| 国产美女诱惑一区二区| 亚洲精品免费一区二区三区| 小嫩嫩精品导航| 亚洲精品免费看| 久久综合狠狠综合久久综合88| 国产精品美女久久久| 亚洲久久视频| 免费看精品久久片|