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

Cpper
C/C++高級工程師 Android高級軟件工程師 IT集成工程師 音頻工程師 熟悉c,c++,java,c#,py,js,asp等多種語言 程序猿

線程 Joining and Detaching相關(guān)函數(shù)4個
pthread_joinpthread_detach

pthread_attr_setdetachstate

pthread_attr_getdetachstate
Joining的作用
Joining是線程同步的方法之一
當(dāng)且僅當(dāng)線程被設(shè)置為joinable時其可被Joining
一個例子:
#include 
<pthread/pthread.h>
#include 
<stdio.h>
#include 
<stdlib.h>
#include 
<math.h>
#define NUM_THREADS    4

void *BusyWork(void *t)
{
       
int i;
       
long tid;
       
double result=0.0;
       tid 
= (long)t;
       printf(
"Thread %ld starting\n",tid);
       
for (i=0; i<1000000; i++)
       {
             result 
= result + sin(i) * tan(i);
       }
       printf(
"Thread %ld done. Result = %e\n",tid, result);
       pthread_exit((
void*) t);
}

int main (int argc, char *argv[])
{
      pthread_t thread[NUM_THREADS];
      pthread_attr_t attr;
      
int rc;
      
long t;
      
void *status;

      
//! 設(shè)置線程屬性
      pthread_attr_init(&attr);
      pthread_attr_setdetachstate(
&attr, PTHREAD_CREATE_JOINABLE);

      
for(t=0; t<NUM_THREADS; t++)
      {
            printf(
"Main: creating thread %ld\n", t);
            rc 
= pthread_create(&thread[t], &attr, BusyWork, (void *)t);
            
if (rc)
            {
                    printf(
"ERROR; return code from pthread_create()is %d\n", rc);
                    exit(
-1);
            }
        }

        
//! 銷毀線程屬性
        pthread_attr_destroy(&attr);
        
for(t=0; t<NUM_THREADS; t++)
        {
               rc 
= pthread_join(thread[t], &status);
               
if (rc)
              {
                      printf(
"ERROR; return code from pthread_join()is %d\n", rc);
                      exit(
-1);
               }
               printf(
"Main: completed join with thread %ld having a status of %ld\n",t,(long)status);
       }

       printf(
"Main: program completed. Exiting.\n");
       pthread_exit(NULL);
}

posted @ 2010-12-02 10:15 ccsdu2009 閱讀(365) | 評論 (0)編輯 收藏
 
1.使用pthread的理由
      2個字:簡單
2.pthread組件
      thread,
      mutex,     
      condition var
      synchronization
3.線程的終止和產(chǎn)生
小例:
#include <pthread/pthread.h>
#include <stdio.h>
#define NUM_THREADS     5

void *PrintHello(void *threadid)
{
      long tid;
      tid = (long)threadid;
      printf("Hello World! It's me, thread #%ld!\n", tid);
      pthread_exit(NULL);
}

int main (int argc, char *argv[])
{
     pthread_t threads[NUM_THREADS];
     int rc;
     long t;
     for(t=0; t<NUM_THREADS; t++)
     {
          printf("In main: creating thread %ld\n", t);
          rc = pthread_create(&threads[t], NULL, PrintHello, (void *)t);
          if (rc)
          {
               printf("ERROR; return code from pthread_create() is %d\n", rc);
               exit(-1);
          }
      }
     pthread_exit(NULL);
     return 0;
}

通過pthread_create來創(chuàng)建線程
    其第一個參數(shù)為線程id,第二個為線程屬性,第三個為線程函數(shù),最后一個為數(shù)據(jù)參數(shù)

那么線程如何終止呢:
1.從運行函數(shù)終止
2.調(diào)用pthread_exit終止
3.調(diào)用pthread_cance
4.進程終止

向線程傳遞參數(shù)
#include <pthread/pthread.h>
#include <stdio.h>
#include <string>
#include <iostream>
#define NUM_THREADS     5

struct Data
{
        std::string name;
};

Data* data_impl;

void *PrintHello(void* data_ptr)
{
         struct Data* data;
         data = (Data*)data_ptr;
         std::cout<<data->name<<std::endl;
         pthread_exit(NULL);
}

int main (int argc, char *argv[])
{
      pthread_t threads[NUM_THREADS];
      data_impl = new Data[NUM_THREADS];
      data_impl[0].name = "T1";
      data_impl[1] .name= "T2";
      data_impl[2] .name= "T3";
      data_impl[3] .name= "T4";
      data_impl[4] .name= "T5";
      for(int t=0; t<NUM_THREADS; t++)
      {
          int rc = pthread_create(&threads[t], NULL, PrintHello,&data_impl[t]);
      }
      pthread_exit(NULL);
      delete []data_impl;
      return 0;
}

