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.234 by root, Thu May 25 16:24:44 2006 UTC vs.
Revision 1.239 by root, Thu May 25 22:29:57 2006 UTC

458sub set_parent { 458sub set_parent {
459 my ($self, $parent) = @_; 459 my ($self, $parent) = @_;
460 460
461 Scalar::Util::weaken ($self->{parent} = $parent); 461 Scalar::Util::weaken ($self->{parent} = $parent);
462 462
463 $self->{root} = $parent->{root};
464 $self->{visible} = $parent->{visible};
465
463 # TODO: req_w _does_change after ->reconfigure 466 # TODO: req_w _does_change after ->reconfigure
464 $self->check_size 467 $self->check_size
465 unless exists $self->{req_w}; 468 unless exists $self->{req_w};
466 469
467 $self->show; 470 $self->show;
618 delete $child->{parent}; 621 delete $child->{parent};
619 $child->hide; 622 $child->hide;
620 623
621 $self->{children} = [ grep $_ != $child, @{ $self->{children} } ]; 624 $self->{children} = [ grep $_ != $child, @{ $self->{children} } ];
622 625
623 $self->check_size; 626 $self->check_size (1);
624 $self->update; 627 $self->update;
625} 628}
626 629
627sub clear { 630sub clear {
628 my ($self) = @_; 631 my ($self) = @_;
871 $self->{vp}->add ($self->{scrolled}); 874 $self->{vp}->add ($self->{scrolled});
872 $self->add ($self->{vp}); 875 $self->add ($self->{vp});
873 $self->add ($self->{slider}); 876 $self->add ($self->{slider});
874 877
875 $self 878 $self
879}
880
881sub update {
882 my ($self) = @_;
883
884 $self->SUPER::update;
885
886 # todo: overwrite size_allocate of child
887 my $child = $self->{vp}->child;
888 $self->{slider}->set_range ([$self->{slider}{range}[0], 0, $child->{h}, $self->{vp}{h}, 1]);
876} 889}
877 890
878sub size_allocate { 891sub size_allocate {
879 my ($self, $w, $h) = @_; 892 my ($self, $w, $h) = @_;
880 893
1101 col_expand => [], 1114 col_expand => [],
1102 @_, 1115 @_,
1103 ) 1116 )
1104} 1117}
1105 1118
1119sub children {
1120 grep $_, map @$_, grep $_, @{ $_[0]{children} }
1121}
1122
1106sub add { 1123sub add {
1107 my ($self, $x, $y, $child) = @_; 1124 my ($self, $x, $y, $child) = @_;
1108 1125
1109 $child->set_parent ($self); 1126 $child->set_parent ($self);
1110 $self->{children}[$y][$x] = $child; 1127 $self->{children}[$y][$x] = $child;
1111 1128
1112 $child->check_size; 1129 $self->check_size (1);
1113} 1130}
1114 1131
1115sub children {
1116 grep $_, map @$_, grep $_, @{ $_[0]{children} }
1117}
1118
1119# TODO: move to container class maybe? send childs a signal on removal? 1132# TODO: move to container class maybe? send children a signal on removal?
1120sub clear { 1133sub clear {
1121 my ($self) = @_; 1134 my ($self) = @_;
1122 1135
1123 my @children = $self->children; 1136 my @children = $self->children;
1124 delete $self->{children}; 1137 delete $self->{children};
1126 for (@children) { 1139 for (@children) {
1127 delete $_->{parent}; 1140 delete $_->{parent};
1128 $_->hide; 1141 $_->hide;
1129 } 1142 }
1130 1143
1144 $self->check_size (1);
1131 $self->update; 1145 $self->update;
1132} 1146}
1133 1147
1134sub get_wh { 1148sub get_wh {
1135 my ($self) = @_; 1149 my ($self) = @_;
1167sub size_allocate { 1181sub size_allocate {
1168 my ($self, $w, $h) = @_; 1182 my ($self, $w, $h) = @_;
1169 1183
1170 my ($ws, $hs) = $self->get_wh; 1184 my ($ws, $hs) = $self->get_wh;
1171 1185
1172 my $req_w = sum @$ws; 1186 my $req_w = (sum @$ws) || 1;
1173 my $req_h = sum @$hs; 1187 my $req_h = (sum @$hs) || 1;
1174 1188
1175 # TODO: nicer code && do row_expand 1189 # TODO: nicer code && do row_expand
1176 my @col_expand = @{$self->{col_expand}}; 1190 my @col_expand = @{$self->{col_expand}};
1177 @col_expand = (1) x @$ws unless @col_expand; 1191 @col_expand = (1) x @$ws unless @col_expand;
1178 my $col_expand = (sum @col_expand) || 1; 1192 my $col_expand = (sum @col_expand) || 1;
2132} 2146}
2133 2147
2134sub set_range { 2148sub set_range {
2135 my ($self, $range) = @_; 2149 my ($self, $range) = @_;
2136 2150
2137 $self->{range} = $range; 2151 ($range, $self->{range}) = ($self->{range}, $range);
2138 2152
2139 $self->update; 2153 $self->update
2154 if "@$range" ne "@{$self->{range}}";
2140} 2155}
2141 2156
2142sub set_value { 2157sub set_value {
2143 my ($self, $value) = @_; 2158 my ($self, $value) = @_;
2144 2159
2709 $self->SUPER::DESTROY; 2724 $self->SUPER::DESTROY;
2710} 2725}
2711 2726
2712############################################################################# 2727#############################################################################
2713 2728
2714package CFClient::UI::InventoryItem;
2715
2716our @ISA = CFClient::UI::HBox::;
2717
2718sub new {
2719 my $class = shift;
2720
2721 my %args = @_;
2722
2723 my $item = delete $args{item};
2724
2725 my $desc = CFClient::Item::desc_string $item;
2726
2727 my $self = $class->SUPER::new (
2728 can_hover => 1,
2729 can_events => 1,
2730 tooltip => ((CFClient::UI::Label::escape $desc)
2731 . "\n<small>leftclick - examine\nshift+leftclick - move/pickup/drop\nmiddle click - apply\nrightclick - menu</small>"),
2732 connect_button_down => sub {
2733 my ($self, $ev, $x, $y) = @_;
2734
2735 # todo: maybe put examine on 1? but should just be a tooltip :(
2736 if (($ev->{mod} & CFClient::KMOD_SHIFT) && $ev->{button} == 1) {
2737 my $targ = $::CONN->{player}{tag};
2738
2739 if ($item->{container} == $::CONN->{player}{tag}) {
2740 $targ = $main::OPENCONT;
2741 }
2742
2743 $::CONN->send ("move $targ $item->{tag} 0");
2744 } elsif ($ev->{button} == 1) {
2745 $::CONN->send ("examine $item->{tag}");
2746 } elsif ($ev->{button} == 2) {
2747 $::CONN->send ("apply $item->{tag}");
2748 } elsif ($ev->{button} == 3) {
2749 my @menu_items = (
2750 ["examine", sub { $::CONN->send ("examine $item->{tag}") }],
2751 ["mark", sub { $::CONN->send ("mark ". pack "N", $item->{tag}) }],
2752 ["apply", sub { $::CONN->send ("apply $item->{tag}") }],
2753 (
2754 $item->{flags} & Crossfire::Protocol::F_LOCKED
2755 ? (
2756 ["unlock", sub { $::CONN->send ("lock " . pack "CN", 0, $item->{tag}) }],
2757 )
2758 : (
2759 ["lock", sub { $::CONN->send ("lock " . pack "CN", 1, $item->{tag}) }],
2760 ["drop", sub { $::CONN->send ("move $main::OPENCONT $item->{tag} 0") }],
2761 )
2762 ),
2763 );
2764
2765 CFClient::UI::Menu->new (items => \@menu_items)->popup ($ev);
2766 }
2767
2768 1
2769 },
2770 %args
2771 );
2772
2773
2774 $self->add (new CFClient::UI::Face
2775 can_events => 0,
2776 face => $item->{face},
2777 anim => $item->{anim},
2778 animspeed => $item->{animspeed},
2779 );
2780
2781 $self->add ($self->{name_lbl} = new CFClient::UI::Label can_events => 0);
2782
2783 $self->{item} = $item;
2784
2785 $self->update_item;
2786
2787 $self
2788}
2789
2790sub update_item {
2791 my ($self) = @_;
2792
2793 my $desc = CFClient::Item::desc_string ($self->{item});
2794
2795 $self->{name_lbl}->set_text ($desc);
2796}
2797
2798#############################################################################
2799
2800package CFClient::UI::Inventory; 2729package CFClient::UI::Inventory;
2801 2730
2802our @ISA = CFClient::UI::ScrolledWindow::; 2731our @ISA = CFClient::UI::ScrolledWindow::;
2803 2732
2804sub new { 2733sub new {
2833 $self->{scrolled}->add (1, $row, $item->{desc_widget}); 2762 $self->{scrolled}->add (1, $row, $item->{desc_widget});
2834 $self->{scrolled}->add (2, $row, $item->{weight_widget}); 2763 $self->{scrolled}->add (2, $row, $item->{weight_widget});
2835 2764
2836 $row++; 2765 $row++;
2837 } 2766 }
2838
2839# $range->{range} = [$self->{pos}, 0, $self->{max_pos}, $page];
2840} 2767}
2841 2768
2842sub size_request { 2769sub size_request {
2843 my ($self) = @_; 2770 my ($self) = @_;
2844 ($self->{req_w}, $self->{req_h}); 2771 ($self->{req_w}, $self->{req_h});

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines