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

天行健 君子當(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>
            久久精品亚洲精品国产欧美kt∨| 亚洲人成在线观看一区二区| 午夜在线电影亚洲一区| 欧美在线亚洲一区| 狠狠色丁香婷婷综合久久片| 蜜臀av在线播放一区二区三区| 亚洲精品乱码久久久久久蜜桃91 | 羞羞视频在线观看欧美| 国产日韩1区| 免费人成精品欧美精品| 99视频在线观看一区三区| 小黄鸭视频精品导航| 狠狠色伊人亚洲综合成人| 欧美国产日本在线| 夜夜嗨网站十八久久| 久久久999成人| 亚洲精品一区二区在线观看| 国产精品劲爆视频| 久久久www成人免费精品| 亚洲精品欧美精品| 久久精品女人的天堂av| 99re6这里只有精品视频在线观看| 欧美视频在线观看免费网址| 久久精品国产欧美亚洲人人爽| 欧美肥婆在线| 久久精品理论片| 夜夜嗨av一区二区三区| 狠狠操狠狠色综合网| 欧美日韩一卡二卡| 久久美女艺术照精彩视频福利播放| 亚洲欧洲精品一区二区三区不卡| 久久久高清一区二区三区| 99这里只有久久精品视频| 国内自拍一区| 国产精品久久久久秋霞鲁丝| 欧美成人国产| 久久免费一区| 午夜精品福利电影| 一区二区三区导航| 亚洲激情网站| 模特精品在线| 久久久中精品2020中文| 亚洲欧美日韩天堂一区二区| 亚洲精品乱码| 亚洲国产一区二区精品专区| 国产亚洲欧洲| 国产精品狼人久久影院观看方式| 欧美fxxxxxx另类| 久久精品日韩一区二区三区| 亚洲新中文字幕| 亚洲精品日韩综合观看成人91 | 欧美大片一区二区三区| 久久国产成人| 午夜精品一区二区三区电影天堂| 9久re热视频在线精品| 亚洲丶国产丶欧美一区二区三区| 国产亚洲欧美一区二区三区| 国产精品视频免费一区| 国产精品扒开腿爽爽爽视频| 欧美女同视频| 欧美激情一区二区三区不卡| 女仆av观看一区| 免费人成精品欧美精品| 久久尤物视频| 久久香蕉国产线看观看av| 久久久噜久噜久久综合| 久久精品30| 久久人人97超碰精品888| 久久久久久久999| 久久久国产精彩视频美女艺术照福利 | 欧美日韩精品国产| 欧美—级a级欧美特级ar全黄| 麻豆成人精品| 欧美成人激情在线| 欧美人交a欧美精品| 欧美韩国一区| 欧美天堂在线观看| 国产精品午夜在线观看| 国产人成一区二区三区影院| 国产一区二区三区高清| 国内精品久久久久久影视8| 狠狠色综合一区二区| 在线日本成人| 亚洲精品少妇30p| 亚洲一区二区三区免费在线观看| 亚洲一区二区日本| 欧美一区二区在线视频| 久久在线免费观看视频| 欧美激情第8页| 亚洲精选国产| 亚洲在线视频观看| 久久久久se| 欧美激情视频网站| 国产精品久久久久毛片软件 | 欧美日韩国产在线观看| 欧美性猛交99久久久久99按摩| 国产精品毛片一区二区三区| 国产午夜精品在线| 亚洲人成亚洲人成在线观看图片 | 欧美伦理一区二区| 国产精品一区视频| 亚洲国产精品一区制服丝袜 | 亚洲国产精品va在线看黑人动漫| 日韩视频―中文字幕| 亚洲欧美日韩国产一区二区三区| 久久九九全国免费精品观看| 欧美韩日一区二区| 国产小视频国产精品| 亚洲精品一区二区三区在线观看| 亚洲特黄一级片| 老司机午夜免费精品视频| 一本久久知道综合久久| 久久精品二区亚洲w码| 欧美乱妇高清无乱码| 狠狠做深爱婷婷久久综合一区| 99在线精品视频在线观看| 久久精品在线观看| 亚洲精品免费看| 久久精品国产99国产精品澳门| 欧美日本一区二区三区| 激情伊人五月天久久综合| 亚洲午夜久久久久久久久电影院 | 午夜精品久久久久久久99热浪潮 | 亚洲欧洲日本mm| 欧美专区在线观看一区| 国产精品成人一区二区三区夜夜夜 | 欧美激情在线有限公司| 国产一区观看| 亚洲免费网站| 亚洲日本中文字幕免费在线不卡| 欧美伊人精品成人久久综合97| 欧美日韩不卡合集视频| 亚洲国产精品一区二区久| 久久精彩视频| 亚洲欧美国产日韩天堂区| 欧美日韩国产美女| 最近中文字幕mv在线一区二区三区四区 | 一本到高清视频免费精品| 欧美大成色www永久网站婷| 欧美一级视频免费在线观看| 欧美日韩一区二区在线视频| 亚洲日本欧美| 亚洲成人中文| 女人色偷偷aa久久天堂| 亚洲成色www久久网站| 久久久久国内| 欧美一区=区| 国产亚洲网站| 欧美在线一二三| 亚洲欧美春色| 国产精品视频免费| 欧美一区二区三区在线播放| 亚洲网站在线观看| 国产精品夫妻自拍| 亚洲综合视频一区| 一区二区三区 在线观看视频| 欧美日韩一区二区在线观看| av不卡在线观看| 亚洲免费黄色| 欧美午夜久久久| 亚洲欧美卡通另类91av| 亚洲影音先锋| 国产精品亚洲视频| 久久精品日韩一区二区三区| 欧美在线看片a免费观看| 国产一区二区三区久久 | 国产欧美日韩三区| 性视频1819p久久| 午夜伦欧美伦电影理论片| 国产欧美一区视频| 久久久av毛片精品| 久久久久久亚洲精品中文字幕| 精品电影在线观看| 亚洲国产高清aⅴ视频| 欧美日韩一区二区三区| 午夜精品久久| 欧美在线影院| 亚洲黄色成人久久久| 亚洲精品美女在线观看| 国产精品久久久久久超碰| 午夜精品福利电影| 久久精品电影| 亚洲精品久久久久久久久久久久久 | 久久高清国产| 久久综合一区二区| 99精品欧美一区二区蜜桃免费| 夜夜狂射影院欧美极品| 国产欧美一区二区在线观看| 免费看精品久久片| 欧美区日韩区| 久久精品亚洲一区二区| 麻豆精品91| 亚洲欧美电影在线观看| 欧美在线地址| 一本一本久久a久久精品综合麻豆| 一区二区日韩免费看| 好吊成人免视频| 亚洲精品一区二区三区婷婷月| 国产乱子伦一区二区三区国色天香| 久热re这里精品视频在线6|