… | |
… | |
185 | |
185 | |
186 | static void |
186 | static void |
187 | layout_update_font (DC__Layout self) |
187 | layout_update_font (DC__Layout self) |
188 | { |
188 | { |
189 | /* use a random scale factor to account for unknown descenders, 0.8 works |
189 | /* use a random scale factor to account for unknown descenders, 0.8 works |
190 | * reasonably well with bitstream vera |
190 | * reasonably well with dejavu/bistream fonts |
191 | */ |
191 | */ |
192 | PangoFontDescription *font = self->font ? self->font : default_font; |
192 | PangoFontDescription *font = self->font ? self->font : default_font; |
193 | |
193 | |
194 | pango_font_description_set_absolute_size (font, |
194 | pango_font_description_set_absolute_size (font, |
195 | MAX (MIN_FONT_HEIGHT, self->base_height) * (PANGO_SCALE * 8 / 10)); |
195 | MAX (MIN_FONT_HEIGHT, self->base_height) * (PANGO_SCALE * 8 / 10)); |
… | |
… | |
673 | CODE: |
673 | CODE: |
674 | { |
674 | { |
675 | opengl_fontmap = pango_opengl_font_map_new (); |
675 | opengl_fontmap = pango_opengl_font_map_new (); |
676 | pango_opengl_font_map_set_default_substitute ((PangoOpenGLFontMap *)opengl_fontmap, substitute_func, 0, 0); |
676 | pango_opengl_font_map_set_default_substitute ((PangoOpenGLFontMap *)opengl_fontmap, substitute_func, 0, 0); |
677 | opengl_context = pango_opengl_font_map_create_context ((PangoOpenGLFontMap *)opengl_fontmap); |
677 | opengl_context = pango_opengl_font_map_create_context ((PangoOpenGLFontMap *)opengl_fontmap); |
|
|
678 | /*pango_context_set_font_description (opengl_context, default_font);*/ |
678 | #if PANGO_VERSION_CHECK (1, 15, 2) |
679 | #if PANGO_VERSION_CHECK (1, 15, 2) |
679 | pango_context_set_language (opengl_context, pango_language_from_string ("en")); |
680 | pango_context_set_language (opengl_context, pango_language_from_string ("en")); |
680 | /*pango_context_set_base_dir (opengl_context, PANGO_DIRECTION_WEAK_LTR);*/ |
681 | /*pango_context_set_base_dir (opengl_context, PANGO_DIRECTION_WEAK_LTR);*/ |
681 | #endif |
682 | #endif |
682 | } |
683 | } |
… | |
… | |
915 | } |
916 | } |
916 | } |
917 | } |
917 | #endif |
918 | #endif |
918 | } |
919 | } |
919 | |
920 | |
920 | void |
921 | int |
921 | add_font (char *file) |
922 | add_font (char *file) |
922 | CODE: |
923 | CODE: |
923 | FcConfigAppFontAddFile (0, (const FcChar8 *)file); |
924 | RETVAL = FcConfigAppFontAddFile (0, (const FcChar8 *)file); |
|
|
925 | OUTPUT: |
|
|
926 | RETVAL |
924 | |
927 | |
925 | void |
928 | void |
926 | load_image_inline (SV *image_) |
929 | load_image_inline (SV *image_) |
927 | ALIAS: |
930 | ALIAS: |
928 | load_image_file = 1 |
931 | load_image_file = 1 |
… | |
… | |
2289 | else |
2292 | else |
2290 | *data++ = 0; |
2293 | *data++ = 0; |
2291 | } |
2294 | } |
2292 | } |
2295 | } |
2293 | |
2296 | |
|
|
2297 | /* if size is w*h + 5 then no data has been found */ |
|
|
2298 | if (data - (uint8_t *)SvPVX (data_sv) != w * h + 5) |
|
|
2299 | { |
2294 | SvPOK_only (data_sv); |
2300 | SvPOK_only (data_sv); |
2295 | SvCUR_set (data_sv, data - (uint8_t *)SvPVX (data_sv)); |
2301 | SvCUR_set (data_sv, data - (uint8_t *)SvPVX (data_sv)); |
|
|
2302 | } |
|
|
2303 | |
2296 | RETVAL = data_sv; |
2304 | RETVAL = data_sv; |
2297 | } |
2305 | } |
2298 | OUTPUT: |
2306 | OUTPUT: |
2299 | RETVAL |
2307 | RETVAL |
2300 | |
2308 | |
2301 | void |
2309 | void |
2302 | set_rect (DC::Map self, int x0, int y0, uint8_t *data) |
2310 | set_rect (DC::Map self, int x0, int y0, SV *data_sv) |
2303 | PPCODE: |
2311 | PPCODE: |
2304 | { |
2312 | { |
2305 | int x, y, z; |
2313 | int x, y, z; |
2306 | int w, h; |
2314 | int w, h; |
2307 | int x1, y1; |
2315 | int x1, y1; |
|
|
2316 | STRLEN len; |
|
|
2317 | uint8_t *data, *end; |
|
|
2318 | |
|
|
2319 | len = SvLEN (data_sv); |
|
|
2320 | SvGROW (data_sv, len + 8); // reserve at least 7+ bytes more |
|
|
2321 | data = SvPVbyte_nolen (data_sv); |
|
|
2322 | end = data + len + 8; |
|
|
2323 | |
|
|
2324 | if (len < 5) |
|
|
2325 | XSRETURN_EMPTY; |
2308 | |
2326 | |
2309 | if (*data++ != 0) |
2327 | if (*data++ != 0) |
2310 | XSRETURN_EMPTY; /* version mismatch */ |
2328 | XSRETURN_EMPTY; /* version mismatch */ |
2311 | |
2329 | |
2312 | w = *data++ << 8; w |= *data++; |
2330 | w = *data++ << 8; w |= *data++; |
… | |
… | |
2327 | { |
2345 | { |
2328 | maprow *row = map_get_row (self, y); |
2346 | maprow *row = map_get_row (self, y); |
2329 | |
2347 | |
2330 | for (x = x0; x < x1; x++) |
2348 | for (x = x0; x < x1; x++) |
2331 | { |
2349 | { |
|
|
2350 | uint8_t flags; |
|
|
2351 | |
|
|
2352 | if (data + 7 >= end) |
|
|
2353 | XSRETURN_EMPTY; |
|
|
2354 | |
2332 | uint8_t flags = *data++; |
2355 | flags = *data++; |
2333 | |
2356 | |
2334 | if (flags) |
2357 | if (flags) |
2335 | { |
2358 | { |
2336 | mapcell *cell = row_get_cell (row, x); |
2359 | mapcell *cell = row_get_cell (row, x); |
2337 | tileid tile[3] = { 0, 0, 0 }; |
2360 | tileid tile[3] = { 0, 0, 0 }; |
… | |
… | |
2340 | if (flags & 2) { tile[1] = *data++ << 8; tile[1] |= *data++; } |
2363 | if (flags & 2) { tile[1] = *data++ << 8; tile[1] |= *data++; } |
2341 | if (flags & 4) { tile[2] = *data++ << 8; tile[2] |= *data++; } |
2364 | if (flags & 4) { tile[2] = *data++ << 8; tile[2] |= *data++; } |
2342 | |
2365 | |
2343 | if (cell->darkness == 0) |
2366 | if (cell->darkness == 0) |
2344 | { |
2367 | { |
2345 | cell->darkness = 0; |
2368 | /*cell->darkness = 0;*/ |
|
|
2369 | EXTEND (SP, 3); |
2346 | |
2370 | |
2347 | for (z = 0; z <= 2; z++) |
2371 | for (z = 0; z <= 2; z++) |
2348 | { |
2372 | { |
2349 | tileid t = tile [z]; |
2373 | tileid t = tile [z]; |
2350 | |
2374 | |
2351 | if (t >= self->texs || (t && !self->tex [t].name)) |
2375 | if (t >= self->texs || (t && !self->tex [t].name)) |
2352 | { |
2376 | { |
2353 | XPUSHs (sv_2mortal (newSViv (t))); |
2377 | PUSHs (sv_2mortal (newSViv (t))); |
2354 | need_texid (self, t); |
2378 | need_texid (self, t); |
2355 | } |
2379 | } |
2356 | |
2380 | |
2357 | cell->tile [z] = t; |
2381 | cell->tile [z] = t; |
2358 | } |
2382 | } |