其他相關(guān)線程庫:
1.zthread,
2.opentherad
3.boost therad
4.原生態(tài)的平臺線程函數(shù)

posted @ 2010-12-01 14:02 ccsdu2009 閱讀(1820) | 評論 (0)編輯 收藏
 
boost是一個很好的庫
但是并不是完美的
在使用的時候需要詳細(xì)注意

    std::string tag;
    boost::tokenizer
<> tok(std::string("貓 狗 豬"));
    
for(boost::tokenizer<>::iterator beg=tok.begin();beg!=tok.end();++beg)
    {
        tag 
+= *beg;
        tag 
+= "+";
    }
    std::cout<<tag<<std::endl;
大家說說結(jié)果吧

posted @ 2010-11-19 15:56 ccsdu2009 閱讀(3013) | 評論 (12)編輯 收藏
 
1.原DLL分為2個gcore和device(這樣可以在其他軟件中使用前者)
2.支持xp,vista,win7,linux操作系統(tǒng)
3.支持msvc7.1,8.0,9.0,mingw,bcb,dev++,codeblock編譯器系列
4.提供方便易用的xml序列化框架一個
5.提供可插式圖形插件接口
6.移除原有的RefPtr對象改用boost系列智能指針
7.移除原有的Manager對象
8.修改了filesystem接口
9.在UI中增加了柵格主題,UI工廠,UI_ProgressBar增加了進度的顯示
10.粒子系統(tǒng)中增加了粒子工廠
11.移除了原有的Cursor類
12.移除線程類對象(改用boost thread.)
13.增加了Helper文件以方便用戶
14.增加了Sprite2對象

posted @ 2010-11-11 16:45 ccsdu2009 閱讀(668) | 評論 (0)編輯 收藏
 
蓋莫引擎2.3.0算是做完了
不過這個做的很不盡人意(不過沒關(guān)系咱慢慢做只要堅持O(∩_∩)O~)
一個問題就是引擎中的RefPtr設(shè)計有點問題
索性下個引擎版本就是用boost庫吧
免得一些基礎(chǔ)需要自己寫

要使用boost庫其中的智能指針必不可少
林林總總有好幾個類型
不過常用得還是3個
scoped_ptr,
shared_ptr,
weak_ptr
這里先說shared_ptr
它還是引用計數(shù)類型的指針咯
貌似比較好用(但是根本還是在于使用的人)
為了正確使用它需要注意幾個問題
1.多線程環(huán)境和循環(huán)引用
    應(yīng)該配合weak_ptr
2.使用了shared_ptr就不應(yīng)該使用其他內(nèi)存管理機制
3.不要構(gòu)造臨時的shared_tr作為函數(shù)參數(shù)
4.其他...
   

posted @ 2010-10-27 09:57 ccsdu2009 閱讀(2058) | 評論 (6)編輯 收藏
 
     摘要: Code highlighting produced by Actipro CodeHighlighter (freeware)http://www.CodeHighlighter.com/-->【基本介紹】蓋莫音頻引擎SDK1.6.0(類似fmod音頻api)原本為蓋莫游戲引擎開發(fā)當(dāng)前支持win7,xmp,vista操作系統(tǒng)支持10種音頻格式:mp3,ogg,wav,au,aiff,mod,it...  閱讀全文
posted @ 2010-10-26 08:57 ccsdu2009 閱讀(831) | 評論 (0)編輯 收藏
 
