… | |
… | |
19 | my $new; |
19 | my $new; |
20 | |
20 | |
21 | my $name = $ws->{ns}->pl->ob->name; |
21 | my $name = $ws->{ns}->pl->ob->name; |
22 | |
22 | |
23 | while (my ($k, $v) = each %PLAYERINFO) { |
23 | while (my ($k, $v) = each %PLAYERINFO) { |
24 | my $label = $old->{$k} || do { |
24 | my $label = (delete $old->{$k}) || do { |
25 | my $label = $ws->new (Label => |
25 | my $label = $ws->new (Label => |
26 | text => $k, |
26 | text => $k, |
27 | fontsize => 0.2, |
27 | fontsize => 0.2, |
|
|
28 | ); |
|
|
29 | |
|
|
30 | my $marker = $ws->new (Face => |
|
|
31 | face => $ws->{ns}->need_face ("res/map-arrow"), |
|
|
32 | ); |
|
|
33 | my $children = [$label, $marker]; |
|
|
34 | |
|
|
35 | $ws->{canvas}->add (my $vbox = $ws->new (VBox => |
|
|
36 | children => $children, |
28 | c_halign => -.5, |
37 | c_halign => -.5, |
29 | c_valign => -1, |
38 | c_valign => -1, |
30 | ); |
39 | )); |
31 | $ws->{canvas}->add ($label); |
40 | $vbox->{children} = $children; |
|
|
41 | |
32 | $label |
42 | $vbox |
33 | }; |
43 | }; |
34 | |
44 | |
35 | $new->{$k} = $label; |
45 | $new->{$k} = $label; |
36 | |
46 | |
37 | if ($v != $label->{prevpos}) { |
47 | if ($v != $label->{prevpos}) { |
… | |
… | |
63 | $_[0]{visibility} = $_[1]; |
73 | $_[0]{visibility} = $_[1]; |
64 | update_worldmap $_[0]{ws} if $_[1]; |
74 | update_worldmap $_[0]{ws} if $_[1]; |
65 | }, |
75 | }, |
66 | ); |
76 | ); |
67 | |
77 | |
68 | my $face = cf::face::find "res/worldmap.jpg"; |
|
|
69 | $ns->send_face ($face); |
|
|
70 | $ns->flush_fx; |
|
|
71 | |
|
|
72 | $w->add (my $sw = $ws->{window} = $ws->new (ScrolledWindow => scroll_x => 1, scroll_y => 1)); |
78 | $w->add (my $sw = $ws->{window} = $ws->new (ScrolledWindow => scroll_x => 1, scroll_y => 1)); |
73 | $sw->add (my $canvas = $ws->{canvas} = $ws->new (Canvas => expand => 1)); |
79 | $sw->add (my $canvas = $ws->{canvas} = $ws->new (Canvas => expand => 1)); |
74 | |
80 | |
75 | $ws->{mapface} = $ws->new (Face => |
81 | $ws->{mapface} = $ws->new (Face => |
76 | expand => 1, |
|
|
77 | size_w => undef, |
82 | size_w => undef, |
78 | size_h => undef, |
83 | size_h => undef, |
79 | face => $face, |
84 | face => $ws->{ns}->need_face ("res/worldmap"), |
80 | ); |
85 | ); |
81 | |
86 | |
82 | $ws->{canvas}->add ($ws->{mapface}); |
87 | $ws->{canvas}->add ($ws->{mapface}); |
83 | |
88 | |
84 | $ws |
89 | $ws |
… | |
… | |
92 | |
97 | |
93 | if ($ns->{can_widget}) { |
98 | if ($ns->{can_widget}) { |
94 | my $ws = $ns->{ws_worldmap} ||= create_widgets $ns; |
99 | my $ws = $ns->{ws_worldmap} ||= create_widgets $ns; |
95 | $ws->{toplevel}->toggle_visibility; |
100 | $ws->{toplevel}->toggle_visibility; |
96 | } else { |
101 | } else { |
97 | $ns->send_msg ("log", "Your client doesn't support the (required) widget extension. Try CFPlus at http://crossfire.schmorp.de/.", cf::NDI_RED); |
102 | $ns->send_msg ("log", "Your client doesn't support the (required) widget extension. Try the deliantra client at http://www.deliantra.net/.", cf::NDI_RED); |
98 | } |
103 | } |
99 | |
104 | |
100 | cf::override 1; |
105 | cf::override 1; |
101 | }, |
106 | }, |
102 | ; |
107 | ; |
103 | |
108 | |
104 | cf::async_ext { |
109 | cf::async_ext { |
105 | my $schedule_interval = Coro::Event->timer (after => 1); |
110 | $Coro::current->{desc} = "worldmap updater"; |
106 | |
111 | |
107 | while () { |
112 | while () { |
108 | $schedule_interval->interval ($WORLDMAP_UPDATE_INTERVAL); |
113 | Coro::EV::timer_once $WORLDMAP_UPDATE_INTERVAL; |
109 | $schedule_interval->next; |
|
|
110 | |
114 | |
111 | cf::get_slot 0.01, -50, "worldmap update"; |
115 | cf::get_slot 0.01, -50, "worldmap update"; |
112 | |
116 | |
113 | ++$GENCOUNT; |
117 | ++$GENCOUNT; |
114 | |
118 | |