… | |
… | |
85 | static PangoFontMap *ft2_fontmap, *cairo_fontmap; |
85 | static PangoFontMap *ft2_fontmap, *cairo_fontmap; |
86 | |
86 | |
87 | static void |
87 | static void |
88 | substitute_func (FcPattern *pattern, gpointer data) |
88 | substitute_func (FcPattern *pattern, gpointer data) |
89 | { |
89 | { |
90 | FcPatternAddBool (pattern, FC_HINTING , 1); |
90 | FcPatternAddBool (pattern, FC_HINTING, 1); |
|
|
91 | FcPatternAddBool (pattern, FC_HINTSTYLE, FC_HINT_FULL); |
91 | #ifdef _WIN32 |
92 | #ifdef _WIN32 |
92 | FcPatternAddBool (pattern, FC_AUTOHINT, 1); |
93 | FcPatternAddBool (pattern, FC_AUTOHINT, 1); |
93 | #else |
94 | #else |
94 | FcPatternAddBool (pattern, FC_AUTOHINT, 0); |
95 | FcPatternAddBool (pattern, FC_AUTOHINT, 0); |
95 | #endif |
96 | #endif |
… | |
… | |
418 | } |
419 | } |
419 | |
420 | |
420 | void |
421 | void |
421 | pango_init () |
422 | pango_init () |
422 | CODE: |
423 | CODE: |
423 | { |
|
|
424 | // delayed, so it can pick up new fonts added by AddFontResourceEx |
424 | // delayed, so it can pick up new fonts added by AddFontResourceEx |
|
|
425 | { |
|
|
426 | { |
425 | ft2_fontmap = pango_ft2_font_map_new (); |
427 | ft2_fontmap = pango_ft2_font_map_new (); |
426 | pango_ft2_font_map_set_default_substitute ((PangoFT2FontMap *)ft2_fontmap, substitute_func, 0, 0); |
428 | pango_ft2_font_map_set_default_substitute ((PangoFT2FontMap *)ft2_fontmap, substitute_func, 0, 0); |
427 | ft2_context = pango_ft2_font_map_create_context ((PangoFT2FontMap *)ft2_fontmap); |
429 | ft2_context = pango_ft2_font_map_create_context ((PangoFT2FontMap *)ft2_fontmap); |
428 | |
430 | } |
|
|
431 | { |
|
|
432 | cairo_font_options_t *fopt = cairo_font_options_create (); |
429 | cairo_fontmap = pango_cairo_font_map_get_default (); |
433 | cairo_fontmap = pango_cairo_font_map_get_default (); |
430 | cairo_context = pango_cairo_font_map_create_context ((PangoCairoFontMap *)cairo_fontmap); |
434 | cairo_context = pango_cairo_font_map_create_context ((PangoCairoFontMap *)cairo_fontmap); |
|
|
435 | #ifdef _WIN32 |
|
|
436 | // cairo looks like shit eaten twice on windows |
|
|
437 | cairo_font_options_set_antialias (fopt, CAIRO_ANTIALIAS_NONE); |
|
|
438 | #else |
|
|
439 | cairo_font_options_set_antialias (fopt, CAIRO_ANTIALIAS_GRAY); |
|
|
440 | #endif |
|
|
441 | cairo_font_options_set_hint_style (fopt, CAIRO_HINT_STYLE_FULL); |
|
|
442 | cairo_font_options_set_hint_metrics (fopt, CAIRO_HINT_METRICS_ON); |
|
|
443 | pango_cairo_context_set_font_options (cairo_context, fopt); |
|
|
444 | cairo_font_options_destroy (fopt); |
|
|
445 | } |
431 | } |
446 | } |
432 | |
447 | |
433 | int |
448 | int |
434 | SDL_Init (U32 flags = SDL_INIT_VIDEO | SDL_INIT_AUDIO) |
449 | SDL_Init (U32 flags = SDL_INIT_VIDEO | SDL_INIT_AUDIO) |
435 | |
450 | |
… | |
… | |
717 | MODULE = CFClient PACKAGE = CFClient::Layout |
732 | MODULE = CFClient PACKAGE = CFClient::Layout |
718 | |
733 | |
719 | CFClient::Layout |
734 | CFClient::Layout |
720 | new (SV *class, int rgba = 0) |
735 | new (SV *class, int rgba = 0) |
721 | CODE: |
736 | CODE: |
722 | #if _WIN32 |
|
|
723 | //rgba = 0;//D makes text nicer, breaks TextView |
|
|
724 | #endif |
|
|
725 | rgba=1;//D |
|
|
726 | New (0, RETVAL, 1, struct cf_layout); |
737 | New (0, RETVAL, 1, struct cf_layout); |
727 | |
738 | |
728 | RETVAL->pl = pango_layout_new (rgba ? cairo_context : ft2_context); |
739 | RETVAL->pl = pango_layout_new (rgba ? cairo_context : ft2_context); |
729 | RETVAL->rgba = rgba; |
740 | RETVAL->rgba = rgba; |
730 | RETVAL->r = 1.; |
741 | RETVAL->r = 1.; |
… | |
… | |
774 | |
785 | |
775 | SV * |
786 | SV * |
776 | get_text (CFClient::Layout self) |
787 | get_text (CFClient::Layout self) |
777 | CODE: |
788 | CODE: |
778 | RETVAL = newSVpv (pango_layout_get_text (self->pl), 0); |
789 | RETVAL = newSVpv (pango_layout_get_text (self->pl), 0); |
779 | SvUTF8_on (RETVAL); |
790 | sv_utf8_decode (RETVAL); |
780 | OUTPUT: |
791 | OUTPUT: |
781 | RETVAL |
792 | RETVAL |
782 | |
793 | |
783 | void |
794 | void |
784 | set_foreground (CFClient::Layout self, float r, float g, float b, float a = 1.) |
795 | set_foreground (CFClient::Layout self, float r, float g, float b, float a = 1.) |