Real-Time Hatching

Download as pdf or txt
Download as pdf or txt
You are on page 1of 7

Preprint draft: to appear in ACM SIGGRAPH 2001 - do not distribute

Real-Time Hatching
Emil Praun Hugues Hoppe Matthew Webb Adam Finkelstein
Princeton University Microsoft Research Princeton University Princeton University

Abstract
Drawing surfaces using hatching strokes simultaneously conveys
material, tone, and form. We present a system for real-time
rendering of hatching strokes over arbitrary surfaces, in a variety
of non-photorealistic styles. During an automatic preprocess, we
construct a sequence of mip-mapped hatch images corresponding to
different tones, collectively called a tonal art map. Strokes within
the hatch images are scaled to attain appropriate stroke size and
density at all resolutions, and are organized to maintain coherence
across scales and tones. At runtime, hardware multitexturing blends
the hatch images over the rendered faces to locally vary tone while
maintaining both spatial and temporal coherence. In order to
render strokes over arbitrary surfaces, we build a lapped texture
parametrization where the overlapping patches align to a curvature-
based direction field. By exploiting modern texture-mapping
hardware, our scheme convincingly renders hatching strokes in
real-time on a variety of complex surfaces.
Keywords: non-photorealistic rendering, line art, multitexturing,
chicken-and-egg problem
Figure 1: 3D model shaded with hatching strokes at interactive rate.
1 Introduction
In drawings, hatching can simultaneously convey lighting, suggest temporal coherence among the strokes: image-space and object-
material properties, and reveal shape. Hatching generally refers to space. Use of image-space coherence makes it easier to maintain
groups of strokes with spatially-coherent direction and quality. The the relatively constant stroke width that one expects of a drawing.
density of the strokes controls tone for shading. Their character However, the animated sequence can suffer from the “shower-door
and aggregate arrangement suggests surface texture. Lastly, their effect” – the illusion that the user is viewing the scene through a
direction on a surface often follows natural parameter lines or sheet of semi-transmissive glass in which the strokes are embed-
principal curvatures, thereby revealing bulk or form. ded. Furthermore, with image-space coherence, it may be difficult
to align stroke directions with the surface parametrizations in order
Several non-photorealistic rendering (NPR) methods address
to reveal shape. Instead, we opt for object-space coherence. The
hatching in still images rendered from 3D scenes (e.g. [11, 31]).
difficulty when associating strokes with the object is that the stroke
However, these methods lack temporal coherence, and are thus
widths and densities must be adjusted to maintain desired tones,
unsuitable for animation. Methods designed to render temporally
even as the object moves toward or away from the camera.
coherent strokes in animations (e.g. [18]) usually require significant
computation and are therefore inappropriate for interactive use. In In short, hatching in an interactive setting presents three main
this paper, we present a method for real-time hatching suitable for challenges: (1) operating with limited run-time computation,
interactive NPR applications (see Figure 1.) Applications for this (2) maintaining frame-to-frame coherence among strokes, and
technology include games, interactive technical illustrations, and (3) controlling stroke size and density under dynamic viewing con-
artistic virtual environments [13]. ditions. We address these challenges by exploiting modern texture-
In the interactive setting, the camera, lighting, and scene change mapping hardware.
in response to guidance by the user, requiring dynamic rearrange- Our approach is to pre-render hatch strokes into a sequence of
ment of the strokes in the image. If the strokes are placed indepen- mip-mapped images corresponding to different tones, collectively
dently for each image in a sequence, the resulting animation will called a tonal art map (TAM). At runtime, surfaces in the scene
have a flickery, random appearance that is typically undesirable for are textured using these TAM images. The key problem then is to
hatching. There are two obvious frames of reference for achieving locally vary tone over the surface while maintaining both spatial
and temporal coherence of the underlying strokes. Our solution to
URL: http://www.cs.princeton.edu/gfx/proj/hatching this problem has two parts. First, when creating the TAM images
we establish a nesting structure among the strokes, both between
tones and between mip-map levels. We achieve tone coherence
by requiring that strokes in lighter images be subsets of those
in darker ones. Likewise, we achieve resolution coherence by
making strokes at coarser mip-map levels be subsets of those at finer
levels. Second, when rendering each triangle face, we blend several
TAM images using hardware multitexturing, weighting each texture
image according to shading computations at the vertices. Since the
blended TAM images share many of their strokes, the effect is that,
as an area of the surface moves closer or becomes darker, existing
strokes persist while a small number of new strokes fade in.
Preprint draft: to appear in ACM SIGGRAPH 2001 - do not distribute
As observed by Girshick et al. [5], the direction of strokes maps in two ways. First, art maps contain varying tone within each
drawn on an object can provide a strong visual cue of its shape. image, whereas TAMs are organized as a series of art maps, each
For surfaces carrying a natural underlying parametrization, TAMs establishing a single tone. Second, TAMs provide stroke coherence
may be applied in the obvious way: by letting the rendered across both scales and tones in order to improve temporal coherence
strokes follow the parametrization. However, to generate hatching in the resulting imagery.
over a surface of arbitrary topology, we construct for the given Three previous systems have addressed real-time hatching in
model a lapped texture parametrization [21], and render TAMs 3D scenes. Markosian et al. [17] introduced a simple hatching style
over the resulting set of parametrized patches. The lapped texture indicative of a light source near the camera, by scattering a few
construction aligns the patches with a direction field on the surface. strokes on the surface near (and parallel to) silhouettes. Elber [4]
This direction field may be either guided by the user to follow showed how to render line art for parametric surfaces in real
semantic features of the shape, or aligned automatically with time; he circumvented the coherence challenge by choosing a fixed
principal curvature directions using a method similar to that of density of strokes on the surface regardless of viewing distance.
Hertzmann and Zorin [11]. Finally, Lake et al. [15] described an interactive system for hatching
The specific contributions of this paper are: with stroke coherence in image space (rather than object space).
• a real-time hatching system for shading 3D models,
• the introduction of tonal art maps to leverage current texturing 3 Tonal Art Maps
hardware for rendering strokes (§3), Drawing strokes as individual primitives is expensive even on to-
• an automatic stroke-placement algorithm for creating TAMs day’s graphics hardware. In photorealistic rendering, the traditional
with stroke coherence at different scales and tones (§4), approach for rendering complex detail is to capture it in the form
• a multitexturing algorithm for efficiently rendering TAMs with of a texture map. We apply this same approach to the rendering of
both spatial and temporal coherence (§5), and hatching strokes for NPR. Strokes are pre-rendered into a set of tex-
ture images, and at runtime, the surface is rendered by appropriately
• the integration of TAMs, lapped textures and curvature-based blending these textures.
direction fields to convey shape and tone for surfaces of arbitrary Whereas conventional texture maps only serve to capture ma-
topology (§6). terial detail, hatch strokes in hand-drawn illustrations convey both
material and shading. We therefore discretize the range of tone val-
2 Previous work ues, and construct a sequence of hatch images representing these
Much of the work in non-photorealistic rendering has focused on discrete tones. To render a surface, we compute its desired tone
tools to help artists (or non-artists) generate imagery in various value (using lighting computation on the CPU), and render the sur-
traditional media or styles such as impressionism [8, 9, 16, 18], face unlit using the texture of the appropriate tone. By selecting
technical illustration [6, 23, 24], watercolor [2], engraving [20], and multiple textures on each face and blending them together, we can
pen-and-ink [3, 26, 27, 31, 32]. Our work is applicable over a range achieve fine local control over surface tone while at the same time
of artistic styles in which individual hatching strokes are visible, for maintaining spatial and temporal coherence of the stroke detail. We
example pencil, charcoal, or crayon. present further details in Section 5.
One way to categorize NPR methods would be to consider the Another difficulty in applying conventional texture maps to non-
form of input used. A branch of stroke-based NPR work uses a photorealistic detail is that scaling does not achieve the desired
reference image for color, tone, or orientation [8, 9, 26, 25, 27]. effect. For instance, one expects the strokes to have roughly
For painterly processing of video, Litwinowitcz [16] and later the same screen-space width when representing both near and far
Hertzmann and Perlin [10] addressed the challenge of frame-to- objects. Thus, when magnifying an object, we would like to see
frame coherence by applying optical flow methods to approximate more strokes appear (so as to maintain constant tone), whereas
object-space coherence for strokes. Our work follows a branch of ordinary texture mapping simply makes existing strokes larger. The
research that relies on 3D models for input. art maps of Klein et al. [13] address this problem by defining
Much of the work in 3D has focused on creating still images of custom mip-map images for use by the texturing hardware. In this
3D scenes [3, 4, 10, 24, 30, 29, 31, 32]. However, several systems paper, we use a similar approach for stroke-based textures. We
have addressed off-line animation [1, 3, 18], wherein object-space design the mip-map levels such that strokes have the same (pixel)
stroke coherence is considerably easier to address than it is for width in all levels. Finer levels maintain constant tone by adding
processing of video. A number of researchers have introduced new strokes to fill the enlarged gaps between the old strokes. We
technologies for interactive NPR for 3D scenes, for example, perform this mip-map construction for the stroke image associated
shading for technical illustration [7], “graftals” (geometric textures with each tone. We call the resulting sequence of mip-mapped
especially effective for abstract fur and leaves) [12, 14], or real- images a tonal art map (TAM).
time silhouettes [4, 7, 11, 17, 19, 22]. While not the focus of our A tonal art map consists of a 2D grid of images, as illustrated in
research, we extract and render silhouettes because they often play Figure 2. Let (, t) refer to indices in the grid, where the row index
a crucial role in drawings.  is the mipmap level ( = 0 is coarsest) and the column index t
In this paper, we introduce tonal art maps, which build on two denotes the tone value (t = 0 is white).
previous technologies: “prioritized stroke textures” and “art maps.” Since we render the surface by blending between textures
Described by both Salisbury et al. [26] and Winkenbach et al. [31], corresponding to different tones and different resolutions (mipmap
a prioritized stroke texture is a collection of strokes that simulta- levels), it is important that the textures have a high degree of
neously convey material and continuously-variable tone. Priori- coherence. The art maps constructed in [13] suffered from
tized stroke textures were designed for creating still imagery and lack of coherence, because each mipmap level was constructed
therefore do not address either efficient rendering or temporal co- independently using “off the shelf” NPR image processing tools.
herence. One might think of TAMs as an organization for sampling The lack of coherence between the strokes at the different levels
and storage of prioritized stroke textures at a discrete set of scales create the impression of “swimming strokes” when approaching or
and tones, for subsequent real-time, temporally-coherent rendering. receding from the surface.
TAMs also build on the “art maps” of Klein et al. [13], which adjust Our solution is to propose a stroke nesting property: all strokes
screen-space stroke density in real time by using texture-mapping in a texture image (, t) appear in the same place in all the darker
hardware to slowly fade strokes in or out. TAMs differ from art images of the same resolution and in all the finer images of the same

