• Ogre参考手册(六)3.3 粒子


    3.3 粒子Particle

    粒子系统脚本可以作为模板,在运行时创建多个粒子系统

    粒子系统脚本在初始化时加载,默认为所有公共资源位置(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。粒子系统支持一些公共属性和粒子发射器(创建粒子)、影响器(修改粒子)。发射器和影响器的的参数依赖于各发射器和影响器的类型。

    3.3.1 属性

    quota

    粒子系统最多包含粒子数量, 例:quota 10000

     

    material

    材质,例:material Example/Flare

     

    paticle_width / paticle_height

    世界坐标系中的粒子宽\高。例:paticle_width 100。

    注:当billboard_type为point或perpendicular_self时该属性为固定的,billboard_type为oriented_comon\oriented_set\perpendicular_common时将根据方向矢量(dirction vector)的长度缩放

    cull_each

    是否独立裁剪。默认情况下粒子系统根据包围盒整体裁剪,某些情况下可以设为true以优化性能。

    例:cull_each true

    renderer

    渲染器。粒子系统通过ParticleRenderer类渲染,类可以通过管理类注册。Ogre提供默认的billboard基础的渲染器。可以通过插件注册其它渲染器,每个指定唯一的名字。

    示例:renderer billboard

    sorted

    默认情况粒子并不排序,可通过设置为true实现更好的渲染效果

    local_space

    默认情况下粒子发射到世界空间,可通过设置为true修改为本地空间

    billboard_type

    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)

    common_direction  <x y z>

    设置oriented_commo、perpendicular_common类型公告牌采用的公共方向矢量(common direction)

    common_up_vector  <x y z>

    设置perpendicular_common\perpendicular_self类型公告牌采用的公共上矢量(common up vector)

    billboard_origin  <top/center/bottom_left/(center)/right>

    粒子原点类型,默认为中心

    例:billboard_orign top_left ,默认: billboard_orign center

    billboard_rotation_type  <vertex/texcoord>

    旋转类型,公告牌粒子默认采用纹理旋转作为粒子旋转实现。但这样旋转时原来角部纹理会丢失,在重叠采样(wrap address)或者采用子纹理时角部也会出现不需要纹理。可通过设置为旋转顶点(vertex)解决,但效率稍低

    用法: billboard_rotaion_type vertex/texcoord

    point_rendering  <true/false>

    公告牌默认采用四个顶点的四边形渲染,可设置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

    accurate_facing  on/off

    默认关闭off,即采用相机朝向的反方向。开启后on将单个计算各公告牌指向相机的方向

    iteration_interval <float>

    粒子系统默认按帧率更新,可以设置固定更新时间(秒),0表示按帧率更新

    示例:iteration_interval 0.01

    nonvisible_update_timeout <float>

    粒子系统在不可见的情况下默认一直更新以便保持一致,可设置超时时间(秒)以便不可见一段时间后停止更新。默认值0,表示一直更新。 示例:nonvisible_update_timeout 5

    emit_emitter_quota <int>

    被发射的发射器限额,发射器也可以被发射,这个参数控制被发射器发射的发射器个数

    emitter

    指定发射器,用法:emitter <type> { … }

    例:

    emitter Box { … }

    3.3.2 发射器emitter

    发射器为emitter内嵌指令:emitter <type> { … }, type为发射器类型,区分大小写。Ogre当前支持’Point点、Box盒、Cylinder圆柱、Ellipsod椭球、HollowEllipsoid中空椭球、Ring圆环等几种类型发射器,可以通过插件注册新的发射器类型

    3.3.3 发射器公共属性

    各种发射器含有以下公共属性,除此之外各发射器还含有自身特殊属性:

    name  <name>

    发射器名称,当被用于其它发射器时使用

    position  <x y z>

    发射器相对粒子系统所属场景节点位置

    direction  <x y z>

    粒子发射方向

    angle <degrees>

    最大偏离方向角度,180表示全方向发射, 默认 0严格按照发射方向发射粒子

    emission_rate  <num>

    每秒发射粒子个数

    velocity <float>

    发射速度,每秒世界坐标单位

    velocity_min & velocity_max

    发射速度范围,避免相同的发射速度,需要成对设置覆盖velocity

    colour

    颜色, 用法:colour <r> <g> <b> [<a>]

    colour_range_start & colour_range_end

    颜色范围

    time_to_live <float>

    粒子存活时间

    time_to_live_min & time_to_live_max

    粒子存活时间范围,成对设置

    duration <float>

    发射器持续活动时间,默认0表示无限长

    duration_min & duration_max

    发射器持续活动时间范围

    repeat_delay <float>

    发射器停止后(因duration过期)重新启动时间

    repeat_delay_min & repeat_delay_max

    重启时间范围

    emit_emitter <name>

    发射发射器:当前发射的粒子结束时在该位置发射指定名称的发射器,类似于烟花

    示例:

    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

    }

    }

    3.3.4 Ogre粒子发射器

    Ogre实现了以下粒子发射器。可以通过插件实现新的粒子发射器,可参考:Plugin_ParticleFX项目

    Point 点发射器

    从单个点发射粒子,没有自己特定的属性

    示例: emitter Point { }

    Box 箱/盒发射器

    从三维大小的盒子任意位置发射粒子,额外属性:

    width <units> 宽,默认 100,

    height <units> 高,默认100

    depth <unit> 高/深, 默认 100

    Cylingder 圆柱发射器

    与Box相同,含width\height\depth三个自有属性

    Ellipsoid 椭球发射器

    与Box相同,含width\height\depth三个自有属性

    HollowEllipsoid 椭球发射器

    与Ellipsoid相同,中空部分不发射粒子,含width\height\depth三个自有属性

    同时包含三个属性指明中空的椭球大小:inner_width\ inner_height\ inner_depth

    Ring 圆环发射器

    与HollowEllipsoid类似相同,区别在于为二维,除width\height外

    另包括:inner_width\ inner_height 两个属性

    3.3.5 影响器affector

    影响器为affector内嵌指令:affector <type> { … }, type为影响器类型,区分大小写。Ogre当前支持LinearForce和ColourFader两种类型影响器,可以通过插件注册新的影响器类型。

    影响器没有公共属性

    3.3.6 Ogre粒子影响器

    Ogre实现了以下影响器。可以通过插件实现新的粒子影响器,可参考:Plugin_ParticleFX项目

    LinearForce 线性力

    对所有粒子应用线性力矢量,改变粒子的运动速度和方向,用于模仿重力、风等

    属性:

    force_vector      <x> <y> <z>

    力矢量,x y z 大小代表力的大小

    force_application <add|average>

    力叠加方式:

     add 累加,每秒增加力矢量大小

     average 平均(每次刷新时与当前速度取平均,因为刷新率很高,原始速度按指数递减,粒子瞬间到达力矢量速度,实际上没有用处)

    ColourFader 颜色

    改变粒子的颜色,包含以下四个属性:

    red <float> 每秒改变红色成份

    green/blue/alpha < float >

    ColourFader2 两阶段颜色变化

    改变粒子的颜色,包含以下属性:

    red1/green1/blue1/alpha1 第一阶段颜色每秒变化

    state_change<float >第二阶段时长(粒子存活结束时间前的state_change时间段为第二阶段,很糟的设计)

    red2/green2/blue2/alpha2 第二阶段颜色变化

    Scaler  缩放

    rate<float>每秒缩放倍数

    Rotator 旋转

    默认旋转纹理方式旋转粒子

    rotation_speed_range_start/end <degress_per_sercond>

    每秒旋转度数范围

    rotation_range_start/end <degrees>

    初始旋转角度数范围

    ColourInterpolator 颜色差值

    任意指定阶段时间相对长度和颜色值, 最多指定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

    ColourImage 一维图片渐变

    根据一维的图片渐变粒子颜色,与ColourInterpolator类似:

    image <image_name>, 例: image smokecolors.png

    DeflectorPlane 反弹平面

    粒子碰撞后反弹:

    plane_point <x y z>      平面上一点

    plane_normal <x y z> 平面法线

    bounce <rate> 反射速度比例,0-1.0,默认1

    DirectionRandomiser 随机方向

    应用随机量影响粒子运动,可以模拟雪花、树叶

    randomness 随机量大小

    scope    影响粒子比例(0-1.0),默认1.0即全部

    keep_velocity 是否保持速度不变,默认false

  • 相关阅读:
    Choosing the Type at Runtime
    User-Defined Components Must Be Capitalized
    Computed property names
    Controlled Components
    Handling Event
    State
    props
    Functional and Class Components
    招聘漂亮的员工
    Spread Syntax
  • 原文地址:https://www.cnblogs.com/wiki3d/p/4658247.html
Copyright © 2020-2023  润新知