2019-05-09 18:05:04 +00:00
|
|
|
{
|
|
|
|
"MaxCount": 6000,
|
|
|
|
"Drawable": {
|
|
|
|
"Type": "SkCircleDrawable",
|
|
|
|
"Radius": 2
|
|
|
|
},
|
2019-09-12 20:25:52 +00:00
|
|
|
"EffectCode": [
|
|
|
|
"void effectSpawn(inout Effect effect) {",
|
|
|
|
" effect.rate = 2000;",
|
|
|
|
"}",
|
2019-07-25 20:27:35 +00:00
|
|
|
"",
|
2019-09-12 20:25:52 +00:00
|
|
|
"void effectUpdate(inout Effect effect) {",
|
|
|
|
"}",
|
|
|
|
""
|
|
|
|
],
|
|
|
|
"Code": [
|
2019-07-25 20:58:46 +00:00
|
|
|
"void spawn(inout Particle p) {",
|
2019-10-15 14:27:59 +00:00
|
|
|
" p.pos.y += sin(effect.age * 6.28) * 40;",
|
2019-07-25 20:27:35 +00:00
|
|
|
" p.lifetime = 2 + (rand * 2);",
|
|
|
|
" p.vel.x = (30 * rand) + 50;",
|
|
|
|
" p.vel.y = (20 * rand) - 10;",
|
|
|
|
"}",
|
|
|
|
"",
|
2019-07-25 20:58:46 +00:00
|
|
|
"void update(inout Particle p) {",
|
2019-07-25 20:27:35 +00:00
|
|
|
" p.color.r = p.age;",
|
|
|
|
" p.color.g = 1 - p.age;",
|
|
|
|
" float s1 = 0.5 + (1.5 * p.age);",
|
|
|
|
" float s2 = 1.0 + (-0.75 * p.age);",
|
|
|
|
" p.scale = s1 + (s2 - s1) * rand;",
|
|
|
|
" p.vel.y += 20.0 * dt;",
|
|
|
|
"}",
|
|
|
|
""
|
|
|
|
],
|
Major rewrite of the particle system based on the SkSL interpreter
This removes all of the fixed-function particle affector classes.
Instead, each particle effect just has two SkSL snippets, one for
spawn logic, and one for update logic. Each one gets an inout copy
of the particle struct. Ultimately, this makes the effects much
simpler and smaller, while also being far more flexible (you can
do whatever you want with any values you want). Finally, because
the interpreter is vectorized and a particular effect's scripts
are usually tuned to the specific behaviors desired, it's faster
on basically every effect I compared.
I re-created all of the old effects in the new system. Many just
use pure SkSL (no curves or anything). Some of the old curve and
path/text stuff was very handy, though - so those are now exposed
as external values in the interpreter. Basically, an effect can
have any number of named "bindings" that are a callable thing.
This can be a path, text (shortcut for making fancy paths), curve,
or color curve. The path ones return a float4 with position and
normal, the curves return one or four floats.
... and this transposes all of the particle data storage into
SoA form, so that it can use the much faster interpreter entry
point.
Change-Id: Iebe711c45994c4201041b12d171af976bc5e758e
Reviewed-on: https://skia-review.googlesource.com/c/skia/+/222057
Commit-Queue: Brian Osman <brianosman@google.com>
Reviewed-by: Mike Reed <reed@google.com>
2019-07-25 19:14:50 +00:00
|
|
|
"Bindings": []
|
2019-05-09 18:05:04 +00:00
|
|
|
}
|