Mercurial > molko
annotate src/window.h @ 1:03f6d572fd17
core: implement basic drawing, closes #2438
author | David Demelier <markand@malikania.fr> |
---|---|
date | Mon, 06 Jan 2020 13:06:52 +0100 |
parents | efcc908bca21 |
children | 832c20d6cce9 |
rev | line source |
---|---|
0
efcc908bca21
core: implement basic windowing, closes #2437
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
1 /* |
efcc908bca21
core: implement basic windowing, closes #2437
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
2 * window.h -- basic window management |
efcc908bca21
core: implement basic windowing, closes #2437
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
3 * |
efcc908bca21
core: implement basic windowing, closes #2437
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
4 * Copyright (c) 2020 David Demelier <markand@malikania.fr> |
efcc908bca21
core: implement basic windowing, closes #2437
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
5 * |
efcc908bca21
core: implement basic windowing, closes #2437
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
6 * Permission to use, copy, modify, and/or distribute this software for any |
efcc908bca21
core: implement basic windowing, closes #2437
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
7 * purpose with or without fee is hereby granted, provided that the above |
efcc908bca21
core: implement basic windowing, closes #2437
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
8 * copyright notice and this permission notice appear in all copies. |
efcc908bca21
core: implement basic windowing, closes #2437
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
9 * |
efcc908bca21
core: implement basic windowing, closes #2437
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
10 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES |
efcc908bca21
core: implement basic windowing, closes #2437
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
11 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF |
efcc908bca21
core: implement basic windowing, closes #2437
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
12 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR |
efcc908bca21
core: implement basic windowing, closes #2437
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
13 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES |
efcc908bca21
core: implement basic windowing, closes #2437
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
14 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN |
efcc908bca21
core: implement basic windowing, closes #2437
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
15 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF |
efcc908bca21
core: implement basic windowing, closes #2437
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
16 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. |
efcc908bca21
core: implement basic windowing, closes #2437
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
17 */ |
efcc908bca21
core: implement basic windowing, closes #2437
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
18 |
efcc908bca21
core: implement basic windowing, closes #2437
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
19 #ifndef MOLKO_WINDOW_H |
efcc908bca21
core: implement basic windowing, closes #2437
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
20 #define MOLKO_WINDOW_H |
efcc908bca21
core: implement basic windowing, closes #2437
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
21 |
1
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
22 /** |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
23 * \file window.h |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
24 * \brief Basic window management. |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
25 */ |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
26 |
0
efcc908bca21
core: implement basic windowing, closes #2437
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
27 #include <stdbool.h> |
1
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
28 #include <stdint.h> |
0
efcc908bca21
core: implement basic windowing, closes #2437
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
29 |
1
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
30 /** |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
31 * \brief Window opaque object. |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
32 */ |
0
efcc908bca21
core: implement basic windowing, closes #2437
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
33 struct window; |
efcc908bca21
core: implement basic windowing, closes #2437
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
34 |
1
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
35 /** |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
36 * Initialize window. |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
37 * |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
38 * \pre title != NULL |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
39 * \param title the window title |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
40 * \param width the desired width |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
41 * \param height the desired height |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
42 * \return the window or NULL on error |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
43 */ |
0
efcc908bca21
core: implement basic windowing, closes #2437
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
44 struct window * |
1
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
45 window_init(const char *title, unsigned width, unsigned height); |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
46 |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
47 /** |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
48 * Get the current drawing color. |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
49 * |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
50 * \pre window != NULL |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
51 * \param window the window |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
52 * \return the color in RRGGBBAA format |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
53 */ |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
54 uint32_t |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
55 window_get_color(const struct window *window); |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
56 |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
57 /** |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
58 * Set the rendering drawing color. |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
59 * |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
60 * \pre window != NULL |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
61 * \param window the window |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
62 * \param color in RRGGBBAA format |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
63 */ |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
64 void |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
65 window_set_color(struct window *window, uint32_t color); |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
66 |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
67 /** |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
68 * Draw a line. |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
69 * |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
70 * \pre window != NULL |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
71 * \param window the window |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
72 * \param x1 first X coordinate |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
73 * \param y1 first Y coordinate |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
74 * \param x2 second X coordinate |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
75 * \param y2 second Y coordinate |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
76 */ |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
77 void |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
78 window_draw_line(struct window *window, int x1, int y1, int x2, int y2); |
0
efcc908bca21
core: implement basic windowing, closes #2437
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
79 |
1
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
80 /** |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
81 * Draw a pixel point. |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
82 * |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
83 * \pre window != NULL |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
84 * \param window the window |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
85 * \param x the X coordinate |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
86 * \param y the Y coordinate |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
87 */ |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
88 void |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
89 window_draw_point(struct window *window, int x, int y); |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
90 |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
91 /** |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
92 * Draw a rectangle |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
93 * |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
94 * \pre window != NULL |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
95 * \param window the window |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
96 * \param fill set to true to fill the rectangle |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
97 * \param x the X coordinate |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
98 * \param y the Y coordinate |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
99 * \param w the rectangle width |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
100 * \param h the rectangle height |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
101 */ |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
102 void |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
103 window_draw_rectangle(struct window *window, |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
104 bool fill, |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
105 int x, |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
106 int y, |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
107 unsigned w, |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
108 unsigned h); |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
109 |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
110 /** |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
111 * Clear the window. |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
112 * |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
113 * \pre window != NULL |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
114 * \param window the window |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
115 */ |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
116 void |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
117 window_clear(struct window *window); |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
118 |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
119 /** |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
120 * Present the window, only call this function one time in the main loop. |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
121 * |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
122 * \pre window != NULL |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
123 * \param window the window |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
124 */ |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
125 void |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
126 window_present(struct window *window); |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
127 |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
128 /** |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
129 * Close the window and destroy associated resources, do not use pointer |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
130 * afterwards. |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
131 * |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
132 * \pre window != NULL |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
133 * \param window the window |
03f6d572fd17
core: implement basic drawing, closes #2438
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
134 */ |
0
efcc908bca21
core: implement basic windowing, closes #2437
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
135 void |
efcc908bca21
core: implement basic windowing, closes #2437
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
136 window_close(struct window *window); |
efcc908bca21
core: implement basic windowing, closes #2437
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
137 |
efcc908bca21
core: implement basic windowing, closes #2437
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
138 #endif /* !MOLKO_WINDOW_H */ |