--- deliantra/Deliantra-Client/bin/cfplus 2007/08/01 14:27:21 1.199
+++ deliantra/Deliantra-Client/bin/cfplus 2007/08/09 03:40:44 1.206
@@ -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;
@@ -216,6 +219,9 @@
$CFG->{effects_enable}
or return;
+ $AUDIO_PLAY{$face}
+ or return;
+
if (my $chunk = $AUDIO_CHUNK{$face}) {
for (grep $_->[0] >= Event::time, @{(delete $AUDIO_PLAY{$face}) || []}) {
my (undef, $dx, $dy, $vol) = @$_;
@@ -238,14 +244,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 " . (JSON::XS::to_json $meta) . " unloadable: " . CFPlus::Mix_GetError;
$chunk->volume (($meta->{meta}{volume} || 1) * 128);
$AUDIO_CHUNK{$face} = $chunk;
@@ -269,6 +277,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;
@@ -295,7 +315,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;
@@ -308,8 +328,8 @@
$MUSIC_START = time;
}
- delete $MUSIC_PLAYING_META->{stop_time};
- delete $MUSIC_PLAYING_META->{stop_pos};
+ delete $meta->{stop_time};
+ delete $meta->{stop_pos};
}
}
@@ -338,8 +358,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;
@@ -353,7 +372,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];
@@ -374,6 +393,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;
@@ -861,16 +882,20 @@
# $CFG->{effects_volume} = $_[1];
# });
- $table->add_at (0, $row, new CFPlus::UI::Label valign => 0, align => 1, text => "Effects Volume");
+ $table->add_at (0, $row, new CFPlus::UI::Label valign => 0, align => 1, text => "Sound Effects");
$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 }
+ on_changed => sub {
+ $CFG->{effects_enable} = $_[1];
+ $CONN->update_fx_want if $CONN;
+ 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.",
+ . "is set highest (rightmost) and you use your operating system volume setting. Changes are instant.",
on_changed => sub { $CFG->{effects_volume} = $_[1]; 0 }
);
@@ -878,7 +903,11 @@
$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 }
+ on_changed => sub {
+ $CFG->{bgm_enable} = $_[1];
+ $CONN->update_fx_want if $CONN;
+ 0
+ }
);
$table->add_at (2, $row++, new CFPlus::UI::Slider
expand => 1, range => [$CFG->{bgm_volume}, 0, 1, 0, 1/128],
@@ -1588,6 +1617,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) = @_;
@@ -1634,9 +1703,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);
@@ -2224,13 +2296,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
@@ -2238,8 +2312,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