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

Cpper
C/C++高級工程師 Android高級軟件工程師 IT集成工程師 音頻工程師 熟悉c,c++,java,c#,py,js,asp等多種語言 程序猿
插件系統是游戲引擎中一個比較大的子系統
這個系統的目的就是動態增加引擎的功能而不必修改引擎接口

之前雖然做過插件這塊‘
但是感覺設計的不好
這次總算弄了一個比較完備的插件系統

相關對象和結構
1.插件 Plugin
///////////////////////////////////////////////////////////
/// 定義引擎插件數據結構
///////////////////////////////////////////////////////////
class Plugin
{
public:
    Plugin()
    {   
        Reset();
    }   
    
///////////////////////////////////////////////////////
    
/// 插件重啟
    
///////////////////////////////////////////////////////     
    void Reset();
    
///////////////////////////////////////////////////////
    
/// 插件名字
    
///////////////////////////////////////////////////////     
    engine_string name;
    
///////////////////////////////////////////////////////
    
/// 插件作者
    
///////////////////////////////////////////////////////     
    engine_string maker;
    
///////////////////////////////////////////////////////
    
///插件描述
    
///////////////////////////////////////////////////////     
    engine_string description;
    
///////////////////////////////////////////////////////
    
/// 插件版本
    
///////////////////////////////////////////////////////     
    ushort  vermain;
    
ushort  versub;
    
ushort  verpitch;
    
///////////////////////////////////////////////////////
    
/// 插件類型
    
///////////////////////////////////////////////////////     
    ushort  type;
    
///////////////////////////////////////////////////////
    
/// 插件合法性標記
    
///////////////////////////////////////////////////////     
    ushort  valid;
};
插件數據結構只包含了插件的一些基本信息 比如名字,描述,作者,功能類型等

2.PluginLoader
////////////////////////////////////////////////////////
/// 定義插件載入類
////////////////////////////////////////////////////////
class PluginLoader
{
public:
    
/////////////////////////////////////////////////////
    
/// 構造,析構插件載入
    
/////////////////////////////////////////////////////
    PluginLoader();
    
~PluginLoader();
public:     
    
/////////////////////////////////////////////////////
    
/// 載入插件和卸載
    
/////////////////////////////////////////////////////
    bool  Load(const engine_string &plugin);
    
void  Free();     
    
/////////////////////////////////////////////////////
    
/// 獲取插件指定符號地址
    
/////////////////////////////////////////////////////     
    void* GetAddress(const engine_string &name);
    
/////////////////////////////////////////////////////
    
/// 檢測插件是否合法
    
/////////////////////////////////////////////////////     
    bool  IsValid()const{return handle != NULL;}
    
/////////////////////////////////////////////////////
    
/// 獲取插件句柄
    
/////////////////////////////////////////////////////
    void* GetHandle(){return handle;}
    
void* GetHandle()const{return handle;}   
    
/////////////////////////////////////////////////////
    
/// 獲取插件名
    
/////////////////////////////////////////////////////
    engine_string GetPluginName()const{return pluginame;}   
private:     
    
void*         handle;
    engine_string pluginame;   
};

PluginLoader主要是載入插件文件并獲取給定符號的函數指針
這個并沒沒有暴漏出來供用戶調用
3.PluginFactory

///////////////////////////////////////////////////////////
/// 定義引擎插件工廠基類
///////////////////////////////////////////////////////////
class GAPI PluginFactory : public Object
{
public:
    
///////////////////////////////////////////////////////
    
/// 構造和析構引擎插件工廠基類
    
///////////////////////////////////////////////////////
    PluginFactory();
    
virtual ~PluginFactory();
public:
    
///////////////////////////////////////////////////////
    
/// 注冊,反注冊插件
    
///////////////////////////////////////////////////////
    virtual bool ENGINE_CALL RegisterFactory(const engine_string& plugin) = 0;
    
virtual void ENGINE_CALL UnregisterFacory() = 0;
public:     
    
///////////////////////////////////////////////////////
    
/// 獲取對應插件類型標識
    
///////////////////////////////////////////////////////     
    virtual ushort GetPluginType()const = 0;
private:
    DECLARE_OBJECT(PluginFactory)        
};

插件工廠是一切需要從插件中獲取功能的對象工廠
她主要提供了插件的注冊和反注冊以及獲取插件工廠所對應的插件類型

