… | |
… | |
37 | |
37 | |
38 | static void |
38 | static void |
39 | substitute_func (FcPattern *pattern, gpointer data) |
39 | substitute_func (FcPattern *pattern, gpointer data) |
40 | { |
40 | { |
41 | FcPatternAddBool (pattern, FC_HINTING , 1); |
41 | FcPatternAddBool (pattern, FC_HINTING , 1); |
42 | FcPatternAddBool (pattern, FC_AUTOHINT, 1); |
42 | FcPatternAddBool (pattern, FC_AUTOHINT, 0); |
43 | } |
43 | } |
44 | |
44 | |
45 | static void |
45 | static void |
46 | layout_update (CFClient__Layout self) |
46 | layout_update (CFClient__Layout self) |
47 | { |
47 | { |
… | |
… | |
285 | CODE: |
285 | CODE: |
286 | g_object_unref (self->pl); |
286 | g_object_unref (self->pl); |
287 | Safefree (self); |
287 | Safefree (self); |
288 | |
288 | |
289 | void |
289 | void |
|
|
290 | set_text (CFClient::Layout self, SV *text_) |
|
|
291 | CODE: |
|
|
292 | { |
|
|
293 | STRLEN textlen; |
|
|
294 | char *text = SvPVutf8 (text_, textlen); |
|
|
295 | |
|
|
296 | pango_layout_set_text (self->pl, text, textlen); |
|
|
297 | } |
|
|
298 | |
|
|
299 | void |
290 | set_markup (CFClient::Layout self, SV *text_) |
300 | set_markup (CFClient::Layout self, SV *text_) |
291 | CODE: |
301 | CODE: |
292 | { |
302 | { |
293 | STRLEN textlen; |
303 | STRLEN textlen; |
294 | char *text = SvPVutf8 (text_, textlen); |
304 | char *text = SvPVutf8 (text_, textlen); |
… | |
… | |
564 | } |
574 | } |
565 | } |
575 | } |
566 | |
576 | |
567 | void |
577 | void |
568 | draw (CFClient::Map self, int x0, int y0, int sw, int sh) |
578 | draw (CFClient::Map self, int x0, int y0, int sw, int sh) |
569 | CODE: |
579 | PPCODE: |
570 | { |
580 | { |
|
|
581 | int sw4 = (sw + 3) & ~3; |
|
|
582 | SV *darkness_sv = sv_2mortal (newSV (sw4 * sh)); |
|
|
583 | uint8_t *darkness = (uint8_t *)SvPVX (darkness_sv); |
|
|
584 | |
|
|
585 | SvPOK_only (darkness_sv); |
|
|
586 | SvCUR_set (darkness_sv, sw4 * sh); |
|
|
587 | |
571 | int vx = self->vx = self->w >= sw |
588 | int vx = self->vx = self->w >= sw |
572 | ? self->x + (self->w - sw) / 2 |
589 | ? self->x + (self->w - sw) / 2 |
573 | : MIN (self->x, MAX (self->x + self->w - sw + 1, self->vx)); |
590 | : MIN (self->x, MAX (self->x + self->w - sw + 1, self->vx)); |
574 | |
591 | |
575 | int vy = self->vy = self->h >= sh |
592 | int vy = self->vy = self->h >= sh |
… | |
… | |
597 | |
614 | |
598 | for (x = 0; x < sw; x++) |
615 | for (x = 0; x < sw; x++) |
599 | if (row->c0 <= x + vx && x + vx < row->c1) |
616 | if (row->c0 <= x + vx && x + vx < row->c1) |
600 | { |
617 | { |
601 | mapcell *cell = row->col + (x + vx - row->c0); |
618 | mapcell *cell = row->col + (x + vx - row->c0); |
|
|
619 | |
|
|
620 | darkness[y * sw4 + x] = cell->darkness < 0 |
|
|
621 | ? 255 - FOW_DARKNESS |
|
|
622 | : 255 - cell->darkness; |
|
|
623 | |
602 | uint16_t face = cell->face [z]; |
624 | uint16_t face = cell->face [z]; |
603 | |
625 | |
604 | if (face) |
626 | if (face) |
605 | { |
627 | { |
606 | mapface tex = self->face [face]; |
628 | mapface tex = self->face [face]; |
… | |
… | |
623 | } |
645 | } |
624 | } |
646 | } |
625 | } |
647 | } |
626 | |
648 | |
627 | glEnd (); |
649 | glEnd (); |
628 | } |
|
|
629 | |
650 | |
|
|
651 | glDisable (GL_TEXTURE_2D); |
|
|
652 | glDisable (GL_BLEND); |
|
|
653 | |
|
|
654 | EXTEND (SP, 3); |
|
|
655 | PUSHs (sv_2mortal (newSViv (sw4))); |
|
|
656 | PUSHs (sv_2mortal (newSViv (sh))); |
|
|
657 | PUSHs (darkness_sv); |
|
|
658 | } |
|
|
659 | |