Add commands for most of the audio box buttons/hotkeys

Originally committed to SVN as r5232.
This commit is contained in:
Thomas Goyne 2011-01-17 23:53:59 +00:00
parent 33d8dd2975
commit f79c9e57a0
3 changed files with 262 additions and 51 deletions

View File

@ -44,8 +44,10 @@
#include "command.h"
#include "../selection_controller.h"
#include "../ass_dialogue.h"
#include "../audio_controller.h"
#include "../audio_timing.h"
#include "../compat.h"
#include "../include/aegisub/context.h"
#include "../selection_controller.h"
@ -156,7 +158,7 @@ struct audio_view_waveform : public Command {
}
};
/// Save the audio for the selected lines..
/// Save the audio for the selected lines.
struct audio_save_clip : public Command {
CMD_NAME("audio/save/clip")
STR_MENU("Create audio clip")
@ -174,18 +176,184 @@ struct audio_save_clip : public Command {
}
};
/// Play the current audio selection
struct audio_play_selection : public Command {
CMD_NAME("audio/play/selection")
STR_MENU("Play audio selection")
STR_DISP("Play audio selection")
STR_HELP("Play selection")
void operator()(agi::Context *c) {
c->audioController->PlayPrimaryRange();
}
};
/// Stop playing audio
struct audio_stop : public Command {
CMD_NAME("audio/stop")
STR_MENU("Stop playing")
STR_DISP("Stop playing")
STR_HELP("Stop")
void operator()(agi::Context *c) {
c->audioController->Stop();
}
};
/// Play 500 ms before the selected audio range
struct audio_play_before : public Command {
CMD_NAME("audio/play/selection/before")
STR_MENU("Play 500 ms before selection")
STR_DISP("Play 500 ms before selection")
STR_HELP("Play 500 ms before selection")
void operator()(agi::Context *c) {
SampleRange times(c->audioController->GetPrimaryPlaybackRange());
c->audioController->PlayRange(SampleRange(
times.begin() - c->audioController->SamplesFromMilliseconds(500),
times.begin()));
}
};
/// Play 500 ms after the selected audio range
struct audio_play_after : public Command {
CMD_NAME("audio/play/selection/after")
STR_MENU("Play 500 ms after selection")
STR_DISP("Play 500 ms after selection")
STR_HELP("Play 500 ms after selection")
void operator()(agi::Context *c) {
SampleRange times(c->audioController->GetPrimaryPlaybackRange());
c->audioController->PlayRange(SampleRange(
times.end(),
times.end() + c->audioController->SamplesFromMilliseconds(500)));
}
};
/// Play from the beginning of the audio range to the end of the file
struct audio_play_end : public Command {
CMD_NAME("audio/play/selection/end")
STR_MENU("Play last 500 ms of selection")
STR_DISP("Play last 500 ms of selection")
STR_HELP("Play last 500 ms of selection")
void operator()(agi::Context *c) {
SampleRange times(c->audioController->GetPrimaryPlaybackRange());
c->audioController->PlayRange(SampleRange(
times.begin(),
times.begin() + std::min(
c->audioController->SamplesFromMilliseconds(500),
times.length())));
}
};
/// Play the first 500 ms of the audio range
struct audio_play_begin : public Command {
CMD_NAME("audio/play/selection/begin")
STR_MENU("Play first 500 ms of selection")
STR_DISP("Play first 500 ms of selection")
STR_HELP("Play first 500 ms of selection")
void operator()(agi::Context *c) {
SampleRange times(c->audioController->GetPrimaryPlaybackRange());
c->audioController->PlayRange(SampleRange(
times.end() - std::min(
c->audioController->SamplesFromMilliseconds(500),
times.length()),
times.end()));
}
};
/// Play the last 500 ms of the audio range
struct audio_play_to_end : public Command {
CMD_NAME("audio/play/to_end")
STR_MENU("Play from selection start to end of file")
STR_DISP("Play from selection start to end of file")
STR_HELP("Play from selection start to end of file")
void operator()(agi::Context *c) {
c->audioController->PlayToEnd(c->audioController->GetPrimaryPlaybackRange().begin());
}
};
/// Commit any pending audio timing changes
/// @todo maybe move to time?
struct audio_commit : public Command {
CMD_NAME("audio/commit")
STR_MENU("Commit")
STR_DISP("Commit")
STR_HELP("Commit")
void operator()(agi::Context *c) {
c->audioController->GetTimingController()->Commit();
}
};
/// Scroll the audio display to the current selection
struct audio_go_to : public Command {
CMD_NAME("audio/?")
STR_MENU("Go to selection")
STR_DISP("Go to selection")
STR_HELP("Go to selection")
void operator()(agi::Context *c) {
//if (c->audioController->GetTimingController())
//audioDisplay->ScrollSampleRangeInView(c->audioController->GetTimingController()->GetIdealVisibleSampleRange());
}
};
static inline void toggle(const char *opt) {
OPT_SET(opt)->SetBool(!OPT_GET(opt)->GetBool());
}
/// Toggle autoscrolling the audio display to the selected line when switch lines
struct audio_autoscroll : public Command {
CMD_NAME("audio/opt/autoscroll")
STR_MENU("Auto scrolls audio display to selected line")
STR_DISP("Auto scrolls audio display to selected line")
STR_HELP("Auto scrolls audio display to selected line")
void operator()(agi::Context *c) {
toggle("Audio/Auto/Scroll");
}
};
/// Toggle automatically committing changes made in the audio display
struct audio_autocommit : public Command {
CMD_NAME("audio/opt/autocommit")
STR_MENU("Automatically commit all changes")
STR_DISP("Automatically commit all changes")
STR_HELP("Automatically commit all changes")
void operator()(agi::Context *c) {
toggle("Audio/Auto/Commit");
}
};
/// Toggle automatically advancing to the next line after a commit
struct audio_autonext : public Command {
CMD_NAME("audio/opt/autonext")
STR_MENU("Auto goes to next line on commit")
STR_DISP("Auto goes to next line on commit")
STR_HELP("Auto goes to next line on commit")
void operator()(agi::Context *c) {
toggle("Audio/Next Line on Commit");
}
};
/// @}
/// Init audio/ commands
void init_audio(CommandManager *cm) {
cm->reg(new audio_close());
cm->reg(new audio_open());
cm->reg(new audio_open_blank());
cm->reg(new audio_open_noise());
cm->reg(new audio_open_video());
cm->reg(new audio_view_spectrum());
cm->reg(new audio_view_waveform());
cm->reg(new audio_save_clip());
cm->reg(new audio_autocommit);
cm->reg(new audio_autonext);
cm->reg(new audio_autoscroll);
cm->reg(new audio_close);
cm->reg(new audio_commit);
cm->reg(new audio_go_to);
cm->reg(new audio_open);
cm->reg(new audio_open_blank);
cm->reg(new audio_open_noise);
cm->reg(new audio_open_video);
cm->reg(new audio_play_after);
cm->reg(new audio_play_before);
cm->reg(new audio_play_begin);
cm->reg(new audio_play_end);
cm->reg(new audio_play_selection);
cm->reg(new audio_play_to_end);
cm->reg(new audio_save_clip);
cm->reg(new audio_stop);
cm->reg(new audio_view_spectrum);
cm->reg(new audio_view_waveform);
}
} // namespace cmd

View File

@ -44,12 +44,15 @@
#include "command.h"
#include "../selection_controller.h"
#include "../ass_dialogue.h"
#include "../ass_file.h"
#include "../audio_controller.h"
#include "../audio_timing.h"
#include "../dialog_shift_times.h"
#include "../include/aegisub/context.h"
#include "../subs_grid.h"
#include "../video_context.h"
#include "../ass_dialogue.h"
#include "../dialog_shift_times.h"
#include "../ass_file.h"
namespace cmd {
/// @defgroup cmd-time Time manipulation commands.
@ -230,6 +233,26 @@ struct time_snap_scene : public Command {
}
};
struct time_add_lead_in : public Command {
CMD_NAME("time/lead/in")
STR_MENU("Add lead in")
STR_DISP("Add lead in")
STR_HELP("Add lead in")
void operator()(agi::Context *c) {
//audioDisplay->AddLead(true,false);
}
};
struct time_add_lead_out : public Command {
CMD_NAME("time/lead/out")
STR_MENU("Add lead out")
STR_DISP("Add lead out")
STR_HELP("Add lead out")
void operator()(agi::Context *c) {
//audioDisplay->AddLead(false,true);
}
};
/// Set start of selected subtitles to current video frame.
struct time_snap_start_video : public Command {
@ -285,21 +308,53 @@ struct time_sort_style : public Command {
}
};
/// Switch to the next timeable thing (line or syllable)
struct time_next : public Command {
CMD_NAME("time/next")
STR_MENU("Next line")
STR_DISP("Next line")
STR_HELP("Next line")
void operator()(agi::Context *c) {
c->audioController->Stop();
if (c->audioController->GetTimingController())
c->audioController->GetTimingController()->Next();
c->audioController->PlayPrimaryRange();
}
};
/// Switch to the previous timeable thing (line or syllable)
struct time_prev : public Command {
CMD_NAME("time/prev")
STR_MENU("Previous line")
STR_DISP("Previous line")
STR_HELP("Previous line")
void operator()(agi::Context *c) {
c->audioController->Stop();
if (c->audioController->GetTimingController())
c->audioController->GetTimingController()->Prev();
c->audioController->PlayPrimaryRange();
}
};
/// @}
/// Init time/ commands.
void init_time(CommandManager *cm) {
cm->reg(new time_continuous_end());
cm->reg(new time_continuous_start());
cm->reg(new time_frame_current());
cm->reg(new time_shift());
cm->reg(new time_snap_end_video());
cm->reg(new time_snap_frame());
cm->reg(new time_snap_scene());
cm->reg(new time_snap_start_video());
cm->reg(new time_sort_end());
cm->reg(new time_sort_start());
cm->reg(new time_sort_style());
cm->reg(new time_add_lead_in);
cm->reg(new time_add_lead_out);
cm->reg(new time_continuous_end);
cm->reg(new time_continuous_start);
cm->reg(new time_frame_current);
cm->reg(new time_next);
cm->reg(new time_prev);
cm->reg(new time_shift);
cm->reg(new time_snap_end_video);
cm->reg(new time_snap_frame);
cm->reg(new time_snap_scene);
cm->reg(new time_snap_start_video);
cm->reg(new time_sort_end);
cm->reg(new time_sort_start);
cm->reg(new time_sort_style);
}
} // namespace cmd

