… | |
… | |
2474 | my $class = shift; |
2474 | my $class = shift; |
2475 | |
2475 | |
2476 | my $self = $class->SUPER::new ( |
2476 | my $self = $class->SUPER::new ( |
2477 | fontsize => 1, |
2477 | fontsize => 1, |
2478 | can_events => 0, |
2478 | can_events => 0, |
|
|
2479 | indent => 0, |
2479 | #font => default_font |
2480 | #font => default_font |
2480 | @_, |
2481 | @_, |
2481 | |
2482 | |
2482 | layout => (new CFClient::Layout 1), |
2483 | layout => (new CFClient::Layout 1), |
2483 | par => [], |
2484 | par => [], |
… | |
… | |
2506 | $self->SUPER::size_allocate ($w, $h); |
2507 | $self->SUPER::size_allocate ($w, $h); |
2507 | |
2508 | |
2508 | $self->{layout}->set_font ($self->{font}) if $self->{font}; |
2509 | $self->{layout}->set_font ($self->{font}) if $self->{font}; |
2509 | $self->{layout}->set_height ($self->{fontsize} * $::FONTSIZE); |
2510 | $self->{layout}->set_height ($self->{fontsize} * $::FONTSIZE); |
2510 | $self->{layout}->set_width ($self->{children}[0]{w}); |
2511 | $self->{layout}->set_width ($self->{children}[0]{w}); |
2511 | $self->{layout}->set_indent (-$self->{fontsize} * $::FONTSIZE * 4); |
2512 | $self->{layout}->set_indent ($self->{fontsize} * $::FONTSIZE * $self->{indent}); |
2512 | |
2513 | |
2513 | $self->reflow; |
2514 | $self->reflow; |
2514 | } |
2515 | } |
2515 | |
2516 | |
2516 | sub text_size { |
2517 | sub text_size { |
… | |
… | |
2518 | |
2519 | |
2519 | my $layout = $self->{layout}; |
2520 | my $layout = $self->{layout}; |
2520 | |
2521 | |
2521 | $layout->set_height ($self->{fontsize} * $::FONTSIZE); |
2522 | $layout->set_height ($self->{fontsize} * $::FONTSIZE); |
2522 | $layout->set_width ($self->{children}[0]{w} - $indent); |
2523 | $layout->set_width ($self->{children}[0]{w} - $indent); |
2523 | $layout->set_indent (-$self->{fontsize} * $::FONTSIZE * 4); |
2524 | $layout->set_indent ($self->{fontsize} * $::FONTSIZE * $self->{indent}); |
2524 | $layout->set_markup ($text); |
2525 | $layout->set_markup ($text); |
2525 | |
2526 | |
2526 | $layout->size |
2527 | $layout->size |
2527 | } |
2528 | } |
2528 | |
2529 | |
… | |
… | |
2580 | $layout->set_height ($self->{fontsize} * $::FONTSIZE); |
2581 | $layout->set_height ($self->{fontsize} * $::FONTSIZE); |
2581 | |
2582 | |
2582 | for (@{$self->{par}}) { |
2583 | for (@{$self->{par}}) { |
2583 | if (1 || $_->[0] >= $W) { # TODO: works,but needs reconfigure etc. support |
2584 | if (1 || $_->[0] >= $W) { # TODO: works,but needs reconfigure etc. support |
2584 | $layout->set_width ($W - $_->[3]); |
2585 | $layout->set_width ($W - $_->[3]); |
2585 | $layout->set_indent (-$self->{fontsize} * $::FONTSIZE * 4); |
2586 | $layout->set_indent ($self->{fontsize} * $::FONTSIZE * $self->{indent}); |
2586 | $layout->set_markup ($_->[4]); |
2587 | $layout->set_markup ($_->[4]); |
2587 | my ($w, $h) = $layout->size; |
2588 | my ($w, $h) = $layout->size; |
2588 | $_->[0] = $w + $_->[3]; |
2589 | $_->[0] = $w + $_->[3]; |
2589 | $_->[1] = $h; |
2590 | $_->[1] = $h; |
2590 | } |
2591 | } |
… | |
… | |
2622 | my $h = $par->[1]; |
2623 | my $h = $par->[1]; |
2623 | |
2624 | |
2624 | if ($y0 < $y + $h && $y < $y1) { |
2625 | if ($y0 < $y + $h && $y < $y1) { |
2625 | $layout->set_foreground (@{ $par->[2] }); |
2626 | $layout->set_foreground (@{ $par->[2] }); |
2626 | $layout->set_width ($W - $par->[3]); |
2627 | $layout->set_width ($W - $par->[3]); |
2627 | $layout->set_indent (-$self->{fontsize} * $::FONTSIZE * 4); |
2628 | $layout->set_indent ($self->{fontsize} * $::FONTSIZE * $self->{indent}); |
2628 | $layout->set_markup ($par->[4]); |
2629 | $layout->set_markup ($par->[4]); |
2629 | |
2630 | |
2630 | my ($w, $h, $data, $format, $internalformat) = $layout->render; |
2631 | my ($w, $h, $data, $format, $internalformat) = $layout->render; |
2631 | |
2632 | |
2632 | glRasterPos $par->[3], $y - $y0; |
2633 | glRasterPos $par->[3], $y - $y0; |