Blend Mode
Control how textures are blended with the background when rendering. Setting a blend mode affects how the colors of a sprite or a game object are combined with the colors of the pixels behind them.
Blend modes have different effects under Canvas and WebGL, and from browser to browser, depending on support. Blend Modes also cause a WebGL batch flush should it encounter a new blend mode. For these reasons try to be careful about the construction of your Scene and the frequency in which blend modes are used.
WebGL and Canvas
'NORMAL'
, orPhaser.BlendModes.NORMAL
, or0
- Default setting and draws new shapes on top of the existing canvas content.
'ADD'
, orPhaser.BlendModes.ADD
, or1
- Where both shapes overlap the color is determined by adding color values.
'MULTIPLY'
, orPhaser.BlendModes.MULTIPLY
, or2
- The pixels are of the top layer are multiplied with the corresponding pixel of the bottom layer. A darker picture is the result.
'SCREEN'
, orPhaser.BlendModes.SCREEN
, or3
- The pixels are inverted, multiplied, and inverted again. A lighter picture is the result (opposite of multiply)
'ERASE'
, orPhaser.BlendModes.ERASE
, or17
- Alpha erase blend mode. Only works when rendering to a framebuffer, like a Render Texture
Canvas only
'OVERLAY'
, orPhaser.BlendModes.OVERLAY
, or4
- A combination of multiply and screen. Dark parts on the base layer become darker, and light parts become lighter.
'DARKEN'
, orPhaser.BlendModes.DARKEN
, or5
- Retains the darkest pixels of both layers.
'LIGHTEN'
, orPhaser.BlendModes.LIGHTEN
, or6
- Retains the lightest pixels of both layers.
'COLOR_DODGE'
, orPhaser.BlendModes.COLOR_DODGE
, or7
- Divides the bottom layer by the inverted top layer.
'COLOR_BURN'
, orPhaser.BlendModes.COLOR_BURN
, or8
- Divides the inverted bottom layer by the top layer, and then inverts the result.
'HARD_LIGHT'
, orPhaser.BlendModes.HARD_LIGHT
, or9
- A combination of multiply and screen like overlay, but with top and bottom layer swapped.
'SOFT_LIGHT'
, orPhaser.BlendModes.SOFT_LIGHT
, or10
- A softer version of hard-light. Pure black or white does not result in pure black or white.
'DIFFERENCE'
, orPhaser.BlendModes.DIFFERENCE
, or11
- Subtracts the bottom layer from the top layer or the other way round to always get a positive value.
'EXCLUSION'
, orPhaser.BlendModes.EXCLUSION
, or12
- Like difference, but with lower contrast.
'HUE'
, orPhaser.BlendModes.HUE
, or13
- Preserves the luma and chroma of the bottom layer, while adopting the hue of the top layer.
'SATURATION'
, orPhaser.BlendModes.SATURATION
, or14
- Preserves the luma and hue of the bottom layer, while adopting the chroma of the top layer.
'COLOR'
, orPhaser.BlendModes.COLOR
, or15
- Preserves the luma of the bottom layer, while adopting the hue and chroma of the top layer.
'LUMINOSITY'
, orPhaser.BlendModes.LUMINOSITY
, or16
- Preserves the hue and chroma of the bottom layer, while adopting the luma of the top layer.
'SOURCE_IN'
, orPhaser.BlendModes.SOURCE_IN
, or18
- The new shape is drawn only where both the new shape and the destination canvas overlap. Everything else is made transparent.
'SOURCE_OUT'
, orPhaser.BlendModes.SOURCE_OUT
, or19
- The new shape is drawn where it doesn't overlap the existing canvas content.
'SOURCE_ATOP'
, orPhaser.BlendModes.SOURCE_ATOP
, or20
- The new shape is only drawn where it overlaps the existing canvas content.
'DESTINATION_OVER'
, orPhaser.BlendModes.DESTINATION_OVER
, or21
- New shapes are drawn behind the existing canvas content.
'DESTINATION_IN'
, orPhaser.BlendModes.DESTINATION_IN
, or22
- The existing canvas content is kept where both the new shape and existing canvas content overlap. Everything else is made transparent.
'DESTINATION_OUT'
, orPhaser.BlendModes.DESTINATION_OUT
, or23
- The existing content is kept where it doesn't overlap the new shape.
'DESTINATION_ATOP'
, orPhaser.BlendModes.DESTINATION_ATOP
, or24
- The existing canvas is only kept where it overlaps the new shape. The new shape is drawn behind the canvas content.
'LIGHTER'
, orPhaser.BlendModes.LIGHTER
, or25
- Where both shapes overlap the color is determined by adding color values.
'COPY'
, orPhaser.BlendModes.COPY
, or26
- Only the new shape is shown.
'XOR'
, orPhaser.BlendModes.XOR
, or27
- Shapes are made transparent where both overlap and drawn normal everywhere else.
Color
The Color class holds a single color value and allows for easy modification and reading of it.
Get color integer
-
Hex string, or color integer
var color = Phaser.Display.Color.ValueToColor(input);
input
: Hex string, or color integer
-
RGB to color
var color = Phaser.Display.Color.GetColor(red, green, blue);
red
,green
,blue
: 0 ~ 255
-
RGBA to color
var color = Phaser.Display.Color.GetColor32(red, green, blue, alpha);
red
,green
,blue
,alpha
: 0 ~ 255
-
Hex string to color
var color = Phaser.Display.Color.HexStringToColor(hex).color;
- hex :
#0033ff
,#03f
,0x0033ff
, or0x03f
- hex :
-
RGB string to color
var color = Phaser.Display.Color.RGBStringToColor(rgb);
- rgb :
'rgb(r,g,b)'
, or'rgba(r,g,b,a)'
- r, g, b : 0 ~ 255
- a : 0 ~ 1
- rgb :
-
HSV to color
var color = Phaser.Display.Color.HSVToRGB(h, s, v).color;
h
,s
,v
: 0 ~ 1
Color integer to RGB
var rgb = Phaser.Display.Color.IntegerToRGB(color);
color
: Color integer (0xAARRGGBB
)rgb
: JSON object ({r, g, b, a}
)
HSV color wheel
-
Create color array
var colorArray = Phaser.Display.Color.HSVColorWheel(s, v);
-
Get color
var color = colorArray[i].color; // i : 0 ~ 359
Color object
Create color object
-
Create via r,g,b,a components
var color = new Phaser.Display.Color(red, green, blue); // alpha = 255 // var color = new Phaser.Display.Color(red, green, blue, alpha);
red
,green
,blue
,alpha
: 0 ~ 255
-
Create via color integer
var color = Phaser.Display.Color.IntegerToColor(colorInteger);
- colorInteger : Color integer (
0xAARRGGBB
)
- colorInteger : Color integer (
Set color
-
Set color
color.setTo(red, green, blue); // alpha = 255 // color.setTo(red, green, blue, alpha);
red
,green
,blue
,alpha
: 0 ~ 255
-
Set color in GL values
color.setGLTo(red, green, blue); // alpha = 1 // color.setTo(red, green, blue, alpha);
red
,green
,blue
,alpha
: 0 ~ 1
-
Set color from color object
color.setFromRGB(rgba);
-
rgba :
{ r: 0, g: 0, b: 0, // a: 0 }
-
-
Set color from HSV
color.setFromHSV(h, s, v);
-
Set to transparent ()
color.transparent();
- Set (red, green, blue) to
0
- Set (red, green, blue) to
-
Set to gray color
color.gray(value);
-
Set to a random color
color.random();
or
color.random(min, max);
min
: 0 ~ 255. Default value is 0.max
: 0 ~ 255. Default value is 255.
-
Set to random gray
color.randomGray();
or
color.randomGray(min, max);
-
Set red/green/blue/alpha channel : 0 ~ 255
color.red = value; // color.red += value; color.green = value; // color.green += value; color.blue = value; // color.blue += value; color.alpha = value; // color.alpha += value;
-
Set H/S/V channel : 0 ~ 1
color.h = value; // color.h += value; color.s = value; // color.s += value; color.v = value; // color.v += value;
-
Set normalized red, green, blue, alpha : 0 ~ 1
color.redGL = value; // color.redGL += value; color.greenGL = value; // color.greenGL += value; color.blueGL = value; // color.blueGL += value; color.alphaGL = value; // color.alphaGL += value;
-
Set brighten
color.brighten(value);
value
: Percentage, 0 ~ 100
-
Saturate : Increase the saturation (S) of this Color by the percentage amount given.
color.saturate(value);
value
: Percentage, 0 ~ 100
-
Desaturate : Decrease the saturation (S) of this Color by the percentage amount given.
color.desaturate(value);
value
: Percentage, 0 ~ 100
-
Lighten : Increase the lightness (V) of this Color by the percentage amount given.
color.lighten(value);
value
: Percentage, 0 ~ 100
-
Darken : Decrease the lightness (V) of this Color by the percentage amount given.
color.darken(value);
value
: Percentage, 0 ~ 100
Properties
-
RGB Color, not including the alpha channel
var c = color.color;
-
RGB Color, including the alpha channel.
var c = color.color32;
-
RGB color string which can be used in CSS color values.
var c = color.rgba;
-
Red, green, blue, alpha : 0 ~ 255
var r = color.red; var g = color.green; var b = color.blue; var a = color.alpha;
-
H, S, V : 0 ~ 1
var h = color.h; var s = color.s; var v = color.v;
-
Normalized red, green, blue, alpha : 0 ~ 1
var r = color.redGL; var g = color.greenGL; var b = color.blueGL; var a = color.alphaGL;
Clone
var newColor = color.clone();
To hex string
var hexString = Phaser.Display.Color.RGBToString(color.r, color.g, color.b, color.a);
// var hexString = Phaser.Display.Color.RGBToString(color.r, color.g, color.b, color.a, prefix);
Interpolation
Interpolate between 2 colors.
var colorOut = Phaser.Display.Color.Interpolate.RGBWithRGB(r1, g1, b1, r2, g2, b2, length, index);
var colorOut = Phaser.Display.Color.Interpolate.ColorWithColor(color1, color2, length, index);
var colorOut = Phaser.Display.Color.Interpolate.ColorWithRGB(color, r, g, b, length, index);
length
,index
: t =index/length
(0~1)
Masks
Phaser has the ability to 'mask' Game Objects as they are rendered. A mask allows you to 'hide' areas of the Game Object from rendering. There are two types of mask available: Geometry Masks and Bitmap Masks. The Geometry Mask works by using geometry data in order to create the mask. For example rectangles, circles, ellipses, polygons and more. This data is used to create a path that forms the mask. Internally, it uses what is known as the stencil buffer in WebGL and the clip path in Canvas.
The Bitmap Mask works by using a texture as the mask. This texture can be any size and shape you like, and can be animated, or even a video. The alpha values of the pixels in the texture control what the mask looks like on-screen. For example, a pixel with an alpha value of 0 will hide the Game Object, where-as a pixel with an alpha value of 1 will show it. This allows you to create detailed effects, such as feathering, not possible with a Geometry Mask. Bitmap Masks are a WebGL only feature.
Masks in Phaser are slightly unique in that they are drawn and positioned in world space. A Game Object can only have one mask applied to it at any one time. However, you can apply the same mask to multiple Game Objects, if you wish. They are not Game Object specific and if you then move the Game Object, the mask will not 'follow' it. This means they require some careful planning to use effectively.
Create mask object
Bitmap mask
var mask = scene.add.bitmapMask([maskObject], [x], [y], [texture], [frame]);
maskObject
: The Game Object or Dynamic Texture that will be used as the mask. If null it will generate an Image Game Object using the rest of the arguments.x
: If creating a Game Object, the horizontal position in the world.y
: If creating a Game Object, the vertical position in the world.texture
: If creating a Game Object, the key, or instance of the Texture it will use to render with, as stored in the Texture Manager.frame
: If creating a Game Object, an optional frame from the Texture this Game Object is rendering with.
Examples
-
Create image (image, sprite, bitmap text, particles, text),or shader
var shape = scene.add.image(x, y, key).setVisible(false);
-
Create mask
var mask = shape.createBitmapMask();
or
var mask = scene.add.bitmapMask(shape);
Geometry mask
The mask is essentially a clipping path which can only make a masked pixel fully visible or fully invisible without changing its alpha (opacity).
-
Create graphics
var shape = scene.make.graphics();
-
Create mask
var mask = shape.createGeometryMask();
Apply mask object
gameObject.setMask(mask); // image.mask = mask;
A mask object could be added to many game objects.
!!! error Don't put game object and its mask into a container together. See this testing, enable line 22-24.
!!! note Bitmap Mask is WebGL only.
!!! note Can combine Geometry Masks and Blend Modes on the same Game Object, but Bitmap Masks can't.
Clear mask
-
Clear mask
image.clearMask();
-
Clear mask and destroy mask object
image.clearMask(true);
Invert alpha
Only GeometryMask has inverse alpha
feature.
-
Inverse alpha
mask.setInvertAlpha(); // mask.invertAlpha = true;
-
Disable
mask.setInvertAlpha(false); // mask.invertAlpha = false;
Get shape game object
-
Bitmap mask
var shape = mask.bitmapMask;
-
Geometry mask
var shape = mask.geometryMask;
Author Credits
Content on this page includes work by: