ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/deliantra/Deliantra-Client/DC/UI.pm
(Generate patch)

Comparing deliantra/Deliantra-Client/DC/UI.pm (file contents):
Revision 1.149 by root, Sat Apr 22 23:11:32 2006 UTC vs.
Revision 1.165 by root, Mon Apr 24 08:22:22 2006 UTC

8use CFClient; 8use CFClient;
9 9
10our ($FOCUS, $HOVER, $GRAB); # various widgets 10our ($FOCUS, $HOVER, $GRAB); # various widgets
11 11
12our $ROOT; 12our $ROOT;
13our $TOOLTIP;
13our $BUTTON_STATE; 14our $BUTTON_STATE;
15
16sub check_tooltip {
17 if (!$GRAB) {
18 for (my $widget = $HOVER; $widget; $widget = $widget->{parent}) {
19 if (length $widget->{tooltip}) {
20
21 if ($TOOLTIP->{owner} != $widget) {
22 $TOOLTIP->{owner} = $widget;
23
24 my $tip = $widget->{tooltip};
25
26 $tip = $tip->($widget) if CODE:: eq ref $tip;
27
28 $TOOLTIP->set_markup ($widget->{tooltip});
29 $TOOLTIP->move ($widget->coord2global ($widget->{w}, 0));
30 $TOOLTIP->show;
31 }
32
33 return;
34 }
35 }
36 }
37
38 $TOOLTIP->hide;
39 delete $TOOLTIP->{owner};
40}
14 41
15# class methods for events 42# class methods for events
16sub feed_sdl_key_down_event { 43sub feed_sdl_key_down_event {
17 $FOCUS->key_down ($_[0]) if $FOCUS; 44 $FOCUS->emit (key_down => $_[0]) || $FOCUS->key_down ($_[0])
45 if $FOCUS;
18} 46}
19 47
20sub feed_sdl_key_up_event { 48sub feed_sdl_key_up_event {
21 $FOCUS->key_up ($_[0]) if $FOCUS; 49 $FOCUS->emit (key_up => $_[0]) || $FOCUS->key_up ($_[0])
50 if $FOCUS;
22} 51}
23 52
24sub feed_sdl_button_down_event { 53sub feed_sdl_button_down_event {
25 my ($ev) = @_; 54 my ($ev) = @_;
26 my ($x, $y) = ($ev->{x}, $ev->{y}); 55 my ($x, $y) = ($ev->{x}, $ev->{y});
28 if (!$BUTTON_STATE) { 57 if (!$BUTTON_STATE) {
29 my $widget = $ROOT->find_widget ($x, $y); 58 my $widget = $ROOT->find_widget ($x, $y);
30 59
31 $GRAB = $widget; 60 $GRAB = $widget;
32 $GRAB->update if $GRAB; 61 $GRAB->update if $GRAB;
62
63 check_tooltip;
33 } 64 }
34 65
35 $BUTTON_STATE |= 1 << ($ev->{button} - 1); 66 $BUTTON_STATE |= 1 << ($ev->{button} - 1);
36 67
37 $GRAB->button_down ($ev, $GRAB->coord2local ($x, $y)) if $GRAB; 68 if ($GRAB) {
69 ($x, $y) = $GRAB->coord2local ($x, $y);
70 $GRAB->emit (button_down => $ev, $x, $y) || $GRAB->button_down ($ev, $x, $y);
71 }
38} 72}
39 73
40sub feed_sdl_button_up_event { 74sub feed_sdl_button_up_event {
41 my ($ev) = @_; 75 my ($ev) = @_;
42 my ($x, $y) = ($ev->{x}, $ev->{y}); 76 my ($x, $y) = ($ev->{x}, $ev->{y});
43 77
44 my $widget = $GRAB || $ROOT->find_widget ($x, $y); 78 my $widget = $GRAB || $ROOT->find_widget ($x, $y);
45 79
46 $BUTTON_STATE &= ~(1 << ($ev->{button} - 1)); 80 $BUTTON_STATE &= ~(1 << ($ev->{button} - 1));
47 81
48 $GRAB->button_up ($ev, $GRAB->coord2local ($x, $y)) if $GRAB; 82 if ($GRAB) {
83 ($x, $y) = $GRAB->coord2local ($x, $y);
84 $GRAB->emit (button_up => $ev, $x, $y) || $GRAB->button_up ($ev, $x, $y);
85 }
49 86
50 if (!$BUTTON_STATE) { 87 if (!$BUTTON_STATE) {
51 my $grab = $GRAB; undef $GRAB; 88 my $grab = $GRAB; undef $GRAB;
52 $grab->update if $grab; 89 $grab->update if $grab;
53 $GRAB->update if $GRAB; 90 $GRAB->update if $GRAB;
91
92 check_tooltip;
54 } 93 }
55} 94}
56 95
57sub feed_sdl_motion_event { 96sub feed_sdl_motion_event {
58 my ($ev) = @_; 97 my ($ev) = @_;
63 if ($widget != $HOVER) { 102 if ($widget != $HOVER) {
64 my $hover = $HOVER; $HOVER = $widget; 103 my $hover = $HOVER; $HOVER = $widget;
65 104
66 $hover->update if $hover && $hover->{can_hover}; 105 $hover->update if $hover && $hover->{can_hover};
67 $HOVER->update if $HOVER && $HOVER->{can_hover}; 106 $HOVER->update if $HOVER && $HOVER->{can_hover};
68 }
69 107
70 $HOVER->mouse_motion ($ev, $HOVER->coord2local ($x, $y)) if $HOVER; 108 check_tooltip;
109 }
110
111 if ($HOVER) {
112 ($x, $y) = $HOVER->coord2local ($x, $y);
113 $HOVER->emit (mouse_motion => $ev, $x, $y) || $HOVER->mouse_motion ($ev, $x, $y);
114 }
71} 115}
72 116
73# convert position array to integers 117# convert position array to integers
74sub harmonize { 118sub harmonize {
75 my ($vals) = @_; 119 my ($vals) = @_;
93 137
94sub new { 138sub new {
95 my $class = shift; 139 my $class = shift;
96 140
97 my $self = bless { 141 my $self = bless {
98 x => 0, 142 x => 0,
99 y => 0, 143 y => 0,
100 z => 0, 144 z => 0,
145 can_events => 1,
101 @_ 146 @_
102 }, $class; 147 }, $class;
103 148
104 for (keys %$self) { 149 for (keys %$self) {
105 if (/^connect_(.*)$/) { 150 if (/^connect_(.*)$/) {
108 } 153 }
109 154
110 $self 155 $self
111} 156}
112 157
158sub destroy {
159 my ($self) = @_;
160
161 $self->hide;
162 %$self = ();
163}
164
113sub show { 165sub show {
114 my ($self) = @_; 166 my ($self) = @_;
115 167
116 return if $self->{parent}; 168 return if $self->{parent};
117 169
119} 171}
120 172
121sub hide { 173sub hide {
122 my ($self) = @_; 174 my ($self) = @_;
123 175
124 return unless $self->{parent}; 176 undef $GRAB if $GRAB == $self;
177 undef $HOVER if $HOVER == $self;
125 178
126 $self->{parent}->remove ($self); 179 $self->{parent}->remove ($self)
180 if $self->{parent};
127} 181}
128 182
129sub move { 183sub move {
130 my ($self, $x, $y, $z) = @_; 184 my ($self, $x, $y, $z) = @_;
131 185
134 $self->{z} = $z if defined $z; 188 $self->{z} = $z if defined $z;
135 189
136 $self->update; 190 $self->update;
137} 191}
138 192
139sub needs_redraw { 193sub set_size {
140 0 194 my ($self, $w, $h) = @_;
195
196 $self->{user_w} = $w;
197 $self->{user_h} = $h;
198
199 $self->check_size;
141} 200}
142 201
143sub size_request { 202sub size_request {
144 require Carp; 203 require Carp;
145 Carp::confess "size_request is abstract"; 204 Carp::confess "size_request is abstract";
175 } 234 }
176} 235}
177 236
178sub size_allocate { 237sub size_allocate {
179 # nothing to be done 238 # nothing to be done
239}
240
241sub set_max_size {
242 my ($self, $w, $h) = @_;
243
244 delete $self->{max_w}; $self->{max_w} = $w if $w;
245 delete $self->{max_h}; $self->{max_h} = $h if $h;
180} 246}
181 247
182# return top left coordinates 248# return top left coordinates
183sub _topleft { 249sub _topleft {
184 my ($self, $x, $y) = @_; 250 my ($self, $x, $y) = @_;
267 glVertex $x + $self->{w}, $y + $self->{h}; 333 glVertex $x + $self->{w}, $y + $self->{h};
268 glVertex $x , $y + $self->{h}; 334 glVertex $x , $y + $self->{h};
269 glEnd; 335 glEnd;
270 glDisable GL_BLEND; 336 glDisable GL_BLEND;
271 } 337 }
338
339 if ($ENV{PCLIENT_DEBUG}) {
340 glPushMatrix;
341 glColor 1, 1, 0, 1;
342 glTranslate $self->{x} + 0.375, $self->{y} + 0.375;
343 glBegin GL_LINE_LOOP;
344 glVertex 0 , 0;
345 glVertex $self->{w}, 0;
346 glVertex $self->{w}, $self->{h};
347 glVertex 0 , $self->{h};
348 glEnd;
349 glPopMatrix;
350 CFClient::UI::Label->new (w => $self->{w}, h => $self->{h}, text => $self, fontsize => 0)->_draw;
351 }
272} 352}
273 353
274sub _draw { 354sub _draw {
275 my ($self) = @_; 355 my ($self) = @_;
276 356
277 warn "no draw defined for $self\n"; 357 warn "no draw defined for $self\n";
278} 358}
279 359
280sub find_widget { 360sub find_widget {
281 my ($self, $x, $y) = @_; 361 my ($self, $x, $y) = @_;
362
363 return () unless $self->{can_events};
282 364
283 return $self 365 return $self
284 if $x >= $self->{x} && $x < $self->{x} + $self->{w} 366 if $x >= $self->{x} && $x < $self->{x} + $self->{w}
285 && $y >= $self->{y} && $y < $self->{y} + $self->{h}; 367 && $y >= $self->{y} && $y < $self->{y} + $self->{h};
286 368
294} 376}
295 377
296sub check_size { 378sub check_size {
297 my ($self) = @_; 379 my ($self) = @_;
298 380
299 return unless $self->{parent}; 381 $self->{parent}
382 or return 1;
300 383
301 my ($w, $h) = $self->size_request; 384 my ($w, $h) = $self->{user_w} && $self->{user_h}
385 ? @$self{qw(user_w user_h)}
386 : $self->size_request;
302 387
303 if ($w != $self->{req_w} || $h != $self->{req_h}) { 388 if ($w != $self->{req_w} || $h != $self->{req_h}) {
304 $self->{req_w} = $w; 389 $self->{req_w} = $w;
305 $self->{req_h} = $h; 390 $self->{req_h} = $h;
306 391
307 $self->{parent}->check_size; 392 $self->{parent}->check_size
393 or $self->size_allocate (
394 (List::Util::max $self->{w}, $w),
395 (List::Util::max $self->{h}, $h),
396 );
397
398 1
399 } else {
400 0
308 } 401 }
309} 402}
310 403
311sub update { 404sub update {
312 my ($self) = @_; 405 my ($self) = @_;
322} 415}
323 416
324sub emit { 417sub emit {
325 my ($self, $signal, @args) = @_; 418 my ($self, $signal, @args) = @_;
326 419
327 for my $cb (@{$self->{signal_cb}{$signal} || []}) { 420 List::Util::sum map $_->($self, @args), @{$self->{signal_cb}{$signal} || []}
328 $cb->($self, @args);
329 }
330} 421}
331 422
332sub DESTROY { 423sub DESTROY {
333 my ($self) = @_; 424 my ($self) = @_;
334 425
379 470
380package CFClient::UI::Empty; 471package CFClient::UI::Empty;
381 472
382our @ISA = CFClient::UI::Base::; 473our @ISA = CFClient::UI::Base::;
383 474
475sub new {
476 my ($class, %arg) = @_;
477 $class->SUPER::new (can_events => 0, %arg);
478}
479
384sub size_request { 480sub size_request {
385 (0, 0) 481 (0, 0)
386} 482}
387 483
388sub draw { } 484sub draw { }
396sub new { 492sub new {
397 my ($class, %arg) = @_; 493 my ($class, %arg) = @_;
398 494
399 my $children = delete $arg{children} || []; 495 my $children = delete $arg{children} || [];
400 496
401 my $self = $class->SUPER::new (children => [], %arg); 497 my $self = $class->SUPER::new (children => [], can_events => 0, %arg);
402 $self->add ($_) for @$children; 498 $self->add ($_) for @$children;
403 499
404 $self 500 $self
405} 501}
406 502
421 517
422sub remove { 518sub remove {
423 my ($self, $child) = @_; 519 my ($self, $child) = @_;
424 520
425 delete $child->{parent}; 521 delete $child->{parent};
522 $child->hide;
426 523
427 $self->{children} = [ grep $_ != $child, @{ $self->{children} } ]; 524 $self->{children} = [ grep $_ != $child, @{ $self->{children} } ];
428 525
429 $self->check_size; 526 $self->check_size;
527 $self->update;
528}
529
530sub clear {
531 my ($self) = @_;
532
533 my $children = delete $self->{children};
534 $self->{children} = [];
535
536 for (@$children) {
537 delete $_->{parent};
538 $_->hide;
539 }
430} 540}
431 541
432sub find_widget { 542sub find_widget {
433 my ($self, $x, $y) = @_; 543 my ($self, $x, $y) = @_;
434 544
594 border => 0.8, 704 border => 0.8,
595 @_ 705 @_
596 ); 706 );
597 707
598 $self 708 $self
599}
600
601sub set_size {
602 my ($self, $w, $h) = @_;
603 $self->{req_w} = $w;
604 $self->{req_h} = $h;
605 $self->check_size;
606}
607
608sub size_request {
609 my ($self) = @_;
610 ($self->{req_w}, $self->{req_h})
611}
612
613sub size_allocate {
614 my ($self, $w, $h) = @_;
615 $self->{w} = $w;
616 $self->{h} = $h;
617 $self->child->configure (0, 0, $w, $h);
618} 709}
619 710
620sub _draw { 711sub _draw {
621 my ($self) = @_; 712 my ($self) = @_;
622 713
657 my $class = shift; 748 my $class = shift;
658 749
659 # TODO: user_x, user_y, overwrite moveto? 750 # TODO: user_x, user_y, overwrite moveto?
660 751
661 my $self = $class->SUPER::new ( 752 my $self = $class->SUPER::new (
662 bg => [1, 1, 1, 1], 753 bg => [1, 1, 1, 1],
663 border_bg => [1, 1, 1, 1], 754 border_bg => [1, 1, 1, 1],
664 border => 0.8, 755 border => 0.8,
665 @_ 756 @_
666 ); 757 );
667 758
668 $self->{title} &&= new CFClient::UI::Label 759 $self->{title} &&= new CFClient::UI::Label
669 align => 0, 760 align => 0,
679} 770}
680 771
681sub size_request { 772sub size_request {
682 my ($self) = @_; 773 my ($self) = @_;
683 774
684 return ($self->{user_w}, $self->{user_h}) if $self->{user_w} && $self->{user_h};
685
686 my ($w, $h) = $self->SUPER::size_request; 775 my ($w, $h) = $self->SUPER::size_request;
687 776
688 ( 777 (
689 $w + $self->border * 2, 778 $w + $self->border * 2,
690 $h + $self->border * 2, 779 $h + $self->border * 2,
822 911
823# TODO: move to container class maybe? send childs a signal on removal? 912# TODO: move to container class maybe? send childs a signal on removal?
824sub clear { 913sub clear {
825 my ($self) = @_; 914 my ($self) = @_;
826 915
827 delete $self->{children}; 916 my $children = delete $self->{children};
917
918 for (grep $_, map @$_, grep $_, @$children) {
919 delete $_->{parent};
920 $_->hide;
921 }
922
828 $self->update; 923 $self->update;
829} 924}
830 925
831sub get_wh { 926sub get_wh {
832 my ($self) = @_; 927 my ($self) = @_;
1055 1150
1056sub new { 1151sub new {
1057 my ($class, %arg) = @_; 1152 my ($class, %arg) = @_;
1058 1153
1059 my $self = $class->SUPER::new ( 1154 my $self = $class->SUPER::new (
1060 fg => [1, 1, 1], 1155 fg => [1, 1, 1],
1156 #font => default_font
1061 fontsize => 1, 1157 fontsize => 1,
1062 text => "", 1158 text => "",
1063 align => -1, 1159 align => -1,
1064 valign => -1, 1160 valign => -1,
1065 padding => 2, 1161 padding => 2,
1066 layout => new CFClient::Layout, 1162 layout => new CFClient::Layout,
1163 can_events => 0,
1067 %arg 1164 %arg
1068 ); 1165 );
1069 1166
1070 if (exists $self->{template}) { 1167 if (exists $self->{template}) {
1071 my $layout = new CFClient::Layout; 1168 my $layout = new CFClient::Layout;
1077 $self->set_markup (delete $self->{markup}) if exists $self->{markup}; 1174 $self->set_markup (delete $self->{markup}) if exists $self->{markup};
1078 1175
1079 $self 1176 $self
1080} 1177}
1081 1178
1082sub escape_text { 1179sub escape {
1083 local $_ = $_[1]; 1180 local $_ = $_[1];
1084 1181
1085 s/&/&amp;/g; 1182 s/&/&amp;/g;
1086 s/>/&gt;/g; 1183 s/>/&gt;/g;
1087 s/</&lt;/g; 1184 s/</&lt;/g;
1110} 1207}
1111 1208
1112sub size_request { 1209sub size_request {
1113 my ($self) = @_; 1210 my ($self) = @_;
1114 1211
1115 $self->{layout}->set_width; 1212 $self->{layout}->set_font ($self->{font}) if $self->{font};
1213 $self->{layout}->set_width ($self->{max_w} || -1);
1116 $self->{layout}->set_height ($self->{fontsize} * $::FONTSIZE); 1214 $self->{layout}->set_height ($self->{fontsize} * $::FONTSIZE);
1117 1215
1118 my ($w, $h) = $self->{layout}->size; 1216 my ($w, $h) = $self->{layout}->size;
1119 1217
1120 if (exists $self->{template}) { 1218 if (exists $self->{template}) {
1219 $self->{template}->set_font ($self->{font}) if $self->{font};
1121 $self->{template}->set_height ($self->{fontsize} * $::FONTSIZE); 1220 $self->{template}->set_height ($self->{fontsize} * $::FONTSIZE);
1122 1221
1123 my ($w2, $h2) = $self->{template}->size; 1222 my ($w2, $h2) = $self->{template}->size;
1124 1223
1125 $w = List::Util::max $w, $w2; 1224 $w = List::Util::max $w, $w2;
1140 1239
1141sub set_fontsize { 1240sub set_fontsize {
1142 my ($self, $fontsize) = @_; 1241 my ($self, $fontsize) = @_;
1143 1242
1144 $self->{fontsize} = $fontsize; 1243 $self->{fontsize} = $fontsize;
1244 delete $self->{texture};
1145 $self->check_size; 1245 $self->check_size;
1246 $self->update;
1146} 1247}
1147 1248
1148sub _draw { 1249sub _draw {
1149 my ($self) = @_; 1250 my ($self) = @_;
1150 1251
1151 my $tex = $self->{texture} ||= do { 1252 my $tex = $self->{texture} ||= do {
1253 $self->{layout}->set_font ($self->{font}) if $self->{font};
1152 $self->{layout}->set_width ($self->{w}); 1254 $self->{layout}->set_width ($self->{w});
1153 $self->{layout}->set_height (List::Util::min $self->{h}, $self->{fontsize} * $::FONTSIZE); 1255 $self->{layout}->set_height (List::Util::min $self->{h}, $self->{fontsize} * $::FONTSIZE);
1154 new_from_layout CFClient::Texture $self->{layout} 1256 new_from_layout CFClient::Texture $self->{layout}
1155 }; 1257 };
1156 1258
1189 1291
1190sub new { 1292sub new {
1191 my $class = shift; 1293 my $class = shift;
1192 1294
1193 $class->SUPER::new ( 1295 $class->SUPER::new (
1194 fg => [1, 1, 1], 1296 fg => [1, 1, 1],
1195 bg => [0, 0, 0, 0.2], 1297 bg => [0, 0, 0, 0.2],
1196 active_bg => [1, 1, 1, 0.5], 1298 active_bg => [1, 1, 1, 0.5],
1197 active_fg => [0, 0, 0], 1299 active_fg => [0, 0, 0],
1198 can_hover => 1, 1300 can_hover => 1,
1199 can_focus => 1, 1301 can_focus => 1,
1200 valign => 0, 1302 valign => 0,
1303 can_events => 1,
1201 @_ 1304 @_
1202 ) 1305 )
1203} 1306}
1204 1307
1205sub _set_text { 1308sub _set_text {
1383 1486
1384sub new { 1487sub new {
1385 my $class = shift; 1488 my $class = shift;
1386 1489
1387 $class->SUPER::new ( 1490 $class->SUPER::new (
1388 padding => 4, 1491 padding => 4,
1389 fg => [1, 1, 1], 1492 fg => [1, 1, 1],
1390 bg => [1, 1, 1, 0.2], 1493 bg => [1, 1, 1, 0.2],
1391 active_fg => [0, 0, 1], 1494 active_fg => [0, 0, 1],
1392 can_hover => 1, 1495 can_hover => 1,
1393 align => 0, 1496 align => 0,
1394 valign => 0, 1497 valign => 0,
1498 can_events => 1,
1395 @_ 1499 @_
1396 ) 1500 )
1397} 1501}
1398 1502
1399sub button_up { 1503sub button_up {
1504our %loaded_images; 1608our %loaded_images;
1505 1609
1506sub new { 1610sub new {
1507 my $class = shift; 1611 my $class = shift;
1508 1612
1509 my $self = $class->SUPER::new (@_); 1613 my $self = $class->SUPER::new (can_events => 0, @_);
1510 1614
1511 $self->{image} or confess "Image has 'image' not set. This is a fatal error!"; 1615 $self->{image} or confess "Image has 'image' not set. This is a fatal error!";
1512 1616
1513 $loaded_images{$self->{image}} ||= 1617 $loaded_images{$self->{image}} ||=
1514 new_from_file CFClient::Texture CFClient::find_rcfile $self->{image}, mipmap => 1; 1618 new_from_file CFClient::Texture CFClient::find_rcfile $self->{image}, mipmap => 1;
1556############################################################################# 1660#############################################################################
1557 1661
1558package CFClient::UI::VGauge; 1662package CFClient::UI::VGauge;
1559 1663
1560our @ISA = CFClient::UI::Base::; 1664our @ISA = CFClient::UI::Base::;
1665
1666use List::Util qw(min max);
1561 1667
1562use CFClient::OpenGL; 1668use CFClient::OpenGL;
1563 1669
1564my %tex = ( 1670my %tex = (
1565 food => [ 1671 food => [
1566 map { new_from_file CFClient::Texture CFClient::find_rcfile $_, mipmap => 1 } 1672 map { new_from_file CFClient::Texture CFClient::find_rcfile $_, mipmap => 1 }
1567 qw/g1_food_gauge_empty.png g1_food_gauge_full.png/ 1673 qw/g1_food_gauge_empty.png g1_food_gauge_full.png/
1568 ], 1674 ],
1569 grace => [ 1675 grace => [
1570 map { new_from_file CFClient::Texture CFClient::find_rcfile $_, mipmap => 1 } 1676 map { new_from_file CFClient::Texture CFClient::find_rcfile $_, mipmap => 1 }
1571 qw/g1_grace_gauge_empty.png g1_grace_gauge_full.png/ 1677 qw/g1_grace_gauge_empty.png g1_grace_gauge_full.png g1_grace_gauge_overflow.png/
1572 ], 1678 ],
1573 hp => [ 1679 hp => [
1574 map { new_from_file CFClient::Texture CFClient::find_rcfile $_, mipmap => 1 } 1680 map { new_from_file CFClient::Texture CFClient::find_rcfile $_, mipmap => 1 }
1575 qw/g1_hp_gauge_empty.png g1_hp_gauge_full.png/ 1681 qw/g1_hp_gauge_empty.png g1_hp_gauge_full.png/
1576 ], 1682 ],
1577 mana => [ 1683 mana => [
1578 map { new_from_file CFClient::Texture CFClient::find_rcfile $_, mipmap => 1 } 1684 map { new_from_file CFClient::Texture CFClient::find_rcfile $_, mipmap => 1 }
1579 qw/g1_mana_gauge_empty.png g1_mana_gauge_full.png/ 1685 qw/g1_mana_gauge_empty.png g1_mana_gauge_full.png g1_mana_gauge_overflow.png/
1580 ], 1686 ],
1581); 1687);
1582 1688
1583# eg. VGauge->new (gauge => 'food'), default gauge: food 1689# eg. VGauge->new (gauge => 'food'), default gauge: food
1584sub new { 1690sub new {
1622 1728
1623sub _draw { 1729sub _draw {
1624 my ($self) = @_; 1730 my ($self) = @_;
1625 1731
1626 my $tex = $tex{$self->{type}}; 1732 my $tex = $tex{$self->{type}};
1733 my ($t1, $t2, $t3) = @$tex;
1627 1734
1628 my ($w, $h) = ($self->{w}, $self->{h}); 1735 my ($w, $h) = ($self->{w}, $self->{h});
1629 1736
1630 if ($self->{vertical}) { 1737 if ($self->{vertical}) {
1631 glRotate 90, 0, 0, 1; 1738 glRotate 90, 0, 0, 1;
1633 1740
1634 ($w, $h) = ($h, $w); 1741 ($w, $h) = ($h, $w);
1635 } 1742 }
1636 1743
1637 my $ycut = $self->{val} / ($self->{max_val} || 1); 1744 my $ycut = $self->{val} / ($self->{max_val} || 1);
1638 $ycut = 1 if $self->{val} > $self->{max_val};
1639 1745
1640 my $t1 = $tex->[0]; 1746 my $ycut1 = max 0, min 1, $ycut;
1641 my $t2 = $tex->[1]; 1747 my $ycut2 = max 0, min 1, $ycut - 1;
1748
1749 my $h1 = $self->{h} * (1 - $ycut1);
1750 my $h2 = $self->{h} * (1 - $ycut2);
1642 1751
1643 glEnable GL_BLEND; 1752 glEnable GL_BLEND;
1644 glBlendFunc GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA; 1753 glBlendFunc GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA;
1645 glEnable GL_TEXTURE_2D; 1754 glEnable GL_TEXTURE_2D;
1646 glTexEnv GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_REPLACE; 1755 glTexEnv GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_REPLACE;
1647 1756
1648 my $h1 = $self->{h} - $ycut * $self->{h};
1649 my $h2 = $ycut * $self->{h};
1650
1651 glBindTexture GL_TEXTURE_2D, $t1->{name}; 1757 glBindTexture GL_TEXTURE_2D, $t1->{name};
1652 glBegin GL_QUADS; 1758 glBegin GL_QUADS;
1653 glTexCoord 0 , 0; glVertex 0 , 0; 1759 glTexCoord 0 , 0; glVertex 0 , 0;
1654 glTexCoord 0 , $t1->{t} * (1 - $ycut); glVertex 0 , $h1; 1760 glTexCoord 0 , $t1->{t} * (1 - $ycut1); glVertex 0 , $h1;
1655 glTexCoord $t1->{s}, $t1->{t} * (1 - $ycut); glVertex $w, $h1; 1761 glTexCoord $t1->{s}, $t1->{t} * (1 - $ycut1); glVertex $w, $h1;
1656 glTexCoord $t1->{s}, 0; glVertex $w, 0; 1762 glTexCoord $t1->{s}, 0; glVertex $w, 0;
1657 glEnd; 1763 glEnd;
1658 1764
1765 my $ycut1 = List::Util::min 1, $ycut;
1659 glBindTexture GL_TEXTURE_2D, $t2->{name}; 1766 glBindTexture GL_TEXTURE_2D, $t2->{name};
1660 glBegin GL_QUADS; 1767 glBegin GL_QUADS;
1661 glTexCoord 0 , $t2->{t} * (1 - $ycut); glVertex 0 , $h1; 1768 glTexCoord 0 , $t2->{t} * (1 - $ycut1); glVertex 0 , $h1;
1662 glTexCoord 0 , $t2->{t}; glVertex 0 , $h1 + $h2; 1769 glTexCoord 0 , $t2->{t} * (1 - $ycut2); glVertex 0 , $h2;
1663 glTexCoord $t2->{s}, $t2->{t}; glVertex $w, $h1 + $h2; 1770 glTexCoord $t2->{s}, $t2->{t} * (1 - $ycut2); glVertex $w, $h2;
1664 glTexCoord $t2->{s}, $t2->{t} * (1 - $ycut); glVertex $w, $h1; 1771 glTexCoord $t2->{s}, $t2->{t} * (1 - $ycut1); glVertex $w, $h1;
1665 glEnd; 1772 glEnd;
1773
1774 if ($t3) {
1775 glBindTexture GL_TEXTURE_2D, $t3->{name};
1776 glBegin GL_QUADS;
1777 glTexCoord 0 , $t3->{t} * (1 - $ycut2); glVertex 0 , $h2;
1778 glTexCoord 0 , $t3->{t}; glVertex 0 , $self->{h};
1779 glTexCoord $t3->{s}, $t3->{t}; glVertex $w, $self->{h};
1780 glTexCoord $t3->{s}, $t3->{t} * (1 - $ycut2); glVertex $w, $h2;
1781 glEnd;
1782 }
1666 1783
1667 glDisable GL_BLEND; 1784 glDisable GL_BLEND;
1668 glDisable GL_TEXTURE_2D; 1785 glDisable GL_TEXTURE_2D;
1669} 1786}
1670 1787
1673package CFClient::UI::Gauge; 1790package CFClient::UI::Gauge;
1674 1791
1675our @ISA = CFClient::UI::VBox::; 1792our @ISA = CFClient::UI::VBox::;
1676 1793
1677sub new { 1794sub new {
1678 my ($class, %arg) = shift; 1795 my ($class, %arg) = @_;
1679 1796
1680 my $self = $class->SUPER::new ( 1797 my $self = $class->SUPER::new (
1681 @_, 1798 tooltip => $arg{type},
1799 can_hover => 1,
1800 %arg,
1682 ); 1801 );
1683 1802
1684 $self->add ($self->{value} = new CFClient::UI::Label valign => 1, align => 0, template => "999"); 1803 $self->add ($self->{value} = new CFClient::UI::Label valign => +1, align => 0, template => "999");
1685 $self->add ($self->{gauge} = new CFClient::UI::VGauge type => $self->{type}, expand => 1); 1804 $self->add ($self->{gauge} = new CFClient::UI::VGauge type => $self->{type}, expand => 1, can_hover => 1);
1686 $self->add ($self->{max} = new CFClient::UI::Label valign => 1, align => 0, template => "999"); 1805 $self->add ($self->{max} = new CFClient::UI::Label valign => -1, align => 0, template => "999");
1687 1806
1688 $self 1807 $self
1689} 1808}
1690 1809
1691sub set_fontsize { 1810sub set_fontsize {
1857 1976
1858sub new { 1977sub new {
1859 my $class = shift; 1978 my $class = shift;
1860 1979
1861 my $self = $class->SUPER::new ( 1980 my $self = $class->SUPER::new (
1862 fontsize => 1, 1981 fontsize => 1,
1982 can_events => 0,
1983 #font => default_font
1863 @_, 1984 @_,
1864 1985
1865 layout => (new CFClient::Layout), 1986 layout => (new CFClient::Layout),
1866 par => [], 1987 par => [],
1867 height => 0, 1988 height => 0,
1868 children => [ 1989 children => [
1869 (new CFClient::UI::Empty expand => 1), 1990 (new CFClient::UI::Empty expand => 1),
1870 (new CFClient::UI::Slider vertical => 1), 1991 (new CFClient::UI::Slider vertical => 1),
1871 ], 1992 ],
1872 ); 1993 );
1873 1994
1907sub size_allocate { 2028sub size_allocate {
1908 my ($self, $w, $h) = @_; 2029 my ($self, $w, $h) = @_;
1909 2030
1910 $self->SUPER::size_allocate ($w, $h); 2031 $self->SUPER::size_allocate ($w, $h);
1911 2032
2033 $self->{layout}->set_font ($self->{font}) if $self->{font};
1912 $self->{layout}->set_height ($self->{fontsize} * $::FONTSIZE); 2034 $self->{layout}->set_height ($self->{fontsize} * $::FONTSIZE);
1913 $self->{layout}->set_width ($self->{children}[0]{w}); 2035 $self->{layout}->set_width ($self->{children}[0]{w});
1914 2036
1915 $self->reflow; 2037 $self->reflow;
1916} 2038}
1968 my $y1 = $top + $self->{h}; 2090 my $y1 = $top + $self->{h};
1969 2091
1970 my $y = 0; 2092 my $y = 0;
1971 2093
1972 my $layout = $self->{layout}; 2094 my $layout = $self->{layout};
2095
2096 $layout->set_font ($self->{font}) if $self->{font};
1973 2097
1974 for my $par (@{$self->{par}}) { 2098 for my $par (@{$self->{par}}) {
1975 my $h = $par->[0]; 2099 my $h = $par->[0];
1976 2100
1977 if ($y0 < $y + $h && $y < $y1) { 2101 if ($y0 < $y + $h && $y < $y1) {
2055 2179
2056sub new { 2180sub new {
2057 my $class = shift; 2181 my $class = shift;
2058 2182
2059 my $self = $class->SUPER::new ( 2183 my $self = $class->SUPER::new (
2060 state => 0, 2184 state => 0,
2061 connect_activate => \&toggle_flopper, 2185 connect_activate => \&toggle_flopper,
2062 @_ 2186 @_
2063 ); 2187 );
2064 2188
2065 if ($self->{state}) { 2189 if ($self->{state}) {
2086 $self->emit (changed => $self->{state}); 2210 $self->emit (changed => $self->{state});
2087} 2211}
2088 2212
2089############################################################################# 2213#############################################################################
2090 2214
2215package CFClient::UI::Tooltip;
2216
2217our @ISA = CFClient::UI::Bin::;
2218
2219use CFClient::OpenGL;
2220
2221sub new {
2222 my $class = shift;
2223
2224 $class->SUPER::new (
2225 @_,
2226 can_events => 0,
2227 )
2228}
2229
2230sub set_markup {
2231 my ($self, $text) = @_;
2232
2233 $self->{label} ||= new CFClient::UI::Label fontsize => 0.8, fg => [0, 0, 0];
2234 $self->{label}->set_markup ($text);
2235 $self->add ($self->{label});
2236}
2237
2238sub size_request {
2239 my ($self) = @_;
2240
2241 $self->child->set_max_size ($::WIDTH * 0.3);
2242
2243 my ($w, $h) = @{$self->child}{qw(req_w req_h)};
2244
2245 ($w + 4, $h + 4)
2246}
2247
2248sub size_allocate {
2249 my ($self, $w, $h) = @_;
2250
2251 $self->SUPER::size_allocate ($w - 4, $h - 4);
2252}
2253
2254sub _draw {
2255 my ($self) = @_;
2256
2257 glPushMatrix;
2258 glTranslate 0.375, 0.375;
2259
2260 my ($w, $h) = @$self{qw(w h)};
2261
2262 glColor 1, 0.8, 0.4;
2263 glBegin GL_QUADS;
2264 glVertex 0 , 0;
2265 glVertex 0 , $h;
2266 glVertex $w, $h;
2267 glVertex $w, 0;
2268 glEnd;
2269
2270 glColor 0, 0, 0;
2271 glBegin GL_LINE_LOOP;
2272 glVertex 0 , 0;
2273 glVertex 0 , $h;
2274 glVertex $w, $h;
2275 glVertex $w, 0;
2276 glEnd;
2277
2278 glPopMatrix;
2279
2280 glTranslate 2, 2;
2281 $self->SUPER::_draw;
2282}
2283
2284#############################################################################
2285
2286package CFClient::UI::Face;
2287
2288our @ISA = CFClient::UI::Base::;
2289
2290use CFClient::OpenGL;
2291
2292sub new {
2293 my $class = shift;
2294
2295 $class->SUPER::new (
2296 aspect => 1,
2297 @_,
2298 )
2299}
2300
2301sub size_request {
2302 (32, 8)
2303}
2304
2305sub draw {
2306 my ($self) = @_;
2307
2308 my $tex = $::CONN->{texture}[$::CONN->{faceid}[$self->{face}]];
2309
2310 if ($tex) {
2311 glEnable GL_BLEND;
2312 glBlendFunc GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA;
2313 glEnable GL_TEXTURE_2D;
2314 glTexEnv GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_REPLACE;
2315 glColor 1, 1, 1, 1;
2316 $tex->draw_quad (0, 0, $self->{w}, $self->{h});
2317 glDisable GL_TEXTURE_2D;
2318 glDisable GL_BLEND;
2319 }
2320}
2321
2322#############################################################################
2323
2091package CFClient::UI::Root; 2324package CFClient::UI::Root;
2092 2325
2093our @ISA = CFClient::UI::Container::; 2326our @ISA = CFClient::UI::Container::;
2094 2327
2095use CFClient::OpenGL; 2328use CFClient::OpenGL;
2170############################################################################# 2403#############################################################################
2171 2404
2172package CFClient::UI; 2405package CFClient::UI;
2173 2406
2174$ROOT = new CFClient::UI::Root; 2407$ROOT = new CFClient::UI::Root;
2408$TOOLTIP = new CFClient::UI::Tooltip;
2175 2409
21761 24101
2177 2411

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines