src/ascension/text.h

Wed, 06 Aug 2025 00:37:01 +0200

author
Mike Becker <universe@uap-core.de>
date
Wed, 06 Aug 2025 00:37:01 +0200
changeset 256
60014484121c
parent 219
62508d957a22
permissions
-rw-r--r--

remove the asc_col4i datatype in favor of a unified asc_color type

and also adds some min and max functions

3
1efd6da2ad53 add datatypes.h
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1 /*
1efd6da2ad53 add datatypes.h
Mike Becker <universe@uap-core.de>
parents:
diff changeset
2 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
1efd6da2ad53 add datatypes.h
Mike Becker <universe@uap-core.de>
parents:
diff changeset
3 * Copyright 2023 Mike Becker. All rights reserved.
1efd6da2ad53 add datatypes.h
Mike Becker <universe@uap-core.de>
parents:
diff changeset
4 *
1efd6da2ad53 add datatypes.h
Mike Becker <universe@uap-core.de>
parents:
diff changeset
5 * Redistribution and use in source and binary forms, with or without
1efd6da2ad53 add datatypes.h
Mike Becker <universe@uap-core.de>
parents:
diff changeset
6 * modification, are permitted provided that the following conditions are met:
1efd6da2ad53 add datatypes.h
Mike Becker <universe@uap-core.de>
parents:
diff changeset
7 *
1efd6da2ad53 add datatypes.h
Mike Becker <universe@uap-core.de>
parents:
diff changeset
8 * 1. Redistributions of source code must retain the above copyright
1efd6da2ad53 add datatypes.h
Mike Becker <universe@uap-core.de>
parents:
diff changeset
9 * notice, this list of conditions and the following disclaimer.
1efd6da2ad53 add datatypes.h
Mike Becker <universe@uap-core.de>
parents:
diff changeset
10 *
1efd6da2ad53 add datatypes.h
Mike Becker <universe@uap-core.de>
parents:
diff changeset
11 * 2. Redistributions in binary form must reproduce the above copyright
1efd6da2ad53 add datatypes.h
Mike Becker <universe@uap-core.de>
parents:
diff changeset
12 * notice, this list of conditions and the following disclaimer in the
1efd6da2ad53 add datatypes.h
Mike Becker <universe@uap-core.de>
parents:
diff changeset
13 * documentation and/or other materials provided with the distribution.
1efd6da2ad53 add datatypes.h
Mike Becker <universe@uap-core.de>
parents:
diff changeset
14 *
1efd6da2ad53 add datatypes.h
Mike Becker <universe@uap-core.de>
parents:
diff changeset
15 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
1efd6da2ad53 add datatypes.h
Mike Becker <universe@uap-core.de>
parents:
diff changeset
16 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
1efd6da2ad53 add datatypes.h
Mike Becker <universe@uap-core.de>
parents:
diff changeset
17 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
1efd6da2ad53 add datatypes.h
Mike Becker <universe@uap-core.de>
parents:
diff changeset
18 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
1efd6da2ad53 add datatypes.h
Mike Becker <universe@uap-core.de>
parents:
diff changeset
19 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
1efd6da2ad53 add datatypes.h
Mike Becker <universe@uap-core.de>
parents:
diff changeset
20 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
1efd6da2ad53 add datatypes.h
Mike Becker <universe@uap-core.de>
parents:
diff changeset
21 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
1efd6da2ad53 add datatypes.h
Mike Becker <universe@uap-core.de>
parents:
diff changeset
22 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
1efd6da2ad53 add datatypes.h
Mike Becker <universe@uap-core.de>
parents:
diff changeset
23 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
1efd6da2ad53 add datatypes.h
Mike Becker <universe@uap-core.de>
parents:
diff changeset
24 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
1efd6da2ad53 add datatypes.h
Mike Becker <universe@uap-core.de>
parents:
diff changeset
25 * POSSIBILITY OF SUCH DAMAGE.
1efd6da2ad53 add datatypes.h
Mike Becker <universe@uap-core.de>
parents:
diff changeset
26 */
1efd6da2ad53 add datatypes.h
Mike Becker <universe@uap-core.de>
parents:
diff changeset
27
48
6e5b5ba2752c create new UI subdir
Mike Becker <universe@uap-core.de>
parents: 45
diff changeset
28 #ifndef ASCENSION_UI_TEXT_H
6e5b5ba2752c create new UI subdir
Mike Becker <universe@uap-core.de>
parents: 45
diff changeset
29 #define ASCENSION_UI_TEXT_H
11
d83af80eb09b add font management
Mike Becker <universe@uap-core.de>
parents: 6
diff changeset
30
16
c5dde81b6fb2 add text rendering and demo FPS counter
Mike Becker <universe@uap-core.de>
parents: 14
diff changeset
31 #include "font.h"
198
916d2d125ecf remove ui subdir in includes
Mike Becker <universe@uap-core.de>
parents: 196
diff changeset
32 #include "mesh.h"
916d2d125ecf remove ui subdir in includes
Mike Becker <universe@uap-core.de>
parents: 196
diff changeset
33 #include "texture.h"
916d2d125ecf remove ui subdir in includes
Mike Becker <universe@uap-core.de>
parents: 196
diff changeset
34 #include "scene_node.h"
58
26ebb2f1e6e6 improve ui/text.h interface a lot
Mike Becker <universe@uap-core.de>
parents: 55
diff changeset
35
26ebb2f1e6e6 improve ui/text.h interface a lot
Mike Becker <universe@uap-core.de>
parents: 55
diff changeset
36 #include <cx/string.h>
3
1efd6da2ad53 add datatypes.h
Mike Becker <universe@uap-core.de>
parents:
diff changeset
37
145
a3231310d66d consistent naming of structs and their typedefs
Mike Becker <universe@uap-core.de>
parents: 143
diff changeset
38 typedef struct asc_text_s {
196
ac2ade047d5b remove dependency to AscSprite from AscText
Mike Becker <universe@uap-core.de>
parents: 194
diff changeset
39 AscSceneNode base;
ac2ade047d5b remove dependency to AscSprite from AscText
Mike Becker <universe@uap-core.de>
parents: 194
diff changeset
40 AscMesh mesh;
ac2ade047d5b remove dependency to AscSprite from AscText
Mike Becker <universe@uap-core.de>
parents: 194
diff changeset
41 AscTexture *texture;
58
26ebb2f1e6e6 improve ui/text.h interface a lot
Mike Becker <universe@uap-core.de>
parents: 55
diff changeset
42 cxmutstr text;
65
9c44c55d327a consistently refer to windows by ID - fixes #381
Mike Becker <universe@uap-core.de>
parents: 59
diff changeset
43 AscFont font;
256
60014484121c remove the asc_col4i datatype in favor of a unified asc_color type
Mike Becker <universe@uap-core.de>
parents: 219
diff changeset
44 asc_color color;
58
26ebb2f1e6e6 improve ui/text.h interface a lot
Mike Becker <universe@uap-core.de>
parents: 55
diff changeset
45 unsigned short max_width;
116
bfb2a7d62047 replace scaling with correct mesh sizes
Mike Becker <universe@uap-core.de>
parents: 114
diff changeset
46 /**
bfb2a7d62047 replace scaling with correct mesh sizes
Mike Becker <universe@uap-core.de>
parents: 114
diff changeset
47 * The automatically calculated offset in case the text is centered.
bfb2a7d62047 replace scaling with correct mesh sizes
Mike Becker <universe@uap-core.de>
parents: 114
diff changeset
48 */
58
26ebb2f1e6e6 improve ui/text.h interface a lot
Mike Becker <universe@uap-core.de>
parents: 55
diff changeset
49 unsigned short offx;
116
bfb2a7d62047 replace scaling with correct mesh sizes
Mike Becker <universe@uap-core.de>
parents: 114
diff changeset
50 /**
bfb2a7d62047 replace scaling with correct mesh sizes
Mike Becker <universe@uap-core.de>
parents: 114
diff changeset
51 * The automatically calculated text dimension.
bfb2a7d62047 replace scaling with correct mesh sizes
Mike Becker <universe@uap-core.de>
parents: 114
diff changeset
52 */
bfb2a7d62047 replace scaling with correct mesh sizes
Mike Becker <universe@uap-core.de>
parents: 114
diff changeset
53 asc_vec2u dimension;
25
601b3f4e17a2 rename AscTextNode to just AscText
Mike Becker <universe@uap-core.de>
parents: 23
diff changeset
54 } AscText;
16
c5dde81b6fb2 add text rendering and demo FPS counter
Mike Becker <universe@uap-core.de>
parents: 14
diff changeset
55
58
26ebb2f1e6e6 improve ui/text.h interface a lot
Mike Becker <universe@uap-core.de>
parents: 55
diff changeset
56 enum asc_text_alignment {
26ebb2f1e6e6 improve ui/text.h interface a lot
Mike Becker <universe@uap-core.de>
parents: 55
diff changeset
57 ASC_TEXT_ALIGN_LEFT = 0x00,
26ebb2f1e6e6 improve ui/text.h interface a lot
Mike Becker <universe@uap-core.de>
parents: 55
diff changeset
58 ASC_TEXT_ALIGN_CENTERED = 0x01,
26ebb2f1e6e6 improve ui/text.h interface a lot
Mike Becker <universe@uap-core.de>
parents: 55
diff changeset
59 ASC_TEXT_ALIGN_RIGHT = 0x02
26ebb2f1e6e6 improve ui/text.h interface a lot
Mike Becker <universe@uap-core.de>
parents: 55
diff changeset
60 };
26ebb2f1e6e6 improve ui/text.h interface a lot
Mike Becker <universe@uap-core.de>
parents: 55
diff changeset
61 #define ASC_TEXT_ALIGNMENT_MASK 0x03
26ebb2f1e6e6 improve ui/text.h interface a lot
Mike Becker <universe@uap-core.de>
parents: 55
diff changeset
62 #define ASC_TEXT_CENTERED_FLAG 0x04
4
b7acda6a4476 add simple color data types
Mike Becker <universe@uap-core.de>
parents: 3
diff changeset
63
59
764fbb013252 use fancy named parameters for asc_text()
Mike Becker <universe@uap-core.de>
parents: 58
diff changeset
64 struct asc_text_create_args {
214
9d460888a83e remove global active font and color (also fixes #693)
Mike Becker <universe@uap-core.de>
parents: 204
diff changeset
65 AscFont font;
59
764fbb013252 use fancy named parameters for asc_text()
Mike Becker <universe@uap-core.de>
parents: 58
diff changeset
66 int x;
764fbb013252 use fancy named parameters for asc_text()
Mike Becker <universe@uap-core.de>
parents: 58
diff changeset
67 int y;
114
5b91bbab1ac0 give them nodes names
Mike Becker <universe@uap-core.de>
parents: 95
diff changeset
68 const char *name;
149
560772519ff9 resolve east-west conflict
Mike Becker <universe@uap-core.de>
parents: 145
diff changeset
69 const char *text;
256
60014484121c remove the asc_col4i datatype in favor of a unified asc_color type
Mike Becker <universe@uap-core.de>
parents: 219
diff changeset
70 asc_color color;
59
764fbb013252 use fancy named parameters for asc_text()
Mike Becker <universe@uap-core.de>
parents: 58
diff changeset
71 enum asc_text_alignment alignment;
764fbb013252 use fancy named parameters for asc_text()
Mike Becker <universe@uap-core.de>
parents: 58
diff changeset
72 unsigned short max_width;
204
be5cf64b5c29 rework how transformations work to allow rotations around a point of origin
Mike Becker <universe@uap-core.de>
parents: 198
diff changeset
73 bool centered;
59
764fbb013252 use fancy named parameters for asc_text()
Mike Becker <universe@uap-core.de>
parents: 58
diff changeset
74 };
764fbb013252 use fancy named parameters for asc_text()
Mike Becker <universe@uap-core.de>
parents: 58
diff changeset
75
16
c5dde81b6fb2 add text rendering and demo FPS counter
Mike Becker <universe@uap-core.de>
parents: 14
diff changeset
76 /**
19
d0e88022e209 improve text node API
Mike Becker <universe@uap-core.de>
parents: 17
diff changeset
77 * Creates a text node.
11
d83af80eb09b add font management
Mike Becker <universe@uap-core.de>
parents: 6
diff changeset
78 *
36
e26b4ac1661c invert the logic of converting between specialized nodes and the generic interface
Mike Becker <universe@uap-core.de>
parents: 33
diff changeset
79 * The current context ink and font will be used.
4
b7acda6a4476 add simple color data types
Mike Becker <universe@uap-core.de>
parents: 3
diff changeset
80 *
59
764fbb013252 use fancy named parameters for asc_text()
Mike Becker <universe@uap-core.de>
parents: 58
diff changeset
81 * @param args initial arguments for creating the node
36
e26b4ac1661c invert the logic of converting between specialized nodes and the generic interface
Mike Becker <universe@uap-core.de>
parents: 33
diff changeset
82 * @return the scene node
e26b4ac1661c invert the logic of converting between specialized nodes and the generic interface
Mike Becker <universe@uap-core.de>
parents: 33
diff changeset
83 *
16
c5dde81b6fb2 add text rendering and demo FPS counter
Mike Becker <universe@uap-core.de>
parents: 14
diff changeset
84 * @see asc_ink()
c5dde81b6fb2 add text rendering and demo FPS counter
Mike Becker <universe@uap-core.de>
parents: 14
diff changeset
85 * @see asc_font()
4
b7acda6a4476 add simple color data types
Mike Becker <universe@uap-core.de>
parents: 3
diff changeset
86 */
59
764fbb013252 use fancy named parameters for asc_text()
Mike Becker <universe@uap-core.de>
parents: 58
diff changeset
87 AscSceneNode *asc_text_create(struct asc_text_create_args args);
764fbb013252 use fancy named parameters for asc_text()
Mike Becker <universe@uap-core.de>
parents: 58
diff changeset
88
764fbb013252 use fancy named parameters for asc_text()
Mike Becker <universe@uap-core.de>
parents: 58
diff changeset
89 /**
764fbb013252 use fancy named parameters for asc_text()
Mike Becker <universe@uap-core.de>
parents: 58
diff changeset
90 * Creates a text node.
764fbb013252 use fancy named parameters for asc_text()
Mike Becker <universe@uap-core.de>
parents: 58
diff changeset
91 *
764fbb013252 use fancy named parameters for asc_text()
Mike Becker <universe@uap-core.de>
parents: 58
diff changeset
92 * The current context ink and font will be used.
764fbb013252 use fancy named parameters for asc_text()
Mike Becker <universe@uap-core.de>
parents: 58
diff changeset
93 *
764fbb013252 use fancy named parameters for asc_text()
Mike Becker <universe@uap-core.de>
parents: 58
diff changeset
94 * This is a convenience macro that lets you use the arguments
764fbb013252 use fancy named parameters for asc_text()
Mike Becker <universe@uap-core.de>
parents: 58
diff changeset
95 * as named parameters. Usage example:
764fbb013252 use fancy named parameters for asc_text()
Mike Becker <universe@uap-core.de>
parents: 58
diff changeset
96 * @code
764fbb013252 use fancy named parameters for asc_text()
Mike Becker <universe@uap-core.de>
parents: 58
diff changeset
97 * AscSceneNode *mytext = asc_text( .x = 10, .y = 15 );
764fbb013252 use fancy named parameters for asc_text()
Mike Becker <universe@uap-core.de>
parents: 58
diff changeset
98 * @endcode
764fbb013252 use fancy named parameters for asc_text()
Mike Becker <universe@uap-core.de>
parents: 58
diff changeset
99 *
764fbb013252 use fancy named parameters for asc_text()
Mike Becker <universe@uap-core.de>
parents: 58
diff changeset
100 * @param ... initial arguments for creating the node
764fbb013252 use fancy named parameters for asc_text()
Mike Becker <universe@uap-core.de>
parents: 58
diff changeset
101 * @return the scene node
764fbb013252 use fancy named parameters for asc_text()
Mike Becker <universe@uap-core.de>
parents: 58
diff changeset
102 *
764fbb013252 use fancy named parameters for asc_text()
Mike Becker <universe@uap-core.de>
parents: 58
diff changeset
103 * @see asc_ink()
764fbb013252 use fancy named parameters for asc_text()
Mike Becker <universe@uap-core.de>
parents: 58
diff changeset
104 * @see asc_font()
764fbb013252 use fancy named parameters for asc_text()
Mike Becker <universe@uap-core.de>
parents: 58
diff changeset
105 */
764fbb013252 use fancy named parameters for asc_text()
Mike Becker <universe@uap-core.de>
parents: 58
diff changeset
106 #define asc_text(...) \
764fbb013252 use fancy named parameters for asc_text()
Mike Becker <universe@uap-core.de>
parents: 58
diff changeset
107 asc_text_create((struct asc_text_create_args) { __VA_ARGS__ })
36
e26b4ac1661c invert the logic of converting between specialized nodes and the generic interface
Mike Becker <universe@uap-core.de>
parents: 33
diff changeset
108
e26b4ac1661c invert the logic of converting between specialized nodes and the generic interface
Mike Becker <universe@uap-core.de>
parents: 33
diff changeset
109 /**
58
26ebb2f1e6e6 improve ui/text.h interface a lot
Mike Becker <universe@uap-core.de>
parents: 55
diff changeset
110 * Sets the text alignment.
26ebb2f1e6e6 improve ui/text.h interface a lot
Mike Becker <universe@uap-core.de>
parents: 55
diff changeset
111 *
26ebb2f1e6e6 improve ui/text.h interface a lot
Mike Becker <universe@uap-core.de>
parents: 55
diff changeset
112 * @param node the text node
26ebb2f1e6e6 improve ui/text.h interface a lot
Mike Becker <universe@uap-core.de>
parents: 55
diff changeset
113 */
194
7985c3b64460 improve signatures of other text functions and make them linkable symbols
Mike Becker <universe@uap-core.de>
parents: 193
diff changeset
114 void asc_text_alignment(
7985c3b64460 improve signatures of other text functions and make them linkable symbols
Mike Becker <universe@uap-core.de>
parents: 193
diff changeset
115 AscText *node,
58
26ebb2f1e6e6 improve ui/text.h interface a lot
Mike Becker <universe@uap-core.de>
parents: 55
diff changeset
116 enum asc_text_alignment alignment
194
7985c3b64460 improve signatures of other text functions and make them linkable symbols
Mike Becker <universe@uap-core.de>
parents: 193
diff changeset
117 );
58
26ebb2f1e6e6 improve ui/text.h interface a lot
Mike Becker <universe@uap-core.de>
parents: 55
diff changeset
118
26ebb2f1e6e6 improve ui/text.h interface a lot
Mike Becker <universe@uap-core.de>
parents: 55
diff changeset
119 /**
26ebb2f1e6e6 improve ui/text.h interface a lot
Mike Becker <universe@uap-core.de>
parents: 55
diff changeset
120 * Decides whether the text shall be centered.
36
e26b4ac1661c invert the logic of converting between specialized nodes and the generic interface
Mike Becker <universe@uap-core.de>
parents: 33
diff changeset
121 *
58
26ebb2f1e6e6 improve ui/text.h interface a lot
Mike Becker <universe@uap-core.de>
parents: 55
diff changeset
122 * @param node the text node
26ebb2f1e6e6 improve ui/text.h interface a lot
Mike Becker <universe@uap-core.de>
parents: 55
diff changeset
123 * @param centered true when the text shall be centered
26ebb2f1e6e6 improve ui/text.h interface a lot
Mike Becker <universe@uap-core.de>
parents: 55
diff changeset
124 */
194
7985c3b64460 improve signatures of other text functions and make them linkable symbols
Mike Becker <universe@uap-core.de>
parents: 193
diff changeset
125 void asc_text_centered(AscText *node, bool centered);
58
26ebb2f1e6e6 improve ui/text.h interface a lot
Mike Becker <universe@uap-core.de>
parents: 55
diff changeset
126
26ebb2f1e6e6 improve ui/text.h interface a lot
Mike Becker <universe@uap-core.de>
parents: 55
diff changeset
127 /**
26ebb2f1e6e6 improve ui/text.h interface a lot
Mike Becker <universe@uap-core.de>
parents: 55
diff changeset
128 * Sets a new maximum width for the text.
26ebb2f1e6e6 improve ui/text.h interface a lot
Mike Becker <universe@uap-core.de>
parents: 55
diff changeset
129 *
26ebb2f1e6e6 improve ui/text.h interface a lot
Mike Becker <universe@uap-core.de>
parents: 55
diff changeset
130 * @param node the text node
26ebb2f1e6e6 improve ui/text.h interface a lot
Mike Becker <universe@uap-core.de>
parents: 55
diff changeset
131 * @param max_width the new maximum width
36
e26b4ac1661c invert the logic of converting between specialized nodes and the generic interface
Mike Becker <universe@uap-core.de>
parents: 33
diff changeset
132 */
194
7985c3b64460 improve signatures of other text functions and make them linkable symbols
Mike Becker <universe@uap-core.de>
parents: 193
diff changeset
133 void asc_text_max_width(AscText *node, unsigned max_width);
58
26ebb2f1e6e6 improve ui/text.h interface a lot
Mike Becker <universe@uap-core.de>
parents: 55
diff changeset
134
26ebb2f1e6e6 improve ui/text.h interface a lot
Mike Becker <universe@uap-core.de>
parents: 55
diff changeset
135 /**
193
ddf690c0b36b improves signature of asc_text_printf() and adds documentation
Mike Becker <universe@uap-core.de>
parents: 149
diff changeset
136 * Updates the content of a text node with formatted text.
ddf690c0b36b improves signature of asc_text_printf() and adds documentation
Mike Becker <universe@uap-core.de>
parents: 149
diff changeset
137 *
194
7985c3b64460 improve signatures of other text functions and make them linkable symbols
Mike Becker <universe@uap-core.de>
parents: 193
diff changeset
138 * @param node the node
193
ddf690c0b36b improves signature of asc_text_printf() and adds documentation
Mike Becker <universe@uap-core.de>
parents: 149
diff changeset
139 * @param format the format string
ddf690c0b36b improves signature of asc_text_printf() and adds documentation
Mike Becker <universe@uap-core.de>
parents: 149
diff changeset
140 * @param ... the format arguments
58
26ebb2f1e6e6 improve ui/text.h interface a lot
Mike Becker <universe@uap-core.de>
parents: 55
diff changeset
141 */
26ebb2f1e6e6 improve ui/text.h interface a lot
Mike Becker <universe@uap-core.de>
parents: 55
diff changeset
142 void asc_text_printf(
194
7985c3b64460 improve signatures of other text functions and make them linkable symbols
Mike Becker <universe@uap-core.de>
parents: 193
diff changeset
143 AscText *node,
149
560772519ff9 resolve east-west conflict
Mike Becker <universe@uap-core.de>
parents: 145
diff changeset
144 const char *format,
58
26ebb2f1e6e6 improve ui/text.h interface a lot
Mike Becker <universe@uap-core.de>
parents: 55
diff changeset
145 ...
26ebb2f1e6e6 improve ui/text.h interface a lot
Mike Becker <universe@uap-core.de>
parents: 55
diff changeset
146 );
11
d83af80eb09b add font management
Mike Becker <universe@uap-core.de>
parents: 6
diff changeset
147
48
6e5b5ba2752c create new UI subdir
Mike Becker <universe@uap-core.de>
parents: 45
diff changeset
148 #endif //ASCENSION_UI_TEXT_H

mercurial