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.209 by root, Sat Aug 11 14:41:38 2007 UTC vs.
Revision 1.218 by root, Sun Aug 19 14:17:05 2007 UTC

167our $STATUSBOX; 167our $STATUSBOX;
168our $DEBUG_STATUS; 168our $DEBUG_STATUS;
169 169
170our $INV; 170our $INV;
171our $INVR; 171our $INVR;
172our $INV_RIGHT_HB; 172our $INVR_HB;
173
174our $PICKUP_CFG;
175 173
176############################################################################# 174#############################################################################
177 175
178sub status { 176sub status {
179 $STATUSBOX->add (CFPlus::asxml $_[0], pri => -10, group => "status", timeout => 10, fg => [1, 1, 0, 1]); 177 $STATUSBOX->add (CFPlus::asxml $_[0], pri => -10, group => "status", timeout => 10, fg => [1, 1, 0, 1]);
263 or return; 261 or return;
264 $CFG->{effects_enable} 262 $CFG->{effects_enable}
265 or return; 263 or return;
266 264
267 my $queue = $AUDIO_PLAY{$face} ||= []; 265 my $queue = $AUDIO_PLAY{$face} ||= [];
268 push @$queue, [Event::time + 0.2, $dx, $dy, $vol]; # delay sound by max. 0.2s 266 push @$queue, [Event::time + 0.6, $dx, $dy, $vol]; # do not play sound for outdated events
269 audio_sound_push $face 267 audio_sound_push $face
270 unless @$queue > 1; 268 unless @$queue > 1;
271} 269}
272 270
273sub audio_music_set_meta { 271sub audio_music_set_meta {
769 state => $CFG->{fullscreen}, 767 state => $CFG->{fullscreen},
770 tooltip => "Bring the client into fullscreen mode.", 768 tooltip => "Bring the client into fullscreen mode.",
771 on_changed => sub { my ($self, $value) = @_; $CFG->{fullscreen} = $value; 0 } 769 on_changed => sub { my ($self, $value) = @_; $CFG->{fullscreen} = $value; 0 }
772 ); 770 );
773 771
772 $table->add_at (0, $row, new CFPlus::UI::Label valign => 0, align => 1, text => "Force OpenGL 1.1");
773 $table->add_at (1, $row++, new CFPlus::UI::CheckBox
774 state => $CFG->{force_opengl11},
775 tooltip => "Limit CFPlus to use OpenGL 1.1 features only. This will normally result in "
776 . "higher memory usage and slower performance. It will, however, help tremendously on "
777 . "cards that claim to support a feature but fall back to software rendering. "
778 . "Nvidia Geforce FX cards are known to claim features the hardware doesn't support, "
779 . "but cards and drivers from other vendors (ATI) are often just as bad. <b>If you "
780 . "experience extremely low framerates and your card should do better, try this option.</b>",
781 on_changed => sub { my ($self, $value) = @_; $CFG->{force_opengl11} = $value; 0 }
782 );
783
784 $table->add_at (0, $row, new CFPlus::UI::Label valign => 0, align => 1, text => "Compress Textures");
785 $table->add_at (1, $row++, new CFPlus::UI::CheckBox
786 state => $CFG->{texture_compression},
787 tooltip => "Use texture compression. Normally this will not reduce visual quality noticable but "
788 . "will save a lot of memory and increase performance. The compression algorithm "
789 . "can differ form card to card, so your mileage may vary. This setting is ignored in "
790 . "forced OpenGL 1.1 mode.",
791 on_changed => sub { my ($self, $value) = @_; $CFG->{texture_compression} = $value; 0 }
792 );
793
774 $table->add_at (0, $row, new CFPlus::UI::Label valign => 0, align => 1, text => "Fast & Ugly"); 794 $table->add_at (0, $row, new CFPlus::UI::Label valign => 0, align => 1, text => "Fast & Ugly");
775 $table->add_at (1, $row++, new CFPlus::UI::CheckBox 795 $table->add_at (1, $row++, new CFPlus::UI::CheckBox
776 state => $CFG->{fast}, 796 state => $CFG->{fast},
777 tooltip => "Lower the visual quality considerably to speed up rendering.", 797 tooltip => "Lower the visual quality considerably to speed up rendering.",
778 on_changed => sub { my ($self, $value) = @_; $CFG->{fast} = $value; 0 } 798 on_changed => sub { my ($self, $value) = @_; $CFG->{fast} = $value; 0 }
805 $table->add_at (0, $row, new CFPlus::UI::Label valign => 0, align => 1, text => "Map Smoothing"); 825 $table->add_at (0, $row, new CFPlus::UI::Label valign => 0, align => 1, text => "Map Smoothing");
806 $table->add_at (1, $row++, new CFPlus::UI::CheckBox 826 $table->add_at (1, $row++, new CFPlus::UI::CheckBox
807 state => $CFG->{map_smoothing}, 827 state => $CFG->{map_smoothing},
808 tooltip => "<b>Map Smoothing</b> tries to make tile borders less square. " 828 tooltip => "<b>Map Smoothing</b> tries to make tile borders less square. "
809 . "This increases load on the graphics subsystem and works only with TRT servers. " 829 . "This increases load on the graphics subsystem and works only with TRT servers. "
810 . "Changes take effect at next connection only.", 830 . "Changes take effect at next login only.",
811 on_changed => sub { my ($self, $value) = @_; $CFG->{map_smoothing} = $value; 0 } 831 on_changed => sub { my ($self, $value) = @_; $CFG->{map_smoothing} = $value; 0 }
812 ); 832 );
813 833
814 $table->add_at (0, $row, new CFPlus::UI::Label valign => 0, align => 1, text => "Fog of War"); 834 $table->add_at (0, $row, new CFPlus::UI::Label valign => 0, align => 1, text => "Fog of War");
815 $table->add_at (1, $row++, new CFPlus::UI::CheckBox 835 $table->add_at (1, $row++, new CFPlus::UI::CheckBox
826 ); 846 );
827 847
828 $table->add_at (0, $row, new CFPlus::UI::Label valign => 0, align => 1, text => "Message Fontsize"); 848 $table->add_at (0, $row, new CFPlus::UI::Label valign => 0, align => 1, text => "Message Fontsize");
829 $table->add_at (1, $row++, new CFPlus::UI::Slider 849 $table->add_at (1, $row++, new CFPlus::UI::Slider
830 range => [$CFG->{log_fontsize}, 0.5, 2, 0, 0.1], 850 range => [$CFG->{log_fontsize}, 0.5, 2, 0, 0.1],
831 tooltip => "The font size used by the <b>message/server log</b> window only. Changes are instant.", 851 tooltip => "The font size used by the <b>message/server log</b> window only. Changes are instant, "
852 . "but you still need to press apply to correctly re-layout the widget.",
832 on_changed => sub { $MESSAGE_WINDOW->set_fontsize ($CFG->{log_fontsize} = $_[1]); 0 }, 853 on_changed => sub { $MESSAGE_WINDOW->set_fontsize ($CFG->{log_fontsize} = $_[1]); 0 },
833 ); 854 );
834 855
835 $table->add_at (0, $row, new CFPlus::UI::Label valign => 0, align => 1, text => "Gauge fontsize"); 856 $table->add_at (0, $row, new CFPlus::UI::Label valign => 0, align => 1, text => "Gauge fontsize");
836 $table->add_at (1, $row++, new CFPlus::UI::Slider 857 $table->add_at (1, $row++, new CFPlus::UI::Slider
1597 $sw1->add ($INV = new CFPlus::UI::Inventory); 1618 $sw1->add ($INV = new CFPlus::UI::Inventory);
1598 $INV->set_sort_order ($SORT_ORDER{$::CFG->{inv_sort}}); 1619 $INV->set_sort_order ($SORT_ORDER{$::CFG->{inv_sort}});
1599 1620
1600 $hb->add (my $vb2 = new CFPlus::UI::VBox); 1621 $hb->add (my $vb2 = new CFPlus::UI::VBox);
1601 1622
1602 $vb2->add ($INV_RIGHT_HB = new CFPlus::UI::HBox); 1623 $vb2->add ($INVR_HB = new CFPlus::UI::HBox);
1603 1624
1604 $vb2->add (my $sw2 = new CFPlus::UI::ScrolledWindow expand => 1, scroll_y => 1); 1625 $vb2->add (my $sw2 = new CFPlus::UI::ScrolledWindow expand => 1, scroll_y => 1);
1605 $sw2->add ($INVR = new CFPlus::UI::Inventory); 1626 $sw2->add ($INVR = new CFPlus::UI::Inventory);
1606 1627
1607 # XXX: Call after $INVR = ... because set_opencont sets the items 1628 # XXX: Call after $INVR = ... because set_opencont sets the items
1862 on_activate => sub { $QUIT_DIALOG->hide; 0 }, 1883 on_activate => sub { $QUIT_DIALOG->hide; 0 },
1863 ); 1884 );
1864 $hb->add (new CFPlus::UI::Button 1885 $hb->add (new CFPlus::UI::Button
1865 text => "Quit anyway", 1886 text => "Quit anyway",
1866 expand => 1, 1887 expand => 1,
1867 on_activate => sub { exit }, 1888 on_activate => sub { Event::unloop_all },
1868 ); 1889 );
1869 } 1890 }
1870 1891
1871 $QUIT_DIALOG->show; 1892 $QUIT_DIALOG->show;
1872 $QUIT_DIALOG->grab_focus; 1893 $QUIT_DIALOG->grab_focus;
2066 tooltip => "Terminates the program", 2087 tooltip => "Terminates the program",
2067 on_activate => sub { 2088 on_activate => sub {
2068 if ($CONN) { 2089 if ($CONN) {
2069 open_quit_dialog; 2090 open_quit_dialog;
2070 } else { 2091 } else {
2071 exit; 2092 Event::unloop_all;
2072 } 2093 }
2073 0 2094 0
2074 }, 2095 },
2075 ); 2096 );
2076 2097
2077 $BUTTONBAR->show; 2098 $BUTTONBAR->show;
2078 $SETUP_DIALOG->show; 2099 $SETUP_DIALOG->show;
2100 $MESSAGE_WINDOW->show;
2079 } 2101 }
2080 2102
2081 $STATUSBOX->add ("Set video mode $WIDTH×$HEIGHT", timeout => 10, fg => [1, 1, 1, 0.5]); 2103 $STATUSBOX->add ("Set video mode $WIDTH×$HEIGHT", timeout => 10, fg => [1, 1, 1, 0.5]);
2082} 2104}
2083 2105
2177 CFPlus::DB::Server::run; 2199 CFPlus::DB::Server::run;
2178 2200
2179 CFPlus::UI::set_layout ($::CFG->{layout}); 2201 CFPlus::UI::set_layout ($::CFG->{layout});
2180 2202
2181 my %DEF_CFG = ( 2203 my %DEF_CFG = (
2182 sdl_mode => 0, 2204 sdl_mode => 0,
2183 fullscreen => 0, 2205 fullscreen => 0,
2184 fast => 0, 2206 fast => 0,
2207 force_opengl11 => undef,
2208 texture_compression => 1,
2185 map_scale => 1, 2209 map_scale => 1,
2186 fow_enable => 1, 2210 fow_enable => 1,
2187 fow_intensity => 0, 2211 fow_intensity => 0,
2188 map_smoothing => 1, 2212 map_smoothing => 1,
2189 gui_fontsize => 1, 2213 gui_fontsize => 1,
2190 log_fontsize => 0.7, 2214 log_fontsize => 0.7,
2191 gauge_fontsize => 1, 2215 gauge_fontsize => 1,
2192 gauge_size => 0.35, 2216 gauge_size => 0.35,
2193 stat_fontsize => 0.7, 2217 stat_fontsize => 0.7,
2194 mapsize => 100, 2218 mapsize => 100,
2195 audio_enable => 1, 2219 audio_enable => 1,
2196 effects_enable => 1, 2220 effects_enable => 1,
2197 effects_volume => 1, 2221 effects_volume => 1,
2198 bgm_enable => 1, 2222 bgm_enable => 1,
2199 bgm_volume => 0.5, 2223 bgm_volume => 0.5,
2200 output_sync => 1, 2224 output_sync => 1,
2201 output_count => 1, 2225 output_count => 1,
2202 output_rate => "", 2226 output_rate => "",
2203 pickup => 0, 2227 pickup => 0,
2204 inv_sort => "mtime", 2228 inv_sort => "mtime",
2205 default => "profile", # default profile 2229 default => "profile", # default profile
2206 show_tips => 1, 2230 show_tips => 1,
2207 logview_max_par => 1000, 2231 logview_max_par => 1000,
2208 ); 2232 );
2209 2233
2210 while (my ($k, $v) = each %DEF_CFG) { 2234 while (my ($k, $v) = each %DEF_CFG) {
2211 $CFG->{$k} = $v unless exists $CFG->{$k}; 2235 $CFG->{$k} = $v unless exists $CFG->{$k};
2212 } 2236 }
2278} 2302}
2279 2303
2280show_tip_of_the_day if $CFG->{show_tips}; 2304show_tip_of_the_day if $CFG->{show_tips};
2281 2305
2282Event::loop; 2306Event::loop;
2307
2308#video_shutdown;
2309#audio_shutdown;
2283#CFPlus::SDL_Quit; 2310CFPlus::SDL_Quit;
2284#CFPlus::_exit 0;
2285
2286END {
2287 video_shutdown;
2288 audio_shutdown;
2289 CFPlus::SDL_Quit;
2290 CFPlus::DB::Server::stop; 2311CFPlus::DB::Server::stop;
2291}
2292 2312
2293=head1 NAME 2313=head1 NAME
2294 2314
2295cfplus - A Crossfire TRT and Crossfire game client 2315cfplus - A Crossfire TRT and Crossfire game client
2296 2316

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines