2016-10-12 13:39:56 +00:00
|
|
|
Overview
|
|
|
|
========
|
|
|
|
|
2017-03-30 18:42:48 +00:00
|
|
|
SkSL ("Skia Shading Language") is a variant of GLSL which is used as Skia's
|
2016-10-12 13:39:56 +00:00
|
|
|
internal shading language. SkSL is, at its heart, a single standardized version
|
|
|
|
of GLSL which avoids all of the various version and dialect differences found
|
|
|
|
in GLSL "in the wild", but it does bring a few of its own changes to the table.
|
|
|
|
|
|
|
|
Skia uses the SkSL compiler to convert SkSL code to GLSL, GLSL ES, or SPIR-V
|
|
|
|
before handing it over to the graphics driver.
|
|
|
|
|
|
|
|
Differences from GLSL
|
|
|
|
=====================
|
|
|
|
|
|
|
|
SkSL is based on GLSL 4.5. For the most part, write SkSL exactly as you would
|
|
|
|
desktop GLSL, and the SkSL compiler will take care of version and dialect
|
|
|
|
differences (for instance, you always use "in" and "out", and skslc will handle
|
2017-03-30 18:42:48 +00:00
|
|
|
translating them to "varying" and "attribute" as appropriate). Be aware of the
|
2016-10-12 13:39:56 +00:00
|
|
|
following differences between SkSL and GLSL:
|
|
|
|
|
2016-11-21 20:59:48 +00:00
|
|
|
* GLSL caps can be referenced via the syntax 'sk_Caps.<name>', e.g.
|
|
|
|
sk_Caps.sampleVariablesSupport. The value will be a constant boolean or int,
|
|
|
|
as appropriate. As SkSL supports constant folding and branch elimination, this
|
|
|
|
means that an 'if' statement which statically queries a cap will collapse down
|
|
|
|
to the chosen branch, meaning that:
|
|
|
|
|
|
|
|
if (sk_Caps.externalTextureSupport)
|
|
|
|
do_something();
|
|
|
|
else
|
|
|
|
do_something_else();
|
|
|
|
|
|
|
|
will compile as if you had written either 'do_something();' or
|
|
|
|
'do_something_else();', depending on whether that cap is enabled or not.
|
2016-10-13 20:25:34 +00:00
|
|
|
* no #version statement is required, and will be ignored if present
|
2016-10-12 13:39:56 +00:00
|
|
|
* the output color is sk_FragColor (do not declare it)
|
2017-02-07 19:53:32 +00:00
|
|
|
* use sk_VertexID instead of gl_VertexID
|
2017-02-09 22:01:22 +00:00
|
|
|
* the fragment coordinate is sk_FragCoord, and is always relative to the upper
|
|
|
|
left.
|
2017-03-30 18:42:48 +00:00
|
|
|
* lowp, mediump, and highp are always permitted (but will only be respected if
|
2017-02-09 22:01:22 +00:00
|
|
|
you run on a device which supports them)
|
2016-10-12 13:39:56 +00:00
|
|
|
* you do not need to include ".0" to make a number a float (meaning that
|
|
|
|
"vec2(x, y) * 4" is perfectly legal in SkSL, unlike GLSL where it would often
|
2017-03-30 18:42:48 +00:00
|
|
|
have to be expressed "vec2(x, y) * 4.0". There is no performance penalty for
|
2016-10-12 13:39:56 +00:00
|
|
|
this, as the number is converted to a float at compile time)
|
|
|
|
* type suffixes on numbers (1.0f, 0xFFu) are both unnecessary and unsupported
|
2017-02-09 18:57:14 +00:00
|
|
|
* creating a smaller vector from a larger vector (e.g. vec2(vec3(1))) is
|
|
|
|
intentionally disallowed, as it is just a wordier way of performing a swizzle.
|
|
|
|
Use swizzles instead.
|
2016-11-28 17:03:26 +00:00
|
|
|
* Use texture() instead of textureProj(), e.g. texture(sampler2D, vec3) is
|
|
|
|
equivalent to GLSL's textureProj(sampler2D, vec3)
|
2016-10-12 13:39:56 +00:00
|
|
|
* some built-in functions and one or two rarely-used language features are not
|
|
|
|
yet supported (sorry!)
|
|
|
|
|
|
|
|
SkSL is still under development, and is expected to diverge further from GLSL
|
|
|
|
over time.
|