接上篇
我們接著說UI部分的控件基類
控件基類應(yīng)該具備的要素
1.按名生成
2.控件尺寸
3.控件大小
4.控件狀態(tài)
5.對消息事件的處理
6.控件渲染
7.控件檢測
8.控件文本
然后具體代碼如下:
///////////////////////////////////////////////////////////
/// 定義UI控件基類
///////////////////////////////////////////////////////////
class GAPI UI_Widget : public SlotHolder,public UI_EventHandler,public Object
{
public:
    typedef std::list
<UI_EventListener*> UIEventListener;
    typedef std::list
<UI_EventListener*>::iterator UIEventListenerItr;
public:
    
////////////////////////////////////////////////////////
    
/// 窗體構(gòu)造和析構(gòu)
    
////////////////////////////////////////////////////////
    explicit UI_Widget(UI_Widget* parent = NULL,const engine_wstring& text = L"widget");
    
virtual ~UI_Widget();
public:
    
////////////////////////////////////////////////////////
    
/// 獲取,設(shè)置設(shè)置窗體文本
    
////////////////////////////////////////////////////////
    engine_wstring GetText()const{return text_;}
    
void SetText(const engine_wstring& text);
public:
    
////////////////////////////////////////////////////////
    
/// 窗體大小和尺寸
    
////////////////////////////////////////////////////////
    Size  GetSize()const;
    
void  SetSize(const Size& size);
    Point GetPosition()
const;
    
void  SetPosition(const Point& point);

    
////////////////////////////////////////////////////////
    
/// 獲取窗體推薦大小
    
////////////////////////////////////////////////////////
    virtual Size GetRecommendedSize()const;
public:
    
////////////////////////////////////////////////////////
    
/// 檢測給定點下控件
    
////////////////////////////////////////////////////////
    UI_Widget* GetWidgetBelow(int x,int y);

    
////////////////////////////////////////////////////////
    
/// 獲取本控件的頂層控件
    
////////////////////////////////////////////////////////
    UI_Widget* GetTopWidget()const;

    
////////////////////////////////////////////////////////
    
/// 獲取,設(shè)置父窗體
    
////////////////////////////////////////////////////////
    UI_Widget* GetParentWidget()const;
    
void  SetParentWidget(UI_Widget* parent);
public:
    
////////////////////////////////////////////////////////
    
/// 設(shè)置,獲取控件邊框
    
////////////////////////////////////////////////////////
    void SetBorder(const RefPtr<UI_AbstractBorder>& border);
    RefPtr
<UI_AbstractBorder> GetBorder()const;
    
////////////////////////////////////////////////////////
    
/// 設(shè)置,獲取是否渲染邊框
    
////////////////////////////////////////////////////////
    void SetBorderVisible(bool visible);
    
bool IsBorderVisible();
public:
    
////////////////////////////////////////////////////////
    
/// 增加,移除事件消息
    
////////////////////////////////////////////////////////
    void AddEventListener(UI_EventListener* listener);
    
void RemoveEventListener(UI_EventListener* listener);
    
////////////////////////////////////////////////////////
    
/// 消息處理
    
////////////////////////////////////////////////////////
    virtual bool Process(const UI_Event& event);
public:
    
////////////////////////////////////////////////////////
    
/// 焦點函數(shù)
    
////////////////////////////////////////////////////////
    bool IsFocusOn()const;
    
void SetFocusOn(bool focus);
    
void ChangedFocusOn();

    
////////////////////////////////////////////////////////
    
/// 設(shè)置,檢測是否為活動控件
    
////////////////////////////////////////////////////////
    void SetAsActiveWidget();
    
bool IsActiveWidget()const;

    
////////////////////////////////////////////////////////
    
/// 檢測控件層次關(guān)系
    
////////////////////////////////////////////////////////
    virtual bool DoesHierarchyContain(UI_Widget* widget)const;
public:
    
////////////////////////////////////////////////////////
    
/// 顯示,隱藏窗體
    
////////////////////////////////////////////////////////
    void SetVisible(bool visible);
    
void Show();
    
void Hide();
    
bool IsVisible()const;

    
////////////////////////////////////////////////////////
    
/// 窗體狀態(tài)函數(shù)
    
////////////////////////////////////////////////////////
    void IsEnable(){enabled_ = true;}
    
void Disable(){enabled_ = false;}
    
bool IsEnabled()const{return enabled_;}
public:
    
////////////////////////////////////////////////////////
    
/// 窗體渲染
    
////////////////////////////////////////////////////////
    void Render();

    
////////////////////////////////////////////////////////
    
/// 當(dāng)窗體關(guān)閉的時候發(fā)射信號
    
////////////////////////////////////////////////////////
    Signal0 closed_;

     
////////////////////////////////////////////////////////
    
/// 窗體數(shù)據(jù)載入
    
////////////////////////////////////////////////////////
    virtual bool Load(const engine_string& file,const engine_string& widget);
protected:
    
////////////////////////////////////////////////////////
    
/// 執(zhí)行函數(shù)
    
////////////////////////////////////////////////////////
    virtual void OnResize(){}
    
virtual void OnMove(){}
    
virtual void OnTextChanged(){}
    
virtual void OnShow(){}
    
virtual void OnHide(){}
    
virtual void OnGainedFocus(){}
    
virtual void OnLostFocus(){}
    
virtual void OnDraw(){}
private:
    UI_Widget
*         parent_;
    UIEventListener    message_listeners_;
    engine_wstring     text_;
    Size               size_;
    Point              position_;
    
bool               visible_;
    
bool               enabled_;
    RefPtr
<UI_AbstractBorder> border_;
    
bool               border_visible_;
private:
    DECLARE_OBJECT(UI_Widget)
};

}

