Compound shapes

Description

There may be situations when it's necessary to have more control over the collision shape being used by AGK. This is where compound shapes come into play. They are used to add extra shapes on top of any existing collision shape that a sprite has.

This example loads an image named penguin.png:


Two sprites are created with one on the left using a convex shape and the one on the right using a convex shape and a small box at its feet, as shown in this screen shot:


By adding an extra shape to the sprite on the right it's possible to stabilise the penguin when it collides with the floor. When you run the example notice how the sprite on the left (using the default convex shape) topples over when hitting the floor, while the sprite on the right (with an extra box added) will remain standing upon impact.

Getting started

The initial set up code defines a virtual resolution of 320 x 480, followed by the creation of two sprites:

SetVirtualResolution ( 320, 480 )

CreateSprite ( LoadImage ( "background7.jpg" ) )
LoadImage ( 1, "penguin.png" )
CreateSprite ( 1, 1 ) SetSpritePosition ( 1, 0, 20 ) SetSpritePhysicsOn ( 1, 2 ) SetSpriteShape ( 1, 3 )
CreateSprite ( 2, 1 ) SetSpritePosition ( 2, 200, 20 ) SetSpritePhysicsOn ( 2, 2 ) SetSpriteShape ( 2, 3 ) AddSpriteShapeBox ( 2, 20, 135, 90, 137, 0 )
SetPhysicsDebugOn ( )

Sprite 1 has a convex shape attached to it and is positioned on the left side of the screen. Sprite 2 is handled slightly differently, while it has a convex shape attached it also has an additional shape attached as a box, which gets placed at the feet of the penguin. This is achieved with the command AddSpriteShapeBox. This command takes several parameters: ID of the sprite, x, y, x2, y2 and an angle. The x and y parameters are used to define the top left position of the box and the x2 and y2 parameters define the bottom right of the box. Finally the angle parameter is used to supply rotation for the box. When you run the example notice how a little box appears under the penguin on the right.

Circles and polygon shapes can also be added to sprites by using AddSpriteShapeCircle and AddSpriteShapePolygon. Any of these additional shapes can be removed by calling ClearSpriteShapes.

Main loop

The main loop of the program only needs to call Sync, as the aim of the example is to demonstrate how an additional collision shape can affect interactions.

Full code listing

Everything is now in place. Here's the final code for our program:

SetVirtualResolution ( 320, 480 )

LoadImage ( 1, "penguin.png" )
CreateSprite ( 1, 1 ) SetSpritePosition ( 1, 0, 20 ) SetSpritePhysicsOn ( 1, 2 ) SetSpriteShape ( 1, 3 )
CreateSprite ( 2, 1 ) SetSpritePosition ( 2, 200, 20 ) SetSpritePhysicsOn ( 2, 2 ) SetSpriteShape ( 2, 3 ) AddSpriteShapeBox ( 2, 20, 135, 90, 137, 0 )
SetPhysicsDebugOn ( )
do Sync ( ) loop

Conclusion

The commands demonstrated in this example offer you complete control and extra flexibility when dealing with collisions. They are useful for many situations and are easy to use and implement.