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

天行健 君子當自強而不息

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

 

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

 

下載源碼和工程

 

cMapIcs類的測試代碼:


 

創建游戲內核【OO改良版】創建3D圖形引擎【OO改良版】的代碼為基礎進行開發。


 

/************************************************************************************
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) 評論(0)  編輯 收藏 引用


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   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>
            亚洲精品一区在线观看| 午夜精品一区二区在线观看| 久久中文字幕一区二区三区| 激情亚洲网站| 欧美成人午夜剧场免费观看| 久久只精品国产| 亚洲精品国产欧美| 亚洲乱亚洲高清| 国产精品大片免费观看| 欧美一区二区三区四区在线| 午夜精品视频| 一区免费观看| 亚洲破处大片| 国产精品免费观看视频| 久久国产欧美日韩精品| 久久久亚洲影院你懂的| 9色精品在线| 亚洲欧美日韩另类| 亚洲国产一区视频| 一本一本a久久| 国产在线精品成人一区二区三区| 狂野欧美激情性xxxx欧美| 欧美国产日韩一区二区在线观看| 亚洲一区亚洲| 麻豆国产精品777777在线| 中文精品99久久国产香蕉| 欧美一级免费视频| 亚洲免费观看高清完整版在线观看熊| 亚洲最新中文字幕| 亚洲国产精品传媒在线观看| 99精品视频免费全部在线| 国产乱码精品一区二区三区忘忧草 | 欧美日本在线观看| 久久成人精品电影| 欧美精品久久99| 久久久精品日韩欧美| 欧美日本精品| 欧美国产日韩在线| 国产一区二区毛片| 99天天综合性| 亚洲区欧美区| 久久亚裔精品欧美| 久久精品一二三区| 欧美日韩精品在线观看| 老妇喷水一区二区三区| 国产美女诱惑一区二区| 亚洲精品亚洲人成人网| 亚洲电影在线观看| 欧美一区激情| 欧美一区亚洲| 国产精品theporn| 亚洲精品影视在线观看| 亚洲欧洲日韩在线| 老司机免费视频一区二区| 久久激情五月婷婷| 国产欧美日韩一区| 午夜日韩在线观看| 欧美影院在线播放| 国产精品美女xx| 中国av一区| 亚洲欧美日韩区| 国产精品国产馆在线真实露脸| 亚洲国产美女| 亚洲精品综合精品自拍| 欧美大片在线观看一区| 欧美激情一区二区久久久| 136国产福利精品导航| 久久久国产精品一区| 久久只精品国产| 在线电影欧美日韩一区二区私密| 久久成人国产精品| 六月天综合网| 亚洲国产欧美在线| 欧美久久久久久久久| 99av国产精品欲麻豆| 中日韩视频在线观看| 国产精品sss| 性娇小13――14欧美| 久久久99免费视频| 在线精品一区| 欧美国产日韩免费| 一本色道久久88综合日韩精品| 亚洲在线网站| 黄色成人在线观看| 免费观看成人网| 亚洲精品一区二区三区蜜桃久| 一区二区三区精密机械公司 | 国产欧美亚洲一区| 久久成人久久爱| 欧美刺激午夜性久久久久久久| 亚洲激情小视频| 国产精品r级在线| 久久av在线看| 亚洲韩日在线| 羞羞色国产精品| 亚洲成在人线av| 欧美日韩一区二区高清| 亚洲一区二区四区| 久久综合久久久久88| 日韩网站在线观看| 国产欧美精品一区二区三区介绍| 久久av一区二区三区| 亚洲精品日韩激情在线电影| 亚洲欧美日韩国产中文| **性色生活片久久毛片| 欧美精品久久一区| 欧美一级久久| 亚洲美女精品久久| 久久裸体视频| 亚洲天堂免费观看| 伊甸园精品99久久久久久| 欧美日韩精品二区第二页| 久久精品国产亚洲高清剧情介绍| 最新国产精品拍自在线播放| 久久国产精品72免费观看| 亚洲精品影院| 精品不卡一区| 国产欧美一区二区三区久久 | 午夜精品久久久久久久蜜桃app| 亚洲大胆av| 久久婷婷色综合| 亚洲视频综合| 亚洲经典在线| 韩国在线视频一区| 国产精品视频yy9099| 欧美国产精品| 模特精品在线| 久久激五月天综合精品| 亚洲影视中文字幕| 在线一区二区三区四区| 亚洲裸体视频| 亚洲精品少妇网址| 亚洲国产一区视频| 欧美超级免费视 在线| 久久久久综合一区二区三区| 亚洲欧美一级二级三级| 亚洲素人一区二区| 中文国产成人精品| 一区二区三区高清在线| 99天天综合性| 一区二区高清在线| 夜夜嗨一区二区三区| 亚洲美女区一区| 一区二区三区精品在线| 9久re热视频在线精品| 日韩视频精品在线观看| 99视频一区二区三区| 一区二区动漫| 亚洲视频图片小说| 亚洲欧美另类中文字幕| 亚洲你懂的在线视频| 亚洲免费影视| 久久激情五月丁香伊人| 久久手机精品视频| 麻豆九一精品爱看视频在线观看免费| 久久久久99| 欧美丰满少妇xxxbbb| 欧美成人福利视频| 亚洲国产日韩在线一区模特| 亚洲日本欧美日韩高观看| 日韩视频国产视频| 在线一区二区三区做爰视频网站| 亚洲婷婷综合色高清在线| 亚洲欧美日韩成人| 久久久亚洲精品一区二区三区 | 久久久综合香蕉尹人综合网| 欧美xxx在线观看| 欧美日韩一区二区三区免费看| 欧美日韩伊人| 国产午夜精品视频免费不卡69堂| 国内激情久久| 99国产精品久久久久老师| 亚洲综合色在线| 久久中文欧美| 亚洲国产精品一区二区www在线| 日韩午夜一区| 久久福利精品| 欧美片在线观看| 国产亚洲欧美一区二区| 亚洲日本精品国产第一区| 亚洲欧美日韩精品久久| 老司机亚洲精品| 一本色道久久综合亚洲精品小说| 欧美一级二区| 欧美日本在线| 亚洲大片av| 亚洲图片欧美一区| 欧美成人免费在线观看| 亚洲视频欧洲视频| 久热精品视频| 国产精品一卡| 一本久道久久综合中文字幕| 久久国产欧美精品| 日韩视频在线一区二区| 久久天天躁狠狠躁夜夜av| 国产精品视频| 亚洲小说区图片区| 亚洲电影下载| 久久美女性网| 国产亚洲欧美aaaa|