#ifdef G_COMPILER_MSVC
#pragma warning(pop)
#endif

需要說明的就是這里有3個父類
一個是Object
一個是SlotHolder這是消息樁
另外一個是UI_EventHandler負(fù)責(zé)對事件的處理

需要說明的是UI_Widget總是和UI_WidgetManager配合使用的
畢竟UI上下文最大只能有一個活動控件
posted @ 2010-10-20 18:19 ccsdu2009 閱讀(2024) | 評論 (4)編輯 收藏
 
接上文:http://m.shnenglu.com/gaimor/archive/2010/09/30/128134.html
本文我們接著說UI庫的消息事件部分:
1.UI基本事件類型
  基本上就下面幾種:
////////////////////////////////////////////////////////////
/// 枚舉UI消息類型
////////////////////////////////////////////////////////////
enum UI_EVENT
{
    
//! 鼠標(biāo)移動
    UI_EVENT_MOUSE_MOVE = 0,
    
//! 鼠標(biāo)點擊
    UI_EVENT_MOUSE_CLICK,
    
//! 鼠標(biāo)進入
    UI_EVENT_MOUSE_ENTERED,
    
//! 鼠標(biāo)退出
    UI_EVENT_MOUSE_EXITED,
    
//! 鼠標(biāo)滾輪事件
    UI_EVENT_MOUSE_WHEEL,
    
//! 字符輸入
    UI_EVENT_CHAR_INPUT,
    
//! 鍵盤按鍵
    UI_EVENT_KEY_PRESS,
    
//! 按鍵退出
    UI_EVENT_KEY_RELEASE,
    
//! 焦點事件
    UI_EVENT_LOST_FOCUSE,
    UI_EVENT_GAIN_FOCUSE,
    
//! 滑塊事件
    UI_EVENT_SLIDER_MOVE,
    
//! 編輯事件
    UI_EVENT_EDIT,
    
//! 選擇,反選擇
    UI_EVENT_SELECTED,
    UI_EVENT_DESELECTED
};
2.
關(guān)于事件一般就3個相關(guān)對象:
事件,消息聽者和消息處理對象3個單元塊:
如下所示:

///////////////////////////////////////////////////////////
/// 定義引擎事件基類模板
///////////////////////////////////////////////////////////
template<class EventType = int>
class Event : NonCopyable
{
public:
    
///////////////////////////////////////////////////////
    
/// 事件基類構(gòu)造函數(shù)
    
///////////////////////////////////////////////////////
    Event(const EventType& type):type_(type){}

    
////////////////////////////////////////////////////////
    
/// 事件基類析構(gòu)函數(shù)
    
////////////////////////////////////////////////////////
    virtual ~Event(){}

    
////////////////////////////////////////////////////////
    
/// 獲取事件類型
    
////////////////////////////////////////////////////////
    EventType GetEventType()const{return type_;}
private:
    
////////////////////////////////////////////////////////
    
/// 數(shù)據(jù)成員變量
    
////////////////////////////////////////////////////////
    EventType type_;
};

