粒子系统脚本可以作为模板,在运行时创建多个粒子系统
粒子系统脚本在初始化时加载,默认为所有公共资源位置(Root::addResourceLocation)下的’.particle’文件。你可以通过ParticleSystemManager::getSingleton().parseAllSources方法加载自定义扩展名的文件类型,或者通过ParticleSystemManager::getSingleton().parseScript解析单个脚本文件
示例:
particle_system Examples/PurpleFountain
{
material Examples/Flare2
quota 10000
billboard_type oriented_self
emitter Point
{
emission_rate 75
}
affector LinearForce
{
force_vector 0 -100 0
}
affector ColourFader
{
red -0.25
}
}
粒子需要全局唯一的名字,如:Examples/PurpleFountain。粒子系统支持一些公共属性和粒子发射器(创建粒子)、影响器(修改粒子)。发射器和影响器的的参数依赖于各发射器和影响器的类型。
粒子系统最多包含粒子数量, 例:quota 10000
材质,例:material Example/Flare
世界坐标系中的粒子宽\高。例:paticle_width 100。
注:当billboard_type为point或perpendicular_self时该属性为固定的,billboard_type为oriented_comon\oriented_set\perpendicular_common时将根据方向矢量(dirction vector)的长度缩放
是否独立裁剪。默认情况下粒子系统根据包围盒整体裁剪,某些情况下可以设为true以优化性能。
例:cull_each true
渲染器。粒子系统通过ParticleRenderer类渲染,类可以通过管理类注册。Ogre提供默认的billboard基础的渲染器。可以通过插件注册其它渲染器,每个指定唯一的名字。
示例:renderer billboard
默认情况粒子并不排序,可通过设置为true实现更好的渲染效果
默认情况下粒子发射到世界空间,可通过设置为true修改为本地空间
billboard渲染器属性,默认值point,用法:
billboard_type point|oriented_common|oriented_self|perpendicular_common| perpendicular_self
说明:
point 朝向相机,采用相机的x, y轴(up矢量),适合含糊的球面,如闪光(light flare)
oriented_common 采用common_direction作为公共y轴,并绕该轴旋转以朝向相机。适合暴风雨、星空
oriented_self 采用独自的direction vector作为y轴,适合laser fire、烟火等条带状有着各自朝向的粒子
perpendicular_common采用common_direction作为公共z轴,y轴通过z与common_up_vector计算。这种类型粒子不旋转,因此需要设置双面纹理,避免背面裁剪。适合光环,比perpendicular_self稍快
perpendicular_self 各自独立的方向矢量作为z轴,适合堆积的环,有各自的方向(rings stack)
设置oriented_commo、perpendicular_common类型公告牌采用的公共方向矢量(common direction)
设置perpendicular_common\perpendicular_self类型公告牌采用的公共上矢量(common up vector)
粒子原点类型,默认为中心
例:billboard_orign top_left ,默认: billboard_orign center
旋转类型,公告牌粒子默认采用纹理旋转作为粒子旋转实现。但这样旋转时原来角部纹理会丢失,在重叠采样(wrap address)或者采用子纹理时角部也会出现不需要纹理。可通过设置为旋转顶点(vertex)解决,但效率稍低
用法: billboard_rotaion_type vertex/texcoord
公告牌默认采用四个顶点的四边形渲染,可设置true采用硬件点渲染(速度并不明显提高),此时受硬件渲染状态控制,并有以下限制:
l 只支持point 类型公告牌
l 粒子显示受所采用材质渲染通道控制:(point_size, point_size_attenuation, point_sprites)
l 受图形卡显示,最大点大小为64-256像素
例:point_rendering true
同时材质通道需开启点精灵渲染:
point_sprites on
point_size_attenuation on 0 10 0
默认关闭off,即采用相机朝向的反方向。开启后on将单个计算各公告牌指向相机的方向
粒子系统默认按帧率更新,可以设置固定更新时间(秒),0表示按帧率更新
示例:iteration_interval 0.01
粒子系统在不可见的情况下默认一直更新以便保持一致,可设置超时时间(秒)以便不可见一段时间后停止更新。默认值0,表示一直更新。 示例:nonvisible_update_timeout 5
被发射的发射器限额,发射器也可以被发射,这个参数控制被发射器发射的发射器个数
指定发射器,用法:emitter <type> { … }
例:
emitter Box { … }
发射器为emitter内嵌指令:emitter <type> { … }, type为发射器类型,区分大小写。Ogre当前支持’Point点、Box盒、Cylinder圆柱、Ellipsod椭球、HollowEllipsoid中空椭球、Ring圆环等几种类型发射器,可以通过插件注册新的发射器类型
各种发射器含有以下公共属性,除此之外各发射器还含有自身特殊属性:
发射器名称,当被用于其它发射器时使用
发射器相对粒子系统所属场景节点位置
粒子发射方向
最大偏离方向角度,180表示全方向发射, 默认 0严格按照发射方向发射粒子
每秒发射粒子个数
发射速度,每秒世界坐标单位
发射速度范围,避免相同的发射速度,需要成对设置覆盖velocity
颜色, 用法:colour <r> <g> <b> [<a>]
颜色范围
粒子存活时间
粒子存活时间范围,成对设置
发射器持续活动时间,默认0表示无限长
发射器持续活动时间范围
发射器停止后(因duration过期)重新启动时间
重启时间范围
发射发射器:当前发射的粒子结束时在该位置发射指定名称的发射器,类似于烟花
示例:
particle_system Examples/Fireworks
{
material Examples/Flare
quota 1000
emit_emitter_quota 10 //最多发射10个发射器:mainEmitter粒子
// 发射发射器的发射器
{
emit_emitter explosion //发射explosion发射器
emission_rate 1000
time_to_live 3
}
// 被发射的发射器
emitter Point
{
name explosion
emission_rate 1000
time_to_live 2
duration 0.1
repeat_delay_min 2
repeat_delay_max 3
}
}
Ogre实现了以下粒子发射器。可以通过插件实现新的粒子发射器,可参考:Plugin_ParticleFX项目
从单个点发射粒子,没有自己特定的属性
示例: emitter Point { }
从三维大小的盒子任意位置发射粒子,额外属性:
width <units> 宽,默认 100,
height <units> 高,默认100
depth <unit> 高/深, 默认 100
与Box相同,含width\height\depth三个自有属性
与Box相同,含width\height\depth三个自有属性
与Ellipsoid相同,中空部分不发射粒子,含width\height\depth三个自有属性
同时包含三个属性指明中空的椭球大小:inner_width\ inner_height\ inner_depth
与HollowEllipsoid类似相同,区别在于为二维,除width\height外
另包括:inner_width\ inner_height 两个属性
影响器为affector内嵌指令:affector <type> { … }, type为影响器类型,区分大小写。Ogre当前支持LinearForce和ColourFader两种类型影响器,可以通过插件注册新的影响器类型。
影响器没有公共属性
Ogre实现了以下影响器。可以通过插件实现新的粒子影响器,可参考:Plugin_ParticleFX项目
对所有粒子应用线性力矢量,改变粒子的运动速度和方向,用于模仿重力、风等
属性:
force_vector <x> <y> <z>
力矢量,x y z 大小代表力的大小
force_application <add|average>
力叠加方式:
add 累加,每秒增加力矢量大小
average 平均(每次刷新时与当前速度取平均,因为刷新率很高,原始速度按指数递减,粒子瞬间到达力矢量速度,实际上没有用处)
改变粒子的颜色,包含以下四个属性:
red <float> 每秒改变红色成份
green/blue/alpha < float >
改变粒子的颜色,包含以下属性:
red1/green1/blue1/alpha1 第一阶段颜色每秒变化
state_change<float >第二阶段时长(粒子存活结束时间前的state_change时间段为第二阶段,很糟的设计)
red2/green2/blue2/alpha2 第二阶段颜色变化
rate<float>每秒缩放倍数
默认旋转纹理方式旋转粒子
rotation_speed_range_start/end <degress_per_sercond>
每秒旋转度数范围
rotation_range_start/end <degrees>
初始旋转角度数范围
任意指定阶段时间相对长度和颜色值, 最多指定6个阶段(注:各阶段一半的时间用于前一阶段渐变):
time0/1/2/3/4/5 <rate>
colour0/1/2/3/4/5 <r> <g> <b> [<a>]
例:time0 0.5
colour0 1 0 0
time1 0.5
colour1 0 1 0
根据一维的图片渐变粒子颜色,与ColourInterpolator类似:
image <image_name>, 例: image smokecolors.png
粒子碰撞后反弹:
plane_point <x y z> 平面上一点
plane_normal <x y z> 平面法线
bounce <rate> 反射速度比例,0-1.0,默认1
应用随机量影响粒子运动,可以模拟雪花、树叶
randomness 随机量大小
scope 影响粒子比例(0-1.0),默认1.0即全部
keep_velocity 是否保持速度不变,默认false