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

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>
            久久久夜精品| 99re国产精品| 久久成人人人人精品欧| 在线综合亚洲| 国产精品久久久久久久久免费| 一本色道久久综合亚洲精品不 | 国户精品久久久久久久久久久不卡| 亚洲一二三区在线观看| 一区二区三区高清不卡| 国产精品第一区| 亚欧成人在线| 欧美在线国产精品| 亚洲二区在线观看| 99国内精品久久久久久久软件| 欧美日韩一区在线| 久久成人在线| 久热精品视频在线| 99在线|亚洲一区二区| 一区二区不卡在线视频 午夜欧美不卡在 | 亚洲午夜电影| 国内伊人久久久久久网站视频| 欧美国产日韩a欧美在线观看| 欧美日韩国产精品成人| 羞羞答答国产精品www一本| 久久久精品国产99久久精品芒果| 亚洲欧洲日本在线| 这里只有精品视频在线| 韩国美女久久| 日韩一级成人av| 国产丝袜美腿一区二区三区| 欧美大片一区二区三区| 欧美亚州在线观看| 欧美二区在线播放| 国产精品亚洲网站| 亚洲第一在线视频| 国产精品麻豆成人av电影艾秋| 久久影视精品| 国产精品激情av在线播放| 老牛影视一区二区三区| 欧美视频在线看| 欧美成人影音| 国内精品久久久久久久果冻传媒| 亚洲激情在线播放| 黄色免费成人| 亚洲女人天堂av| 一区二区久久| 欧美成人免费大片| 狂野欧美激情性xxxx欧美| 国产精品青草综合久久久久99 | 亚洲影院在线观看| 欧美成人午夜影院| 美日韩精品视频| 国产色产综合色产在线视频| 亚洲精品乱码久久久久久久久| 国产主播一区二区三区四区| 一区二区三区精品视频| 99视频精品全国免费| 女生裸体视频一区二区三区| 久久久91精品国产一区二区三区 | 欧美福利视频在线| 蜜臀91精品一区二区三区| 国产亚洲欧美中文| 亚洲免费在线播放| 亚洲欧洲av一区二区| 国产精品xxxxx| 亚洲精品社区| 99精品国产在热久久下载| 久久综合网色—综合色88| 久久亚洲精品一区| 狠狠色丁香久久综合频道| 久久精品国产91精品亚洲| 久久久不卡网国产精品一区| 国产欧美日韩三级| 性做久久久久久久久| 久久国产乱子精品免费女| 国产亚洲人成a一在线v站| 欧美一区二区视频97| 久久亚洲精品网站| 亚洲国产成人精品久久久国产成人一区 | 免费观看国产成人| 亚洲国产精品综合| 欧美精品在线看| 一本久道久久久| 亚洲欧美日韩在线| 国产三级精品在线不卡| 久久九九免费视频| 亚洲高清网站| 亚洲一区二区精品视频| 国产精品日韩一区| 久久精品亚洲乱码伦伦中文 | 夜夜嗨av一区二区三区中文字幕 | 亚洲欧美视频| 久久手机免费观看| 亚洲欧洲日本在线| 欧美午夜在线| 久久成人免费电影| 91久久精品国产91性色| 亚洲在线观看视频| 激情综合色丁香一区二区| 欧美高清免费| 亚洲一区一卡| 你懂的视频欧美| 中国女人久久久| 国产午夜精品全部视频在线播放| 久久久爽爽爽美女图片| 日韩亚洲一区二区| 久久久亚洲一区| 在线视频一区二区| 尤物九九久久国产精品的特点| 欧美激情免费在线| 欧美在线视频全部完| 亚洲激情av| 久久久久亚洲综合| 亚洲午夜在线观看视频在线| 精品白丝av| 国产精品久久久久久久免费软件 | 久久综合电影| 亚洲嫩草精品久久| 亚洲国产专区| 老司机精品视频网站| 亚洲欧美日韩一区二区三区在线| 亚洲国产精品福利| 国产日韩欧美精品在线| 欧美人在线观看| 久久综合国产精品台湾中文娱乐网| 亚洲最新色图| 亚洲精品久久久久久久久久久久 | 最新亚洲视频| 国产一区在线播放| 国产精品一卡二卡| 欧美日韩亚洲免费| 欧美韩日一区二区三区| 久久深夜福利| 久久精品亚洲乱码伦伦中文| 亚洲欧美成人| 亚洲一区二区三区四区五区午夜 | 美女爽到呻吟久久久久| 久久精品官网| 欧美在线精品一区| 午夜一级在线看亚洲| 亚洲欧美三级在线| 亚洲欧美国产视频| 亚洲综合国产激情另类一区| 一区二区三区国产盗摄| 日韩视频免费| 一本色道久久综合精品竹菊| 亚洲三级影片| 亚洲精品永久免费| 亚洲免费av网站| 亚洲精品自在久久| 亚洲美女视频在线观看| 亚洲精品中文字| 夜久久久久久| 一区二区三区视频在线观看| 一本色道久久综合亚洲精品小说 | 亚洲综合成人婷婷小说| 一区二区三区黄色| 亚洲一区二区三区涩| 亚洲一区在线免费| 久久国产精品99久久久久久老狼 | 91久久久国产精品| 日韩午夜精品| 亚洲欧美久久久久一区二区三区| 亚洲综合社区| 久久av在线看| 欧美成人精品| 日韩亚洲国产欧美| 亚洲自拍偷拍福利| 久久精品国产亚洲高清剧情介绍| 久久久久久9| 欧美精品在线观看播放| 国产精品久久网站| 一区二区亚洲| 99精品欧美一区二区蜜桃免费| 亚洲一区综合| 久热这里只精品99re8久| 亚洲国产精品视频| 亚洲午夜在线| 久久在线播放| 国产精品女人网站| **网站欧美大片在线观看| 99视频精品免费观看| 久久精品中文| 亚洲国产专区校园欧美| 亚洲欧美另类在线| 欧美成人蜜桃| 国产日韩高清一区二区三区在线| 亚洲第一搞黄网站| 午夜一区在线| 亚洲激情影视| 欧美主播一区二区三区美女 久久精品人 | 久久久蜜桃精品| 99精品99| 欧美~级网站不卡| 国产视频一区免费看| 一区二区不卡在线视频 午夜欧美不卡'| 午夜视频在线观看一区二区三区| 欧美国产精品| 久久精品视频在线观看| 国产精品每日更新|