////////////////////////////////////////////////////////////
/// 定義事件聽者基類
////////////////////////////////////////////////////////////
template<class Event,class Target>
class EventListener
{
public:
    
////////////////////////////////////////////////////////
    
/// 事件聽者虛析構(gòu)函數(shù)
    
////////////////////////////////////////////////////////
    virtual ~EventListener(){}

    
////////////////////////////////////////////////////////
    
/// 消息派送
    
////////////////////////////////////////////////////////
    virtual bool Dispatch(const Event& message,Target object= 0;
};

////////////////////////////////////////////////////////////
/// 定義事件處理者基類
////////////////////////////////////////////////////////////
template<class Event,class EventListener>
class EventHandler
{
public:
    
////////////////////////////////////////////////////////
    
/// 事件聽者虛析構(gòu)函數(shù)
    
////////////////////////////////////////////////////////
    virtual ~EventHandler(){}

    
////////////////////////////////////////////////////////
    
/// 消息處理
    
////////////////////////////////////////////////////////
    virtual bool Process(const Event& message){return false;}

    
////////////////////////////////////////////////////////
    
/// 增加,移除事件消息
    
////////////////////////////////////////////////////////
    virtual void AddEventListener(EventListener* listener){}
    
virtual void RemoveEventListener(EventListener* listener){}
};
然后便是模板實例:
typedef Event<UI_EVENT>                          UI_Event;
typedef EventListener<UI_Event,UI_Widget*>       UI_EventListener;
typedef EventHandler<UI_Event,UI_EventListener*> UI_EventHandler;
說實話可以不這樣做而是用boost::function之類的函數(shù)綁定
但是沒法子這樣寫我習(xí)慣了 呵呵
2.下面是UI事件的承接部分:
通過UI管理器承接輸入輸出系統(tǒng)的消息響應(yīng):
{
////////////////////////////////////////////////////////////
/// 蓋莫GUI管理器
////////////////////////////////////////////////////////////
class GAPI UI_WidgetManager : public UI_EventListenerImpl
public:
    
////////////////////////////////////////////////////////
    
/// 按鍵處理
    
////////////////////////////////////////////////////////
    bool OnMouseLeftDown(int x,int y);
    
bool OnMouseLeftUp(int x,int y);
    
bool OnMouseMiddleDown(int x,int y);
    
bool OnMouseMiddleUp(int x,int y);
    
bool OnMouseRightDown(int x,int y);
    
bool OnMouseRightUp(int x,int y);
    
bool OnMouseMove(int x,int y);
    
bool OnChar(wchar_t code);
    
bool OnKeyDown(int code);
    
bool OnKeyUp(int code);
    
bool OnMouseWheel(int z);
public:
3.事件生成:
以上2部分分別是UI事件對象系列和UI事件輸入部分
下面設(shè)計UI事件的生成
無論是鼠標(biāo)還是鍵盤事件實際上都相當(dāng)于生成了一個新的事件
舉例如下:
OnMouseLeftDown(int x,int y)
如果該函數(shù)被調(diào)用
那么就說明鼠標(biāo)的左鍵被點擊同時我們還知道了點擊的位置坐標(biāo)
這樣就生成了一個UI_MouseClickEvent 對象
不過這里需要考慮是鼠標(biāo)雙擊還是單擊
這就要考慮本次點擊和上次點擊的時間間隔了
這樣就生成了一個UI鼠標(biāo)事件
那本事件應(yīng)該傳給誰?
應(yīng)該是目標(biāo)對象
直觀一點應(yīng)該是傳給鼠標(biāo)當(dāng)前位置下的控件對象
但是考慮到實際情況
這里有一個聚焦控件和活動控件的概念
比如說我們打開一個對話框(這是一個聚焦控件)
對話框上有1個按鍵
當(dāng)用戶點擊本按鍵則消息發(fā)送給這個按鍵了
但是當(dāng)鼠標(biāo)移出對話框之外
一般情況其他控件此時處于非活動狀態(tài)
消息應(yīng)該發(fā)送給聚焦控件
所以這里至少有3各類型的控件指針分別為:聚焦控件,活動控件以及鼠標(biāo)下控件(當(dāng)然他們可以是同一控件)
在這里需要說明這三個控件是這樣切換的
如果發(fā)生特定的uI事件則修改當(dāng)前的聚焦控件等對象了
4.具體控件對消息的處理:
   生成特定消息,并發(fā)送給相應(yīng)的控件對象之后那么控件就需要相應(yīng)該消息了:
控件對象的相關(guān)函數(shù):
///////////////////////////////////////////////////////////
/// 定義UI控件基類
///////////////////////////////////////////////////////////
class GAPI UI_Widget : public SlotHolder,public UI_EventHandler,public Object
{
public:
    typedef std::list
<UI_EventListener*> UIEventListener;
    typedef std::list
<UI_EventListener*>::iterator UIEventListenerItr;
    
void RemoveEventListener(UI_EventListener* listener);
    
////////////////////////////////////////////////////////
    
/// 消息處理
    
////////////////////////////////////////////////////////
    virtual bool Process(const UI_Event& event)
在這里我們通過Process函數(shù)來接受UI管理器傳過來的消息對象.
這里是想要的處理
注意我們并不直接根據(jù)消息響應(yīng)控件的各種狀態(tài)!
而是通過迭代消息聽者鏈表的
如下:
bool UI_Widget::Process(const UI_Event& event)
{
    
bool ret = false;
    
if(IsVisible() && IsEnabled())
    {
        UIEventListenerItr it;
        
for(it = message_listeners_.begin();it != message_listeners_.end();++it)
        {
            UI_EventListener
* listener = *it;
            ret 
= ret || listener->Dispatch(event,this);
        }
        
//! 處理控件邊框事件
        if(border_)
            border_
->Process(event);
    }
    
return ret;
}
當(dāng)消息傳來之后我們并不能確定這就是本控件所需要的消息需要驗證它
如何驗證?
就看當(dāng)前控件是不是可顯示和活動的咯
同時如何控件有邊框?qū)ο笪覀儎t把消息發(fā)給它以改變可能的邊框外觀

下篇:UI設(shè)計概要4:UI控件對象

posted @ 2010-10-04 16:46 ccsdu2009 閱讀(1871) | 評論 (0)編輯 收藏
 
接上文:http://m.shnenglu.com/gaimor/archive/2010/09/27/127900.html
第一篇是關(guān)于UI布局管理器的文章
本文主要說說引擎UI部分組件的問題
在這里UI組件是指UI中的各個基礎(chǔ)模塊而非UI控件也
在本引擎之中當(dāng)前UI組件有以下幾個基礎(chǔ)單元
1.UI_Widget UI控件的基類
2.UI_AbstractBorder UI控件邊框類
3.UI_AbstractLayouter UI布局管理器類
4.UI_Event/UI_EventHandler,UI_EventListerner UI事件處理家族
5.UI_Brush UI庫畫筆(當(dāng)前基于OpenGL)
6.UI_AbstractTheme UI庫控件主題
7.UI_ProptyScheme UI庫主題對象
8.UI_WidgetManager UI庫管理器
9.UI_Factory UI庫工廠對象
10.其他通用對象
以上所有對象構(gòu)成了UI庫的框架
下面說下各個部分的功能
1.UI_Widget UI基本控件 所有控件的基類
2.UI_AbstractBorder 控件控件對象邊框外觀
3.UI_AbstractTheme 控件主題
     以上3著構(gòu)成所見控件外觀
每一個控件都有一個主題和邊框?qū)ο?br>所有同質(zhì)控件都采用統(tǒng)一的控件主題以保證統(tǒng)一的外觀
當(dāng)前UI_Border設(shè)計了2中 一種為線性邊框一種為狀態(tài)邊框
當(dāng)前主題設(shè)計了3中分別為簡單主題,位圖主題和矩形主題
UI布局管理器上文已經(jīng)說過當(dāng)前不再贅述
UI事件處理這塊內(nèi)容比較多 下文說吧
UI畫筆的作用是繪制對象元素比如繪制線條,矩陣設(shè)置顏色等等很簡單的咯
UI_PertptyShceme是一個控件主題的集合包含了所有控件類型的主題
在渲染控件的時候調(diào)用對等的主題繪制控件
控件管理器是UI庫的中樞
負(fù)責(zé)統(tǒng)一渲染隊列控件和調(diào)度輸入輸出事件
關(guān)于UI工廠則負(fù)責(zé)按名生成控件指針咯

我一直力圖把UI庫的實際簡單化
但是總是做不到
而且越做越復(fù)雜的

注意當(dāng)前并沒有涉及腳本,
UI編輯器以及完成所有控件對象的開發(fā)
關(guān)于腳本我想采用得到腳本有l(wèi)ua,anglescrip或者自定義腳本
關(guān)于編輯器我想采用wxwidget or qt
雖然很慢但是我一直在努力 呵呵

下篇:UI設(shè)計概要3:UI消息



posted @ 2010-09-30 15:29 ccsdu2009 閱讀(1871) | 評論 (0)編輯 收藏
 
一直想把引擎的UI部分做強做大可是發(fā)現(xiàn)這個難度還是不小
所以只能一步一步蠶食之
一步一步來吧
先說下控件布局管理器吧
布局管理器的目的是按照一定規(guī)則排列控件于給定范圍內(nèi)
這是其基本目的
很顯然基本的布局管理對象應(yīng)該包含以下2個基本功能
1.控件的加入和刪除
2.應(yīng)用布局管理器
當(dāng)然也可以有其他附加功能
比如獲取控件個數(shù)等等
所以我把抽象控件布局對象設(shè)計如下:

///////////////////////////////////////////////////////////
/// 定義引擎UI布局管理器
///////////////////////////////////////////////////////////
class GAPI UI_AbstractLayouter : public Object
{
public:
    typedef std::list
<UI_Widget*> Widgets;
public:
    UI_AbstractLayouter();
    
virtual ~UI_AbstractLayouter();
public:
    
////////////////////////////////////////////////////////////
    
/// 布局管理器加載控件
    
////////////////////////////////////////////////////////////
    void AddWidget(UI_Widget* widget);

    
////////////////////////////////////////////////////////////
    
/// 布局管理器移除控件
    
////////////////////////////////////////////////////////////
    void RemoveWidget(UI_Widget* widget);

    
////////////////////////////////////////////////////////////
    
/// 布局管理器移除所有子控件
    
////////////////////////////////////////////////////////////
    void RemoveAllWidget();

    
////////////////////////////////////////////////////////////
    
/// 布局管理器控件排列
    
////////////////////////////////////////////////////////////
    virtual void ApplyLayouter(UI_Widget* parent) = 0;
protected:
    Widgets  widgets_;
private:
    DECLARE_OBJECT(UI_AbstractLayouter)
};

然后就是具體的幾種布局管理器對象了
下面是我當(dāng)前弄的4種布局管理器了
分別為:
UI_FlowLayouter
    流式布局管理的布局策略是從左到右依次設(shè)定控件位置如果超出父控件則按照設(shè)定的豎直布局換行重新布局(注意它并不改變控件的大小)
UI_GridLayouter
    格子布局管理的策略則是工具設(shè)定布局間隔和子控件,父親控件個數(shù)重寫設(shè)置所有的子控件大小(這樣所有的子控件大小就一樣了)然后把所有的子控件放置在一個一個的格子中
UI_VLayouter
   UI_VLayouter和UI_HLayouter則是我從QT中借鑒來的
   IU_VLayouter把所有子控件按照從上到下的方式依次布局(不改變子控件大小)(可能會超出父控件喔)
UI_HLayouter
   這個就不說了

當(dāng)然還可以定制其他布局管理器了
   比如UI_DockLayouter
       UI_CenterLayouter等等基本原理都是一樣的

做了游戲引擎這么久說實話
UI真是一個大塊頭
對于UI我的設(shè)計理念就是使用簡單,功能豐富

題外話1:08年11月的時候我就想設(shè)計一套UI庫
之前認(rèn)為游戲UI是使用windows API話的 呵呵
題外話2:網(wǎng)上關(guān)于使用一些UI庫的例子很多但是關(guān)于設(shè)計UI庫的例子似乎不多
題外話3:說實話我覺得寫博客是交流思想共同探討而非其他



posted @ 2010-09-27 20:09 ccsdu2009 閱讀(2627) | 評論 (5)編輯 收藏
僅列出標(biāo)題
共38頁: First 22 23 24 25 26 27 28 29 30 Last 
 
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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精品国产在热久久| 欧美国产日韩一二三区| 亚洲色图综合久久| 久久综合色播五月| 国产婷婷成人久久av免费高清| 亚洲经典视频在线观看| 欧美在线地址| 亚洲综合第一| 国产精品日日做人人爱| 亚洲欧洲一区二区三区久久| 麻豆精品传媒视频| 久久久水蜜桃| 亚洲第一精品影视| 免费在线欧美黄色| 狂野欧美一区| 亚洲欧洲久久| 亚洲精品免费观看| 久久综合图片| 亚洲黄色在线视频| 亚洲人成在线观看| 欧美四级在线观看| 午夜宅男欧美| 久久精品国语| 亚洲激情二区| 99精品免费网| 国产精品在线看| 久久免费精品日本久久中文字幕| 久久精品国产一区二区三区| 黄色亚洲精品| 亚洲第一毛片| 欧美日韩在线三级| 欧美专区福利在线| 久久一区二区三区超碰国产精品| 亚洲精品久久久久久久久| 亚洲精选国产| 国产日产亚洲精品系列| 久久综合成人精品亚洲另类欧美 | 亚洲图片激情小说| 亚洲国产片色| 欧美性理论片在线观看片免费| 亚洲男人的天堂在线观看| 亚洲综合色自拍一区| 激情综合激情| 亚洲精品久久久久久一区二区| 国产精品成人aaaaa网站| 久久精品女人的天堂av| 欧美xart系列在线观看| 欧美在线短视频| 欧美日本国产一区| 欧美视频一区二区在线观看| 午夜国产不卡在线观看视频| 欧美中文字幕视频在线观看| 亚洲裸体俱乐部裸体舞表演av| 女女同性精品视频| 欧美国产国产综合| 亚洲欧美视频在线观看视频| 欧美三日本三级少妇三2023| 亚洲精品久久久久久久久久久久久| 老司机午夜精品视频在线观看| 午夜精品久久久久久久久久久久久| 欧美亚一区二区| 亚洲女女女同性video| 亚洲精品一区久久久久久| 免费成人高清视频| 1024亚洲| 亚洲高清视频在线观看| 欧美 日韩 国产一区二区在线视频 | 亚洲最新在线视频| 欧美日韩在线第一页| aⅴ色国产欧美| 一区二区av在线| 国产精品午夜视频| 久久国产精品亚洲77777| 久久不射电影网| 在线成人av网站| 亚洲国产精品毛片| 欧美三区在线观看| 性高湖久久久久久久久| 欧美中文字幕视频| 亚洲肉体裸体xxxx137| 亚洲欧洲在线一区| 欧美日韩hd| 久久久久久高潮国产精品视| 久久午夜视频| 99视频精品在线| 亚洲人体大胆视频| 夜夜嗨av一区二区三区免费区| 国产精品入口夜色视频大尺度| 久久精品免费电影| 男人的天堂亚洲| 亚洲自拍啪啪| 久久精品一区二区国产| 亚洲美女诱惑| 欧美一区2区三区4区公司二百| 亚洲国产日韩精品| 一区二区三区国产精品| 国产在线国偷精品产拍免费yy| 亚洲国产精品v| 国产午夜精品全部视频在线播放| 欧美jizzhd精品欧美巨大免费| 欧美日韩在线第一页| 欧美成人性网| 国产毛片一区| 亚洲国产国产亚洲一二三| 午夜精品理论片| 亚洲国产毛片完整版| 久色成人在线| 国产精品夜色7777狼人| 亚洲国产成人在线视频| 亚洲一区亚洲| 国产精品国产自产拍高清av| 一区二区三区精品| 99精品福利视频| 欧美日韩国产综合视频在线观看中文 | 午夜国产不卡在线观看视频| 久久亚洲私人国产精品va媚药| 亚洲女女做受ⅹxx高潮| 国产一区二区三区av电影| 欧美精品在线极品| 久久精品99国产精品| 亚洲福利视频在线| 久久亚洲精品伦理| 亚洲青涩在线| 一区二区欧美精品| 国产精品久久久久免费a∨| 亚洲网站在线| 亚洲欧美激情四射在线日 | 在线视频你懂得一区| 亚洲一卡二卡三卡四卡五卡| 久久精品一区二区三区中文字幕| 最新精品在线| 亚洲在线黄色| 欧美成人久久| 久久精品一区二区三区不卡| 国产精品一二一区| 亚洲综合大片69999| 日韩亚洲精品在线| 欧美激情精品| 一本一本久久| 午夜精品久久久久久久99水蜜桃 | 黄色在线一区| 99亚洲一区二区| 亚洲开发第一视频在线播放| 久久夜色精品国产| 蜜桃精品久久久久久久免费影院| 国产伦精品一区二区三区四区免费| 亚洲伊人色欲综合网| 欧美一区二区三区视频在线| 国产精品欧美经典| 亚洲欧美日韩一区| 久久久av网站| 亚洲电影免费观看高清| 男女视频一区二区| 夜夜嗨av一区二区三区四季av| 亚洲一区二区视频| 国产精品在线看| 欧美亚洲系列| 久久综合激情| 亚洲免费av网站| 国产精品黄色在线观看| 亚洲一区二区三区乱码aⅴ蜜桃女| 久久国产欧美精品| 在线成人中文字幕| 欧美精品激情在线| 亚洲一区二区不卡免费| 久久久久se| 99re在线精品| 国产精品亚洲综合一区在线观看| 久久久久久久一区二区| 亚洲日韩中文字幕在线播放| 亚洲欧美日韩国产一区二区三区| 狠狠色2019综合网| 欧美另类视频| 欧美专区日韩专区| 最近看过的日韩成人| 久久精品91久久香蕉加勒比| 亚洲欧洲在线视频| 国产精品尤物福利片在线观看| 免费一区二区三区| 亚洲欧美一区二区视频| 亚洲国产成人久久综合一区| 亚洲欧美激情诱惑| 亚洲观看高清完整版在线观看| 欧美日韩在线视频一区二区| 久久久999国产| 亚洲无线视频| 亚洲风情在线资源站| 久久高清免费观看| 久久综合图片| 亚洲天堂av综合网| 欧美国产亚洲视频| 久久大综合网| 亚洲一级网站| 99精品视频一区二区三区| 国内免费精品永久在线视频| 国产精品久久久爽爽爽麻豆色哟哟| 久久婷婷色综合| 香蕉乱码成人久久天堂爱免费| 亚洲三级免费电影| 欧美国产三级|