You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
128 lines
7.1 KiB
128 lines
7.1 KiB
7 months ago
|
---
|
||
|
title: 'SkBlendMode Overview'
|
||
|
linkTitle: 'SkBlendMode Overview'
|
||
|
|
||
|
weight: 260
|
||
|
---
|
||
|
|
||
|
Describes how destination <a href='undocumented#Pixel'>pixel</a> is replaced
|
||
|
with a combination of itself and source <a href='undocumented#Pixel'>pixel</a>.
|
||
|
<a href='#Blend_Mode'>Blend_Mode</a> may use source, destination, or both.
|
||
|
<a href='#Blend_Mode'>Blend_Mode</a> may operate on each
|
||
|
<a href='https://api.skia.org/SkColor_8h.html'>Color</a> component
|
||
|
independently, or may allow all source <a href='undocumented#Pixel'>pixel</a>
|
||
|
components to contribute to one destination
|
||
|
<a href='undocumented#Pixel'>pixel</a> component.
|
||
|
|
||
|
<a href='#Blend_Mode'>Blend_Mode</a> does not use adjacent pixels to determine
|
||
|
the outcome.
|
||
|
|
||
|
<a href='#Blend_Mode'>Blend_Mode</a> uses source and read destination
|
||
|
<a href='https://api.skia.org/SkColor_8h.html#a918cf5a3a68406ac8107f6be48fb906e'>Alpha</a>
|
||
|
to determine written destination
|
||
|
<a href='https://api.skia.org/SkColor_8h.html#a918cf5a3a68406ac8107f6be48fb906e'>Alpha</a>;
|
||
|
both source and destination
|
||
|
<a href='https://api.skia.org/SkColor_8h.html#a918cf5a3a68406ac8107f6be48fb906e'>Alpha</a>
|
||
|
may also affect written destination
|
||
|
<a href='https://api.skia.org/SkColor_8h.html'>Color</a> components.
|
||
|
|
||
|
Regardless of how
|
||
|
<a href='https://api.skia.org/SkColor_8h.html#a918cf5a3a68406ac8107f6be48fb906e'>Alpha</a>
|
||
|
is encoded in source and destination <a href='undocumented#Pixel'>pixel</a>,
|
||
|
nearly all <a href='#Image_Info_Color_Type'>Color_Types</a> treat it as ranging
|
||
|
from zero to one. And, nearly all <a href='#Blend_Mode'>Blend_Mode</a>
|
||
|
algorithms limit the output so that all results are also zero to one.
|
||
|
|
||
|
Two exceptions are
|
||
|
<a href='https://api.skia.org/SkBlendMode_8h.html#ad96d76accb8ff5f3eafa29b91f7a25f0'>SkBlendMode</a>::<a href='#SkBlendMode_kPlus'>kPlus</a>
|
||
|
and
|
||
|
<a href='https://api.skia.org/SkImageInfo_8h.html#a9ac0b62b3d2c6c7e1a80db557243f93e'>kRGBA_F16_SkColorType</a>.
|
||
|
|
||
|
<a href='https://api.skia.org/SkBlendMode_8h.html#ad96d76accb8ff5f3eafa29b91f7a25f0'>SkBlendMode</a>::<a href='#SkBlendMode_kPlus'>kPlus</a>
|
||
|
permits computing
|
||
|
<a href='https://api.skia.org/SkColor_8h.html#a918cf5a3a68406ac8107f6be48fb906e'>Alpha</a>
|
||
|
and <a href='https://api.skia.org/SkColor_8h.html'>Color</a> component values
|
||
|
larger than one. For <a href='#Image_Info_Color_Type'>Color_Types</a> other than
|
||
|
<a href='https://api.skia.org/SkImageInfo_8h.html#a9ac0b62b3d2c6c7e1a80db557243f93e'>kRGBA_F16_SkColorType</a>,
|
||
|
resulting
|
||
|
<a href='https://api.skia.org/SkColor_8h.html#a918cf5a3a68406ac8107f6be48fb906e'>Alpha</a>
|
||
|
and component values are clamped to one.
|
||
|
|
||
|
<a href='https://api.skia.org/SkImageInfo_8h.html#a9ac0b62b3d2c6c7e1a80db557243f93e'>kRGBA_F16_SkColorType</a>
|
||
|
permits values outside the zero to one range. It is up to the client to ensure
|
||
|
that the result is within the range of zero to one, and therefore well-defined.
|
||
|
|
||
|
<a name='Porter_Duff'></a>
|
||
|
|
||
|
<a href='https://graphics.pixar.com/library/Compositing/paper.pdf'>Compositing
|
||
|
Digital Images</a></a> describes
|
||
|
<a href='#Blend_Mode_Overview_Porter_Duff'>Porter_Duff</a> modes
|
||
|
<a href='https://api.skia.org/SkBlendMode_8h.html#ad96d76accb8ff5f3eafa29b91f7a25f0'>SkBlendMode</a>::<a href='#SkBlendMode_kClear'>kClear</a>
|
||
|
through
|
||
|
<a href='https://api.skia.org/SkBlendMode_8h.html#ad96d76accb8ff5f3eafa29b91f7a25f0'>SkBlendMode</a>::<a href='#SkBlendMode_kXor'>kXor</a>.
|
||
|
|
||
|
Drawing a <a href='https://api.skia.org/classSkBitmap.html'>bitmap</a> with
|
||
|
transparency using <a href='#Blend_Mode_Overview_Porter_Duff'>Porter_Duff</a>
|
||
|
compositing is free to clear the destination.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/ca7e5/ca7e5de5d365c8c9b27ab4296280a5b1a84b5799" alt="Porter_Duff"
|
||
|
|
||
|
Draw geometry with transparency using
|
||
|
<a href='#Blend_Mode_Overview_Porter_Duff'>Porter_Duff</a> compositing does not
|
||
|
combine transparent source pixels, leaving the destination outside the geometry
|
||
|
untouched.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/dd769/dd769008f8dcc1a84111e7c23c927b45d88e846b" alt="Porter_Duff"
|
||
|
|
||
|
<a name='Lighten_Darken'></a>
|
||
|
|
||
|
Modes
|
||
|
<a href='https://api.skia.org/SkBlendMode_8h.html#ad96d76accb8ff5f3eafa29b91f7a25f0'>SkBlendMode</a>::<a href='#SkBlendMode_kPlus'>kPlus</a>
|
||
|
and
|
||
|
<a href='https://api.skia.org/SkBlendMode_8h.html#ad96d76accb8ff5f3eafa29b91f7a25f0'>SkBlendMode</a>::<a href='#SkBlendMode_kScreen'>kScreen</a>
|
||
|
use simple arithmetic to lighten or darken the destination. Modes
|
||
|
<a href='https://api.skia.org/SkBlendMode_8h.html#ad96d76accb8ff5f3eafa29b91f7a25f0'>SkBlendMode</a>::<a href='#SkBlendMode_kOverlay'>kOverlay</a>
|
||
|
through
|
||
|
<a href='https://api.skia.org/SkBlendMode_8h.html#ad96d76accb8ff5f3eafa29b91f7a25f0'>SkBlendMode</a>::<a href='#SkBlendMode_kMultiply'>kMultiply</a>
|
||
|
use more complicated algorithms to lighten or darken; sometimes one mode does
|
||
|
both, as described by <a href='https://en.wikipedia.org/wiki/Blend_modes'>Blend
|
||
|
Modes</a></a> .
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/dadd8/dadd83d85a5fca428d7a92fb719dc37dd4a7ef35" alt="Lighten_Darken"
|
||
|
|
||
|
<a name='Modulate_Blend'></a>
|
||
|
|
||
|
<a href='https://api.skia.org/SkBlendMode_8h.html#ad96d76accb8ff5f3eafa29b91f7a25f0'>SkBlendMode</a>::<a href='#SkBlendMode_kModulate'>kModulate</a>
|
||
|
is a mashup of
|
||
|
<a href='https://api.skia.org/SkBlendMode_8h.html#ad96d76accb8ff5f3eafa29b91f7a25f0'>SkBlendMode</a>::<a href='#SkBlendMode_kSrcATop'>kSrcATop</a>
|
||
|
and
|
||
|
<a href='https://api.skia.org/SkBlendMode_8h.html#ad96d76accb8ff5f3eafa29b91f7a25f0'>SkBlendMode</a>::<a href='#SkBlendMode_kMultiply'>kMultiply</a>.
|
||
|
It multiplies all components, including
|
||
|
<a href='https://api.skia.org/SkColor_8h.html#a918cf5a3a68406ac8107f6be48fb906e'>Alpha</a>;
|
||
|
unlike
|
||
|
<a href='https://api.skia.org/SkBlendMode_8h.html#ad96d76accb8ff5f3eafa29b91f7a25f0'>SkBlendMode</a>::<a href='#SkBlendMode_kMultiply'>kMultiply</a>,
|
||
|
if either source or destination is transparent, result is transparent.
|
||
|
<a href='https://api.skia.org/SkBlendMode_8h.html#ad96d76accb8ff5f3eafa29b91f7a25f0'>SkBlendMode</a>::<a href='#SkBlendMode_kModulate'>kModulate</a>
|
||
|
uses <a href='undocumented#Premultiply'>Premultiplied</a> values to compute the
|
||
|
product;
|
||
|
<a href='https://api.skia.org/SkBlendMode_8h.html#ad96d76accb8ff5f3eafa29b91f7a25f0'>SkBlendMode</a>::<a href='#SkBlendMode_kMultiply'>kMultiply</a>
|
||
|
uses <a href='undocumented#Unpremultiply'>Unpremultiplied</a> values to compute
|
||
|
the product.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/88b25/88b25625de79a7843776e66c52652cf7a5dd8ca1" alt="Modulate_Blend"
|
||
|
|
||
|
<a name='Color_Blends'></a>
|
||
|
|
||
|
Modes
|
||
|
<a href='https://api.skia.org/SkBlendMode_8h.html#ad96d76accb8ff5f3eafa29b91f7a25f0'>SkBlendMode</a>::<a href='#SkBlendMode_kHue'>kHue</a>,
|
||
|
<a href='https://api.skia.org/SkBlendMode_8h.html#ad96d76accb8ff5f3eafa29b91f7a25f0'>SkBlendMode</a>::<a href='#SkBlendMode_kSaturation'>kSaturation</a>,
|
||
|
<a href='https://api.skia.org/SkBlendMode_8h.html#ad96d76accb8ff5f3eafa29b91f7a25f0'>SkBlendMode</a>::<a href='#SkBlendMode_kColor'>kColor</a>,
|
||
|
and
|
||
|
<a href='https://api.skia.org/SkBlendMode_8h.html#ad96d76accb8ff5f3eafa29b91f7a25f0'>SkBlendMode</a>::<a href='#SkBlendMode_kLuminosity'>kLuminosity</a>
|
||
|
convert source and destination pixels using all components
|
||
|
<a href='https://api.skia.org/SkColor_8h.html'>color</a> information, using
|
||
|
<a href='https://www.w3.org/TR/compositing-1/#blendingnonseparable'>non-separable
|
||
|
blend modes</a></a> .
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/f9696/f969601c64514dadb11d30786bb80d9ddb591664" alt="Color_Blends"
|