2
Preprint draft: to appear in ACM SIGGRAPH 2001 - do not distribute

Figure 2: A Tonal Art Map. Strokes in one image appear in all the images to the right and down from it.

tone – i.e. in any texture image ( , t ) where  ≥  or t ≥ t. As an the light-tone images where spacing is important, and is gradually
example, the strokes in the gray box in Figure 2 are added to the reduced to 100 for the dark-tone images where strokes overlap.
the image to the left to create the image to the right. Consequently, The length of each candidate stroke is randomly set to between 0.3
when blending between neighboring images in the grid of textures, and 1.0 times the width of the image, and its orientation has a tiny
only a few pixels differ, leading to minimal blending artifacts (some random perturbation from the mean.
gray strokes). Our measure of “best-fitting” includes both progress towards the
Figure 4 demonstrates rendering using tonal art maps. The unlit desired tone value and relative placement of strokes. For each
sphere in Figure 4a shows how the mip-maps gradually fade out the candidate stroke si we measure its progress as follows. For the hatch
strokes where spatial extent is compressed at the parametric pole. image at each level  of the TAM that could receive si , we find the
The lit cylinder in Figure 4b shows how TAMs are able to capture average tones, T and Ti , respectively, of the hatch image drawn
smoothly varying tone. Finally, Figure 4c shows the combination 
with with all previously chosen strokes and with si added. The sum
of both effects. 
(Ti − T ) expresses the darkness that this stroke would add to
all the hatch images in this column – essentially a measure of the
4 Automatic generation of line-art TAM’s “progress” toward the desired tone at all levels of the TAM.
We achieve more even spacing by considering the cumulative
The concept of tonal art maps is quite general and can be used to effect of adding si at all levels p of an image pyramid; even though
represent a large variety of aesthetics (e.g. paint-brush strokes, pen- si might lie next to, but not overlapping, an existing stroke at fine
and-ink, stippling, and charcoal). The grid of images in the TAM levels of the pyramid, it will overlap at coarser levels. Thus we find
can be either hand-drawn or generated automatically. In this section the average tones, Tp and Tip , over each level p of the pyramid
we present our technique for automatically generating a line-art
TAM.

