{"product_id":"computer-graphics-for-java-programmers-isbn-9780470031605","title":"Computer Graphics for Java Programmers","description":"The book covers elementary concepts, from how to produce simple graphical objects using logical coordinates to producing filled regions. The book reinforces concepts with useful and simple examples, then progresses to applied geometry (vectors, polygons) and then onto how to perform rotations and other transformations of graphical objects. \u003cp\u003eIn a logical progression of ideas, the reader is introduced to some of the classic graphics algorithms and finally to chapters which cover particular effects such as perspective drawings and hidden-face and hidden-line elimination.\u003c\/p\u003e \u003cp\u003eThe book also provides a host of ready-to-run programs and worked examples to illuminate general principles and geometric techniques for the creation of both 2D and 3D graphical objects.\u003c\/p\u003e \u003cp\u003ePreface ix\u003c\/p\u003e \u003cp\u003e\u003cb\u003eCHAPTER 1 Elementary Concepts 1\u003c\/b\u003e\u003c\/p\u003e \u003cp\u003e1.1 Lines, Coordinates and Pixels 2\u003c\/p\u003e \u003cp\u003e1.2 The Boundaries of Filled Regions 7\u003c\/p\u003e \u003cp\u003e1.3 Logical Coordinates 8\u003c\/p\u003e \u003cp\u003e1.4 Anisotropic and Isotropic Mapping Modes 14\u003c\/p\u003e \u003cp\u003e1.5 Defining a Polygon by Using the Mouse 21\u003c\/p\u003e \u003cp\u003eExercises 26\u003c\/p\u003e \u003cp\u003e\u003cb\u003eCHAPTER 2 Applied Geometry 31\u003c\/b\u003e\u003c\/p\u003e \u003cp\u003e2.1 Vectors 32\u003c\/p\u003e \u003cp\u003e2.2 Inner Product 34\u003c\/p\u003e \u003cp\u003e2.3 Determinants 34\u003c\/p\u003e \u003cp\u003e2.4 Vector Product 37\u003c\/p\u003e \u003cp\u003e2.5 The Orientation of Three Points 38\u003c\/p\u003e \u003cp\u003e2.6 Polygons 41\u003c\/p\u003e \u003cp\u003e2.7 The Area of a Polygon 42\u003c\/p\u003e \u003cp\u003e2.8 Point-in-Triangle Test 44\u003c\/p\u003e \u003cp\u003e2.9 Point-in-Polygon Test 45\u003c\/p\u003e \u003cp\u003e2.10 Point-on-Line Test 47\u003c\/p\u003e \u003cp\u003e2.11 Distance Between a Point and a Line 50\u003c\/p\u003e \u003cp\u003e2.12 Projection of a Point on a Line 51\u003c\/p\u003e \u003cp\u003e2.13 Triangulation of Polygons 53\u003c\/p\u003e \u003cp\u003eExercises 58\u003c\/p\u003e \u003cp\u003e\u003cb\u003eCHAPTER 3 Geometrical Transformations 63\u003c\/b\u003e\u003c\/p\u003e \u003cp\u003e3.1 Matrix Multiplication 64\u003c\/p\u003e \u003cp\u003e3.2 Linear Transformations 65\u003c\/p\u003e \u003cp\u003e3.3 Translations 71\u003c\/p\u003e \u003cp\u003e3.4 Homogeneous Coordinates 71\u003c\/p\u003e \u003cp\u003e3.5 Inverse Transformations and Matrix Inversion 72\u003c\/p\u003e \u003cp\u003e3.6 Rotation About an Arbitrary Point 74\u003c\/p\u003e \u003cp\u003e3.7 Changing the Coordinate System 78\u003c\/p\u003e \u003cp\u003e3.8 Rotations About 3D Coordinate Axes 79\u003c\/p\u003e \u003cp\u003e3.9 Rotation About an Arbitrary Axis 80\u003c\/p\u003e \u003cp\u003eExercises 88\u003c\/p\u003e \u003cp\u003e\u003cb\u003eCHAPTER 4 Some Classic Algorithms 91\u003c\/b\u003e\u003c\/p\u003e \u003cp\u003e4.1 Bresenham’s Algorithm for Line Drawing 92\u003c\/p\u003e \u003cp\u003e4.2 Doubling the Line-Drawing Speed 97\u003c\/p\u003e \u003cp\u003e4.3 Circles 102\u003c\/p\u003e \u003cp\u003e4.4 Cohen–Sutherland Line Clipping 107\u003c\/p\u003e \u003cp\u003e4.5 Sutherland–Hodgman Polygon Clipping 113\u003c\/p\u003e \u003cp\u003e4.6 B'ezier Curves 120\u003c\/p\u003e \u003cp\u003e4.7 B-Spline Curve Fitting 130\u003c\/p\u003e \u003cp\u003eExercises 135\u003c\/p\u003e \u003cp\u003e\u003cb\u003eCHAPTER 5 Perspective 139\u003c\/b\u003e\u003c\/p\u003e \u003cp\u003e5.1 Introduction 140\u003c\/p\u003e \u003cp\u003e5.2 The Viewing Transformation 141\u003c\/p\u003e \u003cp\u003e5.3 The Perspective Transformation 146\u003c\/p\u003e \u003cp\u003e5.4 A Cube in Perspective 148\u003c\/p\u003e \u003cp\u003e5.5 Some Useful Classes 152\u003c\/p\u003e \u003cp\u003e5.6 A General Program for Wire-Frame Models 168\u003c\/p\u003e \u003cp\u003eExercises 174\u003c\/p\u003e \u003cp\u003e\u003cb\u003eCHAPTER 6 Hidden-Line Elimination 177\u003c\/b\u003e\u003c\/p\u003e \u003cp\u003e6.1 Line Segments and Triangles 178\u003c\/p\u003e \u003cp\u003e6.2 Tests for Visibility 179\u003c\/p\u003e \u003cp\u003e6.3 Specification and Representation of 3D Objects 190\u003c\/p\u003e \u003cp\u003e6.4 Holes and Invisible Line Segments 192\u003c\/p\u003e \u003cp\u003e6.5 Individual Faces and Line Segments 194\u003c\/p\u003e \u003cp\u003e6.6 Automatic Generation of Object Specification 198\u003c\/p\u003e \u003cp\u003e6.7 Hidden-Line Elimination with HP-GL Output 207\u003c\/p\u003e \u003cp\u003e6.8 Implementation 209\u003c\/p\u003e \u003cp\u003eExercises 213\u003c\/p\u003e \u003cp\u003e\u003cb\u003eCHAPTER 7 Hidden-Face Elimination 219\u003c\/b\u003e\u003c\/p\u003e \u003cp\u003e7.1 Back-Face Culling 220\u003c\/p\u003e \u003cp\u003e7.2 Coloring Individual Faces 225\u003c\/p\u003e \u003cp\u003e7.3 Painter’s Algorithm 226\u003c\/p\u003e \u003cp\u003e7.4 Z-Buffer Algorithm 234\u003c\/p\u003e \u003cp\u003eExercises 246\u003c\/p\u003e \u003cp\u003e\u003cb\u003eCHAPTER 8 Fractals 249\u003c\/b\u003e\u003c\/p\u003e \u003cp\u003e8.1 Introduction 249\u003c\/p\u003e \u003cp\u003e8.2 Koch Curves 250\u003c\/p\u003e \u003cp\u003e8.3 String Grammars 253\u003c\/p\u003e \u003cp\u003e8.4 Mandelbrot and Julia Sets 264\u003c\/p\u003e \u003cp\u003eExercises 276\u003c\/p\u003e \u003cp\u003eAPPENDIX A Linear Interpolation of 1\/z 277\u003c\/p\u003e \u003cp\u003eAPPENDIX B A Note on Event Handling 281\u003c\/p\u003e \u003cp\u003eAPPENDIX C File Obj3D.java 287\u003c\/p\u003e \u003cp\u003eAPPENDIX D Class CvHLines.java 293\u003c\/p\u003e \u003cp\u003eAPPENDIX E Some Applications 301\u003c\/p\u003e \u003cp\u003eE.1 Platonic Solids 301\u003c\/p\u003e \u003cp\u003eE.2 Sphere Representations 312\u003c\/p\u003e \u003cp\u003eE.3 A Torus 319\u003c\/p\u003e \u003cp\u003eE.4 Beams in a Spiral 323\u003c\/p\u003e \u003cp\u003eE.5 Functions of Two Variables 326\u003c\/p\u003e \u003cp\u003eAPPENDIX F Hints and Solutions to Exercises 339\u003c\/p\u003e \u003cp\u003eBibliography 371\u003c\/p\u003e \u003cp\u003eIndex 373\u003c\/p\u003e  \u003cb\u003eLeen Ammeraal\u003c\/b\u003e is a retired lecturer of Hogeschool Utrecht, The Netherlands, where he was employed from 1977 to 1998. He has a degree (ir.) in mathematics at University of Technology Delft, The Netherlands. He worked as a programmer and mathematician at Akzo Research and Engineering, Arnhem, The Netherlands, from 1961 to 1972 and did research work on compilers from 1972 to 1977 at Mathematical Centre, Amsterdam. He wrote many books for Wiley (as well as for the Dutch publisher Academic Service). Some of his Wiley books have been translated into other languages (Japanese, Russian, Italian, French, German, Greek, Danish, Portuguese, Bulgarian).  \u003cp\u003e\u003cb\u003eKang Zhang\u003c\/b\u003e is a Professor in Computer Science and Director of Visual Computing Lab at the University of Texas at Dallas. He received his B.Eng. in Computer Engineering from the University of Electronic Science and Technology, China, in 1982; and Ph.D. from the University of Brighton, UK, in 1990. He held academic positions in the UK and Australia, prior to joining UTD. Zhang's current research interests are in the areas of visual languages, graphical visualization, and Web engineering; and has published over 130 papers in these areas. He has taught computer graphics and related subjects at both graduate and undergraduate levels for many years. Zhang was also an editor of two books on software visualization.\u003c\/p\u003e  A great many varied and interesting visual effects can be achieved with computer graphics, for which a fundamental understanding of the underlying mathematical concepts – and a knowledge of how they can be implemented in a particular programming language – is essential.  \u003cp\u003e\u003ci\u003eComputer Graphics for Java Programmers, 2nd edition\u003c\/i\u003e covers elementary concepts in creating and manipulating 2D and 3D graphical objects, covering topics from classic graphics algorithms to perspective drawings and hidden-line elimination. \u003c\/p\u003e \u003cp\u003eCompletely revised and updated throughout, the second edition of this highly popular textbook contains a host of ready-to-run-programs and worked examples, illuminating general principles and geometric techniques. Ideal for classroom use or self-study, it provides a perfect foundation for programming computer graphics using Java. \u003c\/p\u003e","brand":"Wiley","offers":[{"title":"Default Title","offer_id":47988969046245,"sku":"NP9780470031605","price":64.0,"currency_code":"USD","in_stock":false}],"thumbnail_url":"\/\/cdn.shopify.com\/s\/files\/1\/1842\/7735\/files\/9780470031605.jpg?v=1761782252","url":"https:\/\/k12savings.com\/es\/products\/computer-graphics-for-java-programmers-isbn-9780470031605","provider":"K12savings","version":"1.0","type":"link"}