flagship的理想與現實
創新+實踐
C++博客
::
首頁
::
聯系
::
聚合
::
管理
8 Posts :: 0 Stories :: 27 Comments :: 0 Trackbacks
常用鏈接
我的隨筆
我的評論
我參與的隨筆
留言簿
(8)
給我留言
查看公開留言
查看私人留言
我參與的團隊
隨筆分類
FlagshipEngine(8)
其他
游戲編程
游戲設計
隨筆檔案
2009年3月 (2)
2009年2月 (1)
2009年1月 (5)
搜索
最新評論
1.?re: 幾種多線程3D引擎架構的比較
sx
--psychehao
2.?Unreal游戲引擎3教學中文字幕
評論內容較長,點擊標題查看
--Unreal游戲引擎
3.?re: 幾種多線程3D引擎架構的比較
不錯
--Giser
4.?re: 多Pass渲染體系與多線程渲染的矛盾
OGRE里已經把dx9和dx10API抽象了,樓主可以了解一下。
另,樓主有沒有考慮過如果加上網絡下載線程時多線程的設計?
--Combine
5.?re: 幾種多線程3D引擎架構的比較
哥們你這個思想 和我做的游戲 一樣 我們游戲項目 也是這個思想
QQ 23505105
--geforce
閱讀排行榜
1.?幾種多線程3D引擎架構的比較(6845)
2.?3D引擎多線程:渲染與邏輯分離(5578)
3.?3D引擎多線程:資源異步加載(3538)
4.?DX11與多線程渲染(3332)
5.?3D引擎多線程:框架(2843)
評論排行榜
1.?幾種多線程3D引擎架構的比較(10)
2.?3D引擎多線程:渲染與邏輯分離(7)
3.?DX11與多線程渲染(4)
4.?多Pass渲染體系與多線程渲染的矛盾(3)
5.?3D引擎多線程:框架(1)
3D引擎多線程:資源異步加載
資源異步加載恐怕是3D引擎中應用最為廣泛的多線程技術了,特別是在無縫地圖的網絡游戲中,尤為重要,公司3D引擎的資源加載部分采用了硬盤->內存->顯存兩級加載的模式,超時卸載也分兩級,這樣雖然實際效果不錯,但代碼非常繁瑣,在FlagshipEngine中,我設法將其進行了一定程度的簡化。
首先我們需要定義一個Resource基類,它大致上是這樣的:
class
_DLL_Export Resource :
public
Base
{
public
:
Resource();
virtual
~
Resource();
//
是否過期
bool
IsOutOfDate();
public
:
//
是否就緒
virtual
bool
IsReady();
//
讀取資源
virtual
bool
Load();
//
釋放資源
virtual
bool
Release();
//
緩存資源
virtual
bool
Cache();
//
釋放緩存
virtual
void
UnCache();
protected
:
//
加載標記
bool
m_bLoad;
//
完成標記
bool
m_bReady;
private
:
}
;
在實際游戲中,加載資源的范圍大于視野,當攝像機移動到單元格邊緣(必須有一定的緩沖區),就應將新的單元格中的對象加入到資源加載隊列中,喚醒資源加載線程調用Load接口進行加載,完成后將該資源的加載標記設為true。而通過可視剪裁所得到的最終可視實體,則需要調用Cache接口構建圖像API所需對象,當Load和Cache都完成后IsReady才會返回true,這時該資源才能開始被渲染。
卸載方面,在加載新的單元同時,卸載身后舊的單元,對單元內所有資源調用Release,Load/Release帶有引用計數,仍被引用的資源不會被卸載。當某一資源長時間沒有被看見,則超時,調用UnCache釋放VertexBuffer等資源。
為了實現超時卸載功能,我們需要一個ResourceManager類,每幀檢查幾個已Cache的資源,看起是否超時,另外也需對已加載的資源進行分類管理,注冊其資源別名(可以為其文件名),提供查找資源的接口。
另外為了方便使用,我們需要一個模板句柄類ResHandle<T>,設置該資源的別名,其內部調用ResourceManange的查找方法,看此資源是否已存在,如不存在則new一個新的,GetImpliment則返回該資源對象,之后可以將該資源添加到實體中,而無需關心其是否已被加載,代碼如下:
template
<
class
T
>
class
_DLL_Export ResHandle
{
public
:
ResHandle()
{ m_pResource
=
NULL; }
virtual
~
ResHandle()
{}
//
設置資源路徑
void
SetPath( wstring szPath )
{
Resource
*
pResource
=
ResourceManager::GetSingleton()
->
GetResource( Key( szPath ) );
if
( pResource
!=
NULL )
{
m_pResource
=
(T
*
) pResource;
}
else
{
m_pResource
=
new
T;
m_pResource
->
SetPath( szPath );
ResourceManager::GetSingleton()
->
AddResource( m_pResource );
}
}
//
模板實體類指針
T
*
GetImpliment()
{
return
(T
*
) m_pResource; }
T
*
operator
->
()
{
return
(T
*
) m_pResource; }
protected
:
//
模板實體類指針
Resource
*
m_pResource;
private
:
}
;
posted on 2009-01-03 21:37
flagship
閱讀(3538)
評論(0)
編輯
收藏
引用
所屬分類:
FlagshipEngine
只有注冊用戶
登錄
后才能發表評論。
【推薦】100%開源!大型工業跨平臺軟件C++源碼提供,建模,組態!
相關文章:
幾種多線程3D引擎架構的比較
多Pass渲染體系與多線程渲染的矛盾
DX11與多線程渲染
3D引擎多線程:邏輯操作
3D引擎多線程:框架
3D引擎多線程:渲染與邏輯分離
3D引擎多線程:資源異步加載
開篇:關于FlagshipEngine
網站導航:
博客園
IT新聞
BlogJava
博問
Chat2DB
管理
Copyright @ flagship
Powered by:
.Text
and
ASP.NET
Theme by:
.NET Monster
久久AAAA片一区二区
|
久久精品国产乱子伦
|
婷婷久久久亚洲欧洲日产国码AV
|
久久久噜噜噜久久中文字幕色伊伊
|
免费一级欧美大片久久网
|
伊人久久大香线蕉av不变影院
|
99久久婷婷国产综合精品草原
|
中文字幕日本人妻久久久免费
|
久久精品二区
|
久久Av无码精品人妻系列
|
久久精品国产AV一区二区三区
|
久久久久国产一区二区
|
伊人久久久AV老熟妇色
|
欧美精品一本久久男人的天堂
|
色综合久久中文字幕无码
|
久久精品9988
|
AV无码久久久久不卡蜜桃
|
久久精品成人免费观看97
|
国产成人久久精品区一区二区
|
久久天天躁夜夜躁狠狠躁2022
|
精品精品国产自在久久高清
|
人妻无码精品久久亚瑟影视
|
国产99久久久国产精品小说
|
久久噜噜电影你懂的
|
久久夜色精品国产噜噜亚洲AV
|
狠狠综合久久综合88亚洲
|
国产99久久精品一区二区
|
伊人色综合久久天天网
|
中文成人久久久久影院免费观看
|
国产精品女同久久久久电影院
|
久久精品免费一区二区
|
中文字幕久久精品
|
久久综合视频网站
|
午夜精品久久久久久
|
中文字幕精品久久久久人妻
|
久久人妻少妇嫩草AV无码蜜桃
|
91精品国产综合久久香蕉
|
99热精品久久只有精品
|
久久久久亚洲?V成人无码
|
欧美粉嫩小泬久久久久久久
|
久久中文字幕无码专区
|