博客
关于我
粒子模拟(六-粒子组1)
阅读量:205 次
发布时间:2019-02-28

本文共 4221 字,大约阅读时间需要 14 分钟。

这节我们通过前面学过的粒子相关知识,加上粒子组的用法,实现一个有意思的 Demo

第一步:

创建界面

import QtQuick 2.9import QtQuick.Window 2.2import QtQuick.Particles 2.0Window {    visible: true    width: 680    height: 440    title: qsTr("Rocket..")    Item{        anchors.fill: parent        Rectangle {            id: root            anchors.fill: parent            color: "#1F1F1F"        }    }}

第二步:

创建火箭/火箭烟雾的粒子画笔

// ----            // 火箭的粒子画笔            ImageParticle{                id:rocketPainter                system: particleSystem                // 将粒子分组                groups: ['rocket']                // 火箭 Image 图片                source:"qrc:/new/preImg/" +                       "ufo.png"                entryEffect: ImageParticle.None            }            // 火箭烟雾的粒子画笔            ImageParticle{                id:smokePainter                system: particleSystem                groups: ['smoke']                source:"qrc:/new/preImg/" +                       "particle.png"                //                alpha: 0.3                entryEffect: ImageParticle.None            }

上面是火箭/火箭烟雾的粒子画笔!

第三步:

创建火箭/火箭烟雾的粒子发射器

// ----            // 火箭的发射器            Emitter{                id:rocketEmitter                // 定义发射的区域                anchors.bottom: parent.bottom                width: parent.width                // 60 的原因是只能从底部发射                height: 60                system: particleSystem                // 将粒子发射到 rocket 粒子组中,                // 火箭画笔将会绘制这些粒子                group: 'rocket'                emitRate: 2                maximumEmitted: 4                lifeSpan: 4800                lifeSpanVariation: 400                size: 62                // 速度和方向                velocity: AngleDirection{                    // 方向向上                    angle: 270                    // 速度大小                    magnitude: 250                    magnitudeVariation: 50                }                // 加速度(速度向下模拟重力)                acceleration: AngleDirection{                    // 加速度方向向下                    angle: 90                    magnitude: 50                }                // 跟踪器                Tracer{                    color: "red"                    // 跟踪器是否可见                    visible: root.tracer                }            }            // 烟雾发射器            // 注意这是个跟踪发射器            TrailEmitter{                id:smokeEmitter                system: particleSystem                group: 'smoke'                // 跟踪火箭                follow:'rocket'                // 调整烟雾在火箭的位置                emitHeight: 0                emitWidth: 16                // 一次发射的粒子数                emitRatePerParticle: 100                lifeSpan: 200                size: 20                // 大小允许的变化范围                sizeVariation: 4                // 结束时候的大小(直接消失)                endSize: 0                // 速度和方向                velocity: AngleDirection{                    // 方向向下                    angle: 90                    // 速度大小                    magnitude: 100                    magnitudeVariation: 50                }                // 跟踪器                Tracer{                    color: "red"                    // 跟踪器是否可见                    visible: root.tracer                }            }

第四步:

加入摩擦/紊流

// 摩擦            Friction{                // 作用的对象当然是火箭而不是烟雾了.                groups: ['rocket']                // 定义摩擦的区域                anchors.top: parent.top                width: parent.width                height: 120                system: particleSystem                // 到每秒5像素的时候就不再摩擦                threshold: 5                // 摩擦强度                factor: 0.9                Tracer{                    color:"red"                    visible: true                }            }            // 紊流            // 【暂时下面代码失效】            Turbulence{                groups: ['rocket']                // 有 紊流 的区域                anchors.bottom: parent.bottom                width: parent.width                height: 100                system: particleSystem                // 紊流 强度                strength: 95                Tracer{                    color: "red"                    visible: true                }            }

可以看到摩擦/紊流都起作用了!

当 ufo 进入摩擦区域之后,速度减慢,然后由于向下的加速度的原因会向下降,最后耗到生命周期了就消失!

后续>>

转载地址:http://vyei.baihongyu.com/

你可能感兴趣的文章
Node JS: < 一> 初识Node JS
查看>>
Node JS: < 二> Node JS例子解析
查看>>
Node Sass does not yet support your current environment: Linux 64-bit with Unsupported runtime(93)解决
查看>>
Node Sass does not yet support your current environment: Windows 64-bit with Unsupported runtime(72)
查看>>
Node 裁切图片的方法
查看>>
node+express+mysql 实现登陆注册
查看>>
Node+Express连接mysql实现增删改查
查看>>
node, nvm, npm,pnpm,以前简单的前端环境为什么越来越复杂
查看>>
Node-RED中Button按钮组件和TextInput文字输入组件的使用
查看>>
vue3+Ts 项目打包时报错 ‘reactive‘is declared but its value is never read.及解决方法
查看>>
Node-RED中Slider滑杆和Numeric数值输入组件的使用
查看>>
Node-RED中Switch开关和Dropdown选择组件的使用
查看>>
Node-RED中使用exec节点实现调用外部exe程序
查看>>
Node-RED中使用function函式节点实现数值计算(相加计算)
查看>>
Node-RED中使用html节点爬取HTML网页资料之爬取Node-RED的最新版本
查看>>
Node-RED中使用JSON数据建立web网站
查看>>
Node-RED中使用json节点解析JSON数据
查看>>
Node-RED中使用node-random节点来实现随机数在折线图中显示
查看>>
Node-RED中使用node-red-browser-utils节点实现选择Windows操作系统中的文件并实现图片预览
查看>>
Node-RED中使用node-red-contrib-image-output节点实现图片预览
查看>>