… | |
… | |
79 | sub feed_sdl_key_up_event { |
79 | sub feed_sdl_key_up_event { |
80 | $FOCUS->emit (key_up => $_[0]) |
80 | $FOCUS->emit (key_up => $_[0]) |
81 | if $FOCUS; |
81 | if $FOCUS; |
82 | } |
82 | } |
83 | |
83 | |
|
|
84 | sub check_hover { |
|
|
85 | my ($widget) = @_; |
|
|
86 | |
|
|
87 | if ($widget != $HOVER) { |
|
|
88 | my $hover = $HOVER; $HOVER = $widget; |
|
|
89 | |
|
|
90 | $hover->update if $hover && $hover->{can_hover}; |
|
|
91 | $HOVER->update if $HOVER && $HOVER->{can_hover}; |
|
|
92 | |
|
|
93 | $TOOLTIP_WATCHER->start; |
|
|
94 | } |
|
|
95 | } |
|
|
96 | |
84 | sub feed_sdl_button_down_event { |
97 | sub feed_sdl_button_down_event { |
85 | my ($ev) = @_; |
98 | my ($ev) = @_; |
86 | my ($x, $y) = ($ev->{x}, $ev->{y}); |
99 | my ($x, $y) = ($ev->{x}, $ev->{y}); |
87 | |
100 | |
88 | if (!$BUTTON_STATE) { |
101 | unless ($BUTTON_STATE) { |
89 | my $widget = $ROOT->find_widget ($x, $y); |
102 | my $widget = $ROOT->find_widget ($x, $y); |
90 | |
103 | |
91 | $GRAB = $widget; |
104 | $GRAB = $widget; |
92 | $GRAB->update if $GRAB; |
105 | $GRAB->update if $GRAB; |
93 | |
106 | |
94 | $TOOLTIP_WATCHER->cb->(); |
107 | $TOOLTIP_WATCHER->cb->(); |
95 | } |
108 | } |
96 | |
109 | |
97 | $BUTTON_STATE |= 1 << ($ev->{button} - 1); |
110 | $BUTTON_STATE |= 1 << ($ev->{button} - 1); |
98 | |
111 | |
99 | $GRAB->emit (button_down => $ev, $GRAB->coord2local ($x, $y)) |
112 | if ($GRAB) { |
100 | if $GRAB; |
113 | if ($ev->{button} == 4 || $ev->{button} == 5) { |
|
|
114 | # mousewheel |
|
|
115 | $ev->{dx} = 0; |
|
|
116 | $ev->{dy} = $ev->{button} * 2 - 9; |
|
|
117 | $GRAB->emit (mouse_wheel => $ev); |
|
|
118 | } else { |
|
|
119 | $GRAB->emit (button_down => $ev) |
|
|
120 | } |
|
|
121 | } |
101 | } |
122 | } |
102 | |
123 | |
103 | sub feed_sdl_button_up_event { |
124 | sub feed_sdl_button_up_event { |
104 | my ($ev) = @_; |
125 | my ($ev) = @_; |
105 | my ($x, $y) = ($ev->{x}, $ev->{y}); |
|
|
106 | |
126 | |
107 | my $widget = $GRAB || $ROOT->find_widget ($x, $y); |
127 | my $widget = $GRAB || $ROOT->find_widget ($ev->{x}, $ev->{y}); |
108 | |
128 | |
109 | $BUTTON_STATE &= ~(1 << ($ev->{button} - 1)); |
129 | $BUTTON_STATE &= ~(1 << ($ev->{button} - 1)); |
110 | |
130 | |
111 | $GRAB->emit (button_up => $ev, $GRAB->coord2local ($x, $y)) |
131 | $GRAB->emit (button_up => $ev) |
112 | if $GRAB; |
132 | if $GRAB && $ev->{button} != 4 && $ev->{button} != 5; |
113 | |
133 | |
114 | if (!$BUTTON_STATE) { |
134 | unless ($BUTTON_STATE) { |
115 | my $grab = $GRAB; undef $GRAB; |
135 | my $grab = $GRAB; undef $GRAB; |
116 | $grab->update if $grab; |
136 | $grab->update if $grab; |
117 | $GRAB->update if $GRAB; |
137 | $GRAB->update if $GRAB; |
118 | |
138 | |
|
|
139 | check_hover $widget; |
119 | $TOOLTIP_WATCHER->cb->(); |
140 | $TOOLTIP_WATCHER->cb->(); |
120 | } |
141 | } |
121 | } |
142 | } |
122 | |
143 | |
123 | sub feed_sdl_motion_event { |
144 | sub feed_sdl_motion_event { |
124 | my ($ev) = @_; |
145 | my ($ev) = @_; |
125 | my ($x, $y) = ($ev->{x}, $ev->{y}); |
146 | my ($x, $y) = ($ev->{x}, $ev->{y}); |
126 | |
147 | |
127 | my $widget = $GRAB || $ROOT->find_widget ($x, $y); |
148 | my $widget = $GRAB || $ROOT->find_widget ($x, $y); |
128 | |
149 | |
129 | if ($widget != $HOVER) { |
150 | check_hover $widget; |
130 | my $hover = $HOVER; $HOVER = $widget; |
|
|
131 | |
151 | |
132 | $hover->update if $hover && $hover->{can_hover}; |
152 | $HOVER->emit (mouse_motion => $ev) |
133 | $HOVER->update if $HOVER && $HOVER->{can_hover}; |
|
|
134 | |
|
|
135 | $TOOLTIP_WATCHER->start; |
|
|
136 | } |
|
|
137 | |
|
|
138 | $HOVER->emit (mouse_motion => $ev, $HOVER->coord2local ($x, $y)) |
|
|
139 | if $HOVER; |
153 | if $HOVER; |
140 | } |
154 | } |
141 | |
155 | |
142 | # convert position array to integers |
156 | # convert position array to integers |
143 | sub harmonize { |
157 | sub harmonize { |
… | |
… | |
189 | |
203 | |
190 | } |
204 | } |
191 | } |
205 | } |
192 | |
206 | |
193 | reconfigure_widgets; |
207 | reconfigure_widgets; |
|
|
208 | } |
|
|
209 | |
|
|
210 | ############################################################################# |
|
|
211 | |
|
|
212 | package CFClient::UI::Event; |
|
|
213 | |
|
|
214 | sub xy { |
|
|
215 | $_[1]->coord2local ($_[0]{x}, $_[0]{y}) |
194 | } |
216 | } |
195 | |
217 | |
196 | ############################################################################# |
218 | ############################################################################# |
197 | |
219 | |
198 | package CFClient::UI::Base; |
220 | package CFClient::UI::Base; |
… | |
… | |
452 | |
474 | |
453 | $FOCUS->emit ("focus_out") if $FOCUS; |
475 | $FOCUS->emit ("focus_out") if $FOCUS; |
454 | $self->emit ("focus_in"); |
476 | $self->emit ("focus_in"); |
455 | } |
477 | } |
456 | |
478 | |
457 | sub invoke_mouse_motion { 1 } |
479 | sub invoke_mouse_motion { 0 } |
458 | sub invoke_button_up { 1 } |
480 | sub invoke_button_up { 0 } |
459 | sub invoke_key_down { 1 } |
481 | sub invoke_key_down { 0 } |
460 | sub invoke_key_up { 1 } |
482 | sub invoke_key_up { 0 } |
|
|
483 | sub invoke_mouse_wheel { 0 } |
461 | |
484 | |
462 | sub invoke_button_down { |
485 | sub invoke_button_down { |
463 | my ($self, $ev, $x, $y) = @_; |
486 | my ($self, $ev, $x, $y) = @_; |
464 | |
487 | |
465 | $self->grab_focus; |
488 | $self->grab_focus; |
466 | |
489 | |
467 | 1 |
490 | 0 |
468 | } |
491 | } |
469 | |
492 | |
470 | sub connect { |
493 | sub connect { |
471 | my ($self, $signal, $cb) = @_; |
494 | my ($self, $signal, $cb) = @_; |
472 | |
495 | |
… | |
… | |
474 | } |
497 | } |
475 | |
498 | |
476 | sub emit { |
499 | sub emit { |
477 | my ($self, $signal, @args) = @_; |
500 | my ($self, $signal, @args) = @_; |
478 | |
501 | |
|
|
502 | my @append |
|
|
503 | = ref $args[0] && $args[0]->isa ("CFClient::UI::Event") |
|
|
504 | ? $args[0]->xy ($self) |
|
|
505 | : (); |
|
|
506 | |
|
|
507 | #warn +(caller(1))[3] . "emit $signal on $self (parent $self->{parent})\n";#d# |
|
|
508 | |
479 | #d##TODO# stop propagating at first true, do not use sum |
509 | #d##TODO# stop propagating at first true, do not use sum |
480 | (List::Util::sum map $_->($self, @args), @{$self->{signal_cb}{$signal} || []}) # before |
510 | (List::Util::sum map $_->($self, @args, @append), @{$self->{signal_cb}{$signal} || []}) # before |
481 | || ($self->can ("invoke_$signal") || sub { 1 })->($self, @args) # closure |
511 | || ($self->can ("invoke_$signal") || sub { 1 })->($self, @args, @append) # closure |
482 | || ($self->{parent} && $self->{parent}->emit ($signal, @args)) # parent |
512 | || ($self->{parent} && $self->{parent}->emit ($signal, @args)) # parent |
483 | } |
513 | } |
484 | |
514 | |
485 | sub find_widget { |
515 | sub find_widget { |
486 | my ($self, $x, $y) = @_; |
516 | my ($self, $x, $y) = @_; |
487 | |
517 | |
… | |
… | |
587 | } |
617 | } |
588 | |
618 | |
589 | sub DESTROY { |
619 | sub DESTROY { |
590 | my ($self) = @_; |
620 | my ($self) = @_; |
591 | |
621 | |
|
|
622 | return if CFClient::in_destruct; |
|
|
623 | |
592 | delete $WIDGET{$self+0}; |
624 | delete $WIDGET{$self+0}; |
593 | |
625 | |
594 | eval { $self->destroy }; |
626 | eval { $self->destroy }; |
595 | warn "exception during widget destruction: $@" if $@ & $@ != /during global destruction/; |
627 | warn "exception during widget destruction: $@" if $@ & $@ != /during global destruction/; |
596 | } |
628 | } |
… | |
… | |
975 | $self->{vp}->set_offset (0, $_[1]); |
1007 | $self->{vp}->set_offset (0, $_[1]); |
976 | }, |
1008 | }, |
977 | ; |
1009 | ; |
978 | |
1010 | |
979 | $self = $class->SUPER::new ( |
1011 | $self = $class->SUPER::new ( |
980 | vp => (new CFClient::UI::ViewPort expand => 1), |
1012 | vp => (new CFClient::UI::ViewPort expand => 1), |
|
|
1013 | can_events => 1, |
981 | slider => $slider, |
1014 | slider => $slider, |
982 | %arg, |
1015 | %arg, |
983 | ); |
1016 | ); |
984 | |
1017 | |
985 | $self->SUPER::add ($self->{vp}, $self->{slider}); |
1018 | $self->SUPER::add ($self->{vp}, $self->{slider}); |
986 | $self->add ($child) if $child; |
1019 | $self->add ($child) if $child; |
… | |
… | |
992 | |
1025 | |
993 | sub add { |
1026 | sub add { |
994 | my ($self, $widget) = @_; |
1027 | my ($self, $widget) = @_; |
995 | |
1028 | |
996 | $self->{vp}->add ($self->{child} = $widget); |
1029 | $self->{vp}->add ($self->{child} = $widget); |
|
|
1030 | } |
|
|
1031 | |
|
|
1032 | sub invoke_mouse_wheel { |
|
|
1033 | my ($self, $ev) = @_; |
|
|
1034 | |
|
|
1035 | return 0 unless $ev->{dy}; # only vertical movements |
|
|
1036 | |
|
|
1037 | $self->{slider}->emit (mouse_wheel => $ev); |
|
|
1038 | |
|
|
1039 | 1 |
997 | } |
1040 | } |
998 | |
1041 | |
999 | sub update_slider { |
1042 | sub update_slider { |
1000 | my ($self) = @_; |
1043 | my ($self) = @_; |
1001 | |
1044 | |
… | |
… | |
1080 | my $self = $class->SUPER::new ( |
1123 | my $self = $class->SUPER::new ( |
1081 | bg => [1, 1, 1, 1], |
1124 | bg => [1, 1, 1, 1], |
1082 | border_bg => [1, 1, 1, 1], |
1125 | border_bg => [1, 1, 1, 1], |
1083 | border => 0.6, |
1126 | border => 0.6, |
1084 | can_events => 1, |
1127 | can_events => 1, |
1085 | min_w => 16, |
1128 | min_w => 64, |
1086 | min_h => 16, |
1129 | min_h => 32, |
1087 | %arg, |
1130 | %arg, |
1088 | ); |
1131 | ); |
1089 | |
1132 | |
1090 | $self->{title_widget} = new CFClient::UI::Label |
1133 | $self->{title_widget} = new CFClient::UI::Label |
1091 | align => 0, |
1134 | align => 0, |
… | |
… | |
1536 | #font => default_font |
1579 | #font => default_font |
1537 | #text => initial text |
1580 | #text => initial text |
1538 | #markup => initial narkup |
1581 | #markup => initial narkup |
1539 | #max_w => maximum pixel width |
1582 | #max_w => maximum pixel width |
1540 | ellipsise => 3, # end |
1583 | ellipsise => 3, # end |
1541 | layout => (new CFClient::Layout 2), |
1584 | layout => (new CFClient::Layout), |
1542 | fontsize => 1, |
1585 | fontsize => 1, |
1543 | align => -1, |
1586 | align => -1, |
1544 | valign => -1, |
1587 | valign => -1, |
1545 | padding_x => 2, |
1588 | padding_x => 2, |
1546 | padding_y => 2, |
1589 | padding_y => 2, |
1547 | can_events => 0, |
1590 | can_events => 0, |
1548 | %arg |
1591 | %arg |
1549 | ); |
1592 | ); |
1550 | |
1593 | |
1551 | if (exists $self->{template}) { |
1594 | if (exists $self->{template}) { |
1552 | my $layout = new CFClient::Layout 2; |
1595 | my $layout = new CFClient::Layout; |
1553 | $layout->set_text (delete $self->{template}); |
1596 | $layout->set_text (delete $self->{template}); |
1554 | $self->{template} = $layout; |
1597 | $self->{template} = $layout; |
1555 | } |
1598 | } |
1556 | |
1599 | |
1557 | if (exists $self->{markup}) { |
1600 | if (exists $self->{markup}) { |
… | |
… | |
1627 | |
1670 | |
1628 | my ($w, $h) = $self->{layout}->size; |
1671 | my ($w, $h) = $self->{layout}->size; |
1629 | |
1672 | |
1630 | if (exists $self->{template}) { |
1673 | if (exists $self->{template}) { |
1631 | $self->{template}->set_font ($self->{font}) if $self->{font}; |
1674 | $self->{template}->set_font ($self->{font}) if $self->{font}; |
|
|
1675 | $self->{template}->set_width ($self->{max_w} || -1); |
1632 | $self->{template}->set_height ($self->{fontsize} * $::FONTSIZE); |
1676 | $self->{template}->set_height ($self->{fontsize} * $::FONTSIZE); |
1633 | |
1677 | |
1634 | my ($w2, $h2) = $self->{template}->size; |
1678 | my ($w2, $h2) = $self->{template}->size; |
1635 | |
1679 | |
1636 | $w = List::Util::max $w, $w2; |
1680 | $w = List::Util::max $w, $w2; |
… | |
… | |
1688 | $self->{layout}->set_width ($self->{w}); |
1732 | $self->{layout}->set_width ($self->{w}); |
1689 | $self->{layout}->set_ellipsise ($self->{ellipsise}); |
1733 | $self->{layout}->set_ellipsise ($self->{ellipsise}); |
1690 | $self->{layout}->set_single_paragraph_mode ($self->{ellipsise}); |
1734 | $self->{layout}->set_single_paragraph_mode ($self->{ellipsise}); |
1691 | $self->{layout}->set_height ($self->{fontsize} * $::FONTSIZE); |
1735 | $self->{layout}->set_height ($self->{fontsize} * $::FONTSIZE); |
1692 | |
1736 | |
1693 | $self->{size_req} |
1737 | [$self->{layout}->size] |
1694 | }; |
1738 | }; |
1695 | |
1739 | |
1696 | unless (exists $self->{ox}) { |
1740 | unless (exists $self->{ox}) { |
1697 | $self->{ox} = int ($self->{align} < 0 ? $self->{padding_x} |
1741 | $self->{ox} = int ($self->{align} < 0 ? $self->{padding_x} |
1698 | : $self->{align} > 0 ? $self->{w} - $size->[0] - $self->{padding_x} |
1742 | : $self->{align} > 0 ? $self->{w} - $size->[0] - $self->{padding_x} |
… | |
… | |
1825 | |
1869 | |
1826 | my $idx = $self->{layout}->xy_to_index ($x, $y); |
1870 | my $idx = $self->{layout}->xy_to_index ($x, $y); |
1827 | |
1871 | |
1828 | # byte-index to char-index |
1872 | # byte-index to char-index |
1829 | my $text = $self->{text}; |
1873 | my $text = $self->{text}; |
1830 | utf8::encode $text; |
1874 | utf8::encode $text; $text = substr $text, 0, $idx; utf8::decode $text; |
1831 | $self->{cursor} = length substr $text, 0, $idx; |
1875 | $self->{cursor} = length $text; |
1832 | |
1876 | |
1833 | $self->_set_text ($self->{text}); |
1877 | $self->_set_text ($self->{text}); |
1834 | $self->update; |
1878 | $self->update; |
1835 | |
1879 | |
1836 | 1 |
1880 | 1 |
… | |
… | |
2115 | my $self = $class->SUPER::new ( |
2159 | my $self = $class->SUPER::new ( |
2116 | can_events => 0, |
2160 | can_events => 0, |
2117 | @_, |
2161 | @_, |
2118 | ); |
2162 | ); |
2119 | |
2163 | |
2120 | $self->{path} |
2164 | $self->{path} || $self->{tex} |
2121 | or Carp::croak "required attribute 'path' not set"; |
2165 | or Carp::croak "'path' or 'tex' attributes required"; |
2122 | |
2166 | |
2123 | $self->{tex} = $texture_cache{$self->{path}} ||= |
2167 | $self->{tex} ||= $texture_cache{$self->{path}} ||= |
2124 | new_from_file CFClient::Texture CFClient::find_rcfile $self->{path}, mipmap => 1; |
2168 | new_from_file CFClient::Texture CFClient::find_rcfile $self->{path}, mipmap => 1; |
2125 | |
2169 | |
2126 | Scalar::Util::weaken $texture_cache{$self->{path}}; |
2170 | Scalar::Util::weaken $texture_cache{$self->{path}}; |
2127 | |
2171 | |
2128 | $self->{aspect} ||= $self->{tex}{w} / $self->{tex}{h}; |
2172 | $self->{aspect} ||= $self->{tex}{w} / $self->{tex}{h}; |
… | |
… | |
2448 | } |
2492 | } |
2449 | |
2493 | |
2450 | 1 |
2494 | 1 |
2451 | } |
2495 | } |
2452 | |
2496 | |
|
|
2497 | sub invoke_mouse_wheel { |
|
|
2498 | my ($self, $ev) = @_; |
|
|
2499 | |
|
|
2500 | my $delta = $self->{vertical} ? $ev->{dy} : $ev->{dx}; |
|
|
2501 | |
|
|
2502 | $self->set_value ($self->{range}[0] + $delta * $self->{range}[3] * 0.1); |
|
|
2503 | |
|
|
2504 | ! ! $delta |
|
|
2505 | } |
|
|
2506 | |
2453 | sub update { |
2507 | sub update { |
2454 | my ($self) = @_; |
2508 | my ($self) = @_; |
2455 | |
2509 | |
2456 | delete $self->{knob_w}; |
2510 | delete $self->{knob_w}; |
2457 | $self->SUPER::update; |
2511 | $self->SUPER::update; |
… | |
… | |
2556 | sub new { |
2610 | sub new { |
2557 | my $class = shift; |
2611 | my $class = shift; |
2558 | |
2612 | |
2559 | my $self = $class->SUPER::new ( |
2613 | my $self = $class->SUPER::new ( |
2560 | fontsize => 1, |
2614 | fontsize => 1, |
2561 | can_events => 0, |
2615 | can_events => 1, |
2562 | indent => 0, |
2616 | indent => 0, |
2563 | #font => default_font |
2617 | #font => default_font |
2564 | @_, |
2618 | @_, |
2565 | |
2619 | |
2566 | layout => (new CFClient::Layout 2), |
2620 | layout => (new CFClient::Layout), |
2567 | par => [], |
2621 | par => [], |
2568 | height => 0, |
2622 | height => 0, |
2569 | children => [ |
2623 | children => [ |
2570 | (new CFClient::UI::Empty expand => 1), |
2624 | (new CFClient::UI::Empty expand => 1), |
2571 | (new CFClient::UI::Slider vertical => 1), |
2625 | (new CFClient::UI::Slider vertical => 1), |
… | |
… | |
2606 | |
2660 | |
2607 | $self->reflow; |
2661 | $self->reflow; |
2608 | |
2662 | |
2609 | local $self->{children} = [$empty, $slider]; |
2663 | local $self->{children} = [$empty, $slider]; |
2610 | $self->SUPER::invoke_size_allocate ($w, $h) |
2664 | $self->SUPER::invoke_size_allocate ($w, $h) |
|
|
2665 | } |
|
|
2666 | |
|
|
2667 | sub invoke_mouse_wheel { |
|
|
2668 | my ($self, $ev) = @_; |
|
|
2669 | |
|
|
2670 | return 0 unless $ev->{dy}; # only vertical movements |
|
|
2671 | |
|
|
2672 | $self->{children}[1]->emit (mouse_wheel => $ev); |
|
|
2673 | |
|
|
2674 | 1 |
2611 | } |
2675 | } |
2612 | |
2676 | |
2613 | sub get_layout { |
2677 | sub get_layout { |
2614 | my ($self, $para) = @_; |
2678 | my ($self, $para) = @_; |
2615 | |
2679 | |
… | |
… | |
3062 | for my $item (@{ $self->{items} }) { |
3126 | for my $item (@{ $self->{items} }) { |
3063 | my ($widget, $cb, $tooltip) = @$item; |
3127 | my ($widget, $cb, $tooltip) = @$item; |
3064 | |
3128 | |
3065 | # handle various types of items, only text for now |
3129 | # handle various types of items, only text for now |
3066 | if (!ref $widget) { |
3130 | if (!ref $widget) { |
|
|
3131 | if ($widget =~ /\t/) { |
|
|
3132 | my ($left, $right) = split /\t/, $widget, 2; |
|
|
3133 | |
|
|
3134 | $widget = new CFClient::UI::HBox |
|
|
3135 | can_hover => 1, |
|
|
3136 | can_events => 1, |
|
|
3137 | tooltip => $tooltip, |
|
|
3138 | children => [ |
|
|
3139 | (new CFClient::UI::Label markup => $left, expand => 1), |
|
|
3140 | (new CFClient::UI::Label markup => $right, align => +1), |
|
|
3141 | ], |
|
|
3142 | ; |
|
|
3143 | |
|
|
3144 | } else { |
3067 | $widget = new CFClient::UI::Label |
3145 | $widget = new CFClient::UI::Label |
3068 | can_hover => 1, |
3146 | can_hover => 1, |
3069 | can_events => 1, |
3147 | can_events => 1, |
3070 | markup => $widget, |
3148 | markup => $widget, |
3071 | tooltip => $tooltip |
3149 | tooltip => $tooltip; |
|
|
3150 | } |
3072 | } |
3151 | } |
3073 | |
3152 | |
3074 | $self->{item}{$widget} = $item; |
3153 | $self->{item}{$widget} = $item; |
3075 | |
3154 | |
3076 | $self->{vbox}->add ($widget); |
3155 | $self->{vbox}->add ($widget); |
… | |
… | |
3798 | my ($w, $h) = @$widget{qw(alloc_w alloc_h)}; |
3877 | my ($w, $h) = @$widget{qw(alloc_w alloc_h)}; |
3799 | |
3878 | |
3800 | $w = 0 if $w < 0; |
3879 | $w = 0 if $w < 0; |
3801 | $h = 0 if $h < 0; |
3880 | $h = 0 if $h < 0; |
3802 | |
3881 | |
|
|
3882 | $w = max $widget->{min_w}, $w; |
|
|
3883 | $h = max $widget->{min_h}, $h; |
|
|
3884 | |
|
|
3885 | $w = min $widget->{max_w}, $w if exists $widget->{max_w}; |
|
|
3886 | $h = min $widget->{max_h}, $h if exists $widget->{max_h}; |
|
|
3887 | |
3803 | $w = int $w + 0.5; |
3888 | $w = int $w + 0.5; |
3804 | $h = int $h + 0.5; |
3889 | $h = int $h + 0.5; |
3805 | |
3890 | |
3806 | if ($widget->{w} != $w || $widget->{h} != $h || delete $widget->{force_size_alloc}) { |
3891 | if ($widget->{w} != $w || $widget->{h} != $h || delete $widget->{force_size_alloc}) { |
3807 | $widget->{old_w} = $widget->{w}; |
3892 | $widget->{old_w} = $widget->{w}; |
… | |
… | |
3837 | ($draw_x, $draw_y, $draw_w, $draw_h) = |
3922 | ($draw_x, $draw_y, $draw_w, $draw_h) = |
3838 | (0, 0, $self->{w}, $self->{h}); |
3923 | (0, 0, $self->{w}, $self->{h}); |
3839 | } |
3924 | } |
3840 | |
3925 | |
3841 | $self->_draw; |
3926 | $self->_draw; |
3842 | |
|
|
3843 | #TODO#d# display texture cache |
|
|
3844 | { |
|
|
3845 | glEnable GL_TEXTURE_2D; |
|
|
3846 | glBindTexture GL_TEXTURE_2D, 41; |
|
|
3847 | glColor 1, 1, 1, 1; |
|
|
3848 | glTexEnv GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_MODULATE; |
|
|
3849 | glEnable GL_BLEND; |
|
|
3850 | glBlendFunc GL_SRC_ALPHA, GL_ZERO; |
|
|
3851 | glBegin GL_QUADS; |
|
|
3852 | glTexCoord 0,1; glVertex 0,0; |
|
|
3853 | glTexCoord 1,1; glVertex 255,0; |
|
|
3854 | glTexCoord 1,0; glVertex 255,255; |
|
|
3855 | glTexCoord 0,0; glVertex 0,255; |
|
|
3856 | glEnd; |
|
|
3857 | glDisable GL_BLEND; |
|
|
3858 | glDisable GL_TEXTURE_2D; |
|
|
3859 | } |
|
|
3860 | |
|
|
3861 | } |
3927 | } |
3862 | |
3928 | |
3863 | ############################################################################# |
3929 | ############################################################################# |
3864 | |
3930 | |
3865 | package CFClient::UI; |
3931 | package CFClient::UI; |