Creating Sprite Masks

From QB64 Wiki
Revision as of 17:29, 27 January 2013 by imported>Clippy
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)
Jump to navigation Jump to search

Sometimes your program may need to place a shaped sprite over background objects. To do that you cannot use the default PUT using XOR. XOR only works on black backgrounds! It distorts underlying colors. You could use the PSET option, but that places a square sprite only. To get irregularly shaped objects you need to create a "mask" of the sprite. After you have created your sprite with a BLACK background, GET the image to an array. You can BSAVE it if you wish. Then create a mask of the sprite at the sprites current location. Use the GET box area coordinates(minX, maxX and minY, maxY) of sprite in the following routine:

Code by: Ted Weissgerber

FOR xx = minX TO maxX FOR yy = minY TO maxY IF POINT(xx, yy) = 0 THEN PSET (xx, yy), 15 ELSE PSET (xx, yy), 0 NEXT yy NEXT xx GET (minX, minY)-(maxX, maxY), Mask(0)


The mask routine simply changes all black portions of the sprite image to white and all other colors black. If your sprite uses black in it, you will need to assign the areas to another color attribute and change the RGB values to 0 using OUT or the background will show through the final image. Color 8 could be dark enough.


GET the background at the sprite's starting position before trying to place a sprite or move it when necessary. Next we position the mask and PUT it with the AND option. Then the actual sprite is PUT over the mask as shown below:


GET (x, y)-(x + 60, y + 60), BG ' GET BG at start position before sprite is set PUT (x, y), Mask, AND ' PUT mask at start position PUT (x, y), Sprite ' XOR will work fine on a mask


The two PUTs use the same coordinate so moving objects is fairly simple. All you need is a keypress reading loop. Use INP(&H60) Scancodes for diagonal moves.


But what about the background? Once you create the background you will need to GET the sprite's box area at the starting position. You can PUT the background back to erase the sprite when moving. PX and PY are the previous x and y positions before they were changed by the user in a keypress routine:


'user keypress or programmed coordinate changes IF x <> PX OR y <> PY THEN ' look for a changed coordinate value WAIT 936, 8 ' vertical retrace delay PUT (PX, PY), BG, PSET ' replace previous BG first GET (x, y)-(x + 60, y + 60), BG ' GET BG at new position before box is set PUT (x, y), Mask, AND ' PUT mask at new position PUT (x, y), Sprite ' XOR will work fine on the mask END IF PX = x: PY = y


In QB64 _CLEARCOLOR can also be used before using _PUTIMAGE to mask any sprite background color.


See the GET and PUT Demo to see how it works!


See also:



Navigation:
Go to Keyword Reference - Alphabetical
Go to Keyword Reference - By usage
Go to Main WIKI Page