add 2 asset list fmts, user title rework, added show edit, bt tweak
[goodguy/history.git] / cinelerra-5.1 / cinelerra / editpopup.C
index 5fcd8152485f90d156c90d0d3a25b8790055c9d4..1851e058da35b8ed1e281bd3a42ea2b93c6967ec 100644 (file)
@@ -63,6 +63,7 @@ void EditPopup::create_objects()
        add_item(new EditPopupAddTrack(mwindow, this));
        add_item(new EditPopupFindAsset(mwindow, this));
        add_item(new EditPopupTitle(mwindow, this));
+       add_item(new EditPopupShow(mwindow, this));
        resize_option = 0;
        matchsize_option = 0;
 }
@@ -260,63 +261,87 @@ EditPopupTitle::EditPopupTitle(MWindow *mwindow, EditPopup *popup)
 {
        this->mwindow = mwindow;
        this->popup = popup;
-       window = 0;
+       dialog_thread = new EditTitleDialogThread(this);
 }
 
 EditPopupTitle::~EditPopupTitle()
 {
+       delete dialog_thread;
 }
 
 int EditPopupTitle::handle_event()
 {
-       int result;
        if( popup->edit ) {
-               window = new EditPopupTitleWindow (mwindow, popup);
-               window->create_objects();
-               result = window->run_window();
-               if( !result && popup->edit ) {
-                       strcpy(popup->edit->user_title, window->title_text->get_text());
-                       mwindow->gui->draw_canvas(1, 0);
-                       mwindow->gui->flash_canvas(1);
-               }
-               delete window;  window = 0;
+               dialog_thread->close_window();
+               int wx = mwindow->gui->get_abs_cursor_x(0) - 400 / 2;
+               int wy = mwindow->gui->get_abs_cursor_y(0) - 500 / 2;
+               dialog_thread->start(wx, wy);
        }
-
        return 1;
 }
 
+void EditTitleDialogThread::start(int wx, int wy)
+{
+       this->wx = wx;  this->wy = wy;
+       BC_DialogThread::start();
+}
+
+EditTitleDialogThread::EditTitleDialogThread(EditPopupTitle *edit_title)
+{
+       this->edit_title = edit_title;
+       window = 0;
+}
+EditTitleDialogThread::~EditTitleDialogThread()
+{
+       close_window();
+}
 