4.PluginManager 插件管理器
///////////////////////////////////////////////////////////
/// 定義引擎插件管理器
///////////////////////////////////////////////////////////
class GAPI PluginManager
{   
public:
    
///////////////////////////////////////////////////////
    
/// 獲取,設置插件目錄
    
///////////////////////////////////////////////////////
    engine_string GetPluginFolder()const;
    
void SetPluginFolder(const engine_string& folder);
public:
    
///////////////////////////////////////////////////////
    
/// 插件裝載和卸載
    
///////////////////////////////////////////////////////
    void InstallPlugin();   
    
void UnstallPlugin();   
public:
    
///////////////////////////////////////////////////////
    
/// 注冊,反注冊插件工廠
    
///////////////////////////////////////////////////////        
    bool RegisterPluginFactory(PluginFactory* factory);
    
bool UnregisterPluginFactory(PluginFactory* factory);
public:
    
///////////////////////////////////////////////////////
    
/// 獲取插件個數
    
///////////////////////////////////////////////////////        
    ushort ENGINE_CALL GetPluginNumber()const;
    
///////////////////////////////////////////////////////
    
/// 獲取給定索引插件信息
    
///////////////////////////////////////////////////////
    Plugin ENGINE_CALL GetPluginByType(ushort index)const;
    
///////////////////////////////////////////////////////
    
/// 獲取給定索引的插件名
    
///////////////////////////////////////////////////////  
    engine_string ENGINE_CALL GetPluginNameByType(ushort index)const;   
    
///////////////////////////////////////////////////////
    
/// 獲取給定插件類型的插件載入類
    
///////////////////////////////////////////////////////      
private:
    PluginManagerImpl  
*impl;
    DEFINE_SINGLETON(PluginManager);
};

}

//! 定義插件管理器單件
#define GLOBAL_PLUGINMANAGER_PTR (core::PluginManager::GetInstance())
插件管理器是插件系統的核心,充當了插件管理者的角色
要使用插件線需要設置插件目錄
然后裝載插件
然后注冊特定的插件工廠
然后就可以通過插件工廠獲取插件對象指針咯

在這里插件管理器是作為一個單間使用的
具體的宏 DEFINE_SINGLETON(PluginManager);
展開之后為:
#define DEFINE_SINGLETON(SingletonObject)\
private:\
    
static std::auto_ptr<SingletonObject> instance;\
protected:\
    SingletonObject();\
public:\
    
~SingletonObject();\
    
static SingletonObject* GetInstance(){\
    
if(!instance.get())\
    {\
        instance 
= std::auto_ptr<SingletonObject>(new SingletonObject());\
    }\
    
return instance.get();\
}

#define IMPLEMENT_SINGLETON(SingletonObject)\
std::auto_ptr
<SingletonObject> SingletonObject::instance(NULL);
下面是具體的一個插件對象---攝像頭捕獲類
如下:通過調用CaptureImage就可以把攝像頭所見程序保存為image了
///////////////////////////////////////////////////////////
/// 定義攝像頭捕獲類(以插件形式提供之)
///////////////////////////////////////////////////////////
class GAPI CapturePicture : public Object
{
public:
    
///////////////////////////////////////////////////////
    
/// 構造和析構
    
///////////////////////////////////////////////////////
    CapturePicture();
    
virtual ~CapturePicture();
public:
    
///////////////////////////////////////////////////////
    
/// 獲取攝像頭圖形數據
    
///////////////////////////////////////////////////////
    virtual bool CaptureImage(RefPtr<Image> &image);
private:
    DECLARE_OBJECT(CapturePicture)        
};

通過調用CaptureImage就可以把攝像頭所見程序保存為image了

下面這個是對于的工廠:
///////////////////////////////////////////////////////////
/// 定義攝像頭捕獲工廠類
///////////////////////////////////////////////////////////
class GAPI CapturePictureFactory : public PluginFactory
{
public:
    
///////////////////////////////////////////////////////
    
/// 構造和析構
    
///////////////////////////////////////////////////////
    CapturePictureFactory();
    
virtual ~CapturePictureFactory();
public:
    
///////////////////////////////////////////////////////
    
/// 獲取攝像頭捕獲指針
    
///////////////////////////////////////////////////////
    CapturePicture* Create();
    
///////////////////////////////////////////////////////
    
/// 注冊插件
    
///////////////////////////////////////////////////////
    bool ENGINE_CALL RegisterFactory(const engine_string& plugin);
    
void ENGINE_CALL UnregisterFacory();
    
///////////////////////////////////////////////////////
    
/// 獲取對應插件類型標識
    
///////////////////////////////////////////////////////     
    ushort GetPluginType()const;
private:
    PluginLoader
* loader;
    DECLARE_OBJECT(CapturePictureFactory)
};
這個只是多了一個函數Createer而已

