+TrackPopupFindAsset::TrackPopupFindAsset(MWindow *mwindow, TrackPopup *popup)
+ : BC_MenuItem(_("Find in Resources"))
+{
+ this->mwindow = mwindow;
+ this->popup = popup;
+}
+
+int TrackPopupFindAsset::handle_event()
+{
+ Edit *edit = popup->edit;
+ if( edit ) {
+ Indexable *idxbl = (Indexable *)edit->asset;
+ if( !idxbl ) idxbl = (Indexable *)edit->nested_edl;
+ if( idxbl ) {
+ AWindowGUI *agui = mwindow->awindow->gui;
+ agui->lock_window("TrackPopupFindAsset::handle_event");
+ AssetPicon *picon = 0;
+ for( int i=0, n=agui->assets.size(); i<n; ++i ) {
+ AssetPicon *ap = (AssetPicon *)agui->assets[i];
+ int found = ap->indexable && ( idxbl == ap->indexable ||
+ !strcmp(idxbl->path, ap->indexable->path) );
+ if( found && !picon ) picon = ap;
+ ap->set_selected(found);
+ }
+ if( picon ) {
+ int selected_folder = picon->indexable->folder_no;
+ mwindow->edl->session->awindow_folder = selected_folder;
+ for( int i=0,n=agui->folders.size(); i<n; ++i ) {
+ AssetPicon *folder_item = (AssetPicon *)agui->folders[i];
+ int selected = folder_item->foldernum == selected_folder ? 1 : 0;
+ folder_item->set_selected(selected);
+ }
+ }
+ agui->unlock_window();
+ agui->async_update_assets();
+ }
+ }
+ return 1;
+}
+
+
+TrackPopupUserTitle::TrackPopupUserTitle(MWindow *mwindow, TrackPopup *popup)
+ : BC_MenuItem(_("User title..."))
+{
+ this->mwindow = mwindow;
+ this->popup = popup;
+ dialog_thread = new TrackUserTitleDialogThread(this);
+}
+
+TrackPopupUserTitle::~TrackPopupUserTitle()
+{
+ delete dialog_thread;
+}
+
+#define TTW_W xS(300)
+#define TTW_H yS(130)
+
+int TrackPopupUserTitle::handle_event()
+{
+ if( popup->edit ) {
+ dialog_thread->close_window();
+ int wx = mwindow->gui->get_abs_cursor_x(0) - TTW_W / 2;
+ int wy = mwindow->gui->get_abs_cursor_y(0) - TTW_H / 2;
+ dialog_thread->start(wx, wy);
+ }
+ return 1;
+}
+
+void TrackUserTitleDialogThread::start(int wx, int wy)
+{
+ this->wx = wx; this->wy = wy;
+ BC_DialogThread::start();
+}
+
+TrackUserTitleDialogThread::TrackUserTitleDialogThread(TrackPopupUserTitle *edit_title)
+{
+ this->edit_title = edit_title;
+ window = 0;
+}
+TrackUserTitleDialogThread::~TrackUserTitleDialogThread()
+{
+ close_window();
+}
+
+BC_Window* TrackUserTitleDialogThread::new_gui()
+{
+ MWindow *mwindow = edit_title->mwindow;
+ TrackPopup *popup = edit_title->popup;
+ window = new TrackPopupUserTitleWindow(mwindow, popup, wx, wy);
+ window->create_objects();
+ return window;
+}
+
+void TrackUserTitleDialogThread::handle_close_event(int result)
+{
+ window = 0;
+}
+
+void TrackUserTitleDialogThread::handle_done_event(int result)
+{
+ if( result ) return;
+ MWindow *mwindow = edit_title->mwindow;
+ TrackPopup *popup = edit_title->popup;
+ EDL *edl = mwindow->edl;
+ const char *text = window->title_text->get_text();
+ int count = 0;
+ for( Track *track=edl->tracks->first; track; track=track->next ) {
+ if( !track->is_armed() ) continue;
+ for( Edit *edit=track->edits->first; edit; edit=edit->next ) {
+ if( !edit->is_selected ) continue;
+ strcpy(edit->user_title, text);
+ ++count;
+ }
+ }
+ if( count )
+ edl->tracks->clear_selected_edits();
+ else if( popup->edit ) {
+ strcpy(popup->edit->user_title, text);
+ }
+ mwindow->gui->lock_window("TrackUserTitleDialogThread::handle_done_event");
+ mwindow->gui->draw_canvas(1, 0);
+ mwindow->gui->flash_canvas(1);
+ mwindow->gui->unlock_window();
+}
+
+TrackPopupUserTitleWindow::TrackPopupUserTitleWindow(MWindow *mwindow,
+ TrackPopup *popup, int wx, int wy)
+ : BC_Window(_(PROGRAM_NAME ": Set edit title"), wx, wy,
+ TTW_W, TTW_H, TTW_W, TTW_H, 0, 0, 1)
+{
+ this->mwindow = mwindow;
+ this->popup = popup;
+ strcpy(new_text, !popup->edit ? "" : popup->edit->user_title);
+// *** CONTEXT_HELP ***
+ context_help_set_keyword("Track Popup Menu");
+}
+
+TrackPopupUserTitleWindow::~TrackPopupUserTitleWindow()
+{
+}
+
+void TrackPopupUserTitleWindow::create_objects()
+{
+ lock_window("TrackPopupUserTitleWindow::create_objects");
+ int x = xS(10), y = yS(10), x1;
+ BC_Title *title = new BC_Title(x1=x, y, _("User title:"));
+ add_subwindow(title); x1 += title->get_w() + xS(10);
+ title_text = new TrackPopupUserTitleText(this, mwindow, x1, y, new_text);
+ add_subwindow(title_text);
+
+ add_tool(new BC_OKButton(this));
+ add_tool(new BC_CancelButton(this));
+
+
+ show_window();
+ flush();
+ unlock_window();
+}
+
+
+TrackPopupUserTitleText::TrackPopupUserTitleText(TrackPopupUserTitleWindow *window,
+ MWindow *mwindow, int x, int y, const char *text)
+ : BC_TextBox(x, y, window->get_w()-x-xS(15), 1, text)
+{
+ this->window = window;
+ this->mwindow = mwindow;
+}
+
+TrackPopupUserTitleText::~TrackPopupUserTitleText()
+{
+}
+
+int TrackPopupUserTitleText::handle_event()
+{
+ if( get_keypress() == RETURN )
+ window->set_done(0);
+ return 1;
+}
+
+
+TrackPopupTitleColor::TrackPopupTitleColor(MWindow *mwindow, TrackPopup *popup)
+ : BC_MenuItem(_("Bar Color..."))
+{
+ this->mwindow = mwindow;
+ this->popup = popup;
+ color_picker = 0;
+}
+TrackPopupTitleColor::~TrackPopupTitleColor()
+{
+ delete color_picker;
+}
+
+int TrackPopupTitleColor::handle_event()
+{
+ if( popup->edit ) {
+ int color = popup->mwindow->get_title_color(popup->edit);
+ if( !color ) color = popup->mwindow->theme->get_color_title_bg();
+ delete color_picker;
+ color_picker = new TrackTitleColorPicker(popup, color);
+ int alpha = (~color>>24) & 0xff;
+ color_picker->start_window(color & 0xffffff, alpha, 1);
+ }
+ return 1;
+}
+
+TrackTitleColorDefault::TrackTitleColorDefault(
+ TrackTitleColorPicker *color_picker, int x, int y)
+ : BC_GenericButton(x, y, _("default"))
+{
+ this->color_picker = color_picker;
+}
+
+int TrackTitleColorDefault::handle_event()
+{
+ const unsigned color = 0, alpha = 0xff;
+ color_picker->color = color | (~alpha << 24);
+ color_picker->update_gui(color, alpha);
+ return 1;
+}
+
+TrackTitleColorPicker::TrackTitleColorPicker(TrackPopup *popup, int color)
+ : ColorPicker(1, _("Bar Color"))
+{
+ this->popup = popup;
+ this->color = color;
+}
+TrackTitleColorPicker::~TrackTitleColorPicker()
+{
+}
+void TrackTitleColorPicker::create_objects(ColorWindow *gui)
+{
+ gui->lock_window("TrackTitleColorPicker::create_objects");
+ int y = gui->get_h() - BC_CancelButton::calculate_h() + yS(10);
+ int x = gui->get_w() - BC_CancelButton::calculate_w() - xS(10);
+ x -= BC_GenericButton::calculate_w(gui, _("default")) + xS(15);
+ gui->add_subwindow(new TrackTitleColorDefault(this, x, y));
+ gui->unlock_window();
+}
+
+int TrackTitleColorPicker::handle_new_color(int color, int alpha)
+{
+ this->color = color | (~alpha << 24);
+ return 1;
+}
+
+void TrackTitleColorPicker::handle_done_event(int result)
+{
+ if( !result ) {
+ EDL *edl = popup->mwindow->edl;
+ int count = 0;
+ for( Track *track=edl->tracks->first; track; track=track->next ) {
+ if( !track->is_armed() ) continue;
+ for( Edit *edit=track->edits->first; edit; edit=edit->next ) {
+ if( !edit->is_selected ) continue;
+ edit->color = color;
+ ++count;
+ }
+ }
+ if( count )
+ edl->tracks->clear_selected_edits();
+ else
+ popup->edit->color = color;
+ }
+ MWindowGUI *mwindow_gui = popup->mwindow->gui;
+ mwindow_gui->lock_window("GWindowColorUpdate::run");
+ mwindow_gui->draw_trackmovement();
+ mwindow_gui->unlock_window();
+}
+
+
+#define TPW_W xS(300)
+#define TPW_H yS(220)
+
+TrackPopupShow::TrackPopupShow(MWindow *mwindow, TrackPopup *popup)
+ : BC_MenuItem(_("Show edit"))
+{
+ this->mwindow = mwindow;
+ this->popup = popup;
+ dialog_thread = new TrackShowDialogThread(this);
+}
+
+TrackPopupShow::~TrackPopupShow()
+{
+ delete dialog_thread;
+}
+
+int TrackPopupShow::handle_event()
+{
+ if( popup->edit ) {
+ dialog_thread->close_window();
+ int wx = mwindow->gui->get_abs_cursor_x(0) - TPW_W / 2;
+ int wy = mwindow->gui->get_abs_cursor_y(0) - TPW_H / 2;
+ dialog_thread->start(wx, wy);
+ }
+ return 1;
+}
+
+void TrackShowDialogThread::start(int wx, int wy)
+{
+ this->wx = wx; this->wy = wy;
+ BC_DialogThread::start();
+}
+
+TrackShowDialogThread::TrackShowDialogThread(TrackPopupShow *edit_show)
+{
+ this->edit_show = edit_show;
+ window = 0;
+}
+TrackShowDialogThread::~TrackShowDialogThread()
+{
+ close_window();
+}
+
+BC_Window* TrackShowDialogThread::new_gui()
+{
+ MWindow *mwindow = edit_show->mwindow;
+ TrackPopup *popup = edit_show->popup;
+ window = new TrackPopupShowWindow(mwindow, popup, wx, wy);
+ window->create_objects();
+ return window;
+}
+
+void TrackShowDialogThread::handle_close_event(int result)
+{
+ window = 0;
+}
+
+TrackPopupShowWindow::TrackPopupShowWindow(MWindow *mwindow,
+ TrackPopup *popup, int wx, int wy)
+ : BC_Window(_(PROGRAM_NAME ": Show edit"), wx, wy,
+ TPW_W, TPW_H, TPW_W, TPW_H, 0, 0, 1)
+{
+ this->mwindow = mwindow;
+ this->popup = popup;
+// *** CONTEXT_HELP ***
+ context_help_set_keyword("Track Popup Menu");
+}
+
+TrackPopupShowWindow::~TrackPopupShowWindow()
+{
+}
+
+void TrackPopupShowWindow::create_objects()
+{
+ lock_window("TrackPopupShowWindow::create_objects");
+ int x = xS(10), y = yS(10);
+ BC_Title *title;
+ char text[BCTEXTLEN];
+ Edit *edit = popup->edit;
+ Track *track = edit->track;
+ sprintf(text, _("Track %d:"), mwindow->edl->tracks->number_of(track)+1);
+ add_subwindow(title = new BC_Title(x, y, text));
+ int x1 = x + title->get_w() + xS(10);
+ int tw = get_w() - x1 - xS(20);
+ char *track_title = get_truncated_text(MEDIUMFONT, track->title, tw);
+ add_subwindow(new BC_Title(x1, y, track_title));
+ delete [] track_title;
+ y += title->get_h() + 5;
+ sprintf(text, _("Edit %d:"), track->edits->number_of(edit)+1);
+ add_subwindow(title = new BC_Title(x, y, text));
+ edit->get_title(text);
+ char *edit_title = get_truncated_text(MEDIUMFONT, text, tw);
+ add_subwindow(new BC_Title(x1, y, edit_title));
+ delete [] edit_title;
+ y += title->get_h() + 5;
+
+ EDLSession *session = mwindow->edl->session;
+ int time_format = session->time_format;
+ int sample_rate = session->sample_rate;
+ double frame_rate = session->frame_rate;
+ double frames_per_foot = session->frames_per_foot;
+
+ double startsource = track->from_units(edit->startsource);
+ double startproject = track->from_units(edit->startproject);
+ double length = track->from_units(edit->length);
+
+ char text_startsource[BCSTRLEN];
+ char text_startproject[BCSTRLEN];
+ char text_length[BCSTRLEN];
+ sprintf(text, _("StartSource: %s\nStartProject: %s\nLength: %s\n"),
+ Units::totext(text_startsource, startsource,
+ time_format, sample_rate, frame_rate, frames_per_foot),
+ Units::totext(text_startproject, startproject,
+ time_format, sample_rate, frame_rate, frames_per_foot),
+ Units::totext(text_length, length,
+ time_format, sample_rate, frame_rate, frames_per_foot));
+ show_text = new TrackPopupShowText(this, mwindow, x+xS(15), y+yS(10), text);
+ add_subwindow(show_text);
+ add_tool(new BC_OKButton(this));
+
+ show_window();
+ flush();
+ unlock_window();
+}
+
+
+TrackPopupShowText::TrackPopupShowText(TrackPopupShowWindow *window,
+ MWindow *mwindow, int x, int y, const char *text)
+ : BC_TextBox(x, y, xS(250), 4, text)
+{
+ this->window = window;
+ this->mwindow = mwindow;
+}
+
+TrackPopupShowText::~TrackPopupShowText()
+{
+}
+