-EditPopupTitleWindow::EditPopupTitleWindow (MWindow *mwindow, EditPopup *popup)
- : BC_Window (_(PROGRAM_NAME ": Set edit title"),
-       mwindow->gui->get_abs_cursor_x(0) - 400 / 2,
-       mwindow->gui->get_abs_cursor_y(0) - 500 / 2,
+BC_Window* EditTitleDialogThread::new_gui()
+{
+       MWindow *mwindow = edit_title->mwindow;
+       EditPopup *popup = edit_title->popup;
+       window = new EditPopupTitleWindow(mwindow, popup, wx, wy);
+       window->create_objects();
+       return window;
+}
+
+void EditTitleDialogThread::handle_close_event(int result)
+{
+       window = 0;
+}
+
+void EditTitleDialogThread::handle_done_event(int result)
+{
+       if( result ) return;
+       MWindow *mwindow = edit_title->mwindow;
+       EditPopup *popup = edit_title->popup;
+       strcpy(popup->edit->user_title, window->title_text->get_text());
+       mwindow->gui->lock_window("EditTitleDialogThread::handle_done_event");
+       mwindow->gui->draw_canvas(1, 0);
+       mwindow->gui->flash_canvas(1);
+       mwindow->gui->unlock_window();
+}
+
+EditPopupTitleWindow::EditPopupTitleWindow(MWindow *mwindow,
+               EditPopup *popup, int wx, int wy)
+ : BC_Window(_(PROGRAM_NAME ": Set edit title"), wx, wy,
        300, 130, 300, 130, 0, 0, 1)
 {
        this->mwindow = mwindow;
        this->popup = popup;
-       if( popup->edit ) {
-               strcpy(new_text, popup->edit->user_title);
-       }
+       strcpy(new_text, !popup->edit ? "" : popup->edit->user_title);
 }
 
 EditPopupTitleWindow::~EditPopupTitleWindow()
 {
 }
 
-int EditPopupTitleWindow::close_event()
-{
-       set_done(1);
-       return 1;
-}
-
 void EditPopupTitleWindow::create_objects()
 {
        lock_window("EditPopupTitleWindow::create_objects");
-       int x = 10;
-       int y = 10;
-       add_subwindow (new BC_Title (x, y, _("User title:")));
-       title_text = new EditPopupTitleText (this, mwindow, x+15, y+20,
-               popup->edit ? popup->edit->user_title : "");
+       int x = 10, y = 10;
+       add_subwindow(new BC_Title(x, y, _("User title:")));
+       title_text = new EditPopupTitleText(this, mwindow, x+15, y+20, new_text);
        add_subwindow(title_text);
        add_tool(new BC_OKButton(this));
        add_tool(new BC_CancelButton(this));
@@ -328,7 +353,7 @@ void EditPopupTitleWindow::create_objects()
 }
 
 
-EditPopupTitleText::EditPopupTitleText (EditPopupTitleWindow *window,
+EditPopupTitleText::EditPopupTitleText(EditPopupTitleWindow *window,
        MWindow *mwindow, int x, int y, const char *text)
  : BC_TextBox(x, y, 250, 1, text)
 {
@@ -347,3 +372,120 @@ int EditPopupTitleText::handle_event()
        return 1;
 }
 
+
+EditPopupShow::EditPopupShow(MWindow *mwindow, EditPopup *popup)
+ : BC_MenuItem(_("Show edit"))
+{
+       this->mwindow = mwindow;
+       this->popup = popup;
+       dialog_thread = new EditShowDialogThread(this);
+}
+
+EditPopupShow::~EditPopupShow()
+{
+       delete dialog_thread;
+}
+
+int EditPopupShow::handle_event()
+{
+       if( popup->edit ) {
+               dialog_thread->close_window();
+               int wx = mwindow->gui->get_abs_cursor_x(0) - 400 / 2;
+               int wy = mwindow->gui->get_abs_cursor_y(0) - 500 / 2;
+               dialog_thread->start(wx, wy);
+       }
+       return 1;
+}
+
+void EditShowDialogThread::start(int wx, int wy)
+{
+       this->wx = wx;  this->wy = wy;
+       BC_DialogThread::start();
+}
+
+EditShowDialogThread::EditShowDialogThread(EditPopupShow *edit_show)
+{
+       this->edit_show = edit_show;
+       window = 0;
+}
+EditShowDialogThread::~EditShowDialogThread()
+{
+       close_window();
+}
+
+BC_Window* EditShowDialogThread::new_gui()
+{
+       MWindow *mwindow = edit_show->mwindow;
+       EditPopup *popup = edit_show->popup;
+       window = new EditPopupShowWindow(mwindow, popup, wx, wy);
+       window->create_objects();
+       return window;
+}
+
+void EditShowDialogThread::handle_close_event(int result)
+{
+       window = 0;
+}
+
+EditPopupShowWindow::EditPopupShowWindow(MWindow *mwindow,
+               EditPopup *popup, int wx, int wy)
+ : BC_Window(_(PROGRAM_NAME ": Show edit"), wx, wy,
+       300, 200, 300, 200, 0, 0, 1)
+{
+       this->mwindow = mwindow;
+       this->popup = popup;
+}
+
+EditPopupShowWindow::~EditPopupShowWindow()
+{
+}
+
+void EditPopupShowWindow::create_objects()
+{
+       lock_window("EditPopupShowWindow::create_objects");
+       int x = 10, y = 10;
+       add_subwindow(new BC_Title(x, y, _("Show edit:")));
+
+       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;
+
+       Track *track = popup->track;
+       Edit *edit = popup->edit;
+        double startsource = track->from_units(edit->startsource);
+       double startproject = track->from_units(edit->startproject);
+       double length = track->from_units(edit->length);
+
+       char text[BCTEXTLEN], text_length[BCSTRLEN];
+       char text_startsource[BCSTRLEN], text_startproject[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 EditPopupShowText(this, mwindow, x+15, y+20, text);
+       add_subwindow(show_text);
+       add_tool(new BC_OKButton(this));
+
+       show_window();
+       flush();
+       unlock_window();
+}
+
+
+EditPopupShowText::EditPopupShowText(EditPopupShowWindow *window,
+       MWindow *mwindow, int x, int y, const char *text)
+ : BC_TextBox(x, y, 250, 4, text)
+{
+       this->window = window;
+       this->mwindow = mwindow;
+}
+
+EditPopupShowText::~EditPopupShowText()
+{
+}
+