32 #if (defined(LLVG_MAJOR_VERSION) && (LLVG_MAJOR_VERSION != 1)) || (defined(LLVG_MINOR_VERSION) && \
33 (LLVG_MINOR_VERSION < 8))
34 #error "This C Module is only compatible with VG Pack [1.8.0,2.0.0["
41 #include <LLVG_MATRIX_impl.h>
45 #include "vg_drawing.h"
48 #if defined VG_FEATURE_PATH
52 #if defined VG_FEATURE_FONT
53 #include <freetype/internal/ftobjs.h>
57 #if defined VG_FEATURE_FONT_COMPLEX_LAYOUT && (VG_FEATURE_FONT_COMPLEX_LAYOUT == 1)
66 #define MIN_HIGH_SURROGATE ((unsigned short)0xD800)
67 #define MAX_HIGH_SURROGATE ((unsigned short)0xDBFF)
68 #define MIN_LOW_SURROGATE ((unsigned short)0xDC00)
69 #define MAX_LOW_SURROGATE ((unsigned short)0xDFFF)
70 #define MIN_SUPPLEMENTARY_CODE_POINT 0x010000
72 #define GET_NEXT_CHARACTER(t, l, o) ((o) >= (l) ? (unsigned short)0 : (t)[o])
74 #ifdef VG_FEATURE_FONT_COMPLEX_LAYOUT
75 #define IS_SIMPLE_LAYOUT (!(face->face_flags & FT_FACE_FLAG_COMPLEX_LAYOUT))
77 #define IS_SIMPLE_LAYOUT true
87 int32_t LLVG_TRACE_group;
93 static jfloat g_identity_matrix[LLVG_MATRIX_SIZE];
95 #if defined VG_FEATURE_FONT
99 static const unsigned short *current_text;
100 static unsigned int current_length;
101 static int current_offset;
102 static FT_UInt previous_glyph_index;
105 #if defined VG_FEATURE_FONT_COMPLEX_LAYOUT && (VG_FEATURE_FONT_COMPLEX_LAYOUT == 1)
107 static hb_glyph_info_t *glyph_info;
108 static hb_glyph_position_t *glyph_pos;
109 static unsigned int glyph_count;
110 static int current_glyph;
111 static hb_buffer_t *buf;
121 void LLVG_IMPL_initialize(jint trace_group) {
123 LLVG_TRACE_group = trace_group;
126 LLVG_MATRIX_IMPL_identity(g_identity_matrix);
129 VG_DRAWING_initialize();
132 #ifdef VG_FEATURE_PATH
133 VG_PATH_initialize();
137 #if defined VG_FEATURE_FONT && \
138 (defined VG_FEATURE_FONT_FREETYPE_VECTOR || defined VG_FEATURE_FONT_FREETYPE_BITMAP) && \
139 (VG_FEATURE_FONT == VG_FEATURE_FONT_FREETYPE_VECTOR || VG_FEATURE_FONT == VG_FEATURE_FONT_FREETYPE_BITMAP)
141 VG_FREETYPE_initialize();
160 unsigned short highPart = GET_NEXT_CHARACTER(textCharRam, length, *offset);
163 if ((highPart >= MIN_HIGH_SURROGATE) && (highPart <= MAX_HIGH_SURROGATE)) {
164 if (*offset < (length - 1)) {
165 unsigned short lowPart = GET_NEXT_CHARACTER(textCharRam, length, *(offset) + 1);
167 if ((lowPart >= MIN_LOW_SURROGATE) && (lowPart <= MAX_LOW_SURROGATE)) {
171 ret += ((int)highPart - (
int)MIN_HIGH_SURROGATE);
173 ret += ((int)lowPart - (
int)MIN_LOW_SURROGATE);
174 ret += (int)MIN_SUPPLEMENTARY_CODE_POINT;
183 ret = 0x0000FFFF & (int)highPart;
189 #if defined VG_FEATURE_FONT
191 void VG_HELPER_layout_configure(
int faceHandle,
const unsigned short *text,
int length) {
192 face = (FT_Face)faceHandle;
197 if (IS_SIMPLE_LAYOUT) {
200 current_length = length;
202 previous_glyph_index = 0;
204 #if defined VG_FEATURE_FONT_COMPLEX_LAYOUT && (VG_FEATURE_FONT_COMPLEX_LAYOUT == 1)
205 static hb_font_t *hb_font;
206 static jint current_faceHandle = 0;
208 if (faceHandle != current_faceHandle) {
209 if (0 != current_faceHandle) {
210 hb_font_destroy(hb_font);
213 FT_Set_Pixel_Sizes(face, 0, face->units_per_EM);
214 hb_font = hb_ft_font_create(face, NULL);
215 current_faceHandle = faceHandle;
218 buf = hb_buffer_create();
219 hb_buffer_add_utf16(buf, (
const uint16_t *)text, length, 0, -1);
221 hb_buffer_guess_segment_properties(buf);
223 hb_shape(hb_font, buf, NULL, 0);
225 glyph_info = hb_buffer_get_glyph_infos(buf, &glyph_count);
226 glyph_pos = hb_buffer_get_glyph_positions(buf, &glyph_count);
235 #if defined VG_FEATURE_FONT
237 bool VG_HELPER_layout_load_glyph(uint32_t *glyph_idx,
int *x_advance,
int *y_advance,
int *x_offset,
int *y_offset) {
247 if (IS_SIMPLE_LAYOUT) {
249 FT_ULong next_char =
VG_HELPER_get_utf(current_text, current_length, ¤t_offset);
250 if (0 != next_char) {
251 FT_UInt glyph_index = FT_Get_Char_Index(face, next_char);
253 int error = FT_Load_Glyph(face, glyph_index, FT_LOAD_NO_SCALE);
254 if (FT_ERR(Ok) != error) {
255 MEJ_LOG_ERROR_MICROVG(
"Error while loading glyphid %d: 0x%x, refer to fterrdef.h\n", glyph_index,
259 *x_advance = face->glyph->advance.x;
262 if (FT_HAS_KERNING(face) && previous_glyph_index && glyph_index) {
264 FT_Get_Kerning(face, previous_glyph_index, glyph_index, FT_KERNING_UNSCALED, &delta);
267 *x_advance += delta.x;
270 previous_glyph_index = glyph_index;
272 *glyph_idx = glyph_index;
277 #if defined VG_FEATURE_FONT_COMPLEX_LAYOUT && (VG_FEATURE_FONT_COMPLEX_LAYOUT == 1)
279 if (((
unsigned int)0) != glyph_count) {
280 *glyph_idx = glyph_info[current_glyph].codepoint;
281 *x_advance = glyph_pos[current_glyph].x_advance / 64;
282 *y_advance = glyph_pos[current_glyph].y_advance / 64;
283 *x_offset = glyph_pos[current_glyph].x_offset / 64;
284 *y_offset = glyph_pos[current_glyph].y_offset / 64;
290 int error = FT_Load_Glyph(face, *glyph_idx, FT_LOAD_NO_SCALE);
291 if (FT_ERR(Ok) != error) {
292 MEJ_LOG_ERROR_MICROVG(
"Error while loading glyphid %d: 0x%x, refer to fterrdef.h\n", *glyph_idx, error);
297 hb_buffer_destroy(buf);
309 const jfloat * VG_HELPER_check_matrix(
const jfloat *matrix) {
310 return (NULL == matrix) ? g_identity_matrix : matrix;
314 uint32_t VG_HELPER_apply_alpha(uint32_t color, uint32_t alpha) {
315 uint32_t color_alpha = (((color >> 24) & (uint32_t)0xff) * alpha) / (uint32_t)255;
316 return (color & (uint32_t)0xffffff) | (color_alpha << 24);
320 void VG_HELPER_prepare_matrix(jfloat *dest, jfloat x, jfloat y,
const jfloat *matrix) {
321 const jfloat *local_matrix = VG_HELPER_check_matrix(matrix);
323 if ((0 != x) || (0 != y)) {
325 LLVG_MATRIX_IMPL_setTranslate(dest, x, y);
326 LLVG_MATRIX_IMPL_concatenate(dest, local_matrix);
329 LLVG_MATRIX_IMPL_copy(dest, local_matrix);
MicroEJ MicroVG library low level API: enable some features according to the hardware capacities.
MicroEJ MicroVG library low level API: implementation over FreeType.
BSP_DECLARE_WEAK_FCNT void LLUI_DISPLAY_waitAsynchronousDrawingEnd(void)
Waits until the end of current asynchronous drawing.
int VG_HELPER_get_utf(const unsigned short *textCharRam, int length, int *offset)
Gets the UTF character from a text buffer at the given offset and updates the offset to point to the ...
MicroEJ MicroVG library low level API: helper to implement library natives methods.
MicroEJ MicroVG library low level API: implementation of Path.