Sprite (computer graphics)

For other uses, see Sprite (disambiguation).
Part of a series on:
Video game graphics

In computer graphics, a sprite is a two-dimensional bitmap that is integrated into a larger scene.

Originally sprites referred to independent objects that are composited together, by hardware, with other elements such as a background.[1] This occurs as each scan line is prepared for the video output device, such as a CRT, without involvement of the main CPU and without the need for a full-screen frame buffer.[1] Sprites can be positioned or altered by setting attributes used during the hardware composition process. Examples of systems with hardware sprites include the Atari 8-bit family, Commodore 64, Nintendo Entertainment System, Sega Genesis, and many coin-operated arcade machines of the 1980s.

Use of the term sprite has expanded to refer to any two-dimensional bitmap used as part of a graphics display, even if drawn into a frame buffer (by either software or a GPU) instead of being composited on-the-fly at display time.

The act of creating sprites is a form of pixel art. It is sometimes referred to as spriting, especially in the hobbyist community.

History

The use of sprites originated with arcade games. The first video game to represent player characters as human player images was Taito's Basketball, which was licensed in February 1974 to Midway, releasing it as TV Basketball in North America.[2][3]

Signetics devised the first video/graphics processors capable of generating sprite graphics for home systems. The Signetics 2636 video processors were first used in the 1976 Radofin 1292 Advanced Programmable Video System.

The Atari VCS, released in 1977, features a hardware sprite implementation where five graphical objects can be moved independently of the game playfield. The term sprite was not in use at the time. The VCS's sprites are called movable objects in the programming manual, further identified as two players, two missiles, and one ball.[4] These each consist of a single row of pixels that are displayed on a scan line. To produce a two-dimensional shape, the sprite's single-row bitmap is altered by software from one scanline to the next.

The Atari 400 and 800 home computers of 1979 feature similar, but more elaborate, circuitry capable of moving eight single-color objects per scan line: four 8-bit wide players and four 2-bit wide missiles. Each is the full height of the displaya long, thin strip. DMA from a table in memory automatically sets the graphics pattern registers for each scan line. Hardware registers control the horizontal position of each player and missile. Vertical motion is achieved by moving the bitmap data within a player or missile's strip. The feature was called "player/missile graphics" by Atari.

The Namco Galaxian arcade system board, for the 1979 arcade game Galaxian, featured animated, multi-colored sprites.[5] It pioneered a sprite system that animated pre-loaded sprites over a scrolling background, which became the basis for Nintendo's Radar Scope and Donkey Kong arcade hardware and home consoles such as the Nintendo Entertainment System.[6]

The Elektor TV Games Computer was an early microcomputer capable of generating sprite graphics, which Signetics referred to as "objects".

The term sprite was first used in the graphic sense by one of the definers of the Texas Instruments 9918(A) video display processor (VDP).[7] The term was derived from the fact that sprites, rather than being part of the bitmap data in the framebuffer, instead "floated" around on top without affecting the data in the framebuffer below, much like a ghost or "sprite". By this time, sprites had advanced to the point where complete two-dimensional shapes could be moved around the screen horizontally and vertically with minimal software overhead.

The CPU would instruct the external chips to fetch source images and integrate them into the main screen using direct memory access channels. Calling up external hardware, instead of using the processor alone, greatly improved graphics performance. Because the processor was not occupied by the simple task of transferring data from one place to another, software could run faster; and because the hardware provided certain innate abilities, programs were also smaller.

Hardware sprites

A simple C64 game with few sprites (hardware sprites)

Many early arcade games and home video game systems had chips with sprite support, in which small images were integrated into the screen, often with priority control with respect to the background graphics, at the time the video signal was being generated by the graphics chip.

These contrasted with software and blitter methods of 2D animation which modify a framebuffer held in RAM, which required more memory cycles to load and store the pixels, sometimes with an additional mask, and refresh backgrounds behind moving objects. These methods frequently required double buffering to avoid flickering and tearing, but placed fewer restrictions on the size and number of moving objects.

The sprite engine is a hardware implementation of scanline rendering. For each scanline the appropriate scanlines of the sprites are first copied (the number of pixels is limited by the memory bandwidth and the length of the horizontal retrace) into very fast, small, multiple (limiting the number of sprites on a line), and costly caches (the size of which limit the horizontal width) and as the pixels are sent to the screen, these caches are combined with each other and the background. It may be larger than the screen and is usually tiled, where the tile map is cached, but the tile set is not. For every pixel, every sprite unit signals its presence onto its line on a bus, so every other unit can notice a collision with it. Some sprite engines can automatically reload their "sprite units" from a display list. The sprite engine has synergy with the palette. To save registers, the height of the sprite, the location of the texture, and the zoom factors are often limited. On systems where the word size is the same as the texel there is no penalty for doing unaligned reads needed for rotation. This leads to the limitations of the known implementations, in the following table.

Table of Sprite Hardware Features