然后再說具體的插件部分
插件3函數:
extern "C" void    GAPI Plugin_Info(Plugin &plugin);         
extern "C" Object* GAPI Plugin_Install();
extern "C" void    GAPI Plugin_Unstall(void*);  
具體為通過Plugin_Info
通過Plugin_Install獲取插件實際對象指針
通過Plugin_Unstall卸載插件

最后一個部分是插件的使用小例子:
#include <cstdlib>
#include 
<iostream>
#include 
<GEngine/Header.hpp>

using namespace std;

int main(int argc, char *argv[])
{
    GLOBAL_PLUGINMANAGER_PTR
->SetPluginFolder("plugin");
    GLOBAL_PLUGINMANAGER_PTR
->InstallPlugin();
    std::cout
<<"插件個數:"<<GLOBAL_PLUGINMANAGER_PTR->GetPluginNumber()<<std::endl;
    core::CapturePictureFactory factory;
    std::cout
<<"注冊視頻捕獲插件工廠:"<<GLOBAL_PLUGINMANAGER_PTR->RegisterPluginFactory(&factory)<<std::endl;
    core::CapturePicture
* capturepicture = factory.Create();
    std::cout
<<"插件工廠產品標識:"<<factory.GetPluginType()<<std::endl;
    core::RefPtr
<core::Device> device = core::InitDevice("插件測試");
    
if(!capturepicture)
    {
        std::cout
<<"生成攝像頭捕獲指針失敗了"<<std::endl;
        system(
"PAUSE");
        
return -1;
    }
    core::RefPtr
<core::ResourceManager> resmgr = device->GetResourceManager();
    core::RefPtr
<core::ImageManager> imagemanager = resmgr->GetImageManager();
    core::RefPtr
<core::Image> image = imagemanager->CreateObject("capturepicture");
   
    capturepicture
->CaptureImage(image);
    std::cout
<<"save image is:"<<image->Save("capture.bmp")<<std::endl;
   
    BEGIN_LOOP(device)
       glClearColor(
0.1,0.3,0.2,1.0f);
       glClear(GL_COLOR_BUFFER_BIT 
| GL_DEPTH_BUFFER_BIT);     
    END_LOOP(device)   
   
    GLOBAL_PLUGINMANAGER_PTR
->UnregisterPluginFactory(&factory);
    GLOBAL_PLUGINMANAGER_PTR
->UnstallPlugin();
    
//system("PAUSE");
    return EXIT_SUCCESS;
}
題后話:
當前引擎支持xp,vista,win7環境
在編譯器支持vc7.1,vc8,vc9,devc++,codeblock
也許在不久的將來我會弄一個linux版本的
posted on 2010-07-29 16:40 ccsdu2009 閱讀(2583) 評論(17)  編輯 收藏 引用 所屬分類: Game引擎
Comments
  • # re: 蓋莫游戲引擎-插件系統
    ccsdu2009
    Posted @ 2010-07-29 16:41
    有問題的話 請同志們指針  回復  更多評論   
  • # re: 蓋莫游戲引擎-插件系統
    路青飛
    Posted @ 2010-07-29 17:09
    看起來不錯,等我把王爽老師的匯編語言看完了,學習一下你的引擎。  回復  更多評論   
  • # re: 蓋莫游戲引擎-插件系統
    ccsdu2009
    Posted @ 2010-07-29 18:50
    @路青飛
    謝謝支持  回復  更多評論   
  • # re: 蓋莫游戲引擎-插件系統
    ccsdu2009
    Posted @ 2010-07-29 18:55
    @路青飛
    @路青飛
    有問題請教你匯編問題啊 呵呵我不懂  回復  更多評論   
  • # re: 蓋莫游戲引擎-插件系統
    issingle@gmail.com
    Posted @ 2010-07-30 09:24
    插件系統中,最關鍵和最難點是插件之間的通信.  回復  更多評論   
  • # re: 蓋莫游戲引擎-插件系統
    napolen
    Posted @ 2010-07-30 10:30
    我覺得你這背景應該改一下,看文章看起來太別扭了。  回復  更多評論   
  • # re: 蓋莫游戲引擎-插件系統[未登錄]
    ccsdu2009
    Posted @ 2010-07-30 10:48
    @issingle@gmail.com
    這個不是當前的問題
    我做東西喜歡循序漸進
      回復  更多評論   
  • # re: 蓋莫游戲引擎-插件系統
    Husiwa
    Posted @ 2010-08-02 16:13
    這個,貌似不能夠自動檢測到有多少插件吧?
    我的意思是,用戶寫個插件,放到你的插件目錄下,
    PluginManager能夠自動檢測出來嗎?  回復  更多評論   
  • # re: 蓋莫游戲引擎-插件系統
    ccsdu2009
    Posted @ 2010-08-02 16:46
    @Husiwa

    但是要按照給定插件格式寫  回復  更多評論   
  • # re: 蓋莫游戲引擎-插件系統
    Husiwa
    Posted @ 2010-08-03 10:53
    @ccsdu2009
    哦,上面的代碼貌似沒有體現出這一點。  回復  更多評論   
  • # re: 蓋莫游戲引擎-插件系統
    ccsdu2004
    Posted @ 2010-08-03 10:56
    @Husiwa
    ///////////////////////////////////////////////////////
    /// 獲取插件個數
    ///////////////////////////////////////////////////////
    ushort ENGINE_CALL GetPluginNumber()const;  回復  更多評論   
  • # re: 蓋莫游戲引擎-插件系統
    Husiwa
    Posted @ 2010-08-04 18:14
    @ccsdu2004
    哦,這樣,看的不仔細,不好意思。
    這樣的話,是否需要配置文件呢?
    C#可以通過反射機制來獲取插件信息,C++呢?  回復  更多評論   
  • # re: 蓋莫游戲引擎-插件系統
    ccsdu2009
    Posted @ 2010-08-04 20:41
    @Husiwa
    可以通過載入插件來獲取插件信息  回復  更多評論   
  • # re: 蓋莫游戲引擎-插件系統

    Posted @ 2010-08-08 01:44
    最近在研究插件系統, 能否提供例子代碼下載???  回復  更多評論   
  • # re: 蓋莫游戲引擎-插件系統
    BoYue
    Posted @ 2010-08-08 13:48
    @Husiwa
    可以通過配置文件,也可以通過搜索插件的接口名來確定有哪些插件. 把多個插件的DLL放在目錄下.然后搜索這些DLL,用GetProcAddress即可確定哪些是插件.   回復  更多評論   
  • # re: 蓋莫游戲引擎-插件系統
    ccsdu2009
    Posted @ 2010-08-08 16:16
    @楊
    過段時間吧 O(∩_∩)O~  回復  更多評論   
  • # re: 蓋莫游戲引擎-插件系統

    Posted @ 2010-08-12 10:10
    謝謝,等你。  回復  更多評論   
 
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            一区二区不卡在线视频 午夜欧美不卡在| 9l国产精品久久久久麻豆| 欧美一区观看| 国户精品久久久久久久久久久不卡| 欧美一级二级三级蜜桃| 亚洲欧美日韩国产中文| 一区二区亚洲精品| 欧美成人免费在线| 欧美精品v国产精品v日韩精品| 欧美在线视频在线播放完整版免费观看 | 亚洲精品国偷自产在线99热| 欧美精品99| 性欧美videos另类喷潮| 久久久久国色av免费看影院| 91久久精品国产91久久性色| 亚洲精品一二| 国产麻豆午夜三级精品| 欧美成年人网站| 欧美日韩精品久久久| 欧美一区二区在线免费观看| 久久精品欧美日韩| 一本色道久久综合狠狠躁篇怎么玩| 久久久国际精品| 免费h精品视频在线播放| 夜夜躁日日躁狠狠久久88av| 亚洲香蕉网站| 亚洲成人自拍视频| 亚洲视频欧美在线| 国产精品高潮呻吟久久av黑人| 久久精品国产亚洲精品| 麻豆成人精品| 久久岛国电影| 欧美精品一区二区三区蜜桃| 欧美一区二区| 欧美日本免费| 欧美h视频在线| 国产喷白浆一区二区三区| 亚洲大黄网站| 黄色一区二区在线观看| 一区二区三区导航| 亚洲人体影院| 久久精品中文字幕免费mv| 亚洲一区在线播放| 欧美电影打屁股sp| 噜噜噜噜噜久久久久久91 | 久久亚洲综合| 最新中文字幕亚洲| 欧美在线免费| 亚洲欧美日韩国产成人| 欧美黄在线观看| 欧美xx视频| 伊人久久综合97精品| 午夜精品影院| 亚洲欧美综合精品久久成人| 欧美日韩精品中文字幕| 亚洲娇小video精品| 91久久精品国产91久久性色| 欧美专区在线观看一区| 欧美影院成人| 国产三区精品| 香蕉乱码成人久久天堂爱免费 | 欧美freesex8一10精品| 国产日韩精品电影| 亚洲欧美日韩在线播放| 亚洲一区二区三区免费观看| 欧美精品久久99| 亚洲经典在线看| 亚洲精品中文字幕女同| 欧美成年人网站| 亚洲国产天堂网精品网站| 亚洲精品久久久久久一区二区| 久久久国产精彩视频美女艺术照福利| 久久久久国产精品一区| 国产亚洲一级| 久久米奇亚洲| 亚洲国产高清在线| 亚洲精品小视频| 欧美视频在线不卡| 亚洲一区二区四区| 久久久久综合网| 在线视频国产日韩| 欧美另类视频| 亚洲一区二区三区久久| 久久久欧美精品sm网站| 亚洲国产欧美在线人成| 欧美精品少妇一区二区三区| 亚洲精选成人| 久久国产福利| 亚洲国产成人91精品| 欧美激情在线狂野欧美精品| 一区二区高清视频| 久久精品国产亚洲5555| 亚洲高清资源| 国产精品美女一区二区在线观看| 亚洲欧美日韩国产另类专区| 欧美成人免费网站| 亚洲午夜一级| 在线观看欧美成人| 欧美日韩亚洲高清| 久久精品国产亚洲a| 亚洲国产色一区| 欧美在线亚洲在线| 亚洲精品一区二区三区福利| 国产精品av久久久久久麻豆网| 欧美亚洲日本网站| 日韩午夜电影在线观看| 久久看片网站| 亚洲免费在线电影| 亚洲国产精品va| 国产精品美女视频网站| 欧美成人在线免费观看| 亚洲影院免费观看| 亚洲欧洲另类国产综合| 久久er精品视频| 在线一区二区三区做爰视频网站 | 久久久午夜精品| 亚洲一区二区视频在线| 亚洲国产成人精品女人久久久 | 欧美日韩在线视频一区二区| 久久九九99视频| 亚洲一区二区三区乱码aⅴ| 亚洲高清在线视频| 久久综合久久久| 午夜精品久久久久久久久| 亚洲精品国久久99热| 激情av一区二区| 国产日韩欧美在线看| 欧美日韩一二三区| 欧美国产第二页| 老**午夜毛片一区二区三区| 欧美一区免费视频| 亚洲一区日韩在线| 亚洲天天影视| 9l视频自拍蝌蚪9l视频成人| 亚洲国产裸拍裸体视频在线观看乱了| 另类春色校园亚洲| 久久久久久9999| 久久精品国产精品亚洲精品| 亚洲欧美在线播放| 亚洲欧美怡红院| 亚洲免费网站| 亚洲欧美久久| 午夜视频在线观看一区二区| 亚洲专区在线| 欧美一区二区三区喷汁尤物| 午夜精品久久久久久久| 亚洲女同在线| 欧美在线视频播放| 久久精品一区中文字幕| 久久免费视频在线观看| 久久精品国产亚洲aⅴ| 久久久久久久综合色一本| 久久狠狠亚洲综合| 久久伊人免费视频| 免费亚洲一区二区| 最新国产精品拍自在线播放| 91久久夜色精品国产网站| 亚洲日韩成人| 亚洲综合久久久久| 欧美在线关看| 欧美+亚洲+精品+三区| 欧美激情国产日韩精品一区18| 欧美精品七区| 国产精品爽黄69| 在线国产亚洲欧美| 亚洲美女毛片| 欧美一区二区成人6969| 老司机aⅴ在线精品导航| 欧美国产日本高清在线| 亚洲免费播放| 久久精品国产99精品国产亚洲性色| 久久精品一区二区三区不卡牛牛| 美女久久网站| 欧美午夜精品久久久久久人妖| 国产精品制服诱惑| 一区二区自拍| 亚洲影院免费| 美女精品一区| 一区二区三区视频在线| 久久久精品一品道一区| 欧美日本簧片| 国产亚洲福利| 亚洲一区www| 久久只精品国产| 在线亚洲欧美视频| 久热精品视频在线观看一区| 欧美日韩亚洲综合一区| 在线观看不卡av| 亚洲欧美日韩国产综合| 欧美成人亚洲成人日韩成人| 亚洲四色影视在线观看| 老司机凹凸av亚洲导航| 国产精品家教| 亚洲黄色在线观看| 久久精品国产视频| 一本在线高清不卡dvd | 欧美呦呦网站| 欧美无乱码久久久免费午夜一区| 在线成人激情黄色| 欧美在线视频日韩|