Project

General

Profile

Statistics
| Revision:

root / proj / src / libs / graph / include / sprite.h @ 393

History | View | Annotate | Download (2.31 KB)

1 331 up20180642
#ifndef SPRITE_H_INCLUDED
2
#define SPRITE_H_INCLUDED
3
4
/**
5
 * @defgroup sprite_t sprite_t
6
 * @ingroup graph
7
 * @brief Sprite module.
8
 *
9
 * A sprite allows to draw a basic_sprite_t, while also providing some transformations for that basic_sprite_t.
10
 *
11
 * @{
12
 */
13
14 332 up20180642
#include "basic_sprite.h"
15
16 345 up20180642
/**
17
 * @brief Basic sprite.
18
 */
19 331 up20180642
typedef struct sprite sprite_t;
20 333 up20180642
/**
21
 * @brief Construct sprite.
22
 * @param   bsp Basic sprite from which to build the sprite
23
 * @return      Pointer to constructed sprite, or NULL if failed
24
 */
25 331 up20180642
sprite_t* (sprite_ctor)(const basic_sprite_t *bsp);
26 333 up20180642
/**
27
 * @brief Destruct sprite.
28
 *
29
 *
30
 * @attention Destructor does not destruct the basic sprite passed as
31
 * constructor argument, since it is assumed the same basic sprite may be used to
32
 * draw several sprites. It is thus YOUR responsibility to delete basic sprites.
33 331 up20180642
 * @param   p   Pointer to sprite_t to be destructed
34
 */
35
void      (sprite_dtor)(sprite_t *p);
36 333 up20180642
/**
37
 * @brief Set sprite position.
38
 * @param   p   Pointer to sprite
39
 * @param   x   X-position in map
40
 * @param   y   Y-position in map
41
 */
42 331 up20180642
void (sprite_set_pos)   (sprite_t *p, int16_t x, int16_t y);
43 333 up20180642
/**
44
 * @brief Set sprite angle.
45
 *
46
 * If not provided, will be drawn with angle 0, corresponding to the same
47
 * orientation as the original image.
48
 * @param   p       Pointer to sprite
49
 * @param   angle   Angle in radians, counterclockwise positive and 0 on positive x-axis
50
 */
51 331 up20180642
void (sprite_set_angle) (sprite_t *p, double angle);
52 333 up20180642
/**
53
 * @brief Set sprite scale.
54
 *
55
 * Default scale is 1, corresponding to original image scale.
56
 * @param   p       Pointer to sprite
57
 * @param   scale   Scale, greater than 0
58
 */
59 331 up20180642
void (sprite_set_scale) (sprite_t *p, double scale);
60 333 up20180642
/**
61
 * @brief Get sprite angle.
62
 * @param   p   Pointer to sprite
63
 * @return      Sprite angle
64
 */
65 331 up20180642
double   (sprite_get_angle)(const sprite_t *p);
66 333 up20180642
/**
67
 * @brief   Get sprite width (same as the underlying basic sprite).
68
 * @param   p   Pointer to sprite
69
 * @return      Sprite width
70
 */
71 331 up20180642
uint16_t (sprite_get_w)(const sprite_t *p);
72 333 up20180642
/**
73
 * @brief   Get sprite height (same as the underlying basic sprite).
74
 * @param   p   Pointer to sprite
75
 * @return      Sprite height
76
 */
77 331 up20180642
uint16_t (sprite_get_h)(const sprite_t *p);
78 333 up20180642
/**
79
 * @brief Draw sprite in buffer.
80
 * @param   p   Pointer to sprite
81
 */
82 331 up20180642
void (sprite_draw)(const sprite_t *p);
83
84
/**
85
 * @}
86
 */
87
88
#endif //SPRITE_H_INCLUDED