These are base hardware specs and don't include additional programming techniques, such as using raster interrupts to repurpose sprites mid-frame.

Computer, chip Year Sprites on screen Sprites on line Max. texels on line Texture width Texture height Colors Hardware zoom Rotation Background Collision detection Transparency Source
Amiga, Denise 1985 8 8 ? 16 Arbitrary 3, 15 Vertical by display list No 2 bitmap layers Yes Color key
Amiga (AGA), Lisa 1992 8 8 ? 16, 32, 64 Arbitrary 3, 15 Vertical by display list No 2 bitmap layers Yes Color key
Amstrad Plus, Asic 1990 16 16 ? 16 16 15 1, 2, 4× vertical, 1, 2, 4× horizontal No 1 bitmap layer No Color key [8]
Atari 2600, TIA 1977 5 3 17 1, 8 262 1 1, 2, 4, 8× horizontal Horizontal mirroring 1 bitmap layerYes Color key [9]
Atari 8-bit, GTIA/ANTIC 1979 8 8 40 2, 8 128, 256 1,3 1, 2× vertical, 1, 2, 4× horizontal No 1 tile or bitmap layer Yes Color key [10]
C64, VIC-II 1982 8 8 96, 192 12, 24 21 1, 3 1, 2× integer No 1 tile or bitmap layer Yes Color key [11]
Donkey Kong,
Radar Scope
1979 128 16 256 16 16 3 Integer Horizontal and vertical mirroring 1 tile layer Yes Color key [12]
Game Boy 1989 40 10 80 8 8, 16 3 No Horizontal and vertical mirroring 1 tile layer No Color key [13]
Game Boy Advance 2001 128 128 1210 8, 16, 32, 64 8, 16, 32, 64 15, 255Yes, affine Yes, affine 4 layers, 2 layers, and 1 affine layer, 2 affine layers No Color key, blending [14]
Gameduino 2011 256 96 1,536 16 16 255 No Yes 1 tile layer Yes Color key [15]
Master System,
Game Gear
1985 64 8 128 8, 16 8, 16 15 1, 2× integer, 1, 2× vertical Background tile mirroring 1 tile layer Yes Color key [16][17]
Namco Pac-Man,
arcade hardware
1980 8 8 128 16 16 3 No Horizontal and vertical mirroring 1 tile layer Yes Color key [18]
Nintendo DS 2004 128 128 1,210 8, 16, 32, 64 8, 16, 32, 64 65,536 Yes affine Yes affine 4 layers per screen; each layer is independent No Color key, blending [19]
NES, RP2C0x 1983 64 8 64 8 8, 16 3 No Horizontal and vertical mirroring 1 tile layer Partial Color key [20]
Neo Geo 1990 384 96 1536 16 16 to 512 15 Sprite shrinking Horizontal and vertical mirroring 1 tile layer Partial Color key [21][22][23]
PC Engine, HuC6270A 1987 64 16 256 16, 32 16, 32, 64 15 No No 1 tile layer Yes Color key
PlayStation,
Namco System 11
1994 4000 128 1024 8, 16, 256 8, 16, 256 15, 255 Yes Yes 1 bitmap layer Partial Alpha [24][25]
Genesis 1988 80 20 320 8, 16, 24, 32 8, 16, 24, 32 15 Integer, up to full screen Horizontal and vertical mirroring 2 tile layers Yes Color key [26][27]
Sega OutRun,
arcade hardware
1986 128 128 1600 8 to 512 8 to 256 15 Yes, anisotropic Horizontal and vertical mirroring 2 tile layers and 1 bitmap layer Yes Alpha [28][29][30][31][32][33][34]
Sega Saturn,
Sega ST-V
1994 16,384 555 4443 8 to 504 1 to 255 15 to 32,768 Yes Yes, rotation and distortion 3-6 tile layers and 1-4 bitmap layers Yes Alpha [35][36]
SNES 1990 128 34 272 8, 16, 32, 64 8, 16, 32, 64 15 Background only Background only 3 tile layers or 1 affine mapped tile layer Yes Color key, averaging
Texas Instruments TMS9918197932464 8, 168, 1611, 2× integer No1 tile layerPartial Color key [37]
X68000 1987 128 32 512 16 16 15 1, 2× integer Horizontal and vertical mirroring 1-2 tile layers and 1-4 bitmap layers Partial Color key [38][39][40]
Yamaha V9938 1986 32 8 128 8, 16 8,16 1, 3, 7, 15 per line 1, 2× integer No 1 tile or bitmap layer Partial Color key
Yamaha V9958 1988 32 8 128 8,16 8,16 1, 3, 7, 15 per line 1, 2× integer No 1 tile or bitmap layer Partial Color key
Computer, chip Year Sprites on screen Sprites on line Max. texels on line Texture width Texture height Colors Hardware zoom Rotation Background Collision detection Transparency Source

Use in 3D rendering