(without and with si , respectively) for each unfilled image in the
column, and take the sum p, (Tip − Tp ).
Recall that the strokes in the resulting TAM should satisfy the Finally, this simultaneous measure of progress and even spacing
nesting property described in the previous section. Our approach favors longer strokes over shorter strokes, even at the expense of
is to fill the TAM images in top-to-bottom, left-to-right order. For overlapping a previous stroke. Therefore, we normalize the good-
each column, we begin by copying all the images from the column ness  of the stroke by its length, measuring the “goodness” of si as:
to its left (or setting all images to white when starting at the leftmost 1
(Tip − Tp ). With optimized stroke placement, the hatch
||si || p,
column). This ensures that all strokes in images with lighter tones
also appear in images with darker tone. Within the column, we images are much more uniform, as illustrated in Figures 2 and 3.
then consider each image in top-to-bottom (coarse-to-fine) order. Artists often use parallel strokes to represent lighter tones, and
We repeatedly add strokes to the image until the mean image tone switch to cross-hatching for darker tones. Our TAM construction
reaches the tone value associated with that column. Each stroke process supports cross-hatching, as demonstrated in Figure 2. For
drawn in the image is also added to all the lower (finer) images some number of leftmost columns (e.g. 3), we add only horizontal
in the current column. This ensures that strokes in coarser images strokes. Then, beginning with some middle column (e.g. 4th ), we
always appear in finer images. add only vertical strokes for cross-hatching. Finally, some number
of columns later (e.g. 6th ), we add both vertical and horizontal
The naı̈ve approach of random stroke selection leads
strokes to best fill the remaining gaps.
to a non-uniform distribution of strokes, as illustrated
In our current implementation, stylistic variation (Figure 3)
in the figure to the right. Typically an artist would
between different TAMs comes from the variation in angle, cross-
space the strokes more evenly. To get even spacing, we
hatching schedule, range of lengths, and choice of stroke (given
generate multiple randomly-placed candidate strokes and select the
as a grayscale image). For now we only use grayscale strokes, to
“best-fitting” one. The number of candidates is set to, say, 1000 for
enable an efficient rendering scheme described in the next section.
The finest hatch images are 256 × 256, and are toroidal to allow for
tiled rendering over parametrized surfaces.

