Phaser v4.2.0 #7318
photonstorm
announced in
Announcements
Phaser v4.2.0
#7318
Replies: 0 comments
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Uh oh!
There was an error while loading. Please reload this page.
-
Version 4.2.0 - Giedi - 19th June 2026
New Features
render.alphaStrategy: hint to shaders to handle alpha in different ways.render.stencil: disable stencil buffer creation in a game, saving memory.render.stencilAlphaStrategy: set the default alpha strategy used withinStencilobjects, where regular alpha does nothing.CustomContextgame object is a container which can modify theDrawingContextat render time. This is an advanced rendering technique which reaches into the deep settings of the renderer. Potential uses include:Mesh2Dgame object renders textured triangles. It batches with regular sprites.Mesh2D#buildOrderedIndicesprecomputes an optimized index list (Mesh2D#indicesOrdered) which arranges triangles into quad-forming pairs, synthesizing degenerate triangles where a triangle has no edge-sharing partner. You choose the optimization strategy (0fast,1medium,2high), paying the cost once when the topology is stable. UseMesh2D#useOrderedIndices(andMesh2D#setUseOrderedIndices) to toggle between the ordered and unordered lists without rebuilding.Mesh2D#renderAsTriangles(andMesh2D#setRenderAsTriangles) renders the mesh as individual triangles via the newBatchHandlerTrirender node, which is suitable for dynamic topology that cannot be optimized into quads.BatchHandlerTrirender node draws individual textured triangles (gl.TRIANGLES) as a batch. It extendsBatchHandlerQuad, reusing its shader, vertex layout, and texture handling, and adds abatchTrianglesmethod which accepts vertex and index arrays directly.TransformerVertexrender node now splits its per-vertexrunintosetupMatrix(build the transform matrix once per GameObject) andtransformVertex(project a single vertex with the cached matrix). Mesh rendering uses this to avoid rebuilding the transform matrix for every vertex.runis unchanged for existing callers.Stencilgame object is a container whose contents modify the stencil buffer. This is a fast way to persistently mask the game canvas. There are many ways to combine stencils. The default approach is to add layers to the stencil mask.addLayer,subtractLayer,clear, andclearRegion. Add and subtract can be inverted.StencilReferencegame object re-renders a targetStencilwith different settings. This is useful for removing or reusing stencil geometry.AlphaStrategysetting used in the render system allows you to use GLSLdiscardinstead of alpha in many shaders. This is inefficient, but is useful for some effects and situations.filtersForceComposite) to run graphics through a compatible shader.keep: use alpha as normal.dither: use a dithering algorithm to select pixels to discard.threshold: discard all pixels below a certain alpha.BatchHandlerrender node now has a config option fortopology, allowing extended nodes to opt into different triangulation modes.BatchHandlerTrirender node renders textured triangles. It is used byMesh2Din triangle rendering mode. This can be more efficient than attempting to compile triangles into quads, which is the default strategy.DrawingContextadds more controls:WebGLGlobalWrappernow handles stencil write mask.WebGLStencilParametersFactorynow takes an extrawriteMaskparameter.TintModes.MULTIPLY_TWOis a new tint mode which uses a secondary color. This can create powerful new tint effects, such as fire or inversion.ApplyTintaddition has been changed. TheinTintEffectshader attribute has changed from afloatto avec4, and its encoding has changed from a float32 to four uint8s. This should only affect deep uses of the render system.tint2TopLeftetc), and have a new methodsetTint2(). Additionally, the Mesh2D and Tile objects support constant tint viatint2. (TilemapGPULayer does not support tinting on tiles.)Timestep#setFPSLimitmethod changes the frame rate at runtime. This method updates derived properties, making it safer than manually adjustingTimestep#fpsLimit.New Feature: Cone Lights
Cone lights are standard Phaser dynamic lights restricted to a directional cone. They are useful for flashlights, lantern beams, vision cones, headlights, searchlights, and other focal light sources.
Cone lights run through the existing WebGL lighting shader. They do not require a mask, a second Camera, or rendering the map twice. Any Game Object that already works with Phaser lighting can be lit by a cone light.
Full details can be found in the
Phaser 4 Cone Lights.mdfile in the docs folder in this repo.Light.coneEnabledis a new boolean property that controls if the light is restricted to a cone.Light.coneRotationis a new number property that sets the cone direction in radians.Light.coneInnerAngleis a new number property that sets the inner cone angle in radians.Light.coneOuterAngleis a new number property that sets the outer cone angle in radians.Light.setConeis a new method that sets a Light to be a Cone light.Light.setConeRotationis a new method that sets the cone light rotation.Light.setConeAnglesis a new method that sets the cone light inner and outer angles.Light.disableConeis a new method that disables a cone light.LightsManager.addConeLightis a new method that creates a cone-limited light.DefineLightsGLSL shader gains two new uniforms:vec2 directionandvec3 cone.Thanks to @FSDevelop for adding this feature.
Changes
GameObjects.Components.Filtersnow adds its RenderStep just before the core render method. This allows other steps to run beforehand.WebGLStencilParametersFactorynow defaults to:enabled: true(stencil test is on by default; testing showed little performance impact)func: gl.EQUAL(stencil test now passes if the stencil buffer is EQUAL to 0)Fixes
Layerno longer has a duplicate RenderStep which does nothing.SpriteGPULayerno longer tries to access global namespace for Phaser functionality, which can cause a crash in modules.SpriteGPULayerno longer has a Mask component, as it's a Canvas feature but the object is WebGL only.DrawingContextno longer attempts to unbind textures based on the game canvas, which cannot exist and just wastes time.destroyon its Bob Game Objects as part of its own destroy process. Fix Blitter doesn't destroy its Bobs #7292 (thanks @samme)widthandheightvalues were not being updated after a call tosetTo(). Fix Line width and height aren't updated aftersetTo()#7270 (thanks @samme)Phaser.Math.Pow2now exportsGetPowerOfTwo,IsSizePowerOfTwoandIsValuePowerOfTwo. Fix Phaser.Math.Pow2.GetPowerOfTwo is declared in phaser.d.ts but undefined at runtime in Phaser 4.1.0 #7309 (thanks @Visualizeit)
This discussion was created from the release Phaser v4.2.0.
Beta Was this translation helpful? Give feedback.
All reactions