: BC_DialogThread()
{
this->mwindow = mwindow;
- plugin = 0;
+ this->plugin_id = -1;
+ this->plugin_type = PLUGIN_NONE;
}
PluginDialogThread::~PluginDialogThread()
// 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);
mwindow->session->plugindialog_w / 2;
int y = mwindow->gui->get_abs_cursor_y(0) -
mwindow->session->plugindialog_h / 2;
- plugin_type = 0;
+ plugin_type = PLUGIN_NONE;
PluginDialog *window = new PluginDialog(mwindow,
this,
window_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;
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));
}
+void PluginDialog::clear_selection()
+{
+ standalone_list->set_all_selected(&standalone_data, 0);
+ standalone_list->draw_items(1);
+ shared_list->set_all_selected(&shared_data, 0);
+ shared_list->draw_items(1);
+ module_list->set_all_selected(&module_data, 0);
+ module_list->draw_items(1);
+ selected_available = -1;
+ selected_shared = -1;
+ selected_modules = -1;
+ thread->plugin_id = -1;
+ thread->plugin_type = PLUGIN_NONE;
+}
+
void PluginDialog::apply()
{
if( selected_available >= 0 ) {
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(1);
+ double end = edl->local_session->get_selectionend(1);
+ 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)
int PluginDialogApply::handle_event()
{
dialog->apply();
+ dialog->clear_selection();
return 1;
}
//
// 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)
// }
-
-
-
-
-
-
-
-
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;
}
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;
}
}
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;
// }
//
-
-
-
-
-
-
-
-
-
-
-
-