5 Rendering with TAMs


The nesting structure in the TAM image grid helps to provide tem-
poral coherence during animation. The mip-mapping feature of
hardware texturing automatically blends between different resolu-
Figure 3: Lower-left hatch images from TAMs in 3 other styles. tion levels of the TAM. What is missing, however, is a smooth tran-

3
Preprint draft: to appear in ACM SIGGRAPH 2001 - do not distribute
sition in the tonal dimension of the TAM. We achieve smooth tran-
sitions using a 6-way blending scheme that we will describe shortly.
However, we first present three intermediate approximations.
First, if for each face we select a single tone column from the
TAM (equivalent to flat shading with a quantized palette), our
rendering suffers from both spatial discontinuities (across edges)
and temporal discontinuities (“pops” in tone). Second, the analog of
conventional flat shading is to interpolate between two consecutive
tone columns using a single blend ratio for all pixels in a face. Figure 5: Achieving various degrees of coherence: (a) blending
This effect is temporally smooth, but looks faceted (Figure 5a). 2 textures per face produces temporally smooth but spatially
For spatial coherence we need to blend vertex contributions across discontinuous results; (b) blending 3 textures per face (one per
each face. Thus, our third scheme selects a single tone column vertex) suffers from temporal artifacts; (c) both spatial and temporal
per vertex and blends tones across faces. This scheme is spatially coherence are achieved using 6-way blending
smooth (Figure 5b) but suffers from temporal discontinuities due to
tonal value rounding. (This third scheme is equivalent to Gouraud-
shading with severely quantized vertex lighting computations.)
To obtain both spatial and temporal coherence, we bracket
the continuous tone at each mesh vertex (blending between two
consecutive tone images). Then, for each mesh face, we gather the
blended textures at the three vertices and spatially combine them
across the face (using a barycentric sum as in Gouraud shading).
Since both the 2-way tonal blend and 3-way spatial blend are linear
combinations, this amounts to linearly blending 6 images across
the face (or 12 images when taking into account mip-mapping). (a) (b) (c) (d)
The result is shown in Figure 5c, and the process is illustrated in Figure 6: Illustration of the blending of 6 TAM images on a triangle
Figure 6. While this complex blend operation may initially appear face. Each column (a–c) corresponds to a vertex and shows the
daunting, there are several ways of implementing it efficiently on images for the floor and ceiling of the vertex tone. The resulting
commodity graphics hardware. We next present two such schemes. sum is shown in (d).
Single-pass 6-way blend. The 6-way blend can be implemented
in a single rendering pass. Several existing graphics card support 2 resulting sum. Thus, the images in our paper are rendered using
texture reads during rasterization (and that number will soon jump 6-column TAMs (containing strokes) as well as implicit white.
to 4). Exploiting the fact that our TAM images are grayscale, we When hatching surfaces of arbitrary topology using lapped
pack 6 consecutive tone images in the R,G,B channels of two texture textures, rendering is complicated by the need to modulate each
images. The diffuse and specular fragment colors encode the blend patch texture by the patch outline alpha mask. We address this
ratios. We set these values at vertices, and the hardware interpolates
problem in Section 6.
them at pixel locations. The 6 tones are combined by adding two
dot products between the texture colors and the fragment colors. Triple-pass 2-way blend. If the TAM images contain colored
The first multitexture stage performs the two dot products, while strokes, or if the artist desires more than 6 TAM tone images, an
the second stage adds the results. alternative scheme is to accumulate texture over each face in 3
Hertzmann and Zorin [11] observe that effective drawings can passes. The scheme begins by drawing the whole mesh in black.
use a limited palette of tones, and their scheme targets 4 main Next it renders each triangle 3 times, adding the contribution of
tone levels. For our example TAMs, we have opted for 6 levels. each vertex to the framebuffer. For each vertex we interpolate
Since we can pack all 6 in two textures, there is no need to change between the two TAM columns that bracket the vertex tone. A
texture state between triangles, allowing us to use triangle strips for simple optimization is to organize the faces in triangle fans around
efficiency. We store vertex geometry and texture coordinates on the each vertex.
graphics card in vertex arrays. In contrast, the diffuse and specular
vertex colors must be copied from main memory for every frame. Tone thresholding. The 6-way blend scheme obtains coherence,
Our set of 6 tones do not include white – the “paper” color. but results in the appearance of some gray-toned strokes. Such
However, our interpolation method provides for an implicit white strokes look natural for a variety of artistic styles including pencil
as follows. Since the coefficients of a convex combination sum and charcoal, but are not ideal for some ink-based strokes. To more
to 1.0, by specifying 6 independent coefficients we can implicitly closely match ink strokes, we have experimented with thresholding
blend 7 tones – the 7th tone being 0.0 (black). Since we prefer white, the tone values written to the framebuffer. For the single-pass
we negate the texture inputs before the dot products, as well as the blending scheme, we can configure the multitexturing register
combiners to obtain the transfer function clamp(8t − 3. 5), which
closely models a step function. This transfer function succeeds in
making new strokes appear as gradually lengthening black strokes
instead of gradually darkening gray strokes. Unfortunately, as
shown on the accompanying video and in Figure 7, it has the side-
effect of introducing jaggies along the carefully antialiased edges
of the visible strokes. It may be possible to alleviate these artifacts
through framebuffer supersampling.

Figure 4: Rendering using tonal art maps. (a) illustrates resolution 6 Applying TAM’s to arbitrary surfaces
changes using custom mipmaps; (b) shows smooth changes in tone For parametrized surfaces, one can apply the TAM rendering
and (c) shows their interplay on a shaded sphere. algorithm described in Section 5 directly. For example, the sphere

4
Preprint draft: to appear in ACM SIGGRAPH 2001 - do not distribute

Figure 7: Results: five models rendered with several different TAMs. The right foot was thresholded to black and white in the framebuffer.

and cylinder shown in Figure 4 were textured using a simple tiling buffer. Next, when rendering the patch triangles using the TAM
of a toroidal TAM. However, for surfaces that do not possess natural texture images, the blend operation is set to add the pixels be-
global parametrizations, or for which this parametrization is too ing rendered, multiplied by the alpha value already present in the
distorted, we use lapped textures. framebuffer. (During this operation, only the color channels of the
To review, lapped textures were introduced by Praun et al. [21] framebuffer are written.) As an alternative useful for rendering into
as a way to texture surfaces of arbitrary topology without the need visuals that do not have an alpha channel, the modulation by the
for a continuous global parametrization. The key observation is patch outline may be done using a texture unit. To implement this
that the surface can be covered by a collection of overlapping on graphics cards that allow only two texture reads per pixel, the
patches. All the patches are constructed as topological discs, and consecutive tonal levels to be averaged have to be packed inside a
are parameterized over the plane with little distortion. For many single texture (see Section 5).
textures, including our TAMs, the boundaries between the patches Decoupling the patch shape from the hatch textures presents
are not noticeable, being masked by the high frequency detail of several advantages. First, it reduces memory consumption, since
the textures. Visual masking is further helped by constructing the we only have to store the outline once, and not replicate it for every
patches with irregularly shaped boundaries and with small alpha image in the TAM. Second, having a separate texture transform for
ramps that “feather” the boundaries. the hatch texture allows us to rotate and scale the strokes within
Hatch images are ideal for use with a patch at runtime, without the need to recompute the lapped
lapped textures, because they lack low- parametrization. Third, the stroke textures can be tiled in order to
frequency components (which might oth- cover large patches. Finally, as a consequence of having a different
erwise reveal the patch boundaries). To scale for the outline than for the strokes, we can place different size
render a surface as a lapped texture us- patches on differents parts of the surface (smaller patcher in areas
ing TAMs, we apply the algorithm is Sec- with high curvature, larger patches in flat regions), achieving better
tion 5 for each of the patches, shown coverage while using just a single patch outline (in the original
in random pseudocolor to the right. We lapped textures work, having different size patches could only be
modify the original lapped texture ren- done by using multiple outlines).
dering algorithm to adapt it for hatch ren- Anisotropic lapped textures need a direction field for the
dering by decoupling the patch outline parametrization. In our project, the field governs the direction of
from the stroke textures, storing them strokes on the surface. Girshick et al. [5] observed that stroke di-
separately. When rendering a patch, we rection augments the viewer’s perception of shape, and that prin-
first render its triangles textured using the cipal curvatures are a natural choice for direction. Hertzmann and
patch outline mask, in order to store this Zorin [11] point out that in many drawings the hatch direction fol-
mask into the alpha channel of the frame- lows the curvature of the overall shape, whereas fine details are

