Skip to content

Merge two textures by overlapping it and returns a new and merged image

Notifications You must be signed in to change notification settings

MDIVS/GodotTextureOverlapper

Repository files navigation

Godot Texture Overlapper

Contains a TextureOverlapper class and a example of use made with Godot Engine v4.2.1 - stable.

TextureOverlapper class can be imported in any godot project and is ready to use.

This class only contains the method overlap that merge two textures by overlapping it and returns a new and merged image.

With this approach, merge two textures becomes as simple as calling:

var merged_texture = TextureOverlapper.overlap(texture1, texture2)

Fell free to use and modify this code as you want as well as submit your suggestions of new implementations as pull requests here.

Screenshot

Screenshot

Why overlap textures?

There are lots of use cases where you can't just draw two Sprite2D or TextureRect nodes one over another.

If you have a Skeleton2D controlling a texturized Polygon2D, for instance, draw a static texture over the polygon wont inherit the Skeleton effect.

On the other hand, duplicate the polygon changing the texture you want is not an mainteanable approach.

For this scenario, you problably gonna want to merge textures and apply the merged texture in the polygon.

Performance warning

Keep in mind that we are using the Texture2D.getImage() method. This will fetch the texture data from the GPU, which might cause performance problems when overused. See Godot Documentation for more information.

About

Merge two textures by overlapping it and returns a new and merged image

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published