Color and the Model Loader
When you create a 3D model in Max, Maya, or the like, you can color the model right in the modeling program. I'm not talking about using a texture. I'm talking about just setting a single color to the model as whole. This is called a "flat color." These art programs also allow you to "paint vertex colors": you can color each vertex of the model a different color. Of course, sometimes you do neither, in which case the model is just white.
Every model you load already has a color attribute. Color Attributes are usually not created by the programmer explicitly, they're usually created by the model loader only. There are three possible color attributes created by the model loader:
|| Used by the model loader to indicate that the model has vertex colors stored in its vertex arrays.
|| Used by the model loader to indicate that the model has a single flat color.
|| Used by the model loader to indicate that no particular color was specified. Essentially the same as flat white, but possibly a little faster to render.
Panda combines these color attributes with the textures. If you are accustomed to Photoshop, you should think of the model's color as the bottom (background) layer, and the textures go above that. By default, each texture is modulated (multiplied) with the previous layer, but as in Photoshop, that can be changed.
Recoloring the Model
If you wish, you can manually override the color attribute which has been specified by the model loader.
Again, this is an override. If the model already had vertex colors, these will disappear: the
setColor method is replacing those colors with a new one. If the model already had a flat color, that will be replaced with the new flat color.
It should be mentioned that the color attribute created by the model loader has low priority. That means that even a default-priority
setColor is enough to override it.
You can remove a previous
Tinting the Model
Sometimes, you don't want to replace the existing color, sometimes, you want to tint the existing colors. For this, you need setColorScale:
This color will be modulated (multiplied) with the existing color.
You can remove a previous
To see the difference between
setColorScale, try the code sample below. You will need the nik-dragon model from the Cartoon Shading sample program, which has
vertex colors and no texture:
from panda3d.core import ColorAttrib
# Load three copies of Nik's dragon, which has vertex colors.
model1 = loader.loadModel("nik-dragon")
model2 = loader.loadModel("nik-dragon")
model3 = loader.loadModel("nik-dragon")
# Put them in the scene.
# Arrange them left-to-right
# Model 1 will be left alone, so you can see the original.
# Model 2 will be recolored light blue.
# Model 3 will be tinted light blue.
model2.setColor(0.6, 0.6, 1.0, 1.0)
model3.setColorScale(0.6, 0.6, 1.0, 1.0)
This produces the following output:
The model on the left is the original, unaltered model. Nik has used vertex colors throughout. The yellow of the belly, the black eyes, the red mouth, these are all vertex colors. The one in the
middle has been
setColored to a medium-blue color. As you can see, the
setColor completely replaces the vertex colors. The one on the right bas been
setColorScaleed to the same medium-blue color, but this only tints the model.