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.16 by elmex, Sat May 27 20:00:40 2006 UTC vs.
Revision 1.38 by elmex, Wed May 31 13:44:26 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
103our $INV_WINDOW;
102our $INV; 104our $INV;
103our $INVR; 105our $INVR;
104our $INVR_LBL; 106our $INV_RIGHT_HB;
107
108our $BIND_WINDOW;
109our $BIND_EDITOR;
110
111our $SPELL_LIST;
105 112
106sub status { 113sub status {
107 $STATUSBOX->add (CFClient::UI::Label::escape $_[0], pri => -10, group => "status", timeout => 10, fg => [1, 1, 0, 1]); 114 $STATUSBOX->add (CFClient::UI::Label::escape $_[0], pri => -10, group => "status", timeout => 10, fg => [1, 1, 0, 1]);
108} 115}
109 116
110sub debug { 117sub debug {
111 $DEBUG_STATUS->set_text ($_[0]); 118 $DEBUG_STATUS->set_text ($_[0]);
112 my ($w, $h) = $DEBUG_STATUS->size_request;
113 $DEBUG_STATUS->move ($WIDTH - $w, 0);
114} 119}
115 120
116sub start_game { 121sub start_game {
117 status "logging in..."; 122 status "logging in...";
123
124 $LOGIN_BUTTON->set_text ("Logout");
125 $SERVER_SETUP->hide;
118 126
119 my $mapsize = List::Util::min 32, List::Util::max 11, int $WIDTH * $CFG->{mapsize} * 0.01 / 32; 127 my $mapsize = List::Util::min 32, List::Util::max 11, int $WIDTH * $CFG->{mapsize} * 0.01 / 32;
120 128
121 my ($host, $port) = split /:/, $CFG->{host}; 129 my ($host, $port) = split /:/, $CFG->{host};
122 130
151 }; 159 };
152 160
153 if ($CONN) { 161 if ($CONN) {
154 CFClient::lowdelay fileno $CONN->{fh}; 162 CFClient::lowdelay fileno $CONN->{fh};
155 163
156 $LOGIN_BUTTON->set_text ("Logout");
157 status "login successful"; 164 status "login successful";
158
159 $BUTTONBAR->{children}[1]->emit ("activate")
160 if $BUTTONBAR->{children}[1]->{state};
161
162 } else { 165 } else {
163 status "unable to connect"; 166 status "unable to connect";
164 stop_game(); 167 stop_game();
165 } 168 }
166} 169}
167 170
168sub stop_game { 171sub stop_game {
172 $LOGIN_BUTTON->set_text ("Login");
173 $SERVER_SETUP->show;
174 $INV_WINDOW->hide;
175 $LOGVIEW->hide;
176
169 return unless $CONN; 177 return unless $CONN;
170 178
171 status "connection closed"; 179 status "connection closed";
172 $LOGIN_BUTTON->set_text ("Login"); 180
173 $CONN->destroy; 181 $CONN->destroy;
174 $CONN = 0; # false, does not autovivify 182 $CONN = 0; # false, does not autovivify
175
176 $BUTTONBAR->{children}[1]->emit ("activate")
177 unless $BUTTONBAR->{children}[1]->{state};
178} 183}
179 184
180sub client_setup { 185sub client_setup {
181 my $dialog = new CFClient::UI::FancyFrame 186 my $dialog = new CFClient::UI::FancyFrame
187 x => 1,
188 y => $HEIGHT * (1/8),
182 name => "client_setup", 189 name => "client_setup",
183 title => "Client Setup", 190 title => "Client Setup",
184 child => (my $vbox = new CFClient::UI::VBox); 191 child => (my $vbox = new CFClient::UI::VBox);
192
185 $vbox->add (my $table = new CFClient::UI::Table expand => 1, col_expand => [0, 1]); 193 $vbox->add (my $table = new CFClient::UI::Table expand => 1, col_expand => [0, 1]);
186 194
187 $table->add (0, 0, new CFClient::UI::Label valign => 0, align => 1, text => "Video Mode"); 195 $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); 196 $table->add (1, 0, my $hbox = new CFClient::UI::HBox);
189 197
190 $hbox->add (my $mode_slider = new CFClient::UI::Slider expand => 1, req_w => 100, range => [$CFG->{sdl_mode}, 0, $#SDL_MODES, 0, 1]); 198 $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"); 199 $hbox->add (my $mode_label = new CFClient::UI::Label align => 0, valign => 0, height => 0.8, template => "9999x9999");
192 200
193 $mode_slider->connect (changed => sub { 201 $mode_slider->connect (changed => sub {
194 my ($self, $value) = @_; 202 my ($self, $value) = @_;
195 203
202 210
203 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "Fullscreen"); 211 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "Fullscreen");
204 $table->add (1, $row++, new CFClient::UI::CheckBox 212 $table->add (1, $row++, new CFClient::UI::CheckBox
205 state => $CFG->{fullscreen}, 213 state => $CFG->{fullscreen},
206 tooltip => "Bring the client into fullscreen mode.", 214 tooltip => "Bring the client into fullscreen mode.",
207 connect_changed => sub { 215 on_changed => sub {
208 my ($self, $value) = @_; 216 my ($self, $value) = @_;
209 $CFG->{fullscreen} = $value; 217 $CFG->{fullscreen} = $value;
210 } 218 }
211 ); 219 );
212 220
213 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "Fast & Ugly"); 221 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "Fast & Ugly");
214 $table->add (1, $row++, new CFClient::UI::CheckBox 222 $table->add (1, $row++, new CFClient::UI::CheckBox
215 state => $CFG->{fast}, 223 state => $CFG->{fast},
216 tooltip => "Lower the visual quality considerably to speed up rendering.", 224 tooltip => "Lower the visual quality considerably to speed up rendering.",
217 connect_changed => sub { 225 on_changed => sub {
218 my ($self, $value) = @_; 226 my ($self, $value) = @_;
219 $CFG->{fast} = $value; 227 $CFG->{fast} = $value;
220 } 228 }
221 ); 229 );
222 230
223 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "Map Scale"); 231 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "Map Scale");
224 $table->add (1, $row++, new CFClient::UI::Slider 232 $table->add (1, $row++, new CFClient::UI::Slider
225 range => [(log $CFG->{map_scale}) / (log 2), -3, 1, 0, 1], 233 range => [(log $CFG->{map_scale}) / (log 2), -3, 1, 0, 1],
226 tooltip => "Enlarge or shrink the displayed map. Changes are instant.", 234 tooltip => "Enlarge or shrink the displayed map. Changes are instant.",
227 connect_changed => sub { 235 on_changed => sub {
228 my ($self, $value) = @_; 236 my ($self, $value) = @_;
229 $CFG->{map_scale} = 2 ** $value; 237 $CFG->{map_scale} = 2 ** $value;
230 } 238 }
231 ); 239 );
232 240
233 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "Fog of War"); 241 $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 242 $table->add (1, $row++, new CFClient::UI::CheckBox
235 state => $CFG->{fow_enable}, 243 state => $CFG->{fow_enable},
236 tooltip => "<b>Fog-of-War</b> marks areas that cannot be seen by the player. Changes are instant.", 244 tooltip => "<b>Fog-of-War</b> marks areas that cannot be seen by the player. Changes are instant.",
237 connect_changed => sub { 245 on_changed => sub {
238 my ($self, $value) = @_; 246 my ($self, $value) = @_;
239 $CFG->{fow_enable} = $value; 247 $CFG->{fow_enable} = $value;
240 } 248 }
241 ); 249 );
242 250
243 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "FoW Intensity"); 251 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "FoW Intensity");
244 $table->add (1, $row++, new CFClient::UI::Slider 252 $table->add (1, $row++, new CFClient::UI::Slider
245 range => [$CFG->{fow_intensity}, 0, 1, 0, 1 / 256], 253 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.", 254 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 { 255 on_changed => sub {
248 my ($self, $value) = @_; 256 my ($self, $value) = @_;
249 $CFG->{fow_intensity} = $value; 257 $CFG->{fow_intensity} = $value;
250 } 258 }
251 ); 259 );
252 260
253 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "FoW Smooth"); 261 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "FoW Smooth");
254 $table->add (1, $row++, new CFClient::UI::CheckBox 262 $table->add (1, $row++, new CFClient::UI::CheckBox
255 state => $CFG->{fow_smooth}, 263 state => $CFG->{fow_smooth},
256 tooltip => "Smooth the Fog-of-War a bit to make it more realistic. Changes are instant.", 264 tooltip => "Smooth the Fog-of-War a bit to make it more realistic. Changes are instant.",
257 connect_changed => sub { 265 on_changed => sub {
258 my ($self, $value) = @_; 266 my ($self, $value) = @_;
259 $CFG->{fow_smooth} = $value; 267 $CFG->{fow_smooth} = $value;
260 status "Fog of War smoothing requires OpenGL 1.2 or higher" if $CFClient::OpenGL::GL_VERSION < 1.2; 268 status "Fog of War smoothing requires OpenGL 1.2 or higher" if $CFClient::OpenGL::GL_VERSION < 1.2;
261 } 269 }
262 ); 270 );
263 271
264 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "GUI Fontsize"); 272 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "GUI Fontsize");
265 $table->add (1, $row++, new CFClient::UI::Slider 273 $table->add (1, $row++, new CFClient::UI::Slider
266 range => [$CFG->{gui_fontsize}, 0.5, 2, 0, 0.1], 274 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.", 275 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] }, 276 on_changed => sub { $CFG->{gui_fontsize} = $_[1] },
269 ); 277 );
270 278
271 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "Message Fontsize"); 279 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "Message Fontsize");
272 $table->add (1, $row++, new CFClient::UI::Slider 280 $table->add (1, $row++, new CFClient::UI::Slider
273 range => [$CFG->{log_fontsize}, 0.5, 2, 0, 0.1], 281 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.", 282 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]) }, 283 on_changed => sub { $LOGVIEW->set_fontsize ($CFG->{log_fontsize} = $_[1]) },
276 ); 284 );
277 285
278 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "Stats Fontsize"); 286 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "Stats Fontsize");
279 287
280 $table->add (1, $row++, new CFClient::UI::Slider 288 $table->add (1, $row++, new CFClient::UI::Slider
281 range => [$CFG->{stat_fontsize}, 0.5, 2, 0, 0.1], 289 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.", 290 tooltip => "The font size used by the <b>statistics window</b> only. Changes are instant.",
283 connect_changed => sub { 291 on_changed => sub {
284 $CFG->{stat_fontsize} = $_[1]; 292 $CFG->{stat_fontsize} = $_[1];
285 &set_stats_window_fontsize; 293 &set_stats_window_fontsize;
286 } 294 }
287 ); 295 );
288 296
289 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "Gauge fontsize"); 297 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "Gauge fontsize");
290 $table->add (1, $row++, new CFClient::UI::Slider 298 $table->add (1, $row++, new CFClient::UI::Slider
291 range => [$CFG->{gauge_fontsize}, 0.5, 2, 0, 0.1], 299 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.", 300 tooltip => "Adjusts the fontsize of the gauges at the bottom right. Changes are instant.",
293 connect_changed => sub { 301 on_changed => sub {
294 $CFG->{gauge_fontsize} = $_[1]; 302 $CFG->{gauge_fontsize} = $_[1];
295 &set_gauge_window_fontsize; 303 &set_gauge_window_fontsize;
296 } 304 }
297 ); 305 );
298 306
299 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "Gauge size"); 307 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "Gauge size");
300 $table->add (1, $row++, new CFClient::UI::Slider 308 $table->add (1, $row++, new CFClient::UI::Slider
301 range => [$CFG->{gauge_size}, 0.2, 0.8], 309 range => [$CFG->{gauge_size}, 0.2, 0.8],
302 tooltip => "Adjust the size of the stats gauges at the bottom right. Changes are instant.", 310 tooltip => "Adjust the size of the stats gauges at the bottom right. Changes are instant.",
303 connect_changed => sub { 311 on_changed => sub {
304 $CFG->{gauge_size} = $_[1]; 312 $CFG->{gauge_size} = $_[1];
305 $GAUGES->{win}->set_size ($WIDTH, int $HEIGHT * $CFG->{gauge_size}); 313 $GAUGES->{win}->set_size ($WIDTH, int $HEIGHT * $CFG->{gauge_size});
306 } 314 }
307 ); 315 );
308 316
309 $table->add (1, $row++, new CFClient::UI::Button 317 $table->add (1, $row++, new CFClient::UI::Button
310 expand => 1, align => 0, text => "Apply", 318 expand => 1, align => 0, text => "Apply",
311 tooltip => "Apply the video settings", 319 tooltip => "Apply the video settings",
312 connect_activate => sub { 320 on_activate => sub {
313 video_shutdown (); 321 video_shutdown ();
314 video_init (); 322 video_init ();
315 } 323 }
316 ); 324 );
317 325
318 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "Audio Enable"); 326 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "Audio Enable");
319 $table->add (1, $row++, new CFClient::UI::CheckBox 327 $table->add (1, $row++, new CFClient::UI::CheckBox
320 state => $CFG->{audio_enable}, 328 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.", 329 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 { 330 on_changed => sub {
323 $CFG->{audio_enable} = $_[1]; 331 $CFG->{audio_enable} = $_[1];
324 } 332 }
325 ); 333 );
326# $table->add (0, 9, new CFClient::UI::Label valign => 0, align => 1, text => "Effects Volume"); 334# $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 { 335# $table->add (1, 8, new CFClient::UI::Slider range => [$CFG->{effects_volume}, 0, 128, 1], on_changed => sub {
328# $CFG->{effects_volume} = $_[1]; 336# $CFG->{effects_volume} = $_[1];
329# }); 337# });
330 $table->add (0, $row, new CFClient::UI::Label valign => 0, align => 1, text => "Background Music"); 338 $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); 339 $table->add (1, $row++, my $hbox = new CFClient::UI::HBox);
332 $hbox->add (new CFClient::UI::CheckBox 340 $hbox->add (new CFClient::UI::CheckBox
333 expand => 1, state => $CFG->{bgm_enable}, 341 expand => 1, state => $CFG->{bgm_enable},
334 tooltip => "If enabled, playing of background music is enabled. If disabled, no background music will be played.", 342 tooltip => "If enabled, playing of background music is enabled. If disabled, no background music will be played.",
335 connect_changed => sub { 343 on_changed => sub {
336 $CFG->{bgm_enable} = $_[1]; 344 $CFG->{bgm_enable} = $_[1];
337 } 345 }
338 ); 346 );
339 $hbox->add (new CFClient::UI::Slider 347 $hbox->add (new CFClient::UI::Slider
340 expand => 1, range => [$CFG->{bgm_volume}, 0, 1, 0, 1/128], 348 expand => 1, range => [$CFG->{bgm_volume}, 0, 1, 0, 1/128],
341 tooltip => "The volume of the background music. Changes are instant.", 349 tooltip => "The volume of the background music. Changes are instant.",
342 connect_changed => sub { 350 on_changed => sub {
343 $CFG->{bgm_volume} = $_[1]; 351 $CFG->{bgm_volume} = $_[1];
344 CFClient::MixMusic::volume $_[1] * 128; 352 CFClient::MixMusic::volume $_[1] * 128;
345 } 353 }
346 ); 354 );
347 355
348 $table->add (1, $row++, new CFClient::UI::Button 356 $table->add (1, $row++, new CFClient::UI::Button
349 expand => 1, align => 0, text => "Apply", 357 expand => 1, align => 0, text => "Apply",
350 tooltip => "Apply the audio settings", 358 tooltip => "Apply the audio settings",
351 connect_activate => sub { 359 on_activate => sub {
352 audio_shutdown (); 360 audio_shutdown ();
353 audio_init (); 361 audio_init ();
354 } 362 }
355 ); 363 );
356 364
358 $table->add (1, $row++, my $saycmd = new CFClient::UI::Entry 366 $table->add (1, $row++, my $saycmd = new CFClient::UI::Entry
359 text => $CFG->{say_command}, 367 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. " 368 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. " 369 . "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.", 370 . "But you could also set it to <b>tell <i>playername</i></b> to only chat with that user.",
363 connect_changed => sub { 371 on_changed => sub {
364 my ($self, $value) = @_; 372 my ($self, $value) = @_;
365 $CFG->{say_command} = $value; 373 $CFG->{say_command} = $value;
366 } 374 }
367 ); 375 );
368 376
383 391
384sub make_gauge_window { 392sub make_gauge_window {
385 my $gh = int $HEIGHT * $CFG->{gauge_size}; 393 my $gh = int $HEIGHT * $CFG->{gauge_size};
386 394
387 my $win = new CFClient::UI::Frame ( 395 my $win = new CFClient::UI::Frame (
388 req_y => -1, 396 force_x => 0,
397 force_y => "max",
389 user_w => $WIDTH, 398 force_w => $WIDTH,
390 user_h => $gh, 399 force_h => $gh,
391 ); 400 );
392 401
393 $win->add (my $hbox = new CFClient::UI::HBox 402 $win->add (my $hbox = new CFClient::UI::HBox
394 children => [ 403 children => [
395 (new CFClient::UI::HBox expand => 1), 404 (new CFClient::UI::HBox expand => 1),
431 &set_gauge_window_fontsize; 440 &set_gauge_window_fontsize;
432 441
433 $win 442 $win
434} 443}
435 444
445
436sub make_stats_window { 446sub make_stats_window {
437 my $tgw = new CFClient::UI::FancyFrame title => "Stats", name => "stats_window"; 447 my $tgw = new CFClient::UI::FancyFrame
448 y => $HEIGHT * (2/8),
449 x => "max",
450 title => "Stats",
451 name => "stats_window";
438 452
439 $tgw->add (new CFClient::UI::Window child => my $vb = new CFClient::UI::VBox); 453 $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, 454 $vb->add ($STATWIDS->{title} = new CFClient::UI::Label valign => 0, align => -1, text => "Title:", expand => 1,
441 can_hover => 1, can_events => 1, 455 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."); 456 tooltip => "Your name and title. You can change your title by using the <b>title</b> command, if supported by the server.");
689 $m = [$users, $host, $uptime, $version, $desc]; 703 $m = [$users, $host, $uptime, $version, $desc];
690 704
691 $y++; 705 $y++;
692 706
693 $table->add (0, $y, new CFClient::UI::VBox children => [ 707 $table->add (0, $y, new CFClient::UI::VBox children => [
694 (new CFClient::UI::Button text => "Use", connect_activate => sub { 708 (new CFClient::UI::Button text => "Use", on_activate => sub {
695 $HOST->set_text ($CFG->{host} = $host); 709 $HOST->set_text ($CFG->{host} = $host);
696 }), 710 }),
697 (new CFClient::UI::Empty expand => 1), 711 (new CFClient::UI::Empty expand => 1),
698 ]); 712 ]);
699 713
704 } 718 }
705 }); 719 });
706} 720}
707 721
708sub server_setup { 722sub server_setup {
709 my $dialog = new CFClient::UI::FancyFrame 723 my $dialog = $SERVER_SETUP = new CFClient::UI::FancyFrame
724 x => "center",
725 y => "center",
710 name => "server_setup", 726 name => "server_setup",
711 title => "Server Setup", 727 title => "Server Setup",
712 child => (my $vbox = new CFClient::UI::VBox); 728 child => (my $vbox = new CFClient::UI::VBox),
713 729 ;
730
714 $vbox->add (my $table = new CFClient::UI::Table expand => 1, col_expand => [0, 1]); 731 $vbox->add (my $table = new CFClient::UI::Table expand => 1, col_expand => [0, 1]);
715 $table->add (0, 2, new CFClient::UI::Label valign => 0, align => 1, text => "Host:Port"); 732 $table->add (0, 2, new CFClient::UI::Label valign => 0, align => 1, text => "Host:Port");
716 733
717 { 734 {
718 $table->add (1, 2, my $vbox = new CFClient::UI::VBox); 735 $table->add (1, 2, my $vbox = new CFClient::UI::VBox);
720 $vbox->add ( 737 $vbox->add (
721 my $HOST = new CFClient::UI::Entry 738 my $HOST = new CFClient::UI::Entry
722 expand => 1, 739 expand => 1,
723 text => $CFG->{host}, 740 text => $CFG->{host},
724 tooltip => "The hostname or ip address of the Crossfire(+) server to connect to", 741 tooltip => "The hostname or ip address of the Crossfire(+) server to connect to",
725 connect_changed => sub { 742 on_changed => sub {
726 my ($self, $value) = @_; 743 my ($self, $value) = @_;
727 $CFG->{host} = $value; 744 $CFG->{host} = $value;
728 } 745 }
729 ); 746 );
730 747
733 $vbox->add (new CFClient::UI::Flopper 750 $vbox->add (new CFClient::UI::Flopper
734 expand => 1, 751 expand => 1,
735 text => "Server List", 752 text => "Server List",
736 other => $METASERVER, 753 other => $METASERVER,
737 tooltip => "Show a list of available crossfire servers", 754 tooltip => "Show a list of available crossfire servers",
738 connect_open => sub { 755 on_open => sub {
739 update_metaserver $HOST; 756 update_metaserver $HOST;
740 } 757 }
741 ); 758 );
742 } 759 }
743 760
744 $table->add (0, 4, new CFClient::UI::Label valign => 0, align => 1, text => "Username"); 761 $table->add (0, 4, new CFClient::UI::Label valign => 0, align => 1, text => "Username");
745 $table->add (1, 4, new CFClient::UI::Entry 762 $table->add (1, 4, new CFClient::UI::Entry
746 text => $CFG->{user}, 763 text => $CFG->{user},
747 tooltip => "The name of your character on the server", 764 tooltip => "The name of your character on the server",
748 connect_changed => sub { 765 on_changed => sub {
749 my ($self, $value) = @_; 766 my ($self, $value) = @_;
750 $CFG->{user} = $value; 767 $CFG->{user} = $value;
751 } 768 }
752 ); 769 );
753 770
754 $table->add (0, 5, new CFClient::UI::Label valign => 0, align => 1, text => "Password"); 771 $table->add (0, 5, new CFClient::UI::Label valign => 0, align => 1, text => "Password");
755 $table->add (1, 5, new CFClient::UI::Entry 772 $table->add (1, 5, new CFClient::UI::Entry
756 text => $CFG->{password}, 773 text => $CFG->{password},
757 hidden => 1, 774 hidden => 1,
758 tooltip => "The password for your character", 775 tooltip => "The password for your character",
759 connect_changed => sub { 776 on_changed => sub {
760 my ($self, $value) = @_; 777 my ($self, $value) = @_;
761 $CFG->{password} = $value; 778 $CFG->{password} = $value;
762 } 779 }
763 ); 780 );
764 781
765 $table->add (0, 7, new CFClient::UI::Label valign => 0, align => 1, text => "Map Size"); 782 $table->add (0, 7, new CFClient::UI::Label valign => 0, align => 1, text => "Map Size");
766 $table->add (1, 7, new CFClient::UI::Slider 783 $table->add (1, 7, new CFClient::UI::Slider
767 req_w => 100, 784 force_w => 100,
768 range => [$CFG->{mapsize}, 10, 100, 0, 1], 785 range => [$CFG->{mapsize}, 10, 100, 0, 1],
769 tooltip => "This is the size of the portion of the map update the server sends you. " 786 tooltip => "This is the size of the portion of the map update the server sends you. "
770 . "If you set this to a high value you will be able to see further, " 787 . "If you set this to a high value you will be able to see further, "
771 . "but you also increase bandwidth requirements and latency. " 788 . "but you also increase bandwidth requirements and latency. "
772 . "This option is only used once at log-in.", 789 . "This option is only used once at log-in.",
773 connect_changed => sub { 790 on_changed => sub {
774 my ($self, $value) = @_; 791 my ($self, $value) = @_;
775 792
776 $CFG->{mapsize} = $self->{range}[0] = $value = int $value; 793 $CFG->{mapsize} = $self->{range}[0] = $value = int $value;
777 }, 794 },
778 ); 795 );
785 . "This might increase or create lag, but increases the chances " 802 . "This might increase or create lag, but increases the chances "
786 . "of faces being ready for display when you encounter them. " 803 . "of faces being ready for display when you encounter them. "
787 . "It also uses up server bandwidth on every connect, " 804 . "It also uses up server bandwidth on every connect, "
788 . "so only set it if you really need to prefetch images. " 805 . "so only set it if you really need to prefetch images. "
789 . "This option can be set and unset any time.", 806 . "This option can be set and unset any time.",
790 connect_changed => sub { $CFG->{face_prefetch} = $_[1] }, 807 on_changed => sub { $CFG->{face_prefetch} = $_[1] },
791 ); 808 );
792 809
793 $table->add (0, 9, new CFClient::UI::Label valign => 0, align => 1, text => "Output-Count"); 810 $table->add (0, 9, new CFClient::UI::Label valign => 0, align => 1, text => "Output-Count");
794 $table->add (1, 9, new CFClient::UI::Entry 811 $table->add (1, 9, new CFClient::UI::Entry
795 text => $CFG->{output_count}, 812 text => $CFG->{output_count},
796 tooltip => "Should be set to 1 unless you know what you are doing. This option is only used once at log-in.", 813 tooltip => "Should be set to 1 unless you know what you are doing. This option is only used once at log-in.",
797 connect_changed => sub { $CFG->{output_count} = $_[1] }, 814 on_changed => sub { $CFG->{output_count} = $_[1] },
798 ); 815 );
799 816
800 $table->add (0, 10, new CFClient::UI::Label valign => 0, align => 1, text => "Output-Sync"); 817 $table->add (0, 10, new CFClient::UI::Label valign => 0, align => 1, text => "Output-Sync");
801 $table->add (1, 10, new CFClient::UI::Entry 818 $table->add (1, 10, new CFClient::UI::Entry
802 text => $CFG->{output_sync}, 819 text => $CFG->{output_sync},
803 tooltip => "Should be set to 1 unless you know what you are doing. This option is only used once at log-in.", 820 tooltip => "Should be set to 1 unless you know what you are doing. This option is only used once at log-in.",
804 connect_changed => sub { $CFG->{output_sync} = $_[1] }, 821 on_changed => sub { $CFG->{output_sync} = $_[1] },
805 ); 822 );
806 823
807 $table->add (1, 11, $LOGIN_BUTTON = new CFClient::UI::Button 824 $table->add (1, 11, $LOGIN_BUTTON = new CFClient::UI::Button
808 expand => 1, 825 expand => 1,
809 align => 0, 826 align => 0,
810 text => "Login", 827 text => "Login",
811 connect_activate => sub { 828 on_activate => sub {
812 $CONN ? stop_game 829 $CONN ? stop_game
813 : start_game; 830 : start_game;
814 }, 831 },
815 ); 832 );
816 833
821 my $window = new CFClient::UI::FancyFrame 838 my $window = new CFClient::UI::FancyFrame
822 name => "message_window", 839 name => "message_window",
823 title => "Messages", 840 title => "Messages",
824 border_bg => [1, 1, 1, 1], 841 border_bg => [1, 1, 1, 1],
825 bg => [0, 0, 0, 0.75], 842 bg => [0, 0, 0, 0.75],
843 x => "max",
844 y => 0,
826 user_w => int $::WIDTH / 3, 845 force_w => $::WIDTH / 3,
827 user_h => int $::HEIGHT / 5, 846 force_h => $::HEIGHT / 5,
828 child => (my $vbox = new CFClient::UI::VBox); 847 child => (my $vbox = new CFClient::UI::VBox);
829 848
830 $vbox->add ($LOGVIEW); 849 $vbox->add ($LOGVIEW);
831 850
832 $vbox->add (my $input = new CFClient::UI::Entry 851 $vbox->add (my $input = new CFClient::UI::Entry
833 tooltip => "<b>Chat Box</b>. If you enter a text and press return/enter here, the current <i>communication command</i> " 852 tooltip => "<b>Chat Box</b>. If you enter a text and press return/enter here, the current <i>communication command</i> "
834 . "from the client setup will be prepended (e.g. <b>shout</b>, <b>chat</b>...). " 853 . "from the client setup will be prepended (e.g. <b>shout</b>, <b>chat</b>...). "
835 . "If you prepend a slash (/), you will submit a command instead (similar to IRC). " 854 . "If you prepend a slash (/), you will submit a command instead (similar to IRC). "
836 . "A better way to submit commands (and the occasional chat command) is often the map command completer.", 855 . "A better way to submit commands (and the occasional chat command) is often the map command completer.",
837 connect_focus_in => sub { 856 on_focus_in => sub {
838 my ($input, $prev_focus) = @_; 857 my ($input, $prev_focus) = @_;
839 858
840 delete $input->{refocus_map}; 859 delete $input->{refocus_map};
841 860
842 if ($prev_focus == $MAPWIDGET && $input->{auto_activated}) { 861 if ($prev_focus == $MAPWIDGET && $input->{auto_activated}) {
843 $input->{refocus_map} = 1; 862 $input->{refocus_map} = 1;
844 } 863 }
845 delete $input->{auto_activated}; 864 delete $input->{auto_activated};
846 }, 865 },
847 connect_activate => sub { 866 on_activate => sub {
848 my ($input, $text) = @_; 867 my ($input, $text) = @_;
849 $input->set_text (''); 868 $input->set_text ('');
850 869
870 if ($text =~ /^\/bind\s+(.*)$/) {
871 CFClient::Binder::open_binding_dialog (sub {
872 my ($mod, $sym) = @_;
873 $::CFG->{bindings}->{$mod}->{$sym} = [$1];
874 });
851 if ($text =~ /^\/(.*)/) { 875 } elsif ($text =~ /^\/(.*)/) {
852 $::CONN->user_send ($1); 876 $::CONN->user_send ($1);
853 } else { 877 } else {
854 my $say_cmd = $::CFG->{say_command} || 'say'; 878 my $say_cmd = $::CFG->{say_command} || 'say';
855 $::CONN->user_send ("$say_cmd $text"); 879 $::CONN->user_send ("$say_cmd $text");
856 } 880 }
857 if ($input->{refocus_map}) { 881 if ($input->{refocus_map}) {
858 delete $input->{refocus_map}; 882 delete $input->{refocus_map};
859 $MAPWIDGET->focus_in 883 $MAPWIDGET->focus_in
860 } 884 }
861 }, 885 },
862 connect_escape => sub { 886 on_escape => sub {
863 $MAPWIDGET->focus_in 887 $MAPWIDGET->focus_in
864 }, 888 },
865 ); 889 );
866 890
867 $CONSOLE = { 891 $CONSOLE = {
868 window => $window, 892 window => $window,
869 input => $input 893 input => $input,
870 }; 894 };
871 895
872 $window 896 $window
873} 897}
874 898
875sub open_quit_dialog { 899sub open_quit_dialog {
876 unless ($QUIT_DIALOG) { 900 unless ($QUIT_DIALOG) {
877
878 $QUIT_DIALOG = new CFClient::UI::FancyFrame title => "Really Quit?"; 901 $QUIT_DIALOG = new CFClient::UI::FancyFrame
902 x => "center",
903 y => "center",
904 title => "Really Quit?",
905 ;
879 906
880 $QUIT_DIALOG->add (my $vb = new CFClient::UI::VBox expand => 1); 907 $QUIT_DIALOG->add (my $vb = new CFClient::UI::VBox expand => 1);
881 908
882 $vb->add (new CFClient::UI::Label 909 $vb->add (new CFClient::UI::Label
883 text => "You should find a savebed and apply it first!", 910 text => "You should find a savebed and apply it first!",
886 ); 913 );
887 $vb->add (my $hb = new CFClient::UI::HBox expand => 1); 914 $vb->add (my $hb = new CFClient::UI::HBox expand => 1);
888 $hb->add (new CFClient::UI::Button 915 $hb->add (new CFClient::UI::Button
889 text => "Ok", 916 text => "Ok",
890 expand => 1, 917 expand => 1,
891 connect_activate => sub { $QUIT_DIALOG->hide }, 918 on_activate => sub { $QUIT_DIALOG->hide },
892 ); 919 );
893 $hb->add (new CFClient::UI::Button 920 $hb->add (new CFClient::UI::Button
894 text => "Quit anyway", 921 text => "Quit anyway",
895 expand => 1, 922 expand => 1,
896 connect_activate => sub { exit }, 923 on_activate => sub { exit },
897 ); 924 );
925 }
898 926
899 $QUIT_DIALOG->show_centered; 927 $QUIT_DIALOG->show;
900 } else {
901 $QUIT_DIALOG->show_centered;
902 }
903} 928}
904 929
905sub make_inventory_window { 930sub make_inventory_window {
906 my $invwin = new CFClient::UI::FancyFrame 931 my $invwin = $INV_WINDOW = new CFClient::UI::FancyFrame
907 user_w => $WIDTH * (7/8), user_h => $HEIGHT * (7/8), title => "Inventory", name => "inventory_window"; 932 x => "center",
933 y => "center",
934 force_w => $WIDTH * 9/10,
935 force_h => $HEIGHT * 9/10,
936 title => "Inventory",
937 ;
908 938
909 $invwin->add (my $hb = new CFClient::UI::HBox expand => 1); 939 $invwin->add (my $hb = new CFClient::UI::HBox homogeneous => 1);
910 940
911 $hb->add (my $vb1 = new CFClient::UI::VBox expand => 1); 941 $hb->add (my $vb1 = new CFClient::UI::VBox);
912 $vb1->add (my $lbl = new CFClient::UI::Label align => 0); 942 $vb1->add (new CFClient::UI::Label align => 0, text => "Player");
913 $lbl->set_text ("Player");
914 $vb1->add ($INV = new CFClient::UI::Inventory expand => 1); 943 $vb1->add ($INV = new CFClient::UI::Inventory expand => 1);
915 944
916 $hb->add (my $vb2 = new CFClient::UI::VBox expand => 1); 945 $hb->add (my $vb2 = new CFClient::UI::VBox);
946
947 $vb2->add ($INV_RIGHT_HB = new CFClient::UI::HBox);
948
949 $vb2->add ($INVR = new CFClient::UI::Inventory expand => 1);
950
951 # XXX: Call after $INVR = ... because set_opencont sets the items
952 CFClient::Protocol::set_opencont ($::CONN, 0, "Floor");
953
954 $invwin
955}
956
957sub make_spell_list {
958 $SPELL_LIST = new CFClient::UI::SpellList
959 force_w => $WIDTH * (9/10),
960 force_h => $HEIGHT * (9/10);
961 $SPELL_LIST
962}
963
964sub make_binding_window {
965 my $binding_list = new CFClient::UI::VBox;
966
967 my $refresh;
968 $refresh = sub {
969 $binding_list->clear ();
970
971 for my $mod (keys %{$::CFG->{bindings}}) {
972 for my $sym (keys %{$::CFG->{bindings}->{$mod}}) {
973 my $cmds = $::CFG->{bindings}->{$mod}->{$sym};
974 next unless ref $cmds eq 'ARRAY' and @$cmds > 0;
975
976 my $lbl = join "; ", @$cmds;
977 my $nam = CFClient::Binder::keycombo_to_name ($mod, $sym);
978 $binding_list->add (my $hb = new CFClient::UI::HBox);
979 $hb->add (new CFClient::UI::Button
980 text => "delete",
981 tooltip => "Deletes the binding",
982 on_activate => sub {
983 $binding_list->remove ($hb);
984 delete $::CFG->{bindings}->{$mod}->{$sym};
985 });
986
987 $hb->add (new CFClient::UI::Button
988 text => "edit",
989 tooltip => "Edits the binding",
990 on_activate => sub {
991 $::BIND_EDITOR->set_binding (
992 $mod, $sym, $::CFG->{bindings}->{$mod}->{$sym},
993 sub {
994 my ($nmod, $nsym, $ncmds) = @_;
995 delete $::CFG->{bindings}->{$mod}->{$sym};
996 $::CFG->{bindings}->{$nmod}->{$nsym} = $ncmds;
997 $refresh->();
998 $::BIND_WINDOW->show;
999 },
1000 sub {
1001 $::BIND_WINDOW->show;
1002 });
1003 $::BIND_EDITOR->show;
1004 $::BIND_WINDOW->hide;
1005 });
1006
1007 $hb->add (new CFClient::UI::Label text => "(Key: $nam)");
1008 $hb->add (new CFClient::UI::Label text => $lbl, expand => 1);
1009 }
1010 }
1011 };
1012
1013 $BIND_WINDOW = new CFClient::UI::FancyFrame
1014 title => "Bindings",
1015 x => "center",
1016 y => "center",
1017 def_w => int $WIDTH * 9/10,
1018 def_h => int $HEIGHT * 9/10,
1019 on_visibility_change => sub {
1020 my ($self, $visible) = @_;
1021 $refresh->() if $visible;
1022 };
1023
1024 $BIND_WINDOW->add (my $vb = new CFClient::UI::VBox);
1025 $vb->add ($binding_list);
917 $vb2->add (my $hb2 = new CFClient::UI::HBox); 1026 $vb->add (my $hb = new CFClient::UI::HBox);
918 $hb2->add (new CFClient::UI::Button 1027 $hb->add (new CFClient::UI::Button
919 text => "Close", 1028 text => "record new",
920 tooltip => "Close the currently open container (if one is open)", 1029 expand => 1,
1030 tooltip => "This button opens the binding editor with an empty binding.",
921 connect_activate => sub { 1031 on_activate => sub {
922 $CONN->send ("apply $CONN->{open_container}") 1032 $::BIND_EDITOR->set_binding (undef, undef, [],
923 if $CONN->{open_container} != 0; 1033 sub {
1034 my ($mod, $sym, $cmds) = @_;
1035 $::CFG->{bindings}->{$mod}->{$sym} = $cmds;
1036 $refresh->();
1037 $::BIND_WINDOW->show;
1038 },
1039 sub {
1040 $::BIND_WINDOW->show;
1041 });
1042 $::BIND_WINDOW->hide;
1043 $::BIND_EDITOR->show;
924 }, 1044 },
925 ); 1045 );
926 $hb2->add ($INVR_LBL = new CFClient::UI::Label align => 0); 1046 $hb->add (new CFClient::UI::Button
1047 text => "close",
1048 tooltip => "Closes the binding window",
1049 expand => 1,
1050 on_activate => sub {
1051 $::BIND_WINDOW->hide;
1052 }
1053 );
927 1054
928 $INVR_LBL->set_text ("Floor"); 1055 $refresh->();
929 $vb2->add ($INVR = new CFClient::UI::Inventory expand => 1); 1056 $BIND_WINDOW
930
931 $invwin
932} 1057}
933 1058
934sub make_help_window { 1059sub make_help_window {
935 my $win = new CFClient::UI::FancyFrame 1060 my $win = new CFClient::UI::FancyFrame
936 user_w => $WIDTH * (7/8), user_h => $HEIGHT * (7/8), title => "Documentation"; 1061 def_w => int $WIDTH * 7/8,
1062 def_h => int $HEIGHT * 7/8,
1063 title => "Documentation";
937 1064
938 $win->add (my $vbox = new CFClient::UI::VBox); 1065 $win->add (my $vbox = new CFClient::UI::VBox);
939 1066
940 $vbox->add (my $buttons = new CFClient::UI::HBox); 1067 $vbox->add (my $buttons = new CFClient::UI::HBox);
941 $vbox->add (my $viewer = new CFClient::UI::TextView expand => 1, fontsize => 0.8); 1068 $vbox->add (my $viewer = new CFClient::UI::TextView expand => 1, fontsize => 0.8);
948 ) { 1075 ) {
949 my ($pod, $label) = @$_; 1076 my ($pod, $label) = @$_;
950 1077
951 $buttons->add (new CFClient::UI::Button 1078 $buttons->add (new CFClient::UI::Button
952 text => $label, 1079 text => $label,
953 connect_activate => sub { 1080 on_activate => sub {
954 my $parser = new Pod::POM; 1081 my $parser = new Pod::POM;
955 my $pom = $parser->parse_file (CFClient::find_rcfile "pod/$pod.pod"); 1082 my $pom = $parser->parse_file (CFClient::find_rcfile "pod/$pod.pod");
956 1083
957 $viewer->clear; 1084 $viewer->clear;
958 1085
1002 if ($DEBUG_STATUS) { 1129 if ($DEBUG_STATUS) {
1003 CFClient::UI::rescale_widgets $WIDTH / $old_w, $HEIGHT / $old_h; 1130 CFClient::UI::rescale_widgets $WIDTH / $old_w, $HEIGHT / $old_h;
1004 } else { 1131 } else {
1005 # create the widgets 1132 # create the widgets
1006 1133
1007 $DEBUG_STATUS = new CFClient::UI::Label padding => 0, z => 100, req_x => -1; 1134 $DEBUG_STATUS = new CFClient::UI::Label
1135 padding => 0,
1136 z => 100,
1137 force_x => "max",
1138 force_y => 0;
1008 $DEBUG_STATUS->show; 1139 $DEBUG_STATUS->show;
1009 1140
1141 $BIND_EDITOR = new CFClient::UI::BindEditor (x => "max", y => 0);
1142
1010 $STATUSBOX = new CFClient::UI::Statusbox; 1143 $STATUSBOX = new CFClient::UI::Statusbox;
1011 $STATUSBOX->add ("Use <b>Alt-Enter</b> to toggle fullscreen mode", pri => -100, color => [1, 1, 1, 0.8]); 1144 $STATUSBOX->add ("Use <b>Alt-Enter</b> to toggle fullscreen mode", pri => -100, color => [1, 1, 1, 0.8]);
1012 1145
1013 (new CFClient::UI::Frame 1146 (new CFClient::UI::Frame
1014 bg => [0, 0, 0, 0.4], 1147 bg => [0, 0, 0, 0.4],
1015 req_y => -1, 1148 force_x => 0,
1149 force_y => "max",
1016 child => $STATUSBOX, 1150 child => $STATUSBOX,
1017 )->show; 1151 )->show;
1018 1152
1019 CFClient::UI::FancyFrame->new ( 1153 CFClient::UI::FancyFrame->new (
1154 x => 0,
1155 y => $FONTSIZE + 8,
1020 border_bg => [1, 1, 1, 192/255], 1156 border_bg => [1, 1, 1, 192/255],
1021 bg => [1, 1, 1, 0], 1157 bg => [1, 1, 1, 0],
1022 child => ($MAPMAP = new CFClient::MapWidget::MapMap 1158 child => ($MAPMAP = new CFClient::MapWidget::MapMap
1023 tooltip => "<b>Map</b>. On servers that support this feature, this will display an overview of the surrounding areas.", 1159 tooltip => "<b>Map</b>. On servers that support this feature, this will display an overview of the surrounding areas.",
1024 ), 1160 ),
1047 can_hover => 1, 1183 can_hover => 1,
1048 can_events => 1, 1184 can_events => 1,
1049 tooltip => "<b>Server Log</b>. This text viewer contains all the messages sent by the server.", 1185 tooltip => "<b>Server Log</b>. This text viewer contains all the messages sent by the server.",
1050 ; 1186 ;
1051 1187
1052 $BUTTONBAR = new CFClient::UI::HBox; 1188 $BUTTONBAR = new CFClient::UI::HBox x => 0, y => 0;
1053 1189
1054 $BUTTONBAR->add (new CFClient::UI::Flopper text => "Client Setup", other => client_setup, 1190 $BUTTONBAR->add (new CFClient::UI::Flopper text => "Client Setup", other => client_setup,
1055 tooltip => "Toggles a dialog where you can configure various aspects of the client, such as graphics mode, performance, and audio options."); 1191 tooltip => "Toggles a dialog where you can configure various aspects of the client, such as graphics mode, performance, and audio options.");
1056 $BUTTONBAR->add (new CFClient::UI::Flopper text => "Server Setup", other => server_setup, 1192 $BUTTONBAR->add (new CFClient::UI::Flopper text => "Server Setup", other => server_setup,
1057 tooltip => "Toggles a dialog where you can configure the server to play on, your username, password and other server-related options."); 1193 tooltip => "Toggles a dialog where you can configure the server to play on, your username, password and other server-related options.");
1061 make_gauge_window->show; # XXX: this has to be set before make_stats_window as make_stats_window calls update_stats_window which updated the gauges also X-D 1197 make_gauge_window->show; # XXX: this has to be set before make_stats_window as make_stats_window calls update_stats_window which updated the gauges also X-D
1062 1198
1063 $BUTTONBAR->add (new CFClient::UI::Flopper text => "Stats Window", other => make_stats_window, 1199 $BUTTONBAR->add (new CFClient::UI::Flopper text => "Stats Window", other => make_stats_window,
1064 tooltip => "Toggles the statistics window, where all your Stats and Resistances are being displayed at all times."); 1200 tooltip => "Toggles the statistics window, where all your Stats and Resistances are being displayed at all times.");
1065 $BUTTONBAR->add (new CFClient::UI::Flopper text => "Inventory", other => make_inventory_window, 1201 $BUTTONBAR->add (new CFClient::UI::Flopper text => "Inventory", other => make_inventory_window,
1066 tooltip => "Toggles the inventory window, where you can manage your loot (or treaures :)."); 1202 tooltip => "Toggles the inventory window, where you can manage your loot (or treaures :)."
1203 ."You can also hit the Tab-key to show/hide the Inventory.");
1067 1204
1068 $BUTTONBAR->add (new CFClient::UI::Button 1205 $BUTTONBAR->add (new CFClient::UI::Button
1069 text => "Save Config", 1206 text => "Save Config",
1070 tooltip => "Saves the options chosen in the client setting, server settings and the window layout to be restored on later runs.", 1207 tooltip => "Saves the options chosen in the client setting, server settings and the window layout to be restored on later runs.",
1071 connect_activate => sub { 1208 on_activate => sub {
1072 $::CFG->{layout} = CFClient::UI::get_layout; 1209 $::CFG->{layout} = CFClient::UI::get_layout;
1073 CFClient::write_cfg "$Crossfire::VARDIR/pclientrc"; 1210 CFClient::write_cfg "$Crossfire::VARDIR/cfplusrc";
1074 status "Configuration Saved"; 1211 status "Configuration Saved";
1075 }, 1212 },
1076 ); 1213 );
1077 1214
1078 $BUTTONBAR->add (new CFClient::UI::Flopper text => "Help!", other => make_help_window, 1215 $BUTTONBAR->add (new CFClient::UI::Flopper text => "Help!", other => make_help_window,
1079 tooltip => "View Documentation"); 1216 tooltip => "View Documentation");
1080 1217
1218 $BUTTONBAR->add (new CFClient::UI::Flopper
1219 text => "Bindings",
1220 other => make_binding_window,
1221 tooltip =>
1222 "Lets you define, edit and delete bindings."
1223 ."There is a shortcut for making bindings: LCTRL+Insert opens the binding editor "
1224 ."with nothing set and the recording started. After doing the actions you "
1225 ."want to record press Insert and you will be asked to press a key-combo."
1226 ."After pressing the combo the binding will be saved automatically and the "
1227 ."binding editor closes");
1228
1229 $BUTTONBAR->add (new CFClient::UI::Flopper
1230 text => "Spells",
1231 other => make_spell_list,
1232 tooltip => "The spell list");
1233
1081 $BUTTONBAR->add (new CFClient::UI::Button 1234 $BUTTONBAR->add (new CFClient::UI::Button
1082 text => "Quit", 1235 text => "Quit",
1083 tooltip => "Terminates the program", 1236 tooltip => "Terminates the program",
1084 connect_activate => sub { 1237 on_activate => sub {
1085 if ($CONN) { 1238 if ($CONN) {
1086 open_quit_dialog; 1239 open_quit_dialog;
1087 } else { 1240 } else {
1088 exit; 1241 exit;
1089 } 1242 }
1090 }, 1243 },
1091 ); 1244 );
1092 1245
1093 $BUTTONBAR->show; 1246 $BUTTONBAR->show;
1247 $SERVER_SETUP->show;
1094 1248
1095 $STATUSBOX->add ("Set video mode $WIDTH×$HEIGHT", timeout => 10, fg => [1, 1, 1, 0.5]); 1249 $STATUSBOX->add ("Set video mode $WIDTH×$HEIGHT", timeout => 10, fg => [1, 1, 1, 0.5]);
1096
1097 # delay till geometry is constant
1098 $CFClient::UI::ROOT->on_post_alloc (startup => sub {
1099 $BUTTONBAR->{children}[1]->emit ("activate"); # pop up server setup
1100 my $widget = $GAUGES->{win};
1101 $widget->move (0, $HEIGHT - $widget->{h});#d# to in toplevel
1102 });
1103 force_refresh ();
1104 } 1250 }
1105} 1251}
1106 1252
1107sub video_shutdown { 1253sub video_shutdown {
1108 undef $SDL_ACTIVE; 1254 undef $SDL_ACTIVE;
1176 1322
1177my %demo;#d# 1323my %demo;#d#
1178 1324
1179sub force_refresh { 1325sub force_refresh {
1180 $fps = $fps * 0.95 + 1 / (($NOW - $LAST_REFRESH) || 0.1) * 0.05; 1326 $fps = $fps * 0.95 + 1 / (($NOW - $LAST_REFRESH) || 0.1) * 0.05;
1181 debug sprintf "%3.2f", $fps; 1327 debug sprintf "%3.2f", $fps if $ENV{CFPLUS_DEBUG} & 4;
1182 1328
1183 $CFClient::UI::ROOT->draw; 1329 $CFClient::UI::ROOT->draw;
1184 1330
1185 $WANT_REFRESH = 0; 1331 $WANT_REFRESH = 0;
1186 $CAN_REFRESH = 0; 1332 $CAN_REFRESH = 0;
1318############################################################################# 1464#############################################################################
1319 1465
1320$SIG{INT} = $SIG{TERM} = sub { exit }; 1466$SIG{INT} = $SIG{TERM} = sub { exit };
1321 1467
1322{ 1468{
1323 local $SIG{__DIE__} = sub { CFClient::fatal $_[0] }; 1469 local $SIG{__DIE__} = sub { CFClient::fatal $_[0] if defined $^S && !$^S };
1324 1470
1325 CFClient::read_cfg "$Crossfire::VARDIR/pclientrc"; 1471 CFClient::read_cfg "$Crossfire::VARDIR/cfplusrc";
1326 CFClient::UI::set_layout ($::CFG->{layout}); 1472 CFClient::UI::set_layout ($::CFG->{layout});
1327 1473
1328 my %DEF_CFG = ( 1474 my %DEF_CFG = (
1329 sdl_mode => 0, 1475 sdl_mode => 0,
1330 width => 640, 1476 width => 640,
1408 1554
1409END { CFClient::SDL_Quit } 1555END { CFClient::SDL_Quit }
1410 1556
1411=head1 NAME 1557=head1 NAME
1412 1558
1413pclient - A Crossfire+ and Crossfire game client 1559cfplus - A Crossfire+ and Crossfire game client
1414 1560
1415=head1 SYNOPSIS 1561=head1 SYNOPSIS
1416 1562
1417Just run it - no commandline arguments are supported. 1563Just run it - no commandline arguments are supported.
1418 1564
1419=head1 USAGE 1565=head1 USAGE
1420 1566
1421Pclient utilises OpenGL for all UI elements and the game. It is supposed to be used 1567cfplus utilises OpenGL for all UI elements and the game. It is supposed to be used
1422fullscreen and interactively. 1568fullscreen and interactively.
1423 1569
1424=head1 AUTHOR 1570=head1 AUTHOR
1425 1571
1426Marc Lehmann <crossfire@schmorp.de>, Robin Redeker <elmex@ta-sa.org> 1572Marc Lehmann <crossfire@schmorp.de>, Robin Redeker <elmex@ta-sa.org>

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines