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.235 by root, Thu May 25 16:35:42 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
2747 $self->{scrolled}->add (1, $row, $item->{desc_widget}); 2762 $self->{scrolled}->add (1, $row, $item->{desc_widget});
2748 $self->{scrolled}->add (2, $row, $item->{weight_widget}); 2763 $self->{scrolled}->add (2, $row, $item->{weight_widget});
2749 2764
2750 $row++; 2765 $row++;
2751 } 2766 }
2752
2753# $range->{range} = [$self->{pos}, 0, $self->{max_pos}, $page];
2754} 2767}
2755 2768
2756sub size_request { 2769sub size_request {
2757 my ($self) = @_; 2770 my ($self) = @_;
2758 ($self->{req_w}, $self->{req_h}); 2771 ($self->{req_w}, $self->{req_h});

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines