--- deliantra/Deliantra-Client/bin/cfplus 2007/07/31 02:45:39 1.198
+++ deliantra/Deliantra-Client/bin/cfplus 2007/08/06 05:06:33 1.204
@@ -146,6 +146,9 @@
our $PL_NOTEBOOK;
our $PL_WINDOW;
+our $MUSIC_PLAYING_WIDGET;
+our $LICENSE_WIDGET;
+
our $INVENTORY_PAGE;
our $STATS_PAGE;
our $SKILL_PAGE;
@@ -213,12 +216,15 @@
sub audio_sound_push($) {
my ($face) = @_;
+ $CFG->{effects_enable}
+ or return;
+
if (my $chunk = $AUDIO_CHUNK{$face}) {
for (grep $_->[0] >= Event::time, @{(delete $AUDIO_PLAY{$face}) || []}) {
my (undef, $dx, $dy, $vol) = @$_;
my $channel = CFPlus::Channel::find;
- $channel->volume ($vol * 128 / 255);
+ $channel->volume ($vol * $CFG->{effects_volume} * 128 / 255);
$dx = $dx / 10 * 255;
$channel->set_panning (255 - $dx, 255 + $dx);
@@ -235,14 +241,16 @@
# if its a jingle, play it as ambient music
if ($meta->{meta}{jingle}) {
- delete $AUDIO_PLAY{$face}; # take the jingle out of the sound queue
- push @MUSIC_JINGLE, $meta; # push it oto the music/jingle queue
- &audio_music_push ($face);
+ if (delete $AUDIO_PLAY{$face}) { # take the jingle out of the sound queue
+ push @MUSIC_JINGLE, $meta; # push it oto the music/jingle queue
+ &audio_music_push ($face);
+ }
} else {
# fetch from database
CFPlus::DB::get res_data => $meta->{name}, sub {
my $rwops = new CFPlus::RW $_[0];
- my $chunk = new CFPlus::MixChunk $rwops;
+ my $chunk = new CFPlus::MixChunk $rwops
+ or Carp::confess "sound face $meta->{face} unloadable: " . CFPlus::Mix_GetError;
$chunk->volume (($meta->{meta}{volume} || 1) * 128);
$AUDIO_CHUNK{$face} = $chunk;
@@ -257,6 +265,8 @@
$SDL_MIXER
or return;
+ $CFG->{effects_enable}
+ or return;
my $queue = $AUDIO_PLAY{$face} ||= [];
push @$queue, [Event::time + 0.2, $dx, $dy, $vol]; # delay sound by max. 0.2s
@@ -264,6 +274,18 @@
unless @$queue > 1;
}
+sub audio_music_set_meta {
+ my ($meta) = @_;
+
+ $MUSIC_PLAYING_META = $meta;
+ $MUSIC_PLAYING_WIDGET->set_markup (
+ "Name: " . (CFPlus::asxml $meta->{meta}{name}) . "\n"
+ . "Author: " . (CFPlus::asxml $meta->{meta}{author}) . "\n"
+ . "Source: " . (CFPlus::asxml $meta->{meta}{source}) . "\n"
+ . "License: " . (CFPlus::asxml $meta->{meta}{license})
+ );
+}
+
sub audio_music_update_volume {
return unless $MUSIC_PLAYING_META;
my $volume = $MUSIC_PLAYING_META->{meta}{volume} || 1;
@@ -290,7 +312,7 @@
: new CFPlus::RW $$MUSIC_PLAYING_DATA;
$MUSIC_PLAYER = new CFPlus::MixMusic $rwops
- or ((warn CFPlus::Mix_GetError), return); # pretty fatal error
+ or Carp::confess "music face $meta->{face} unloadable: " . CFPlus::Mix_GetError;
my $NOW = time;
@@ -303,8 +325,8 @@
$MUSIC_START = time;
}
- delete $MUSIC_PLAYING_META->{stop_time};
- delete $MUSIC_PLAYING_META->{stop_pos};
+ delete $meta->{stop_time};
+ delete $meta->{stop_pos};
}
}
@@ -333,8 +355,7 @@
}
# if the currently playing song is acceptable, let it continue
- return if $MUSIC_PLAYING_META
- && grep $MUSIC_PLAYING_META == $_, @MUSIC_HAVE;
+ return if grep $MUSIC_PLAYING_META == $_, @MUSIC_HAVE;
my $NOW = time;
@@ -348,7 +369,7 @@
# if the most recently-played piece played very recently,
# resume it, else choose the oldest piece for rotation.
- $MUSIC_PLAYING_META =
+ audio_music_set_meta
$MUSIC_HAVE[-1]{stop_time} > $NOW - $MUSIC_RESUME
? $MUSIC_HAVE[-1]
: $MUSIC_HAVE[0];
@@ -369,6 +390,8 @@
shift @MUSIC_JINGLE
while @MUSIC_JINGLE && $MUSIC_PLAYING_META == $MUSIC_JINGLE[0];
+ $MUSIC_PLAYING_WIDGET->clear;
+
undef $MUSIC_PLAYER;
undef $MUSIC_PLAYING_META;
undef $MUSIC_PLAYING_DATA;
@@ -841,7 +864,7 @@
sub audio_setup {
my $vbox = new CFPlus::UI::VBox;
- $vbox->add (my $table = new CFPlus::UI::Table expand => 1, col_expand => [0, 1]);
+ $vbox->add (my $table = new CFPlus::UI::Table expand => 1, col_expand => [0, 0, 1]);
my $row = 0;
@@ -855,21 +878,34 @@
# $table->add_at (1, 8, new CFPlus::UI::Slider range => [$CFG->{effects_volume}, 0, 128, 1], on_changed => sub {
# $CFG->{effects_volume} = $_[1];
# });
+
+ $table->add_at (0, $row, new CFPlus::UI::Label valign => 0, align => 1, text => "Effects Volume");
+ $table->add_at (1, $row, new CFPlus::UI::CheckBox
+ expand => 1, state => $CFG->{effects_enable},
+ tooltip => "If enabled, sound effects are enabled. If disabled, no sound effects will be played.",
+ on_changed => sub { $CFG->{effects_enable} = $_[1]; 0 }
+ );
+ $table->add_at (2, $row++, new CFPlus::UI::Slider
+ expand => 1, range => [$CFG->{effects_volume}, 0, 1, 0, 1/128],
+ tooltip => "The relative volume of sound effects. Best audio quality is achieved if this "
+ . "is set highest and you use your operating system volume setting. Changes are instant.",
+ on_changed => sub { $CFG->{effects_volume} = $_[1]; 0 }
+ );
+
$table->add_at (0, $row, new CFPlus::UI::Label valign => 0, align => 1, text => "Background Music");
- $table->add_at (1, $row++, my $hbox = new CFPlus::UI::HBox);
- $hbox->add (new CFPlus::UI::CheckBox
+ $table->add_at (1, $row, new CFPlus::UI::CheckBox
expand => 1, state => $CFG->{bgm_enable},
tooltip => "If enabled, playing of background music is enabled. If disabled, no background music will be played.",
on_changed => sub { $CFG->{bgm_enable} = $_[1]; 0 }
);
- $hbox->add (new CFPlus::UI::Slider
+ $table->add_at (2, $row++, new CFPlus::UI::Slider
expand => 1, range => [$CFG->{bgm_volume}, 0, 1, 0, 1/128],
tooltip => "The volume of the background music. Changes are instant.",
on_changed => sub { $CFG->{bgm_volume} = $_[1]; audio_music_update_volume; 0 }
);
$table->add_at (1, $row++, new CFPlus::UI::Button
- expand => 1, align => 0, text => "Apply",
+ c_colspan => 2, expand => 1, align => 0, text => "Apply",
tooltip => "Apply the audio settings",
on_activate => sub {
audio_shutdown ();
@@ -950,10 +986,10 @@
$table->add_at (0, 5, new CFPlus::UI::TextEdit text => "line1\0152\0153");#d#
$table->add_at (7,7, my $t = new CFPlus::UI::Table expand => 0);
- $t->add_at (0,0, new CFPlus::UI::Label text => "a a a a", rowspan => 1, colspan => 2);
- $t->add_at (2,0, new CFPlus::UI::Label text => "b\nb", rowspan => 2, colspan => 1);
- $t->add_at (1,2, new CFPlus::UI::Label text => "c c c c", rowspan => 1, colspan => 2);
- $t->add_at (0,1, new CFPlus::UI::Label text => "d\nd", rowspan => 2, colspan => 1);
+ $t->add_at (0,0, new CFPlus::UI::Label text => "a a a a", c_rowspan => 1, c_colspan => 2);
+ $t->add_at (2,0, new CFPlus::UI::Label text => "b\nb", c_rowspan => 2, c_colspan => 1);
+ $t->add_at (1,2, new CFPlus::UI::Label text => "c c c c", c_rowspan => 1, c_colspan => 2);
+ $t->add_at (0,1, new CFPlus::UI::Label text => "d\nd", c_rowspan => 2, c_colspan => 1);
$t->add_at (1,1, new CFPlus::UI::Label text => "e");
$table->add_at (7, 6, my $c = new CFPlus::UI::Canvas);
@@ -1570,6 +1606,46 @@
$hb
}
+sub media_window {
+ my $vb = new CFPlus::UI::VBox;
+
+ $vb->add (new CFPlus::UI::FancyFrame
+ label => "Currently playing music",
+ child => new CFPlus::UI::ScrolledWindow scroll_x => 1, scroll_y => 0,
+ child => ($MUSIC_PLAYING_WIDGET = new CFPlus::UI::Label ellipsise => 0, fontsize => 0.8),
+ );
+
+ $vb->add (new CFPlus::UI::FancyFrame
+ label => "Other media used in this session",
+ expand => 1,
+ child => ($LICENSE_WIDGET = new CFPlus::UI::TextScroller
+ expand => 1, fontsize => 0.8, padding_x => 4, padding_y => 4),
+ );
+
+ $vb
+}
+
+sub add_license {
+ my ($meta) = @_;
+
+ $meta = $meta->{meta}
+ or return;
+
+ $meta->{license} || $meta->{author} || $meta->{source}
+ or return;
+
+ $LICENSE_WIDGET->add_paragraph ({
+ fg => [1, 1, 1, 1],
+ markup => ""
+ . "Name: " . (CFPlus::asxml $meta->{name}) . "\n"
+ . "Author: " . (CFPlus::asxml $meta->{author}) . "\n"
+ . "Source: " . (CFPlus::asxml $meta->{source}) . "\n"
+ . "License: " . (CFPlus::asxml $meta->{license}) . "\n"
+ . "",
+ });
+ $LICENSE_WIDGET->scroll_to_bottom;
+}
+
sub toggle_player_page {
my ($widget) = @_;
@@ -1616,9 +1692,12 @@
"Toggles the inventory window, where you can manage your loot (or treasures :). "
. "You can also hit the Tab-key to show/hide the Inventory."
);
- $ntb->add_tab (Pickup => autopickup_setup,
+ $ntb->add_tab (Pickup => autopickup_setup,
"Configure autopickup settings, i.e. which items you will pick up automatically when walking (or running) over them.");
+ $ntb->add_tab (Media => media_window,
+ "License, Author and Source info for media sent by the server.");
+
$ntb->set_current_page ($INVENTORY_PAGE);
$plwin->add ($ntb);
@@ -2115,8 +2194,10 @@
stat_fontsize => 0.7,
mapsize => 100,
audio_enable => 1,
+ effects_enable => 1,
+ effects_volume => 1,
bgm_enable => 1,
- bgm_volume => 0.25,
+ bgm_volume => 0.5,
output_sync => 1,
output_count => 1,
output_rate => "",
@@ -2204,13 +2285,15 @@
#CFPlus::_exit 0;
END {
+ video_shutdown;
+ audio_shutdown;
CFPlus::SDL_Quit;
CFPlus::DB::Server::stop;
}
=head1 NAME
-cfplus - A Crossfire+ and Crossfire game client
+cfplus - A Crossfire TRT and Crossfire game client
=head1 SYNOPSIS
@@ -2218,8 +2301,8 @@
=head1 USAGE
-cfplus utilises OpenGL for all UI elements and the game. It is supposed to be used
-fullscreen and interactively.
+cfplus utilises OpenGL for all UI elements and the game. It is supposed to
+be used in fullscreen mode and interactively.
=head1 DEBUGGING