Download - Texture Mapping
![Page 1: Texture Mapping](https://reader035.vdocuments.mx/reader035/viewer/2022062407/56812bf1550346895d9069cc/html5/thumbnails/1.jpg)
Texture Mapping
![Page 2: Texture Mapping](https://reader035.vdocuments.mx/reader035/viewer/2022062407/56812bf1550346895d9069cc/html5/thumbnails/2.jpg)
2
Motivation
A typical modern graphics card can handle 10s of millions of polygons a second.How many individual blades of grass are there
on a football field?
Modeling the fine detail in real objects with triangles is just too hard sometimes.
![Page 3: Texture Mapping](https://reader035.vdocuments.mx/reader035/viewer/2022062407/56812bf1550346895d9069cc/html5/thumbnails/3.jpg)
3
Motivation
Added surface detail can help computer graphics images look more real.
We can’t explicitly model all of the detail, it’s just too expensive.
Texture mapping let’s us use real images in our CG scenes to add realistic fine detail without the high geometric costs.
![Page 4: Texture Mapping](https://reader035.vdocuments.mx/reader035/viewer/2022062407/56812bf1550346895d9069cc/html5/thumbnails/4.jpg)
4
Fundamentals
Textures are most often 2D imagesA single element of texture is called a texel
The value of the texel is used to modify surface appearance in some way
The mapping between texture and surface determines how pixels and texels correspond
![Page 5: Texture Mapping](https://reader035.vdocuments.mx/reader035/viewer/2022062407/56812bf1550346895d9069cc/html5/thumbnails/5.jpg)
5
How do we find the right texel?
Find the visible pixel
Find the point on the surface the corresponds to the visible pixel
Find the point in the texture (texel) that maps to the point on the surface
Use the texel values as appropriate to shade the pixel
![Page 6: Texture Mapping](https://reader035.vdocuments.mx/reader035/viewer/2022062407/56812bf1550346895d9069cc/html5/thumbnails/6.jpg)
6
Basic Stragegy
Three steps to applying a texture1. specify the texture
• read or generate image• assign to texture• enable texturing
2. assign texture coordinates to vertices• Proper mapping function is left to application
3. specify texture parameters• wrapping, filtering
![Page 7: Texture Mapping](https://reader035.vdocuments.mx/reader035/viewer/2022062407/56812bf1550346895d9069cc/html5/thumbnails/7.jpg)
7
Texture Mapping
s
t
x
y
z
image
geometry screen
![Page 8: Texture Mapping](https://reader035.vdocuments.mx/reader035/viewer/2022062407/56812bf1550346895d9069cc/html5/thumbnails/8.jpg)
8
Texture Example
•The texture (below) is a 256 x 256 image that has been mapped to a rectangular polygon which is viewed in perspective
![Page 9: Texture Mapping](https://reader035.vdocuments.mx/reader035/viewer/2022062407/56812bf1550346895d9069cc/html5/thumbnails/9.jpg)
9
Texture Mapping and the OpenGL Pipeline
geometry pipelinevertices
pixel pipelineimage
rasterizer
• Images and geometry flow through separate pipelines that join at the rasterizer
“complex” textures do not affect geometric complexity
![Page 10: Texture Mapping](https://reader035.vdocuments.mx/reader035/viewer/2022062407/56812bf1550346895d9069cc/html5/thumbnails/10.jpg)
10
• Define a texture image from an array of texels (texture elements) in CPU memory Glubyte my_texels[512][512];
• Define as any other pixel map Scanned image
Generate by application code
• Enable texture mappingglEnable(GL_TEXTURE_2D) OpenGL supports 1-4 dimensional texture maps
Specify Texture Image
![Page 11: Texture Mapping](https://reader035.vdocuments.mx/reader035/viewer/2022062407/56812bf1550346895d9069cc/html5/thumbnails/11.jpg)
11
Define Image as a Texture
glTexImage2D( target, level, components, w, h, border, format, type, texels );
target: type of texture, e.g. GL_TEXTURE_2Dlevel: used for mipmapping (discussed later)components: elements per texelw, h: width and height of texels in pixelsborder: used for smoothing (discussed later)format and type: describe texelstexels: pointer to texel array
glTexImage2D(GL_TEXTURE_2D, 0, 3, 512, 512, 0, GL_RGB, GL_UNSIGNED_BYTE, my_texels);
![Page 12: Texture Mapping](https://reader035.vdocuments.mx/reader035/viewer/2022062407/56812bf1550346895d9069cc/html5/thumbnails/12.jpg)
12
Converting A Texture Image
• OpenGL requires texture dimensions to be powers of 2
• If dimensions of image are not powers of 2•gluScaleImage( format, w_in, h_in, type_in, *data_in, w_out, h_out,
type_out, *data_out );data_in is source imagedata_out is for destination image
• Image interpolated and filtered during scaling
![Page 13: Texture Mapping](https://reader035.vdocuments.mx/reader035/viewer/2022062407/56812bf1550346895d9069cc/html5/thumbnails/13.jpg)
13
• Based on parametric texture coordinates•glTexCoord*() specified at each vertex
s
t1, 1
0, 1
0, 0 1, 0
(s, t) = (0.2, 0.8)
(0.4, 0.2)
(0.8, 0.4)
A
B C
a
bc
Texture Space Object Space
Mapping a Texture
![Page 14: Texture Mapping](https://reader035.vdocuments.mx/reader035/viewer/2022062407/56812bf1550346895d9069cc/html5/thumbnails/14.jpg)
14
Typical Code
glBegin(GL_POLYGON);glColor3f(r0, g0, b0);glNormal3f(u0, v0, w0);glTexCoord2f(s0, t0);glVertex3f(x0, y0, z0);glColor3f(r1, g1, b1);glNormal3f(u1, v1, w1);glTexCoord2f(s1, t1);glVertex3f(x1, y1, z1);
.
.glEnd();
Note that we can use vertex arrays to increase efficiency
![Page 15: Texture Mapping](https://reader035.vdocuments.mx/reader035/viewer/2022062407/56812bf1550346895d9069cc/html5/thumbnails/15.jpg)
15
Interpolation
OpenGL uses bilinear interpolation to find proper texels from specified texture coordinates
Can be distortions
![Page 16: Texture Mapping](https://reader035.vdocuments.mx/reader035/viewer/2022062407/56812bf1550346895d9069cc/html5/thumbnails/16.jpg)
16
Texture Parameters
•OpenGL has a variety of parameters that determine how texture is applied
Wrapping parameters determine what happens of s and t are outside the (0,1) range
Filter modes allow us to use area averaging instead of point samples
Mipmapping allows us to use textures at multiple resolutions
Environment parameters determine how texture mapping interacts with shading
![Page 17: Texture Mapping](https://reader035.vdocuments.mx/reader035/viewer/2022062407/56812bf1550346895d9069cc/html5/thumbnails/17.jpg)
17
Wrapping Mode
Clamping: if s,t > 1 use 1, if s,t <0 use 0Wrapping: use s,t modulo 1
glTexParameteri( GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_CLAMP )
glTexParameteri( GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_REPEAT )
texture
s
t
GL_CLAMPwrapping
GL_REPEATwrapping
![Page 18: Texture Mapping](https://reader035.vdocuments.mx/reader035/viewer/2022062407/56812bf1550346895d9069cc/html5/thumbnails/18.jpg)
18
Magnification and Minification
Texture Polygon
Magnification Minification
PolygonTexture
More than one texel can cover a pixel (minification) ormore than one pixel can cover a texel (magnification)
Can use point sampling (nearest texel) or linear filtering( 2 x 2 filter) to obtain texture values
![Page 19: Texture Mapping](https://reader035.vdocuments.mx/reader035/viewer/2022062407/56812bf1550346895d9069cc/html5/thumbnails/19.jpg)
19
Filter Modes
Modes determined byglTexParameteri( target, type, mode )
glTexParameteri(GL_TEXTURE_2D, GL_TEXURE_MAG_FILTER, GL_NEAREST);
glTexParameteri(GL_TEXTURE_2D, GL_TEXURE_MIN_FILTER, GL_LINEAR);
Note that linear filtering requires a border of an extra texel for filtering at edges (border = 1)
![Page 20: Texture Mapping](https://reader035.vdocuments.mx/reader035/viewer/2022062407/56812bf1550346895d9069cc/html5/thumbnails/20.jpg)
20
Mipmapped Textures
• Mipmapping allows for prefiltered texture maps of decreasing resolutions
• Lessens interpolation errors for smaller textured objects
• Declare mipmap level during texture definitionglTexImage2D( GL_TEXTURE_*D, level, … )
• GLU mipmap builder routines will build all the textures from a given imagegluBuild*DMipmaps( … )
![Page 21: Texture Mapping](https://reader035.vdocuments.mx/reader035/viewer/2022062407/56812bf1550346895d9069cc/html5/thumbnails/21.jpg)
21
MIP-maps
For a 2n x 2n texture, compute n total textures:
Level 0: The original texture
Level i: ½ the resolution of level i-1, each texel is the average of a 2x2 area from level i-1
Level n: 1 texel
How much total space does this take?
![Page 22: Texture Mapping](https://reader035.vdocuments.mx/reader035/viewer/2022062407/56812bf1550346895d9069cc/html5/thumbnails/22.jpg)
22
Texture Functions
• Controls how texture is applied• glTexEnv{fi}[v]( GL_TEXTURE_ENV, prop,
param )
• GL_TEXTURE_ENV_MODE modes GL_MODULATE: modulates with computed shade GL_BLEND: blends with an environmental color GL_REPLACE: use only texture color GL(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_MODULATE);
• Set blend color with GL_TEXTURE_ENV_COLOR
![Page 23: Texture Mapping](https://reader035.vdocuments.mx/reader035/viewer/2022062407/56812bf1550346895d9069cc/html5/thumbnails/23.jpg)
23
Perspective Correction Hint
• Texture coordinate and color interpolation
either linearly in screen space
or using depth/perspective values (slower)
• Noticeable for polygons “on edge”•glHint( GL_PERSPECTIVE_C
ORRECTION_HINT, hint )where hint is one of
•GL_DONT_CARE•GL_NICEST•GL_FASTEST
![Page 24: Texture Mapping](https://reader035.vdocuments.mx/reader035/viewer/2022062407/56812bf1550346895d9069cc/html5/thumbnails/24.jpg)
24
Generating Texture Coordinates
• OpenGL can generate texture coordinates automatically
glTexGen{ifd}[v]()
• specify a plane generate texture coordinates based upon distance from
the plane
• generation modesGL_OBJECT_LINEARGL_EYE_LINEAR GL_SPHERE_MAP (used for environmental maps)
![Page 25: Texture Mapping](https://reader035.vdocuments.mx/reader035/viewer/2022062407/56812bf1550346895d9069cc/html5/thumbnails/25.jpg)
26
Applying Textures II
1. specify textures in texture objects2. set texture filter 3. set texture function 4. set texture wrap mode5. set optional perspective correction hint6. bind texture object 7. enable texturing8. supply texture coordinates for vertex
coordinates can also be generated
![Page 26: Texture Mapping](https://reader035.vdocuments.mx/reader035/viewer/2022062407/56812bf1550346895d9069cc/html5/thumbnails/26.jpg)
27
Other Texture Features
•Environmental Maps Start with image of environment through a wide
angle lens • Can be either a real scanned image or an image created
in OpenGL
Use this texture to generate a spherical map
Use automatic texture coordinate generation
•Multitexturing Apply a sequence of textures through cascaded
texture units