ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/deliantra/Deliantra-Client/bin/cfplus
(Generate patch)

Comparing deliantra/Deliantra-Client/bin/cfplus (file contents):
Revision 1.13 by root, Fri May 26 20:50:35 2006 UTC vs.
Revision 1.33 by root, Tue May 30 07:13:09 2006 UTC

81our $LOGVIEW; 81our $LOGVIEW;
82our $CONSOLE; 82our $CONSOLE;
83our $METASERVER; 83our $METASERVER;
84our $LOGIN_BUTTON; 84our $LOGIN_BUTTON;
85our $QUIT_DIALOG; 85our $QUIT_DIALOG;
86our $SERVER_SETUP;
86 87
87our $FLOORBOX; 88our $FLOORBOX;
88our $GAUGES; 89our $GAUGES;
89our $STATWIDS; 90our $STATWIDS;
90 91
97 98
98our $ALT_ENTER_MESSAGE; 99our $ALT_ENTER_MESSAGE;
99our $STATUSBOX; 100our $STATUSBOX;
100our $DEBUG_STATUS; 101our $DEBUG_STATUS;
101 102
102our $INVWIN; 103our $INV_WINDOW;
103our $INV; 104our $INV;
104our $INVR; 105our $INVR;
105our $INVR_LBL; 106our $INV_RIGHT_HB;
107
108our $BIND_WINDOW;
106 109
107sub status { 110sub status {
108 $STATUSBOX->add (CFClient::UI::Label::escape $_[0], pri => -10, group => "status", timeout => 10, fg => [1, 1, 0, 1]); 111 $STATUSBOX->add (CFClient::UI::Label::escape $_[0], pri => -10, group => "status", timeout => 10, fg => [1, 1, 0, 1]);
109} 112}
110 113
111sub debug { 114sub debug {
112 $DEBUG_STATUS->set_text ($_[0]); 115 $DEBUG_STATUS->set_text ($_[0]);
113 my ($w, $h) = $DEBUG_STATUS->size_request;
114 $DEBUG_STATUS->move ($WIDTH - $w, 0);
115} 116}
116 117
117sub start_game { 118sub start_game {
118 status "logging in..."; 119 status "logging in...";
120
121 $LOGIN_BUTTON->set_text ("Logout");
122 $SERVER_SETUP->hide;
119 123
120 my $mapsize = List::Util::min 32, List::Util::max 11, int $WIDTH * $CFG->{mapsize} * 0.01 / 32; 124 my $mapsize = List::Util::min 32, List::Util::max 11, int $WIDTH * $CFG->{mapsize} * 0.01 / 32;
121 125
122 my ($host, $port) = split /:/, $CFG->{host}; 126 my ($host, $port) = split /:/, $CFG->{host};
123 127
152 }; 156 };
153 157
154 if ($CONN) { 158 if ($CONN) {
155 CFClient::lowdelay fileno $CONN->{fh}; 159 CFClient::lowdelay fileno $CONN->{fh};
156 160
157 $LOGIN_BUTTON->set_text ("Logout");
158 status "login successful"; 161 status "login successful";
159
160 $BUTTONBAR->{children}[1]->emit ("activate")
161 if $BUTTONBAR->{children}[1]->{state};
162
163 } else { 162 } else {
164 status "unable to connect"; 163 status "unable to connect";
165 stop_game(); 164 stop_game();
166 } 165 }
167} 166}
168 167
169sub stop_game { 168sub stop_game {
169 $LOGIN_BUTTON->set_text ("Login");
170 $SERVER_SETUP->show;
171 $INV_WINDOW->hide;
172 $LOGVIEW->hide;
173
170 return unless $CONN; 174 return unless $CONN;
171 175
172 status "connection closed"; 176 status "connection closed";
173 $LOGIN_BUTTON->set_text ("Login"); 177
174 $CONN->destroy; 178 $CONN->destroy;
175 $CONN = 0; # false, does not autovivify 179 $CONN = 0; # false, does not autovivify
176
177 $BUTTONBAR->{children}[1]->emit ("activate")
178 unless $BUTTONBAR->{children}[1]->{state};
179} 180}
180 181
181sub client_setup { 182sub client_setup {
182 my $dialog = new CFClient::UI::FancyFrame 183 my $dialog = new CFClient::UI::FancyFrame
184 x => 1,
185 y => $HEIGHT * (1/8),
186 name => "client_setup",
183 title => "Client Setup", 187 title => "Client Setup",
184 child => (my $vbox = new CFClient::UI::VBox); 188 child => (my $vbox = new CFClient::UI::VBox);
189
185 $vbox->add (my $table = new CFClient::UI::Table expand => 1, col_expand => [0, 1]); 190 $vbox->add (my $table = new CFClient::UI::Table expand => 1, col_expand => [0, 1]);
186 191
187 $table->add (0, 0, new CFClient::UI::Label valign => 0, align => 1, text => "Video Mode"); 192 $table->add (0, 0, new CFClient::UI::Label valign => 0, align => 1, text => "Video Mode");
188 $table->add (1, 0, my $hbox = new CFClient::UI::HBox); 193 $table->add (1, 0, my $hbox = new CFClient::UI::HBox);
189 194
190 $hbox->add (my $mode_slider = new CFClient::UI::Slider expand => 1, req_w => 100, range => [$CFG->{sdl_mode}, 0, $#SDL_MODES, 0, 1]); 195 $hbox->add (my $mode_slider = new CFClient::UI::Slider force_w => $WIDTH * 0.1, expand => 1, range => [$CFG->{sdl_mode}, 0, $#SDL_MODES, 0, 1]);
191 $hbox->add (my $mode_label = new CFClient::UI::Label align => 0, valign => 0, height => 0.8, template => "9999x9999"); 196 $hbox->add (my $mode_label = new CFClient::UI::Label align => 0, valign => 0, height => 0.8, template => "9999x9999");
192 197
193 $mode_slider->connect (changed => sub { 198 $mode_slider->connect (changed => sub {
194 my ($self, $value) = @_; 199 my ($self, $value) = @_;
195 200
202 207
203 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "Fullscreen"); 208 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "Fullscreen");
204 $table->add (1, $row++, new CFClient::UI::CheckBox 209 $table->add (1, $row++, new CFClient::UI::CheckBox
205 state => $CFG->{fullscreen}, 210 state => $CFG->{fullscreen},
206 tooltip => "Bring the client into fullscreen mode.", 211 tooltip => "Bring the client into fullscreen mode.",
207 connect_changed => sub { 212 on_changed => sub {
208 my ($self, $value) = @_; 213 my ($self, $value) = @_;
209 $CFG->{fullscreen} = $value; 214 $CFG->{fullscreen} = $value;
210 } 215 }
211 ); 216 );
212 217
213 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "Fast & Ugly"); 218 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "Fast & Ugly");
214 $table->add (1, $row++, new CFClient::UI::CheckBox 219 $table->add (1, $row++, new CFClient::UI::CheckBox
215 state => $CFG->{fast}, 220 state => $CFG->{fast},
216 tooltip => "Lower the visual quality considerably to speed up rendering.", 221 tooltip => "Lower the visual quality considerably to speed up rendering.",
217 connect_changed => sub { 222 on_changed => sub {
218 my ($self, $value) = @_; 223 my ($self, $value) = @_;
219 $CFG->{fast} = $value; 224 $CFG->{fast} = $value;
220 } 225 }
221 ); 226 );
222 227
223 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "Map Scale"); 228 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "Map Scale");
224 $table->add (1, $row++, new CFClient::UI::Slider 229 $table->add (1, $row++, new CFClient::UI::Slider
225 range => [(log $CFG->{map_scale}) / (log 2), -3, 1, 0, 1], 230 range => [(log $CFG->{map_scale}) / (log 2), -3, 1, 0, 1],
226 tooltip => "Enlarge or shrink the displayed map. Changes are instant.", 231 tooltip => "Enlarge or shrink the displayed map. Changes are instant.",
227 connect_changed => sub { 232 on_changed => sub {
228 my ($self, $value) = @_; 233 my ($self, $value) = @_;
229 $CFG->{map_scale} = 2 ** $value; 234 $CFG->{map_scale} = 2 ** $value;
230 } 235 }
231 ); 236 );
232 237
233 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "Fog of War"); 238 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "Fog of War");
234 $table->add (1, $row++, new CFClient::UI::CheckBox 239 $table->add (1, $row++, new CFClient::UI::CheckBox
235 state => $CFG->{fow_enable}, 240 state => $CFG->{fow_enable},
236 tooltip => "<b>Fog-of-War</b> marks areas that cannot be seen by the player. Changes are instant.", 241 tooltip => "<b>Fog-of-War</b> marks areas that cannot be seen by the player. Changes are instant.",
237 connect_changed => sub { 242 on_changed => sub {
238 my ($self, $value) = @_; 243 my ($self, $value) = @_;
239 $CFG->{fow_enable} = $value; 244 $CFG->{fow_enable} = $value;
240 } 245 }
241 ); 246 );
242 247
243 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "FoW Intensity"); 248 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "FoW Intensity");
244 $table->add (1, $row++, new CFClient::UI::Slider 249 $table->add (1, $row++, new CFClient::UI::Slider
245 range => [$CFG->{fow_intensity}, 0, 1, 0, 1 / 256], 250 range => [$CFG->{fow_intensity}, 0, 1, 0, 1 / 256],
246 tooltip => "<b>Fog of War Lightness.</b> The higher the intensity, the lighter the Fog-of-War color. Changes are instant.", 251 tooltip => "<b>Fog of War Lightness.</b> The higher the intensity, the lighter the Fog-of-War color. Changes are instant.",
247 connect_changed => sub { 252 on_changed => sub {
248 my ($self, $value) = @_; 253 my ($self, $value) = @_;
249 $CFG->{fow_intensity} = $value; 254 $CFG->{fow_intensity} = $value;
250 } 255 }
251 ); 256 );
252 257
253 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "FoW Smooth"); 258 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "FoW Smooth");
254 $table->add (1, $row++, new CFClient::UI::CheckBox 259 $table->add (1, $row++, new CFClient::UI::CheckBox
255 state => $CFG->{fow_smooth}, 260 state => $CFG->{fow_smooth},
256 tooltip => "Smooth the Fog-of-War a bit to make it more realistic. Changes are instant.", 261 tooltip => "Smooth the Fog-of-War a bit to make it more realistic. Changes are instant.",
257 connect_changed => sub { 262 on_changed => sub {
258 my ($self, $value) = @_; 263 my ($self, $value) = @_;
259 $CFG->{fow_smooth} = $value; 264 $CFG->{fow_smooth} = $value;
260 status "Fog of War smoothing requires OpenGL 1.2 or higher" if $CFClient::GL_VERSION < 1.2; 265 status "Fog of War smoothing requires OpenGL 1.2 or higher" if $CFClient::OpenGL::GL_VERSION < 1.2;
261 } 266 }
262 ); 267 );
263 268
264 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "GUI Fontsize"); 269 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "GUI Fontsize");
265 $table->add (1, $row++, new CFClient::UI::Slider 270 $table->add (1, $row++, new CFClient::UI::Slider
266 range => [$CFG->{gui_fontsize}, 0.5, 2, 0, 0.1], 271 range => [$CFG->{gui_fontsize}, 0.5, 2, 0, 0.1],
267 tooltip => "The base font size used by most GUI elements that do not have their own setting.", 272 tooltip => "The base font size used by most GUI elements that do not have their own setting.",
268 connect_changed => sub { $CFG->{gui_fontsize} = $_[1] }, 273 on_changed => sub { $CFG->{gui_fontsize} = $_[1] },
269 ); 274 );
270 275
271 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "Message Fontsize"); 276 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "Message Fontsize");
272 $table->add (1, $row++, new CFClient::UI::Slider 277 $table->add (1, $row++, new CFClient::UI::Slider
273 range => [$CFG->{log_fontsize}, 0.5, 2, 0, 0.1], 278 range => [$CFG->{log_fontsize}, 0.5, 2, 0, 0.1],
274 tooltip => "The font size used by the <b>message/server log</b> window only. Changes are instant.", 279 tooltip => "The font size used by the <b>message/server log</b> window only. Changes are instant.",
275 connect_changed => sub { $LOGVIEW->set_fontsize ($CFG->{log_fontsize} = $_[1]) }, 280 on_changed => sub { $LOGVIEW->set_fontsize ($CFG->{log_fontsize} = $_[1]) },
276 ); 281 );
277 282
278 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "Stats Fontsize"); 283 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "Stats Fontsize");
279 284
280 $table->add (1, $row++, new CFClient::UI::Slider 285 $table->add (1, $row++, new CFClient::UI::Slider
281 range => [$CFG->{stat_fontsize}, 0.5, 2, 0, 0.1], 286 range => [$CFG->{stat_fontsize}, 0.5, 2, 0, 0.1],
282 tooltip => "The font size used by the <b>statistics window</b> only. Changes are instant.", 287 tooltip => "The font size used by the <b>statistics window</b> only. Changes are instant.",
283 connect_changed => sub { 288 on_changed => sub {
284 $CFG->{stat_fontsize} = $_[1]; 289 $CFG->{stat_fontsize} = $_[1];
285 &set_stats_window_fontsize; 290 &set_stats_window_fontsize;
286 } 291 }
287 ); 292 );
288 293
289 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "Gauge fontsize"); 294 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "Gauge fontsize");
290 $table->add (1, $row++, new CFClient::UI::Slider 295 $table->add (1, $row++, new CFClient::UI::Slider
291 range => [$CFG->{gauge_fontsize}, 0.5, 2, 0, 0.1], 296 range => [$CFG->{gauge_fontsize}, 0.5, 2, 0, 0.1],
292 tooltip => "Adjusts the fontsize of the gauges at the bottom right. Changes are instant.", 297 tooltip => "Adjusts the fontsize of the gauges at the bottom right. Changes are instant.",
293 connect_changed => sub { 298 on_changed => sub {
294 $CFG->{gauge_fontsize} = $_[1]; 299 $CFG->{gauge_fontsize} = $_[1];
295 &set_gauge_window_fontsize; 300 &set_gauge_window_fontsize;
296 } 301 }
297 ); 302 );
298 303
299 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "Gauge size"); 304 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "Gauge size");
300 $table->add (1, $row++, new CFClient::UI::Slider 305 $table->add (1, $row++, new CFClient::UI::Slider
301 range => [$CFG->{gauge_size}, 0.2, 0.8], 306 range => [$CFG->{gauge_size}, 0.2, 0.8],
302 tooltip => "Adjust the size of the stats gauges at the bottom right. Changes are instant.", 307 tooltip => "Adjust the size of the stats gauges at the bottom right. Changes are instant.",
303 connect_changed => sub { 308 on_changed => sub {
304 $CFG->{gauge_size} = $_[1]; 309 $CFG->{gauge_size} = $_[1];
305 $GAUGES->{win}->set_size ($WIDTH, int $HEIGHT * $CFG->{gauge_size}); 310 $GAUGES->{win}->set_size ($WIDTH, int $HEIGHT * $CFG->{gauge_size});
306 } 311 }
307 ); 312 );
308 313
309 $table->add (1, $row++, new CFClient::UI::Button 314 $table->add (1, $row++, new CFClient::UI::Button
310 expand => 1, align => 0, text => "Apply", 315 expand => 1, align => 0, text => "Apply",
311 tooltip => "Apply the video settings", 316 tooltip => "Apply the video settings",
312 connect_activate => sub { 317 on_activate => sub {
313 video_shutdown (); 318 video_shutdown ();
314 video_init (); 319 video_init ();
315 } 320 }
316 ); 321 );
317 322
318 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "Audio Enable"); 323 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "Audio Enable");
319 $table->add (1, $row++, new CFClient::UI::CheckBox 324 $table->add (1, $row++, new CFClient::UI::CheckBox
320 state => $CFG->{audio_enable}, 325 state => $CFG->{audio_enable},
321 tooltip => "<b>Master Audio Enable.</b> If enabled, sound effects and music will be played. If disabled, no audio will be used and the soundcard will not be opened.", 326 tooltip => "<b>Master Audio Enable.</b> If enabled, sound effects and music will be played. If disabled, no audio will be used and the soundcard will not be opened.",
322 connect_changed => sub { 327 on_changed => sub {
323 $CFG->{audio_enable} = $_[1]; 328 $CFG->{audio_enable} = $_[1];
324 } 329 }
325 ); 330 );
326# $table->add (0, 9, new CFClient::UI::Label valign => 0, align => 1, text => "Effects Volume"); 331# $table->add (0, 9, new CFClient::UI::Label valign => 0, align => 1, text => "Effects Volume");
327# $table->add (1, 8, new CFClient::UI::Slider range => [$CFG->{effects_volume}, 0, 128, 1], connect_changed => sub { 332# $table->add (1, 8, new CFClient::UI::Slider range => [$CFG->{effects_volume}, 0, 128, 1], on_changed => sub {
328# $CFG->{effects_volume} = $_[1]; 333# $CFG->{effects_volume} = $_[1];
329# }); 334# });
330 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "Background Music"); 335 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "Background Music");
331 $table->add (1, $row++, my $hbox = new CFClient::UI::HBox); 336 $table->add (1, $row++, my $hbox = new CFClient::UI::HBox);
332 $hbox->add (new CFClient::UI::CheckBox 337 $hbox->add (new CFClient::UI::CheckBox
333 expand => 1, state => $CFG->{bgm_enable}, 338 expand => 1, state => $CFG->{bgm_enable},
334 tooltip => "If enabled, playing of background music is enabled. If disabled, no background music will be played.", 339 tooltip => "If enabled, playing of background music is enabled. If disabled, no background music will be played.",
335 connect_changed => sub { 340 on_changed => sub {
336 $CFG->{bgm_enable} = $_[1]; 341 $CFG->{bgm_enable} = $_[1];
337 } 342 }
338 ); 343 );
339 $hbox->add (new CFClient::UI::Slider 344 $hbox->add (new CFClient::UI::Slider
340 expand => 1, range => [$CFG->{bgm_volume}, 0, 1, 0, 1/128], 345 expand => 1, range => [$CFG->{bgm_volume}, 0, 1, 0, 1/128],
341 tooltip => "The volume of the background music. Changes are instant.", 346 tooltip => "The volume of the background music. Changes are instant.",
342 connect_changed => sub { 347 on_changed => sub {
343 $CFG->{bgm_volume} = $_[1]; 348 $CFG->{bgm_volume} = $_[1];
344 CFClient::MixMusic::volume $_[1] * 128; 349 CFClient::MixMusic::volume $_[1] * 128;
345 } 350 }
346 ); 351 );
347 352
348 $table->add (1, $row++, new CFClient::UI::Button 353 $table->add (1, $row++, new CFClient::UI::Button
349 expand => 1, align => 0, text => "Apply", 354 expand => 1, align => 0, text => "Apply",
350 tooltip => "Apply the audio settings", 355 tooltip => "Apply the audio settings",
351 connect_activate => sub { 356 on_activate => sub {
352 audio_shutdown (); 357 audio_shutdown ();
353 audio_init (); 358 audio_init ();
354 } 359 }
355 ); 360 );
356 361
358 $table->add (1, $row++, my $saycmd = new CFClient::UI::Entry 363 $table->add (1, $row++, my $saycmd = new CFClient::UI::Entry
359 text => $CFG->{say_command}, 364 text => $CFG->{say_command},
360 tooltip => "This is the command that will be used if you write a line in the message window entry or press <b>\"</b> in the map window. " 365 tooltip => "This is the command that will be used if you write a line in the message window entry or press <b>\"</b> in the map window. "
361 . "Usually you want to enter something like 'say' or 'shout' or 'gsay' here. " 366 . "Usually you want to enter something like 'say' or 'shout' or 'gsay' here. "
362 . "But you could also set it to <b>tell <i>playername</i></b> to only chat with that user.", 367 . "But you could also set it to <b>tell <i>playername</i></b> to only chat with that user.",
363 connect_changed => sub { 368 on_changed => sub {
364 my ($self, $value) = @_; 369 my ($self, $value) = @_;
365 $CFG->{say_command} = $value; 370 $CFG->{say_command} = $value;
366 } 371 }
367 ); 372 );
368 373
383 388
384sub make_gauge_window { 389sub make_gauge_window {
385 my $gh = int $HEIGHT * $CFG->{gauge_size}; 390 my $gh = int $HEIGHT * $CFG->{gauge_size};
386 391
387 my $win = new CFClient::UI::Frame ( 392 my $win = new CFClient::UI::Frame (
388 req_y => -1, 393 force_x => 0,
394 force_y => "max",
389 user_w => $WIDTH, 395 force_w => $WIDTH,
390 user_h => $gh, 396 force_h => $gh,
391 ); 397 );
392 398
393 $win->add (my $hbox = new CFClient::UI::HBox 399 $win->add (my $hbox = new CFClient::UI::HBox
394 children => [ 400 children => [
395 (new CFClient::UI::HBox expand => 1), 401 (new CFClient::UI::HBox expand => 1),
431 &set_gauge_window_fontsize; 437 &set_gauge_window_fontsize;
432 438
433 $win 439 $win
434} 440}
435 441
442
436sub make_stats_window { 443sub make_stats_window {
437 my $tgw = new CFClient::UI::FancyFrame title => "Stats"; 444 my $tgw = new CFClient::UI::FancyFrame
445 y => $HEIGHT * (2/8),
446 x => "max",
447 title => "Stats",
448 name => "stats_window";
438 449
439 $tgw->add (new CFClient::UI::Window child => my $vb = new CFClient::UI::VBox); 450 $tgw->add (new CFClient::UI::Window child => my $vb = new CFClient::UI::VBox);
440 $vb->add ($STATWIDS->{title} = new CFClient::UI::Label valign => 0, align => -1, text => "Title:", expand => 1, 451 $vb->add ($STATWIDS->{title} = new CFClient::UI::Label valign => 0, align => -1, text => "Title:", expand => 1,
441 can_hover => 1, can_events => 1, 452 can_hover => 1, can_events => 1,
442 tooltip => "Your name and title. You can change your title by using the <b>title</b> command, if supported by the server."); 453 tooltip => "Your name and title. You can change your title by using the <b>title</b> command, if supported by the server.");
445 tooltip => "The map you are currently on (if supported by the server)."); 456 tooltip => "The map you are currently on (if supported by the server).");
446 457
447 $vb->add (my $hb0 = new CFClient::UI::HBox); 458 $vb->add (my $hb0 = new CFClient::UI::HBox);
448 $hb0->add ($STATWIDS->{weight} = new CFClient::UI::Label valign => 0, align => -1, text => "Weight:", expand => 1, 459 $hb0->add ($STATWIDS->{weight} = new CFClient::UI::Label valign => 0, align => -1, text => "Weight:", expand => 1,
449 can_hover => 1, can_events => 1, 460 can_hover => 1, can_events => 1,
450 tooltip => "This is the amount the Player weights."); 461 tooltip => "The weight of the player including all inventory items.");
451 $hb0->add ($STATWIDS->{m_weight} = new CFClient::UI::Label valign => 0, align => -1, text => "Max weight:", expand => 1, 462 $hb0->add ($STATWIDS->{m_weight} = new CFClient::UI::Label valign => 0, align => -1, text => "Max weight:", expand => 1,
452 can_hover => 1, can_events => 1, 463 can_hover => 1, can_events => 1,
453 tooltip => "The weight limit, you can't carry more than this."); 464 tooltip => "The weight limit: you cannot carry more than this.");
454 465
455 466
456 $vb->add (my $hb = new CFClient::UI::HBox expand => 1); 467 $vb->add (my $hb = new CFClient::UI::HBox expand => 1);
457 $hb->add (my $tbl = new CFClient::UI::Table expand => 1); 468 $hb->add (my $tbl = new CFClient::UI::Table expand => 1);
458 469
689 $m = [$users, $host, $uptime, $version, $desc]; 700 $m = [$users, $host, $uptime, $version, $desc];
690 701
691 $y++; 702 $y++;
692 703
693 $table->add (0, $y, new CFClient::UI::VBox children => [ 704 $table->add (0, $y, new CFClient::UI::VBox children => [
694 (new CFClient::UI::Button text => "Use", connect_activate => sub { 705 (new CFClient::UI::Button text => "Use", on_activate => sub {
695 $HOST->set_text ($CFG->{host} = $host); 706 $HOST->set_text ($CFG->{host} = $host);
696 }), 707 }),
697 (new CFClient::UI::Empty expand => 1), 708 (new CFClient::UI::Empty expand => 1),
698 ]); 709 ]);
699 710
704 } 715 }
705 }); 716 });
706} 717}
707 718
708sub server_setup { 719sub server_setup {
709 my $dialog = new CFClient::UI::FancyFrame 720 my $dialog = $SERVER_SETUP = new CFClient::UI::FancyFrame
721 x => "center",
722 y => "center",
723 name => "server_setup",
710 title => "Server Setup", 724 title => "Server Setup",
711 child => (my $vbox = new CFClient::UI::VBox); 725 child => (my $vbox = new CFClient::UI::VBox),
712 726 ;
727
713 $vbox->add (my $table = new CFClient::UI::Table expand => 1, col_expand => [0, 1]); 728 $vbox->add (my $table = new CFClient::UI::Table expand => 1, col_expand => [0, 1]);
714 $table->add (0, 2, new CFClient::UI::Label valign => 0, align => 1, text => "Host:Port"); 729 $table->add (0, 2, new CFClient::UI::Label valign => 0, align => 1, text => "Host:Port");
715 730
716 { 731 {
717 $table->add (1, 2, my $vbox = new CFClient::UI::VBox); 732 $table->add (1, 2, my $vbox = new CFClient::UI::VBox);
719 $vbox->add ( 734 $vbox->add (
720 my $HOST = new CFClient::UI::Entry 735 my $HOST = new CFClient::UI::Entry
721 expand => 1, 736 expand => 1,
722 text => $CFG->{host}, 737 text => $CFG->{host},
723 tooltip => "The hostname or ip address of the Crossfire(+) server to connect to", 738 tooltip => "The hostname or ip address of the Crossfire(+) server to connect to",
724 connect_changed => sub { 739 on_changed => sub {
725 my ($self, $value) = @_; 740 my ($self, $value) = @_;
726 $CFG->{host} = $value; 741 $CFG->{host} = $value;
727 } 742 }
728 ); 743 );
729 744
732 $vbox->add (new CFClient::UI::Flopper 747 $vbox->add (new CFClient::UI::Flopper
733 expand => 1, 748 expand => 1,
734 text => "Server List", 749 text => "Server List",
735 other => $METASERVER, 750 other => $METASERVER,
736 tooltip => "Show a list of available crossfire servers", 751 tooltip => "Show a list of available crossfire servers",
737 connect_open => sub { 752 on_open => sub {
738 update_metaserver $HOST; 753 update_metaserver $HOST;
739 } 754 }
740 ); 755 );
741 } 756 }
742 757
743 $table->add (0, 4, new CFClient::UI::Label valign => 0, align => 1, text => "Username"); 758 $table->add (0, 4, new CFClient::UI::Label valign => 0, align => 1, text => "Username");
744 $table->add (1, 4, new CFClient::UI::Entry 759 $table->add (1, 4, new CFClient::UI::Entry
745 text => $CFG->{user}, 760 text => $CFG->{user},
746 tooltip => "The name of your character on the server", 761 tooltip => "The name of your character on the server",
747 connect_changed => sub { 762 on_changed => sub {
748 my ($self, $value) = @_; 763 my ($self, $value) = @_;
749 $CFG->{user} = $value; 764 $CFG->{user} = $value;
750 } 765 }
751 ); 766 );
752 767
753 $table->add (0, 5, new CFClient::UI::Label valign => 0, align => 1, text => "Password"); 768 $table->add (0, 5, new CFClient::UI::Label valign => 0, align => 1, text => "Password");
754 $table->add (1, 5, new CFClient::UI::Entry 769 $table->add (1, 5, new CFClient::UI::Entry
755 text => $CFG->{password}, 770 text => $CFG->{password},
756 hidden => 1, 771 hidden => 1,
757 tooltip => "The password for your character", 772 tooltip => "The password for your character",
758 connect_changed => sub { 773 on_changed => sub {
759 my ($self, $value) = @_; 774 my ($self, $value) = @_;
760 $CFG->{password} = $value; 775 $CFG->{password} = $value;
761 } 776 }
762 ); 777 );
763 778
764 $table->add (0, 7, new CFClient::UI::Label valign => 0, align => 1, text => "Map Size"); 779 $table->add (0, 7, new CFClient::UI::Label valign => 0, align => 1, text => "Map Size");
765 $table->add (1, 7, new CFClient::UI::Slider 780 $table->add (1, 7, new CFClient::UI::Slider
766 req_w => 100, 781 force_w => 100,
767 range => [$CFG->{mapsize}, 10, 100, 0, 1], 782 range => [$CFG->{mapsize}, 10, 100, 0, 1],
768 tooltip => "This is the size of the portion of the map update the server sends you. " 783 tooltip => "This is the size of the portion of the map update the server sends you. "
769 . "If you set this to a high value you will be able to see further, " 784 . "If you set this to a high value you will be able to see further, "
770 . "but you also increase bandwidth requirements and latency. " 785 . "but you also increase bandwidth requirements and latency. "
771 . "This option is only used once at log-in.", 786 . "This option is only used once at log-in.",
772 connect_changed => sub { 787 on_changed => sub {
773 my ($self, $value) = @_; 788 my ($self, $value) = @_;
774 789
775 $CFG->{mapsize} = $self->{range}[0] = $value = int $value; 790 $CFG->{mapsize} = $self->{range}[0] = $value = int $value;
776 }, 791 },
777 ); 792 );
784 . "This might increase or create lag, but increases the chances " 799 . "This might increase or create lag, but increases the chances "
785 . "of faces being ready for display when you encounter them. " 800 . "of faces being ready for display when you encounter them. "
786 . "It also uses up server bandwidth on every connect, " 801 . "It also uses up server bandwidth on every connect, "
787 . "so only set it if you really need to prefetch images. " 802 . "so only set it if you really need to prefetch images. "
788 . "This option can be set and unset any time.", 803 . "This option can be set and unset any time.",
789 connect_changed => sub { $CFG->{face_prefetch} = $_[1] }, 804 on_changed => sub { $CFG->{face_prefetch} = $_[1] },
790 ); 805 );
791 806
792 $table->add (0, 9, new CFClient::UI::Label valign => 0, align => 1, text => "Output-Count"); 807 $table->add (0, 9, new CFClient::UI::Label valign => 0, align => 1, text => "Output-Count");
793 $table->add (1, 9, new CFClient::UI::Entry 808 $table->add (1, 9, new CFClient::UI::Entry
794 text => $CFG->{output_count}, 809 text => $CFG->{output_count},
795 tooltip => "Should be set to 1 unless you know what you are doing. This option is only used once at log-in.", 810 tooltip => "Should be set to 1 unless you know what you are doing. This option is only used once at log-in.",
796 connect_changed => sub { $CFG->{output_count} = $_[1] }, 811 on_changed => sub { $CFG->{output_count} = $_[1] },
797 ); 812 );
798 813
799 $table->add (0, 10, new CFClient::UI::Label valign => 0, align => 1, text => "Output-Sync"); 814 $table->add (0, 10, new CFClient::UI::Label valign => 0, align => 1, text => "Output-Sync");
800 $table->add (1, 10, new CFClient::UI::Entry 815 $table->add (1, 10, new CFClient::UI::Entry
801 text => $CFG->{output_sync}, 816 text => $CFG->{output_sync},
802 tooltip => "Should be set to 1 unless you know what you are doing. This option is only used once at log-in.", 817 tooltip => "Should be set to 1 unless you know what you are doing. This option is only used once at log-in.",
803 connect_changed => sub { $CFG->{output_sync} = $_[1] }, 818 on_changed => sub { $CFG->{output_sync} = $_[1] },
804 ); 819 );
805 820
806 $table->add (1, 11, $LOGIN_BUTTON = new CFClient::UI::Button 821 $table->add (1, 11, $LOGIN_BUTTON = new CFClient::UI::Button
807 expand => 1, 822 expand => 1,
808 align => 0, 823 align => 0,
809 text => "Login", 824 text => "Login",
810 connect_activate => sub { 825 on_activate => sub {
811 $CONN ? stop_game 826 $CONN ? stop_game
812 : start_game; 827 : start_game;
813 }, 828 },
814 ); 829 );
815 830
816 $dialog 831 $dialog
817} 832}
818 833
819sub message_window { 834sub message_window {
820 my $window = new CFClient::UI::FancyFrame 835 my $window = new CFClient::UI::FancyFrame
836 name => "message_window",
821 title => "Messages", 837 title => "Messages",
822 border_bg => [1, 1, 1, 1], 838 border_bg => [1, 1, 1, 1],
823 bg => [0, 0, 0, 0.75], 839 bg => [0, 0, 0, 0.75],
840 x => "max",
841 y => 0,
824 user_w => int $::WIDTH / 3, 842 force_w => $::WIDTH / 3,
825 user_h => int $::HEIGHT / 5, 843 force_h => $::HEIGHT / 5,
826 child => (my $vbox = new CFClient::UI::VBox); 844 child => (my $vbox = new CFClient::UI::VBox);
827 845
828 $vbox->add ($LOGVIEW); 846 $vbox->add ($LOGVIEW);
829 847
830 $vbox->add (my $input = new CFClient::UI::Entry 848 $vbox->add (my $input = new CFClient::UI::Entry
831 tooltip => "<b>Chat Box</b>. If you enter a text and press return/enter here, the current <i>communication command</i> " 849 tooltip => "<b>Chat Box</b>. If you enter a text and press return/enter here, the current <i>communication command</i> "
832 . "from the client setup will be prepended (e.g. <b>shout</b>, <b>chat</b>...). " 850 . "from the client setup will be prepended (e.g. <b>shout</b>, <b>chat</b>...). "
833 . "If you prepend a slash (/), you will submit a command instead (similar to IRC). " 851 . "If you prepend a slash (/), you will submit a command instead (similar to IRC). "
834 . "A better way to submit commands (and the occasional chat command) is often the map command completer.", 852 . "A better way to submit commands (and the occasional chat command) is often the map command completer.",
835 connect_focus_in => sub { 853 on_focus_in => sub {
836 my ($input, $prev_focus) = @_; 854 my ($input, $prev_focus) = @_;
837 855
838 delete $input->{refocus_map}; 856 delete $input->{refocus_map};
839 857
840 if ($prev_focus == $MAPWIDGET && $input->{auto_activated}) { 858 if ($prev_focus == $MAPWIDGET && $input->{auto_activated}) {
841 $input->{refocus_map} = 1; 859 $input->{refocus_map} = 1;
842 } 860 }
843 delete $input->{auto_activated}; 861 delete $input->{auto_activated};
844 }, 862 },
845 connect_activate => sub { 863 on_activate => sub {
846 my ($input, $text) = @_; 864 my ($input, $text) = @_;
847 $input->set_text (''); 865 $input->set_text ('');
848 866
867 if ($text =~ /^\/bind\s+(.*)$/) {
868 CFClient::Recorder::open_binding_dialog ([$1]);
849 if ($text =~ /^\/(.*)/) { 869 } elsif ($text =~ /^\/(.*)/) {
850 $::CONN->user_send ($1); 870 $::CONN->user_send ($1);
851 } else { 871 } else {
852 my $say_cmd = $::CFG->{say_command} || 'say'; 872 my $say_cmd = $::CFG->{say_command} || 'say';
853 $::CONN->user_send ("$say_cmd $text"); 873 $::CONN->user_send ("$say_cmd $text");
854 } 874 }
855 if ($input->{refocus_map}) { 875 if ($input->{refocus_map}) {
856 delete $input->{refocus_map}; 876 delete $input->{refocus_map};
857 $MAPWIDGET->focus_in 877 $MAPWIDGET->focus_in
858 } 878 }
859 }, 879 },
860 connect_escape => sub { 880 on_escape => sub {
861 $MAPWIDGET->focus_in 881 $MAPWIDGET->focus_in
862 }, 882 },
863 ); 883 );
864 884
865 $CONSOLE = { 885 $CONSOLE = {
866 window => $window, 886 window => $window,
867 input => $input 887 input => $input,
868 }; 888 };
869 889
870 $window 890 $window
871} 891}
872 892
873sub open_quit_dialog { 893sub open_quit_dialog {
874 unless ($QUIT_DIALOG) { 894 unless ($QUIT_DIALOG) {
875
876 $QUIT_DIALOG = new CFClient::UI::FancyFrame title => "Really Quit?"; 895 $QUIT_DIALOG = new CFClient::UI::FancyFrame
896 x => "center",
897 y => "center",
898 title => "Really Quit?",
899 ;
877 900
878 $QUIT_DIALOG->add (my $vb = new CFClient::UI::VBox expand => 1); 901 $QUIT_DIALOG->add (my $vb = new CFClient::UI::VBox expand => 1);
879 902
880 $vb->add (new CFClient::UI::Label 903 $vb->add (new CFClient::UI::Label
881 text => "You should find a savebed and apply it first!", 904 text => "You should find a savebed and apply it first!",
884 ); 907 );
885 $vb->add (my $hb = new CFClient::UI::HBox expand => 1); 908 $vb->add (my $hb = new CFClient::UI::HBox expand => 1);
886 $hb->add (new CFClient::UI::Button 909 $hb->add (new CFClient::UI::Button
887 text => "Ok", 910 text => "Ok",
888 expand => 1, 911 expand => 1,
889 connect_activate => sub { $QUIT_DIALOG->hide }, 912 on_activate => sub { $QUIT_DIALOG->hide },
890 ); 913 );
891 $hb->add (new CFClient::UI::Button 914 $hb->add (new CFClient::UI::Button
892 text => "Quit anyway", 915 text => "Quit anyway",
893 expand => 1, 916 expand => 1,
894 connect_activate => sub { exit }, 917 on_activate => sub { exit },
895 ); 918 );
919 }
896 920
897 $QUIT_DIALOG->show_centered; 921 $QUIT_DIALOG->show;
898 } else {
899 $QUIT_DIALOG->show_centered;
900 }
901} 922}
902 923
903sub make_inventory_window { 924sub make_inventory_window {
904 my $invwin = new CFClient::UI::FancyFrame 925 my $invwin = $INV_WINDOW = new CFClient::UI::FancyFrame
905 user_w => $WIDTH * (7/8), user_h => $HEIGHT * (7/8), title => "Inventory"; 926 x => "center",
927 y => "center",
928 force_w => $WIDTH * 9/10,
929 force_h => $HEIGHT * 9/10,
930 title => "Inventory",
931 name => "inventory_window",
932 ;
906 933
907 $invwin->add (my $hb = new CFClient::UI::HBox expand => 1); 934 $invwin->add (my $hb = new CFClient::UI::HBox homogeneous => 1);
908 935
909 $hb->add (my $vb1 = new CFClient::UI::VBox expand => 1); 936 $hb->add (my $vb1 = new CFClient::UI::VBox);
910 $vb1->add (my $lbl = new CFClient::UI::Label align => 0); 937 $vb1->add (new CFClient::UI::Label align => 0, text => "Player");
911 $lbl->set_text ("Player");
912 $vb1->add ($INV = new CFClient::UI::Inventory expand => 1); 938 $vb1->add ($INV = new CFClient::UI::Inventory expand => 1);
913 939
914 $hb->add (my $vb2 = new CFClient::UI::VBox expand => 1); 940 $hb->add (my $vb2 = new CFClient::UI::VBox);
941
915 $vb2->add ($INVR_LBL = new CFClient::UI::Label align => 0); 942 $vb2->add ($INV_RIGHT_HB = new CFClient::UI::HBox);
916 $INVR_LBL->set_text ("Floor"); 943
917 $vb2->add ($INVR = new CFClient::UI::Inventory expand => 1); 944 $vb2->add ($INVR = new CFClient::UI::Inventory expand => 1);
918 945
946 # XXX: Call after $INVR = ... because set_opencont sets the items
947 CFClient::Protocol::set_opencont ($::CONN, 0, "Floor");
948
919 $invwin 949 $invwin
950}
951
952sub make_binding_window {
953 my $binding_list = new CFClient::UI::VBox;
954
955 my $refresh = sub {
956 $binding_list->clear ();
957
958 for my $mod (keys %{$::CFG->{bindings}}) {
959 for my $sym (keys %{$::CFG->{bindings}->{$mod}}) {
960 my $cmds = $::CFG->{bindings}->{$mod}->{$sym};
961 next unless ref $cmds eq 'ARRAY' and @$cmds > 0;
962
963 my $lbl = join "; ", @$cmds;
964 my $nam = CFClient::Recorder::keycombo_to_name ($mod, $sym);
965 $binding_list->add (my $hb = new CFClient::UI::HBox);
966 $hb->add (new CFClient::UI::Button
967 text => "delete",
968 on_activate => sub {
969 $binding_list->remove ($hb);
970 delete $::CFG->{bindings}->{$mod}->{$sym};
971 });
972 $hb->add (new CFClient::UI::Label text => "($nam)");
973 $hb->add (new CFClient::UI::Label text => $lbl, expand => 1);
974 }
975 }
976 };
977
978 $BIND_WINDOW = new CFClient::UI::FancyFrame
979 title => "Bindings",
980 x => "center",
981 y => "center",
982 def_w => int $WIDTH * 9/10,
983 def_h => int $HEIGHT * 9/10,
984 on_visibility_change => sub {
985 my ($self, $visible) = @_;
986 $refresh->() if $visible;
987 };
988
989 $BIND_WINDOW->add ($binding_list);
990 $refresh->();
991 $BIND_WINDOW
920} 992}
921 993
922sub make_help_window { 994sub make_help_window {
923 my $win = new CFClient::UI::FancyFrame 995 my $win = new CFClient::UI::FancyFrame
924 user_w => $WIDTH * (7/8), user_h => $HEIGHT * (7/8), title => "Documentation"; 996 def_w => int $WIDTH * 7/8,
997 def_h => int $HEIGHT * 7/8,
998 title => "Documentation";
925 999
926 $win->add (my $vbox = new CFClient::UI::VBox); 1000 $win->add (my $vbox = new CFClient::UI::VBox);
927 1001
928 $vbox->add (my $buttons = new CFClient::UI::HBox); 1002 $vbox->add (my $buttons = new CFClient::UI::HBox);
929 $vbox->add (my $viewer = new CFClient::UI::TextView expand => 1, fontsize => 0.8); 1003 $vbox->add (my $viewer = new CFClient::UI::TextView expand => 1, fontsize => 0.8);
936 ) { 1010 ) {
937 my ($pod, $label) = @$_; 1011 my ($pod, $label) = @$_;
938 1012
939 $buttons->add (new CFClient::UI::Button 1013 $buttons->add (new CFClient::UI::Button
940 text => $label, 1014 text => $label,
941 connect_activate => sub { 1015 on_activate => sub {
942 my $parser = new Pod::POM; 1016 my $parser = new Pod::POM;
943 my $pom = $parser->parse_file (CFClient::find_rcfile "pod/$pod.pod"); 1017 my $pom = $parser->parse_file (CFClient::find_rcfile "pod/$pod.pod");
944 1018
945 $viewer->clear; 1019 $viewer->clear;
946 1020
990 if ($DEBUG_STATUS) { 1064 if ($DEBUG_STATUS) {
991 CFClient::UI::rescale_widgets $WIDTH / $old_w, $HEIGHT / $old_h; 1065 CFClient::UI::rescale_widgets $WIDTH / $old_w, $HEIGHT / $old_h;
992 } else { 1066 } else {
993 # create the widgets 1067 # create the widgets
994 1068
995 $DEBUG_STATUS = new CFClient::UI::Label padding => 0, z => 100, req_x => -1; 1069 $DEBUG_STATUS = new CFClient::UI::Label
1070 padding => 0,
1071 z => 100,
1072 force_x => "max",
1073 force_y => 0;
996 $DEBUG_STATUS->show; 1074 $DEBUG_STATUS->show;
997 1075
998 $STATUSBOX = new CFClient::UI::Statusbox; 1076 $STATUSBOX = new CFClient::UI::Statusbox;
999 $STATUSBOX->add ("Use <b>Alt-Enter</b> to toggle fullscreen mode", pri => -100, color => [1, 1, 1, 0.8]); 1077 $STATUSBOX->add ("Use <b>Alt-Enter</b> to toggle fullscreen mode", pri => -100, color => [1, 1, 1, 0.8]);
1000 1078
1001 (new CFClient::UI::Frame 1079 (new CFClient::UI::Frame
1002 bg => [0, 0, 0, 0.4], 1080 bg => [0, 0, 0, 0.4],
1003 req_y => -1, 1081 force_x => 0,
1082 force_y => "max",
1004 child => $STATUSBOX, 1083 child => $STATUSBOX,
1005 )->show; 1084 )->show;
1006 1085
1007 CFClient::UI::FancyFrame->new ( 1086 CFClient::UI::FancyFrame->new (
1087 x => 0,
1088 y => $FONTSIZE + 8,
1008 border_bg => [1, 1, 1, 192/255], 1089 border_bg => [1, 1, 1, 192/255],
1009 bg => [1, 1, 1, 0], 1090 bg => [1, 1, 1, 0],
1010 child => ($MAPMAP = new CFClient::MapWidget::MapMap 1091 child => ($MAPMAP = new CFClient::MapWidget::MapMap
1011 tooltip => "<b>Map</b>. On servers that support this feature, this will display an overview of the surrounding areas.", 1092 tooltip => "<b>Map</b>. On servers that support this feature, this will display an overview of the surrounding areas.",
1012 ), 1093 ),
1035 can_hover => 1, 1116 can_hover => 1,
1036 can_events => 1, 1117 can_events => 1,
1037 tooltip => "<b>Server Log</b>. This text viewer contains all the messages sent by the server.", 1118 tooltip => "<b>Server Log</b>. This text viewer contains all the messages sent by the server.",
1038 ; 1119 ;
1039 1120
1040 $BUTTONBAR = new CFClient::UI::HBox; 1121 $BUTTONBAR = new CFClient::UI::HBox x => 0, y => 0;
1041 1122
1042 $BUTTONBAR->add (new CFClient::UI::Flopper text => "Client Setup", other => client_setup, 1123 $BUTTONBAR->add (new CFClient::UI::Flopper text => "Client Setup", other => client_setup,
1043 tooltip => "Toggles a dialog where you can configure various aspects of the client, such as graphics mode, performance, and audio options."); 1124 tooltip => "Toggles a dialog where you can configure various aspects of the client, such as graphics mode, performance, and audio options.");
1044 $BUTTONBAR->add (new CFClient::UI::Flopper text => "Server Setup", other => server_setup, 1125 $BUTTONBAR->add (new CFClient::UI::Flopper text => "Server Setup", other => server_setup,
1045 tooltip => "Toggles a dialog where you can configure the server to play on, your username, password and other server-related options."); 1126 tooltip => "Toggles a dialog where you can configure the server to play on, your username, password and other server-related options.");
1054 tooltip => "Toggles the inventory window, where you can manage your loot (or treaures :)."); 1135 tooltip => "Toggles the inventory window, where you can manage your loot (or treaures :).");
1055 1136
1056 $BUTTONBAR->add (new CFClient::UI::Button 1137 $BUTTONBAR->add (new CFClient::UI::Button
1057 text => "Save Config", 1138 text => "Save Config",
1058 tooltip => "Saves the options chosen in the client setting, server settings and the window layout to be restored on later runs.", 1139 tooltip => "Saves the options chosen in the client setting, server settings and the window layout to be restored on later runs.",
1059 connect_activate => sub { 1140 on_activate => sub {
1141 $::CFG->{layout} = CFClient::UI::get_layout;
1060 CFClient::write_cfg "$Crossfire::VARDIR/pclientrc"; 1142 CFClient::write_cfg "$Crossfire::VARDIR/cfplusrc";
1061 status "Configuration Saved"; 1143 status "Configuration Saved";
1062 }, 1144 },
1063 ); 1145 );
1064 1146
1065 $BUTTONBAR->add (new CFClient::UI::Flopper text => "Help!", other => make_help_window, 1147 $BUTTONBAR->add (new CFClient::UI::Flopper text => "Help!", other => make_help_window,
1066 tooltip => "View Documentation"); 1148 tooltip => "View Documentation");
1067 1149
1150 $BUTTONBAR->add (new CFClient::UI::Flopper
1151 text => "Bindings",
1152 other => make_binding_window,
1153 tooltip => "Lets you delete bindings you have made with the recorder"
1154 );
1155 $BUTTONBAR->add (new CFClient::UI::Flopper text => "[Rec]", other => CFClient::Recorder::make_window,
1156 tooltip => "This feature lets you record a series of actions (eg. walking a path or ready a skill) and bind them to keys");
1157
1068 $BUTTONBAR->add (new CFClient::UI::Button 1158 $BUTTONBAR->add (new CFClient::UI::Button
1069 text => "Quit", 1159 text => "Quit",
1070 tooltip => "Terminates the program", 1160 tooltip => "Terminates the program",
1071 connect_activate => sub { 1161 on_activate => sub {
1072 if ($CONN) { 1162 if ($CONN) {
1073 open_quit_dialog; 1163 open_quit_dialog;
1074 } else { 1164 } else {
1075 exit; 1165 exit;
1076 } 1166 }
1077 }, 1167 },
1078 ); 1168 );
1079 1169
1080 $BUTTONBAR->show; 1170 $BUTTONBAR->show;
1171 $SERVER_SETUP->show;
1081 1172
1082 $STATUSBOX->add ("Set video mode $WIDTH×$HEIGHT", timeout => 10, fg => [1, 1, 1, 0.5]); 1173 $STATUSBOX->add ("Set video mode $WIDTH×$HEIGHT", timeout => 10, fg => [1, 1, 1, 0.5]);
1083
1084 # delay till geometry is constant
1085 $CFClient::UI::ROOT->on_post_alloc (startup => sub {
1086 $BUTTONBAR->{children}[1]->emit ("activate"); # pop up server setup
1087 my $widget = $GAUGES->{win};
1088 $widget->move (0, $HEIGHT - $widget->{h});#d# to in toplevel
1089 });
1090 force_refresh ();
1091 } 1174 }
1092} 1175}
1093 1176
1094sub video_shutdown { 1177sub video_shutdown {
1095 undef $SDL_ACTIVE; 1178 undef $SDL_ACTIVE;
1163 1246
1164my %demo;#d# 1247my %demo;#d#
1165 1248
1166sub force_refresh { 1249sub force_refresh {
1167 $fps = $fps * 0.95 + 1 / (($NOW - $LAST_REFRESH) || 0.1) * 0.05; 1250 $fps = $fps * 0.95 + 1 / (($NOW - $LAST_REFRESH) || 0.1) * 0.05;
1168 debug sprintf "%3.2f", $fps; 1251 debug sprintf "%3.2f", $fps if $ENV{CFPLUS_DEBUG} & 4;
1169 1252
1170 $CFClient::UI::ROOT->draw; 1253 $CFClient::UI::ROOT->draw;
1171 1254
1172 $WANT_REFRESH = 0; 1255 $WANT_REFRESH = 0;
1173 $CAN_REFRESH = 0; 1256 $CAN_REFRESH = 0;
1305############################################################################# 1388#############################################################################
1306 1389
1307$SIG{INT} = $SIG{TERM} = sub { exit }; 1390$SIG{INT} = $SIG{TERM} = sub { exit };
1308 1391
1309{ 1392{
1310 local $SIG{__DIE__} = sub { CFClient::fatal $_[0] }; 1393 local $SIG{__DIE__} = sub { CFClient::fatal $_[0] if defined $^S && !$^S };
1311 1394
1312 CFClient::read_cfg "$Crossfire::VARDIR/pclientrc"; 1395 CFClient::read_cfg "$Crossfire::VARDIR/cfplusrc";
1396 CFClient::UI::set_layout ($::CFG->{layout});
1313 1397
1314 my %DEF_CFG = ( 1398 my %DEF_CFG = (
1315 sdl_mode => 0, 1399 sdl_mode => 0,
1316 width => 640, 1400 width => 640,
1317 height => 480, 1401 height => 480,
1394 1478
1395END { CFClient::SDL_Quit } 1479END { CFClient::SDL_Quit }
1396 1480
1397=head1 NAME 1481=head1 NAME
1398 1482
1399pclient - A Crossfire+ and Crossfire game client 1483cfplus - A Crossfire+ and Crossfire game client
1400 1484
1401=head1 SYNOPSIS 1485=head1 SYNOPSIS
1402 1486
1403Just run it - no commandline arguments are supported. 1487Just run it - no commandline arguments are supported.
1404 1488
1405=head1 USAGE 1489=head1 USAGE
1406 1490
1407Pclient utilises OpenGL for all UI elements and the game. It is supposed to be used 1491cfplus utilises OpenGL for all UI elements and the game. It is supposed to be used
1408fullscreen and interactively. 1492fullscreen and interactively.
1409 1493
1410=head1 AUTHOR 1494=head1 AUTHOR
1411 1495
1412Marc Lehmann <crossfire@schmorp.de>, Robin Redeker <elmex@ta-sa.org> 1496Marc Lehmann <crossfire@schmorp.de>, Robin Redeker <elmex@ta-sa.org>

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines