PROGRAMMING GUIDE
Visualize supports the concept of color interpolation which can help convey information such as stress, pressure, airflow, altitude, etc... Color interpolation is supported on faces, vertices and edges for shells/meshes/cylinders, and may be smooth (normal color interpolation) or banded (color index interpolation). The ColorInterpolationControl is used to enable or disable color interpolation.
Normal color interpolation is achieved by:
The following code sample shows how to set colors on vertices to get a color interpolation effect:
When color interpolation is used, individual colors typically have a specific value or range of values associated with them. For instance, if you want to show a topographical map with different colors representing different altitude, you would create a color map. In the rendering of the topographical map, you want to show color banding that corresponds to the color map.
Color Index interpolation is achieved by:
The following sample code and images demonstrate the effect of the various color interpolation settings. See our color interpolation sample for additional details.
Contour lines are a special type of line which can delineate different regions on a shell or mesh. The classic use case for contour lines is to show topographic elevation on a map. Coupling this type of line with color bands gives the viewer a sense of varying altitudes at different locations.
Typically, a model like the one above is built out of a mesh. In Visualize, contour lines are always associated with color bands - you can't have contour lines without some kind of color data that delineates the boundaries of the band. You must define the colors using a material palette, then you (indirectly) define the contour boundaries by setting color on individual vertices in the mesh.
A topographic map is usually made out of a rectangular mesh. The z-values of each point are then altered to create the relief. You could then set the color of a particular vertex as a function of its height. After the colors are set, you can use the ContourLineControl to enable visibility as well as other attributes of the lines themselves:
An important consideration when setting contour line attributes is ContourLineControl::SetPositions. This method allows fine control over where the lines appear as well as the interval between them. In the code example above, the interval is set to 1.0f. This means a contour line will be drawn between each color band. A value of 2.0f would mean a line would appear at every other band. The offset, 0.5f, means the contour line will be displaced by half a measure. This method works well if the lines are in a predictable pattern, but if you need to set the contour lines to appear at arbitrary positions, you should look into ContourLineControl::SetPositions(FloatArray). That variant allows you to set the contour lines at specific positions.