5
Preprint draft: to appear in ACM SIGGRAPH 2001 - do not distribute
expressed through tonal variation. Consequently, we compute cur- View-dependent stroke direction. Stroke direction is currently
vatures on the faces of a simplified version of the mesh, smooth determined during the parametrization preprocess. It might be
the resulting direction field, and then resample it on the original useful to attempt to vary stroke direction at runtime as the viewpoint
mesh. For every face of the coarse mesh, we gather the set of ver- moves. One ambitious goal would be to attempt to hide direction
tices adjacent to any of the face’s vertices. We then fit a quadric field singularities. It is well known that one cannot smoothly comb
through these vertices, and finally compute principal curvature di- a hairy ball statically, but perhaps dynamic combing could keep the
rections for this quadric. The error residual from the fit, as well poles hidden from view at all times.
as the ratio of the curvatures, provides a measure of confidence for
the computed directions. Now that we have defined these direc- Acknowledgments
tions for every face, we smooth the field, blending directions from
high-confidence areas into low-confidence areas. We use a global The research reported here was supported by Microsoft Research
non-linear optimization similar to the one described by Hertzmann and a NSF Career Grant. We appreciate the discussion and
and Zorin [11], but adapted for 180◦ rather than 90◦ symmetries. guidance of George Winkenbach and Lee Markosian. The models
shown are from Viewpoint, Cyberware, and Stanford University.