View File

@ -344,7 +344,7 @@
},
"Audio" : {
"audio play" : [
"audio/play/selection" : [
{
"modifiers" : [],
"key" : "Space",
@ -356,70 +356,70 @@
"enable" : true
}
],
"audio play after selection end" : [
"audio/play/selection/after" : [
{
"modifiers" : [],
"key" : "W",
"enable" : true
}
],
"audio play before selection begin" : [
"audio/play/selection/before" : [
{
"modifiers" : [],
"key" : "Q",
"enable" : true
}
],
"audio play toggle" : [
"audio/play/toggle" : [
{
"modifiers" : [],
"key" : "B",
"enable" : true
}
],
"audio play selection begin" : [
"audio/play/selection/begin" : [
{
"modifiers" : [],
"key" : "E",
"enable" : true
}
],
"audio play selection end" : [
"audio/play/selection/end" : [
{
"modifiers" : [],
"key" : "D",
"enable" : true
}
],
"audio play to end" : [
"audio/play/to_end" : [
{
"modifiers" : [],
"key" : "T",
"enable" : true
}
],
"audio scroll left" : [
"audio/scroll/left" : [
{
"modifiers" : [],
"key" : "A",
"enable" : true
}
],
"audio scroll right" : [
"audio/scroll/right" : [
{
"modifiers" : [],
"key" : "F",
"enable" : true
}
],
"audio stop" : [
"audio/stop" : [
{
"modifiers" : [],
"key" : "H",
"enable" : true
}
],
"commit" : [
"audio/commit" : [
{
"modifiers" : [],
"key" : "Enter",
@ -431,26 +431,14 @@
"enable" : true
}
],
"commit and stay" : [
{
"modifiers" : [ "Ctrl" ],
"key" : "Enter",
"enable" : true
},
{
"modifiers" : [],
"key" : "F8",
"enable" : true
}
],
"timing add lead in" : [
"time/lead/in" : [
{
"modifiers" : [],
"key" : "C",
"enable" : true
}
],
"timing add lead out" : [
"time/lead/out" : [
{
"modifiers" : [],
"key" : "V",
@ -485,7 +473,7 @@
"enable" : true
}
],
"timing move to next item" : [
"time/next" : [
{
"modifiers" : [],
"key" : "X",
@ -497,7 +485,7 @@
"enable" : true
}
],
"timing move to prev item" : [
"time/prev" : [
{
"modifiers" : [],
"key" : "Z",
@ -515,7 +503,7 @@
"key" : "KP_Multiply",
"enable" : true
}
],
]
},
"Video" : {