收藏本站
合作伙伴
在线咨询
  • 首页
  • 工作室简介
  • 以往案例
  • 用户评价
  • 新闻动态
  • 服务事项
  • 联系我们
最近更新
  • 1.泛型粒子系统的设计209/10/06
  • 2.泛型粒子系统的设计309/10/06
  • 3.泛型粒子系统的设计409/10/06
  • 4.泛型粒子系统的设计509/10/06
  • 5.泛型粒子系统的设计609/10/06
  • 6.泛型粒子系统的设计709/10/06
  • 7.泛型粒子系统的设计809/10/06
  • 8.斜视角的讨论-游戏中的物体09/10/06
  • 9.斜视角的讨论-绝对坐标系(09/10/06
  • 10.斜视角的讨论-物体和精灵的09/10/06
工作流程
建站套餐
用户须知
泛型粒子系统的设计2
您当前的位置:网站首页 >> 程序技术 >> 图形技术
点击率:366 次 来源/作者:无名 2009-10-06 21:37:15

泛型粒子系统的设计2

现在我们已经可以很方便的组装我们所需要的粒子结构了,但任存在一个问题。每当我们需要加入一个新的粒子部分时必须自定义一个类似SParticlePos的结构,如果我们设计的是一个粒子的拆分部分非常多的系统这无疑是一件非常枯燥的差事。有没有什么方法可以解决呢?我们不妨定义一个泛型的粒子部分:



// 粒子部分

template<

typename _Type

> struct TParticlePart {

_Type m_Value;

};




我们通过_Type模板参数来指定粒子部分的类型,比如原先的SParticlePos我们在使用D3D的平台上可以写成TParticlePart< D3DXVECTOR3 >。这样的设计看似很好,其实隐藏着一个问题。如我们在D3D平台上定义一个如下的粒子:



typedef TParticlePolicy<

boost::mpl::vector<

TParticlePart< D3DXVECTOR3 >, // 位置

TParticlePart< D3DXVECTOR3 >, // 速度

TParticlePart< D3DXCOLOR >, // 颜色

TParticlePart< FLOAT >, // 寿命

>

> tMyParticle;



tMyParticle p;




此时我们要访问粒子的位置部分应该写成p.m_Value,但如果你这样写编译器就会抱怨产生了歧义。原因是不论你需要访问的是位置、速度、颜色还是寿命都应该写成p.m_Value,如何告诉编译器你真正想要访问的部分呢?这就需要引入一个用于区分不同部分的TPartDiff模板类,同时对TParticlePartHolder和TParticlePolicy做一些修改:



// 区分粒子的不同部分

template<

class _Part,

class _Diff

> class TPartDiff : public _Part

{};



// 粒子组装器

template<

class _PartIter,

class _PartsVector

> class TParticlePartHolder

: public TPartDiff<

boost::mpl::deref< _PartIter >::type,

boost::mpl::int_< _PartIter::pos::value >

>

, public TParticlePartHolder< _PartIter::next, _PartsVector >

{};



template<

class _PartsVector

> class TParticlePartHolder< boost::mpl::end< _PartsVector >::type, _PartsVector >

: public boost::blank

{};



// 粒子

template<

class _PartsVector

> struct TParticlePolicy

: public TParticlePartHolder< boost::mpl::begin< _PartsVector >::type, _PartsVector >

{

typedef _PartsVector tPartsVector;



// 部分数

static const int s_ciNumOfParts = boost::mpl::size< _PartsVector >::type::value;



// 获取一个粒子部分

template< size_t nIndex >

TPartDiff< boost::mpl::at_c< _PartsVector, nIndex >::type, boost::mpl::int_< nIndex > >& Part( void ) {

return *this;

}



// 获取一个粒子部分

template< size_t nIndex >

const TPartDiff< boost::mpl::at_c< _PartsVector, nIndex >::type, boost::mpl::int_< nIndex > >& Part( void ) const {

return *this;

}






TPartDiff接受两个模板参数第一个是形如TParticlePart< D3DXVECTOR3 >的粒子部分,第二个是用此粒子部分在粒子定义中的索引位置转换的类型(通过boost::mpl::int_<>可以将常量转换为类型)用于区分。TParticlePartHolder不再直接继承粒子部分,而是通过TPartDiff继承带有区分的粒子部分。TParticlePolicy引入了一个公共模板成员函数Part()用于访问不同的粒子部分,其有一个模板参数用于指定所需要访问的粒子部分的索引,这个函数还有一个Const版本。如果我们要访问以上定义的tMyParticle类型的粒子p的不同部分我们可以写成:



p.Part< 0 >().m_Value; // 访问粒子的位置

p.Part< 1 >().m_Value; // 访问粒子的速度

p.Part< 2 >().m_Value; // 访问粒子的颜色

p.Part< 3 >().m_Value; // 访问粒子的寿命

上一篇: 泛型粒子系统的设计3

下一篇: 游戏资源破解

中国蓝途 ┊ 关于我们 ┊ 服务项目 ┊ 用户评价1 ┊ 用户评价2 ┊ 案例展示 ┊ 合作样本
Powered By 边缘狂人 @ 版权所有 铭扬工作室
业务QQ:124181646 淘宝:kupebank 技术直拨:18267407783 技术支持 程序开发:中国蓝途浙ICP备08008203号 0.884S