7 Results and Discussion References


[1] C URTIS , C. Loose and sketchy animation. SIGGRAPH ’98 Technical Sketch,
Figure 7 shows five 3D models rendered by our system, using 1998.
several different TAMs. The original models range from 7,500
[2] C URTIS , C. J., A NDERSON , S. E., S EIMS , J. E., F LEISCHER , K. W., AND
to 15,000 faces, while overlapping patches due to lapped textures S ALESIN , D. H. Computer-generated watercolor. Proceedings of SIGGRAPH
increase the range by roughly 50%. Our prototype renders these 97, 421–430.
models at 20 to 40 frames per second on a 933MHz Pentium III
[3] D EUSSEN , O., AND S TROTHOTTE , T. Computer-generated pen-and-ink
with OpenGL/GeForce2 graphics.
illustration of trees. Proceedings of SIGGRAPH 2000, 13–18.
The direction field on the “rocker arm” model (Figure 7, upper
middle) was specified by hand in order to follow semantic features [4] E LBER , G. Interactive line art rendering of freeform surfaces. Computer
Graphics Forum 18, 3 (September 1999), 1–12.
of the shape, whereas the rest of the models used direction fields
computed with the method described in Section 6. [5] G IRSHICK , A., I NTERRANTE , V., H AKER , S., AND L EMOINE , T. Line
As demonstrated on the accompanying video tape, the strokes direction matters: An argument for the use of principal directions in 3D line
drawings. Proceedings of NPAR 2000, 43–52.
exhibit temporal coherence when we animate the models and light.
Furthermore, the hatching density is roughly uniform across each [6] G OOCH , A., G OOCH , B., S HIRLEY, P., AND C OHEN , E. A non-photorealistic
model, regardless of the scale of the model in the image plane (for lighting model for automatic technical illustration. Proceedings of SIGGRAPH
example, see the venus in Figure 7). 98, 447–452.

While it is not the focus of our research, we identify silhouette [7] G OOCH , B., S LOAN , P.-P. J., G OOCH , A., S HIRLEY, P., AND R IESENFELD ,
edges using the method of Sander et al. [28] and draw them as R. Interactive technical illustration. 1999 ACM Symposium on Interactive 3D
simple polylines. Graphics, 31–38.
[8] H AEBERLI , P. E. Paint by numbers: Abstract image representations. Proceed-
ings of SIGGRAPH 90, 207–214.
8 Summary and future work [9] H ERTZMANN , A. Painterly rendering with curved brush strokes of multiple
sizes. Proceedings of SIGGRAPH 98, 453–460.
We introduced the tonal art map representation, and showed
that it permits real-time rendering of stroke-based textures. We [10] H ERTZMANN , A., AND P ERLIN , K. Painterly rendering for video and
described a texture blending scheme for maintaining spatial and interaction. Proceedings of NPAR 2000, 7–12.
temporal coherence during changes in view and lighting. Although [11] H ERTZMANN , A., AND Z ORIN , D. Illustrating smooth surfaces. Proceedings
it involves interpolating 6 textures on each triangle, we have of SIGGRAPH 2000, 517–526.
demonstrated that the blending can be implemented efficiently on [12] K APLAN , M., G OOCH , B., AND C OHEN , E. Interactive artistic rendering.
existing multitexturing hardware. We focused our results on line- Proceedings of NPAR 2000, 67–74.
art style renderings, and presented an algorithm for automatically
[13] K LEIN , A., L I , W., K AZHDAN , M., C ORREA , W., F INKELSTEIN , A., AND
constructing tonal art maps in that style. When combined with a
F UNKHOUSER , T. Non-photorealistic virtual environments. Proceedings of
lapped texture parametrization, our framework permits real-time SIGGRAPH 2000, 527–534.
NPR rendering for many complex shapes. There remain a number
of interesting areas for future work: [14] KOWALSKI , M. A., M ARKOSIAN , L., N ORTHRUP, J. D., B OURDEV, L.,
BARZEL , R., H OLDEN , L. S., AND H UGHES , J. Art-based rendering of fur,
grass, and trees. Proceedings of SIGGRAPH 99 (August 1999), 433–438.
Stroke growth. Currently, the tone in the tonal art map is adjusted [15] L AKE , A., M ARSHALL , C., H ARRIS , M., AND B LACKSTEIN , M. Stylized
solely through the number of strokes; one could also consider rendering techniques for scalable real-time 3d animation. Proceedings of NPAR
adjusting the length and width of the strokes. 2000, 13–20.
[16] L ITWINOWICZ , P. Processing images and video for an impressionist effect.
Automatic indication. Artists commonly use indication, strokes Proceedings of SIGGRAPH 97, 407–414.
drawn in selected areas that imply texture over a broader surface. [17] M ARKOSIAN , L., KOWALSKI , M. A., T RYCHIN , S. J., B OURDEV, L. D.,
Addition of this technique would enhance real-time hatching. G OLDSTEIN , D., AND H UGHES , J. F. Real-time nonphotorealistic rendering.
Proceedings of SIGGRAPH 97, 415–420.

