Textures
Because DiffuseMaterial
,
SpecularMaterial
, and EmissiveMaterial
are based on brushes, we need
not be limited to plain colors for our surfaces. We are free to paint 3D
objects with gradient brushes, bitmaps, or drawings. We can even use any
part of a user interface as a brush with which to paint a 3D object. An
image or pattern used to paint a 3D surface is often referred to as a
texture.
To use a textured material, we must tell WPF exactly how the brush should be positioned on the surface. With a solid color, this is a nonissue—the entire surface is of uniform color. But with a bitmap, we need to specify exactly where the image is projected onto the surface.
MeshGeometry3D
provides the
TextureCoordinates
property for
exactly this purpose. For each 3D point in the Positions
, you can specify a 2D texture
coordinate. Example 17-17
defines a simple square surface with four points, joined together with
two triangles.
Example 17-17. MeshGeometry3D with TextureCoordinates
<MeshGeometry3D Positions="−1,1,0 1,1,0 −1,−1,0, 1,−1,0" Normals="0,0,1 0,0,1 0,0,1 0,0,1" TextureCoordinates="0,0 1,0 0,1 1,1" TriangleIndices="0,2,3 0,3,1" />
Figure 17-26 shows the texture
coordinates specified for each corner of the square, and how the
TriangleIndices
collection joins
these together with triangles. Texture coordinates are specified in the
coordinate space of the brush's Viewport
. As we saw in Chapter 13, by default tile brushes use a mapping mode of
RelativeToBoundingBox
, which means that their ...
Get Programming WPF, 2nd Edition now with the O’Reilly learning platform.
O’Reilly members experience books, live events, courses curated by job role, and more from O’Reilly and nearly 200 top publishers.