… | |
… | |
56 | sub button_down { |
56 | sub button_down { |
57 | my ($self, $ev, $x, $y) = @_; |
57 | my ($self, $ev, $x, $y) = @_; |
58 | |
58 | |
59 | $self->focus_in; |
59 | $self->focus_in; |
60 | |
60 | |
61 | if ($ev->{button} == 2) { |
61 | if ($ev->{button} == 1) { |
|
|
62 | my $sw = int $::WIDTH / (32 * $::CFG->{map_scale}) + 0.99; |
|
|
63 | my $sh = int $::HEIGHT / (32 * $::CFG->{map_scale}) + 0.99; |
|
|
64 | |
|
|
65 | my $fx = int +($ev->{x} - $::CFG->{map_shift_x}) / (32 * $::CFG->{map_scale}) - 0.5 * $sw + 0.99; |
|
|
66 | my $fy = int +($ev->{y} - $::CFG->{map_shift_y}) / (32 * $::CFG->{map_scale}) - 0.5 * $sh + 0.99; |
|
|
67 | |
|
|
68 | $::CONN->send (sprintf "lookat %d %d", $fx, $fy); |
|
|
69 | |
|
|
70 | } elsif ($ev->{button} == 2) { |
62 | my ($ox, $oy) = ($ev->{x}, $ev->{y}); |
71 | my ($ox, $oy) = ($ev->{x}, $ev->{y}); |
63 | my ($bw, $bh) = ($::CFG->{map_shift_x}, $::CFG->{map_shift_y}); |
72 | my ($bw, $bh) = ($::CFG->{map_shift_x}, $::CFG->{map_shift_y}); |
64 | |
73 | |
65 | $self->{motion} = sub { |
74 | $self->{motion} = sub { |
66 | my ($ev, $x, $y) = @_; |
75 | my ($ev, $x, $y) = @_; |
… | |
… | |
70 | $::CFG->{map_shift_x} = $bw + $x - $ox; |
79 | $::CFG->{map_shift_x} = $bw + $x - $ox; |
71 | $::CFG->{map_shift_y} = $bh + $y - $oy; |
80 | $::CFG->{map_shift_y} = $bh + $y - $oy; |
72 | |
81 | |
73 | $self->update; |
82 | $self->update; |
74 | }; |
83 | }; |
75 | } elsif ($ev->{button} == 1) { |
|
|
76 | my ($ox, $oy) = ($ev->{x}, $ev->{y}); |
|
|
77 | |
|
|
78 | my $fx = int ((($ev->{x} - $::CFG->{map_shift_x}) / (32 * $::CFG->{map_scale})) + 0.99); |
|
|
79 | my $fy = int ((($ev->{y} - $::CFG->{map_shift_y}) / (32 * $::CFG->{map_scale})) + 0.99); |
|
|
80 | $fx += $::MAP->x; |
|
|
81 | $fy += $::MAP->y; |
|
|
82 | |
|
|
83 | $::CONN->send (sprintf "lookat %d %d", $fx, $fy); |
|
|
84 | |
|
|
85 | warn "FOOX: $fx (".$::MAP->ox.")\n"; |
|
|
86 | warn "FOOY: $fy (".$::MAP->oy.")\n"; |
|
|
87 | } |
84 | } |
88 | |
85 | |
89 | 1 |
86 | 1 |
90 | } |
87 | } |
91 | |
88 | |