I've never quite understood the language of shaders, but I was wondering if this idea was feasible
Currently I have a character image and then a color image layered on top that is white and then altered using love.graphics.setColor() to the appropriate color of the player.
What I was wondering is if it was possible to set some kind of sentinel rgb value color that I could then replace with the player's corresponding color, significantly cutting down on my art workflow.
A Color Replacing Shader?
Re: A Color Replacing Shader?
One way could be of using each channel in the image as a mask for a particular color.
Depending on the style of the art, one channel (like red) could contain all the values (shading etc) and the green and blue could act as masks for one color each.
That way you have everything in one image at least.
Anything in particular about writing the shader you're wondering about?
There's also this thing called "palette swapping". Never tried it myself though, but could perhaps be of interest.
Depending on the style of the art, one channel (like red) could contain all the values (shading etc) and the green and blue could act as masks for one color each.
That way you have everything in one image at least.
Anything in particular about writing the shader you're wondering about?
There's also this thing called "palette swapping". Never tried it myself though, but could perhaps be of interest.
Re: A Color Replacing Shader?
You can easily write a shader that swaps out a specific color in the source texture with one dynamically set (or the current love.setColor-color). You might want to search for "palette swapping" or "palette shader" on the forums, I have written a small one for someone else a few months ago.dizzykiwi3 wrote:I've never quite understood the language of shaders, but I was wondering if this idea was feasible
Currently I have a character image and then a color image layered on top that is white and then altered using love.graphics.setColor() to the appropriate color of the player.
What I was wondering is if it was possible to set some kind of sentinel rgb value color that I could then replace with the player's corresponding color, significantly cutting down on my art workflow.
Hm, I can't find the thread anymore. The shader would basically look like this:
Code: Select all
vec4 the_color_i_want_to_replace = vec4(1.0, 0.0, 0.0, 1.0); // full, solid red is the color that should be changed to lg.setColor()'s value
vec4 effect( vec4 color, Image texture, vec2 texture_coords, vec2 screen_coords )
{
vec4 texcolor = Texel(texture, texture_coords); // color of the pixel we are drawing (on the texture)
if (texcolor == the_color_i_want_to_replace)
return color; // instead return the color set with lg.setColor()
return texcolor; // otherwise return the color from the image
}
- dizzykiwi3
- Citizen
- Posts: 58
- Joined: Tue Jan 14, 2014 2:03 am
Re: A Color Replacing Shader?
Well currently each character image is comprised of a base image and then their color image overlayed on top, so what could be one file is separated into two files, the second of which also requires two numbers to be tracked with it, so as to know what offset to draw it, so I don't have a big image file filled with a ton of blank space (e.g. consider the character holding a big sword, the coloring is only concerned with the body of the character, so I would presume it be more efficient to save that particular color file to be of smaller dimensions and draw it at an offset to how the base is drawn rather than have a lot of blank space)
So if this does in fact work it should save me the time of managing two files for each image, thanks!
So if this does in fact work it should save me the time of managing two files for each image, thanks!
- CaptainMaelstrom
- Party member
- Posts: 163
- Joined: Sat Jan 05, 2013 10:38 pm
Re: A Color Replacing Shader?
dizzykiwi3: You really don't need to be worried about storing your images efficiently unless you are experience problems. Otherwise, you're just committing to premature optimization.
I would use the same size base and color images for each character, that way you can use the same offset. This just makes life easier and really won't cause any performance issues.
A simpler approach:
Make your color image out of only white and transparent pixels, then, right before you love.graphics.draw them, use love.graphics.setColor to change the color.
I would use the same size base and color images for each character, that way you can use the same offset. This just makes life easier and really won't cause any performance issues.
Yes, you can write a shader to do what you're suggesting.dizzykiwi3 wrote:[is] it was possible to set some kind of sentinel rgb value color that I could then replace with the player's corresponding color, significantly cutting down on my art workflow.
A simpler approach:
Make your color image out of only white and transparent pixels, then, right before you love.graphics.draw them, use love.graphics.setColor to change the color.
Re: A Color Replacing Shader?
Yes, Blizzard did exactly this in warcraft 2 for example.dizzykiwi3 wrote: What I was wondering is if it was possible to set some kind of sentinel rgb value color that I could then replace with the player's corresponding color, significantly cutting down on my art workflow.
They had 4 different shades of grey that they replaced on sprites in real time with player colors:
http://www.spriters-resource.com/pc_com ... eet/60022/
- dizzykiwi3
- Citizen
- Posts: 58
- Joined: Tue Jan 14, 2014 2:03 am
Re: A Color Replacing Shader?
That's what I'm currently doing, but it gets rather monotonous, will there really be a significant performance hit for using the shader, or is the only issue the complexity of implementing it?CaptainMaelstrom wrote:dizzykiwi3: You really don't need to be worried about storing your images efficiently unless you are experience problems. Otherwise, you're just committing to premature optimization.
I would use the same size base and color images for each character, that way you can use the same offset. This just makes life easier and really won't cause any performance issues.
Yes, you can write a shader to do what you're suggesting.dizzykiwi3 wrote:[is] it was possible to set some kind of sentinel rgb value color that I could then replace with the player's corresponding color, significantly cutting down on my art workflow.
A simpler approach:
Make your color image out of only white and transparent pixels, then, right before you love.graphics.draw them, use love.graphics.setColor to change the color.
Re: A Color Replacing Shader?
neitherdizzykiwi3 wrote: That's what I'm currently doing, but it gets rather monotonous, will there really be a significant performance hit for using the shader, or is the only issue the complexity of implementing it?
the shader is simple, and there isn't much of a performance impact.
- dizzykiwi3
- Citizen
- Posts: 58
- Joined: Tue Jan 14, 2014 2:03 am
Re: A Color Replacing Shader?
Got it working. I could cry xD well, time to skim away a whole ton of code, thank you so much.
Who is online
Users browsing this forum: Bing [Bot] and 1 guest