2D images with alpha channels constrained to face the camera may be used in 3D graphics. They are common for rendering vegetation, to approximate distant objects, or for particle effects. These are sometimes called "billboards" or "Z-sprites." The technique was most heavily used in Sega game machines in the late 1990s, prior to the era of polygon rendering. If rendered on the fly to cache an approximate view of an underlying 3D model, such sprites are called impostors. Modern hardware may have a specific mode for rendering such point sprites without needing each corner to be defined, or these may be generated by vertex shaders.

Synonyms

Some hardware makers used terms other than sprite, and other terms exist to describe various forms of software-rendering of sprites:

See also

References

  1. 1 2 Hague, James. "Why Do Dedicated Game Consoles Exist?". dadgum.com.
  2. Video Game Firsts, The Golden Age Arcade Historian (November 22, 2013)
  3. Basketball Flyer (1974), Arcade Flyer Museum
  4. Wright, Steve (December 3, 1979). "Stella Programmer's Guide" (PDF).
  5. Dillon, Roberto (19 April 2016). "The Golden Age of Video Games: The Birth of a Multibillion Dollar Industry". CRC Press via Google Books.
  6. Making the Famicom a Reality, Nikkei Electronics (September 12, 1994)
  7. "Karl Guttag Conference on Delphi TI Net - comp.sys.ti | Google Groups". Groups.google.com. Retrieved 2009-11-29.
  8. "Plus - CPCWiki". Cpcwiki.eu. Retrieved 2009-11-29.
  9. "Television Interface Adaptor". AtariArchives.com. Retrieved 2011-02-06.
  10. "Atari 5200 FAQ - Hardware Overview". AtariHQ.com. Retrieved 2011-02-06.
  11. The MOS 6567/6569 video controller (VIC-II) and its application in the Commodore 64 at the Wayback Machine (archived August 30, 2006)
  12. Nathan Altice (2015), I Am Error: The Nintendo Family Computer / Entertainment System Platform, pages 53 & 69, MIT Press
  13. "GameBoy - Spielkonsolen Online Lexikon". At-mix.de. 2004-06-22. Retrieved 2009-11-29.
  14. "Specifications". Nocash.emubase.de. Archived from the original on 2009-06-21. Retrieved 2009-11-29.
  15. "Gameduino Specifications". excamera.com.
  16. Charles MacDonald. "Sega Master System VDP documentation". Archived from the original on 2014-03-18. Retrieved 2011-07-05.
  17. "Sega Master System Technical Information" (TXT). Smspower.org. Retrieved 2016-11-28.
  18. Montfort, Nick; Bogost, Ian (9 January 2009). "Racing the Beam: The Atari Video Computer System". MIT Press via Google Books.
  19. "Specifications". Nocash.emubase.de. Retrieved 2009-11-29.
  20. "Microsoft Word - NESDoc.doc" (PDF). Retrieved 2009-11-29.
  21. "Neo-Geo MVS Hardware Notes" (TXT). Furrtek.free.fr. Retrieved 2016-11-28.
  22. "Neo-Geo Programming Manual" (PDF). Furrtek.free.fr. Retrieved 2016-11-28.
  23. "Big List of Debug Dipswitches". Neo-Geo. 2014-07-09. Retrieved 2016-11-28.
  24. "GPU information" (TXT). Psx.rules.org. Retrieved 2016-11-28.
  25. "NEXT Generation Issue #1 January 1995". Archive.org. Retrieved 2016-11-28.
  26. Sega Programming FAQ October 18, 1995, Sixth Edition - Final at the Wayback Machine (archived January 22, 2005)
  27. Staff, Polygon (2015-02-03). "How Sega built the Genesis". Polygon. Retrieved 2016-11-28.
  28. "Sega Out Run Hardware (Sega)". System 16. 2016-03-31. Retrieved 2016-11-28.
  29. "Out Run". Web.archive.org. 2001-02-27. Retrieved 2016-11-28.
  30. "Out Run Hardware (Sega)". System 16. Retrieved 2009-11-29.
  31. "Version 0.3 - 7th February 1998". Coinop.org. Retrieved 2016-11-28.
  32. "Archived copy". Archived from the original on 2016-01-25. Retrieved 2016-02-09.
  33. "Sega "X-Board" hardware notes" (TXT). Web.archive.org. Retrieved 2016-11-28.
  34. "General Notice" (PDF). Koto.kapsi.fi. Retrieved 2016-11-28.
  35. "General Notice" (PDF). Koto.kapsi.fi. Retrieved 2016-11-28.
  36. TEXAS INSTRUMENTS 9900: TMS9918A/TMS9928AITMS9929A Video Display Processors (PDF). Retrieved 2011-07-05.
  37. "X68000-Computer Museum". Museum.ipsj.or.jp. Retrieved 2016-11-28.
  38. "Shmuplations : ChoRenSha68k Development Notes". Shmuplations.com. Retrieved 2016-11-28.
This article is issued from Wikipedia - version of the 12/2/2016. The text is available under the Creative Commons Attribution/Share Alike but additional terms may apply for the media files.