… | |
… | |
315 | } |
315 | } |
316 | |
316 | |
317 | sub move_abs { |
317 | sub move_abs { |
318 | my ($self, $x, $y, $z) = @_; |
318 | my ($self, $x, $y, $z) = @_; |
319 | |
319 | |
320 | $self->{x} = List::Util::max 0, int $x; |
320 | $self->{x} = List::Util::max 0, List::Util::min $self->{root}{w} - $self->{w}, int $x; |
321 | $self->{y} = List::Util::max 0, int $y; |
321 | $self->{y} = List::Util::max 0, List::Util::min $self->{root}{h} - $self->{h}, int $y; |
322 | $self->{z} = $z if defined $z; |
322 | $self->{z} = $z if defined $z; |
323 | |
323 | |
324 | $self->update; |
324 | $self->update; |
325 | } |
325 | } |
326 | |
326 | |
… | |
… | |
1658 | : ($self->{h} - $tex->{h}) * 0.5); |
1658 | : ($self->{h} - $tex->{h}) * 0.5); |
1659 | }; |
1659 | }; |
1660 | |
1660 | |
1661 | glEnable GL_TEXTURE_2D; |
1661 | glEnable GL_TEXTURE_2D; |
1662 | |
1662 | |
|
|
1663 | my $w = List::Util::min $self->{w} + 4, $tex->{w}; |
|
|
1664 | my $h = List::Util::min $self->{h} + 2, $tex->{h}; |
|
|
1665 | |
1663 | if ($tex->{format} == GL_ALPHA) { |
1666 | if ($tex->{format} == GL_ALPHA) { |
1664 | glTexEnv GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_MODULATE; |
1667 | glTexEnv GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_MODULATE; |
1665 | glColor @{$self->{fg}}; |
1668 | glColor @{$self->{fg}}; |
1666 | $tex->draw_quad_alpha ($self->{ox}, $self->{oy}); |
1669 | $tex->draw_quad_alpha ($self->{ox}, $self->{oy}, $w, $h); |
1667 | } else { |
1670 | } else { |
1668 | glTexEnv GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_REPLACE; |
1671 | glTexEnv GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_REPLACE; |
1669 | $tex->draw_quad_alpha_premultiplied ($self->{ox}, $self->{oy}); |
1672 | $tex->draw_quad_alpha_premultiplied ($self->{ox}, $self->{oy}, $w, $h); |
1670 | } |
1673 | } |
1671 | |
1674 | |
1672 | glDisable GL_TEXTURE_2D; |
1675 | glDisable GL_TEXTURE_2D; |
1673 | } |
1676 | } |
1674 | |
1677 | |
… | |
… | |
2304 | sub set_range { |
2307 | sub set_range { |
2305 | my ($self, $range) = @_; |
2308 | my ($self, $range) = @_; |
2306 | |
2309 | |
2307 | ($range, $self->{range}) = ($self->{range}, $range); |
2310 | ($range, $self->{range}) = ($self->{range}, $range); |
2308 | |
2311 | |
2309 | $self->update |
|
|
2310 | if "@$range" ne "@{$self->{range}}"; |
2312 | if ("@$range" ne "@{$self->{range}}") { |
|
|
2313 | $self->update; |
|
|
2314 | $self->set_value ($self->{range}[0]); |
|
|
2315 | } |
2311 | } |
2316 | } |
2312 | |
2317 | |
2313 | sub set_value { |
2318 | sub set_value { |
2314 | my ($self, $value) = @_; |
2319 | my ($self, $value) = @_; |
2315 | |
2320 | |
… | |
… | |
2474 | my $class = shift; |
2479 | my $class = shift; |
2475 | |
2480 | |
2476 | my $self = $class->SUPER::new ( |
2481 | my $self = $class->SUPER::new ( |
2477 | fontsize => 1, |
2482 | fontsize => 1, |
2478 | can_events => 0, |
2483 | can_events => 0, |
|
|
2484 | indent => 0, |
2479 | #font => default_font |
2485 | #font => default_font |
2480 | @_, |
2486 | @_, |
2481 | |
2487 | |
2482 | layout => (new CFClient::Layout 1), |
2488 | layout => (new CFClient::Layout 1), |
2483 | par => [], |
2489 | par => [], |
… | |
… | |
2506 | $self->SUPER::size_allocate ($w, $h); |
2512 | $self->SUPER::size_allocate ($w, $h); |
2507 | |
2513 | |
2508 | $self->{layout}->set_font ($self->{font}) if $self->{font}; |
2514 | $self->{layout}->set_font ($self->{font}) if $self->{font}; |
2509 | $self->{layout}->set_height ($self->{fontsize} * $::FONTSIZE); |
2515 | $self->{layout}->set_height ($self->{fontsize} * $::FONTSIZE); |
2510 | $self->{layout}->set_width ($self->{children}[0]{w}); |
2516 | $self->{layout}->set_width ($self->{children}[0]{w}); |
|
|
2517 | $self->{layout}->set_indent ($self->{fontsize} * $::FONTSIZE * $self->{indent}); |
2511 | |
2518 | |
2512 | $self->reflow; |
2519 | $self->reflow; |
2513 | } |
2520 | } |
2514 | |
2521 | |
2515 | sub text_size { |
2522 | sub text_size { |
… | |
… | |
2517 | |
2524 | |
2518 | my $layout = $self->{layout}; |
2525 | my $layout = $self->{layout}; |
2519 | |
2526 | |
2520 | $layout->set_height ($self->{fontsize} * $::FONTSIZE); |
2527 | $layout->set_height ($self->{fontsize} * $::FONTSIZE); |
2521 | $layout->set_width ($self->{children}[0]{w} - $indent); |
2528 | $layout->set_width ($self->{children}[0]{w} - $indent); |
|
|
2529 | $layout->set_indent ($self->{fontsize} * $::FONTSIZE * $self->{indent}); |
2522 | $layout->set_markup ($text); |
2530 | $layout->set_markup ($text); |
2523 | |
2531 | |
2524 | $layout->size |
2532 | $layout->size |
2525 | } |
2533 | } |
2526 | |
2534 | |
… | |
… | |
2565 | |
2573 | |
2566 | return unless $self->{h} > 0; |
2574 | return unless $self->{h} > 0; |
2567 | |
2575 | |
2568 | delete $self->{texture}; |
2576 | delete $self->{texture}; |
2569 | |
2577 | |
2570 | $ROOT->on_post_alloc ($self, sub { |
2578 | $ROOT->on_post_alloc ($self => sub { |
2571 | my ($W, $H) = @{$self->{children}[0]}{qw(w h)}; |
2579 | my ($W, $H) = @{$self->{children}[0]}{qw(w h)}; |
2572 | |
2580 | |
2573 | if (delete $self->{need_reflow}) { |
2581 | if (delete $self->{need_reflow}) { |
2574 | my $height = 0; |
2582 | my $height = 0; |
2575 | |
2583 | |
… | |
… | |
2578 | $layout->set_height ($self->{fontsize} * $::FONTSIZE); |
2586 | $layout->set_height ($self->{fontsize} * $::FONTSIZE); |
2579 | |
2587 | |
2580 | for (@{$self->{par}}) { |
2588 | for (@{$self->{par}}) { |
2581 | if (1 || $_->[0] >= $W) { # TODO: works,but needs reconfigure etc. support |
2589 | if (1 || $_->[0] >= $W) { # TODO: works,but needs reconfigure etc. support |
2582 | $layout->set_width ($W - $_->[3]); |
2590 | $layout->set_width ($W - $_->[3]); |
|
|
2591 | $layout->set_indent ($self->{fontsize} * $::FONTSIZE * $self->{indent}); |
2583 | $layout->set_markup ($_->[4]); |
2592 | $layout->set_markup ($_->[4]); |
2584 | my ($w, $h) = $layout->size; |
2593 | my ($w, $h) = $layout->size; |
2585 | $_->[0] = $w + $_->[3]; |
2594 | $_->[0] = $w + $_->[3]; |
2586 | $_->[1] = $h; |
2595 | $_->[1] = $h; |
2587 | } |
2596 | } |
… | |
… | |
2590 | } |
2599 | } |
2591 | |
2600 | |
2592 | $self->{height} = $height; |
2601 | $self->{height} = $height; |
2593 | |
2602 | |
2594 | $self->{children}[1]->set_range ([$height, 0, $height, $H, 1]); |
2603 | $self->{children}[1]->set_range ([$height, 0, $height, $H, 1]); |
2595 | |
2604 | |
2596 | delete $self->{texture}; |
2605 | delete $self->{texture}; |
2597 | } |
2606 | } |
2598 | |
2607 | |
2599 | $self->{texture} ||= new_from_opengl CFClient::Texture $W, $H, sub { |
2608 | $self->{texture} ||= new_from_opengl CFClient::Texture $W, $H, sub { |
2600 | glClearColor 0, 0, 0, 0; |
2609 | glClearColor 0, 0, 0, 0; |
… | |
… | |
2619 | my $h = $par->[1]; |
2628 | my $h = $par->[1]; |
2620 | |
2629 | |
2621 | if ($y0 < $y + $h && $y < $y1) { |
2630 | if ($y0 < $y + $h && $y < $y1) { |
2622 | $layout->set_foreground (@{ $par->[2] }); |
2631 | $layout->set_foreground (@{ $par->[2] }); |
2623 | $layout->set_width ($W - $par->[3]); |
2632 | $layout->set_width ($W - $par->[3]); |
|
|
2633 | $layout->set_indent ($self->{fontsize} * $::FONTSIZE * $self->{indent}); |
2624 | $layout->set_markup ($par->[4]); |
2634 | $layout->set_markup ($par->[4]); |
2625 | |
2635 | |
2626 | my ($w, $h, $data, $format, $internalformat) = $layout->render; |
2636 | my ($w, $h, $data, $format, $internalformat) = $layout->render; |
2627 | |
2637 | |
2628 | glRasterPos $par->[3], $y - $y0; |
2638 | glRasterPos $par->[3], $y - $y0; |
… | |
… | |
2779 | or return; |
2789 | or return; |
2780 | |
2790 | |
2781 | my ($x, $y) = $widget->coord2global ($widget->{w}, 0); |
2791 | my ($x, $y) = $widget->coord2global ($widget->{w}, 0); |
2782 | |
2792 | |
2783 | ($x, $y) = $widget->coord2global (-$self->{w}, 0) |
2793 | ($x, $y) = $widget->coord2global (-$self->{w}, 0) |
2784 | if $x + $self->{w} > $::WIDTH; |
2794 | if $x + $self->{w} > $self->{root}{w}; |
2785 | |
2795 | |
2786 | $self->move_abs ($x, $y); |
2796 | $self->move_abs ($x, $y); |
2787 | }); |
2797 | }); |
2788 | } |
2798 | } |
2789 | |
2799 | |