More general TAMs. Although this paper emphasizes line-art [18] M EIER , B. J. Painterly rendering for animation. Proceedings of SIGGRAPH 96,
477–484.
hatching, we believe our framework extends to a much richer set
of artistic styles. In addition, other axes besides tone could be [19] N ORTHRUP, J. D., AND M ARKOSIAN , L. Artistic silhouettes: A hybrid
used to parametrize art maps; a particularly interesting case would approach. Proceedings of NPAR 2000, 31–38.
be to construct lighting-dependent textures, such as bricks whose [20] O STROMOUKHOV, V. Digital facial engraving. Proceedings of SIGGRAPH 99,
highlights adjust to relative light position (as demonstrated in [31]). 417–424.

6
Preprint draft: to appear in ACM SIGGRAPH 2001 - do not distribute
[21] P RAUN , E., F INKELSTEIN , A., AND H OPPE , H. Lapped textures. Proceedings
of SIGGRAPH 2000, 465–470.
[22] R ASKAR , R., AND C OHEN , M. Image precision silhouette edges. 1999 ACM
Symposium on Interactive 3D Graphics, 135–140.
[23] ROSSL , C., AND KOBBELT, L. Line-art rendering of 3D models. Proceedings
of Pacific Graphics 2000.
[24] S AITO , T., AND TAKAHASHI , T. Comprehensible rendering of 3D shapes.
Proceedings of SIGGRAPH 90, 197–206.
[25] S ALISBURY, M., A NDERSON , C., L ISCHINSKI , D., AND S ALESIN , D. H.
Scale-dependent reproduction of pen-and-ink illustrations. Proceedings of
SIGGRAPH 96, 461–468.
[26] S ALISBURY, M. P., A NDERSON , S. E., BARZEL , R., AND S ALESIN , D. H.
Interactive pen-and-ink illustration. Proceedings of SIGGRAPH 94, 101–108.
[27] S ALISBURY, M. P., WONG , M. T., H UGHES , J. F., AND S ALESIN , D. H.
Orientable textures for image-based pen-and-ink illustration. Proceedings of
SIGGRAPH 97, 401–406.
[28] S ANDER , P., G U , X., G ORTLER , S., H OPPE , H., AND S NYDER , J. Silhouette
clipping. Proceedings of SIGGRAPH 2000, 335–342.
[29] S OUSA , M. C., AND BUCHANAN , J. W. Observational model of blenders
and erasers in computer-generated pencil rendering. Proceedings of Graphics
Interface ’99, 157 – 166.
[30] S OUSA , M. C., AND BUCHANAN , J. W. Computer-generated graphite pencil
rendering of 3d polygonal models. Computer Graphics Forum 18, 3 (September
1999), 195–208.
[31] W INKENBACH , G., AND S ALESIN , D. Computer-generated pen-and-ink
illustration. Proceedings of SIGGRAPH 94, 91–100.
[32] W INKENBACH , G., AND S ALESIN , D. H. Rendering parametric surfaces in pen
and ink. Proceedings of SIGGRAPH 96, 469–476.

You might also like