: BC_DialogThread()
{
this->mwindow = mwindow;
- this->plugin = 0;
+ this->plugin_id = -1;
this->plugin_type = PLUGIN_NONE;
}
// mwindow->gui->lock_window("PluginDialogThread::start_window");
this->track = track;
this->data_type = data_type;
- this->plugin = plugin;
this->is_mainmenu = is_mainmenu;
single_standalone = mwindow->edl->session->single_standalone;
plugin->calculate_title(plugin_title, 0);
this->shared_location = plugin->shared_location;
this->plugin_type = plugin->plugin_type;
+ this->plugin_id = plugin->orig_id;
}
else
{
this->shared_location.plugin = -1;
this->shared_location.module = -1;
this->plugin_type = PLUGIN_NONE;
+ this->plugin_id = -1;
}
strcpy(this->window_title, title);
const char *window_title,
int x,
int y)
- : BC_Window(window_title,
- x,
- y,
+ : BC_Window(window_title, x, y,
mwindow->session->plugindialog_w,
mwindow->session->plugindialog_h,
- 510,
- 415,
- 1,
- 0,
- 1)
+ xS(510), yS(415), 1, 0, 1)
{
this->mwindow = mwindow;
this->thread = thread;
single_standalone = 0;
+// *** CONTEXT_HELP ***
+ switch( thread->data_type ) {
+ case TRACK_AUDIO:
+ context_help_set_keyword("Audio Effects");
+ break;
+ case TRACK_VIDEO:
+ context_help_set_keyword("Video Effects");
+ break;
+ default:
+ context_help_set_keyword("How to Use Plugins");
+ break;
+ }
}
PluginDialog::~PluginDialog()
void PluginDialog::create_objects()
{
+ int xs10 = xS(10);
+ int ys10 = yS(10), ys20 = yS(20);
// int use_default = 1;
mwindow->theme->get_plugindialog_sizes();
lock_window("PluginDialog::create_objects");
module_data.append(new BC_ListBoxItem(track->title));
}
-
-
-
-
// Create widgets
add_subwindow(standalone_title = new BC_Title(mwindow->theme->plugindialog_new_x,
- mwindow->theme->plugindialog_new_y - 20,
+ mwindow->theme->plugindialog_new_y - ys20,
_("Plugins:")));
int x1 = mwindow->theme->plugindialog_new_x, y1 = mwindow->theme->plugindialog_new_y;
int w1 = mwindow->theme->plugindialog_new_w, h1 = mwindow->theme->plugindialog_new_h;
add_subwindow(search_text = new PluginDialogSearchText(this, x1, y1, w1));
- int dy = search_text->get_h() + 10;
+ int dy = search_text->get_h() + ys10;
y1 += dy; h1 -= dy;
load_plugin_list(0);
//
add_subwindow(shared_title = new BC_Title(mwindow->theme->plugindialog_shared_x,
- mwindow->theme->plugindialog_shared_y - 20,
+ mwindow->theme->plugindialog_shared_y - ys20,
_("Shared effects:")));
add_subwindow(shared_list = new PluginDialogShared(this,
&shared_data,
//
add_subwindow(module_title = new BC_Title(mwindow->theme->plugindialog_module_x,
- mwindow->theme->plugindialog_module_y - 20,
+ mwindow->theme->plugindialog_module_y - ys20,
_("Shared tracks:")));
add_subwindow(module_list = new PluginDialogModules(this,
&module_data,
if(thread->is_mainmenu)
add_subwindow(single_standalone = new PluginDialogSingle(this,
- mwindow->theme->plugindialog_new_x + BC_OKButton::calculate_w() + 10,
- mwindow->theme->plugindialog_new_y +
- mwindow->theme->plugindialog_new_h +
+ mwindow->theme->plugindialog_new_x + BC_OKButton::calculate_w() + xs10,
+ mwindow->theme->plugindialog_new_y + mwindow->theme->plugindialog_new_h +
get_text_height(MEDIUMFONT)));
-
-
add_subwindow(ok_btn = new BC_OKButton(this));
add_subwindow(can_btn = new BC_CancelButton(this));
int aw = PluginDialogApply::calculate_w(this, _("Apply"));
int PluginDialog::resize_event(int w, int h)
{
+ int ys10 = yS(10), ys20 = yS(20);
mwindow->session->plugindialog_w = w;
mwindow->session->plugindialog_h = h;
mwindow->theme->get_plugindialog_sizes();
-
standalone_title->reposition_window(mwindow->theme->plugindialog_new_x,
- mwindow->theme->plugindialog_new_y - 20);
+ mwindow->theme->plugindialog_new_y - ys20);
int x1 = mwindow->theme->plugindialog_new_x, y1 = mwindow->theme->plugindialog_new_y;
int w1 = mwindow->theme->plugindialog_new_w, h1 = mwindow->theme->plugindialog_new_h;
search_text->reposition_window(x1, y1, w1);
- int dy = search_text->get_h() + 10;
+ int dy = search_text->get_h() + ys10;
y1 += dy; h1 -= dy;
standalone_list->reposition_window(x1, y1, w1, h1);
// mwindow->theme->plugindialog_newattach_y);
shared_title->reposition_window(mwindow->theme->plugindialog_shared_x,
- mwindow->theme->plugindialog_shared_y - 20);
+ mwindow->theme->plugindialog_shared_y - ys20);
shared_list->reposition_window(mwindow->theme->plugindialog_shared_x,
mwindow->theme->plugindialog_shared_y,
mwindow->theme->plugindialog_shared_w,
module_title->reposition_window(mwindow->theme->plugindialog_module_x,
- mwindow->theme->plugindialog_module_y - 20);
+ mwindow->theme->plugindialog_module_y - ys20);
module_list->reposition_window(mwindow->theme->plugindialog_module_x,
mwindow->theme->plugindialog_module_y,
mwindow->theme->plugindialog_module_w,
if(single_standalone)
single_standalone->reposition_window(
- mwindow->theme->plugindialog_new_x + BC_OKButton::calculate_w() + 10,
+ mwindow->theme->plugindialog_new_x + BC_OKButton::calculate_w() + ys10,
mwindow->theme->plugindialog_new_y + mwindow->theme->plugindialog_new_h +
get_text_height(MEDIUMFONT));
selected_available = -1;
selected_shared = -1;
selected_modules = -1;
- thread->plugin = 0;
+ thread->plugin_id = -1;
thread->plugin_type = PLUGIN_NONE;
}
void PluginDialogThread::apply()
{
- if( mwindow->edl )
- mwindow->edl->session->single_standalone = single_standalone;
+ Plugin *plugin = 0;
+ EDL *edl = mwindow->edl;
+ if( edl )
+ edl->session->single_standalone = single_standalone;
if(plugin_type) {
mwindow->gui->lock_window("PluginDialogThread::run 3");
mwindow->undo->update_undo_before();
mwindow->insert_effect(plugin_title, &shared_location,
data_type, plugin_type, single_standalone);
}
- else {
- if( plugin ) {
- if( mwindow->edl->tracks->plugin_exists(plugin) ) {
- plugin->change_plugin(plugin_title,
- &shared_location, plugin_type);
- }
- }
- else {
- if( mwindow->edl->tracks->track_exists(track) ) {
- mwindow->insert_effect(plugin_title, &shared_location,
- track, 0, 0, 0, plugin_type);
- }
+ else if( (plugin=edl->tracks->plugin_exists(plugin_id)) != 0 ) {
+ plugin->change_plugin(plugin_title,
+ &shared_location, plugin_type);
+ }
+ else if( edl->tracks->track_exists(track) ) {
+ double start = edl->local_session->get_selectionstart();
+ double end = edl->local_session->get_selectionend();
+ if( start >= end ) {
+ start = 0;
+ end = track->get_length();
}
+ double length = end - start;
+ mwindow->insert_effect(plugin_title, &shared_location,
+ track, 0, start, length, plugin_type);
}
mwindow->save_backup();
mwindow->gui->update(1, NORMAL_DRAW, 0, 0, 1, 0, 0);
mwindow->gui->unlock_window();
}
- plugin = 0;
+ plugin_id = -1;
}
PluginDialogApply::PluginDialogApply(PluginDialog *dialog, int x, int y)
//
// PluginDialogTextBox::PluginDialogTextBox(PluginDialog *dialog, char *text, int x, int y)
-// : BC_TextBox(x, y, 200, 1, text)
+// : BC_TextBox(x, y, xS(200), 1, text)
// {
// this->dialog = dialog;
// }
-
-
-
-
-
-
-
-
-
-
PluginDialogNew::PluginDialogNew(PluginDialog *dialog,
ArrayList<BC_ListBoxItem*> *standalone_data,
int x, int y, int w, int h)
return 1;
}
+// *** CONTEXT_HELP ***
+int PluginDialogNew::keypress_event()
+{
+ int item, plugin_no;
+ char title[BCTEXTLEN];
+ PluginServer *plugin = 0;
+
+// printf("PluginDialogNew::keypress_event: %d\n", get_keypress());
+
+ // If not our context help keystroke, redispatch it
+ // to the event handler of the base class
+ if (get_keypress() != 'h' || ! alt_down() ||
+ ! is_tooltip_event_win() || ! cursor_inside())
+ return BC_ListBox::keypress_event();
+
+ // Try to show help for the plugin currently under mouse
+ item = get_highlighted_item();
+ if (item >= 0 && item < dialog->standalone_data.size()) {
+ plugin_no = ((PluginDialogListItem *)dialog->standalone_data[item])->item_no;
+ if (plugin_no >= 0 && plugin_no < dialog->plugindb.total)
+ plugin = dialog->plugindb.values[plugin_no];
+ }
+
+ // If some plugin is highlighted, show its help
+ // Otherwise show more general help
+ if (plugin) {
+ strcpy(title, plugin->title);
+ if (! strcmp(title, "Overlay")) {
+ // "Overlay" plugin title is ambiguous
+ if (plugin->audio) strcat(title, " \\(Audio\\)");
+ if (plugin->video) strcat(title, " \\(Video\\)");
+ }
+ if (plugin->is_ffmpeg()) {
+ // FFmpeg plugins can be audio or video
+ if (plugin->audio)
+ strcpy(title, "FFmpeg Audio Plugins");
+ if (plugin->video)
+ strcpy(title, "FFmpeg Video Plugins");
+ }
+ context_help_show(title);
+ return 1;
+ }
+ else {
+ switch (dialog->thread->data_type) {
+ case TRACK_AUDIO:
+ context_help_show("Audio Effects");
+ return 1;
+ case TRACK_VIDEO:
+ context_help_show("Video Effects");
+ return 1;
+ default:
+ context_help_show("How to Use Plugins");
+ return 1;
+ }
+ context_help_show("How to Use Plugins");
+ return 1;
+ }
+ context_help_show("How to Use Plugins");
+ return 1;
+}
+
// PluginDialogAttachNew::PluginDialogAttachNew(MWindow *mwindow, PluginDialog *dialog, int x, int y)
// : BC_GenericButton(x, y, _("Attach"))
// {
// }
-
-
-
-
-
-
-
-
PluginDialogShared::PluginDialogShared(PluginDialog *dialog,
ArrayList<BC_ListBoxItem*> *shared_data,
- int x,
- int y,
- int w,
- int h)
- : BC_ListBox(x,
- y,
- w,
- h,
- LISTBOX_TEXT,
- shared_data)
+ int x, int y, int w, int h)
+ : BC_ListBox(x, y, w, h, LISTBOX_TEXT, shared_data)
{
this->dialog = dialog;
+ context_help_set_keyword("Shared Effects and Shared Tracks");
}
PluginDialogShared::~PluginDialogShared() { }
int PluginDialogShared::handle_event()
PluginDialogModules::PluginDialogModules(PluginDialog *dialog,
ArrayList<BC_ListBoxItem*> *module_data,
- int x,
- int y,
- int w,
- int h)
- : BC_ListBox(x,
- y,
- w,
- h,
- LISTBOX_TEXT,
- module_data)
+ int x, int y, int w, int h)
+ : BC_ListBox(x, y, w, h, LISTBOX_TEXT, module_data)
{
this->dialog = dialog;
+ context_help_set_keyword("Shared Effects and Shared Tracks");
}
PluginDialogModules::~PluginDialogModules() { }
int PluginDialogModules::handle_event()
}
PluginDialogSingle::PluginDialogSingle(PluginDialog *dialog, int x, int y)
- : BC_CheckBox(x,
- y,
- dialog->thread->single_standalone,
+ : BC_CheckBox(x, y, dialog->thread->single_standalone,
_("Attach single standalone and share others"))
{
this->dialog = dialog;
+ context_help_set_keyword("Shared Effects and Shared Tracks");
}
int PluginDialogSingle::handle_event()
// }
//
-
-
-
-
-
-
-
-
-
-
-
-