Skip to content

Class "Color"⚓︎

Constructors⚓︎

Color ()⚓︎

Color Color ( float R, float G, float B, float A, int RO, int GO, int BO )⚓︎

Constructor for the "Color" class.

When using the Font class, use KColor() instead.

Colors are made of three separate components, tint, colorize and offset. Tint acts like a color multiplicator. Offset is a color which is added after the tint is applied. Colorize is complicated. See the SetColorize() function for a detailed description.

R, G, B and A accept numbers between 0 and 1.

RO, GO and BO accept numbers between -255 and 255.


Operators⚓︎

__mul ()⚓︎

Color __mul ( Color right )⚓︎

Defines the multiplication of two Color objects using the * operator.


Functions⚓︎

Lerp ()⚓︎

static Color Lerp ( Color m1, Color m2, float t )⚓︎

Linear Interpolation between two colors. t is the "progress" of the interpolation. Setting t = 0.5 means that the color in the middle of m1 and m2 will be returned.


Reset ()⚓︎

void Reset ( )⚓︎


Set·Colorize ()⚓︎

void SetColorize ( float Red, float Green, float Blue, float Amount )⚓︎

The colorize function can be used to change the color of sprites. Its the best for that purpose, since it doesnt affect existing coloranimations like the flashing of creep.

The values can be between 0 and 1 for normal coloration. if you use higher numbers the color gets more vibrant.

Notes

The alpha component determines how much colorization must be applied. The function takes the original color, converts it to grayscale, multiplies it by the RGB components and then blends it back with the original color. The alpha value determines the blending factor. Colorization is applied after the tint and before the offset function.

Example Code

SetColorize(1, 1, 1, 1) will turn the sprite into grayscale.

SetColorize(1, 0, 0, 1) will turn it red but not as a red tint but as shades of red.

SetColorize(1, 1, 1, 2) will invert the sprite without touching its luminosity.

This code changes the color of red Creep to be purple

1
2
3
4
5
6
7
Test:AddCallback(ModCallbacks.MC_POST_EFFECT_INIT, function(_, self)
    if self.Variant == EffectVariant.CREEP_RED then
        local color = Color(1, 1, 1, 1, 0, 0, 0)
        color:SetColorize(4, 0, 4, 1)
        self:GetSprite().Color = color
    end
end)


Set·Offset ()⚓︎

void SetOffset ( float RedOffset, float GreenOffset, float BlueOffset )⚓︎

Offset is a color that gets added to the sprite after the Tint was applied.


Set·Tint ()⚓︎

void SetTint ( float RedTint, float GreenTint, float BlueTint, float AlphaTint )⚓︎

Tint acts like a color multiplicator.


Variables⚓︎

A⚓︎

float A⚓︎


B⚓︎

float B⚓︎


BO⚓︎

float BO⚓︎


G⚓︎

float G⚓︎


GO⚓︎

float GO⚓︎


R⚓︎

float R⚓︎


RO⚓︎

float RO⚓︎



Last update: June 9, 2021