}
}
-
-
BC_Window* VWindow::new_gui()
{
//printf("VWindow::create_objects 1\n");
return gui;
}
+void VWindow::handle_close_event(int result)
+{
+ delete playback_engine;
+ playback_engine = 0;
+}
+
EDL* VWindow::get_edl()
{
void VWindow::change_source(int edl_number)
{
if(!is_running()) return;
+ if( playback_engine->is_playing_back )
+ stop_playback(1);
+ gui->lock_window("VWindow::change_source 1");
//printf("VWindow::change_source %d %p\n", __LINE__, mwindow->edl->get_vwindow_edl(edl_number));
if( edl_number >= 0 && edl_number < mwindow->edl->total_vwindow_edls() &&
mwindow->edl->get_vwindow_edl(edl_number) )
// indexable = 0;
// mwindow->edl->vwindow_edl_shared = 0;
}
+ gui->unlock_window();
}
void VWindow::change_source(Indexable *indexable)
{
if(!running()) return;
+ if( playback_engine->is_playing_back )
+ stop_playback(1);
+
// if(asset && this->asset &&
// asset->id == this->asset->id &&
// asset == this->asset) return;
+ gui->lock_window("VWindow::change_source 2");
//printf("VWindow::change_source %d\n", __LINE__);
if(asset)
mwindow->asset_to_edl(this->edl, asset);
else
- mwindow->edl_to_nested(this->edl, nested_edl);
+ this->edl->to_nested(nested_edl);
// Update GUI
gui->change_source(this->edl, title);
//printf("VWindow::change_source 2\n");
+ gui->unlock_window();
}
void VWindow::change_source(EDL *edl)
{
if(!running()) return;
+ if( playback_engine->is_playing_back )
+ stop_playback(1);
+
//printf("VWindow::change_source %d %p\n", __LINE__, edl);
// EDLs are identical
// if(edl && mwindow->edl->vwindow_edl &&
// edl->id == mwindow->edl->vwindow_edl->id) return;
if(edl && get_edl() && edl->id == get_edl()->id) return;
+ gui->lock_window("VWindow::change_source 3");
+
delete_source(1, 0);
if(edl)
}
else
gui->change_source(edl, _("Viewer"));
+ gui->unlock_window();
}
{
//printf("VWindow::update_position %d\n", __LINE__);
//edl->dump();
- playback_engine->que->send_command(CURRENT_FRAME,
- change_type,
- edl,
- 1);
+ playback_engine->refresh_frame(change_type, edl);
double position = edl->local_session->get_selectionstart(1);
if(lock_window) gui->lock_window("VWindow::update_position");
gui->clock->update(position);
+ gui->timebar->update(1);
if(lock_window) gui->unlock_window();
}
}
-void VWindow::stop_playback()
+void VWindow::stop_playback(int wait)
{
- int locked = gui->get_window_lock();
- if( locked ) gui->unlock_window();
- playback_engine->interrupt_playback(1);
- if( locked ) gui->lock_window("VWindow::stop_playback");
+ playback_engine->stop_playback(wait);
}
int VWindow::update_position(double position)
}
}
-void VWindow::clear_inpoint()
+void VWindow::unset_inoutpoint()
{
EDL *edl = get_edl();
if(edl)
{
- edl->local_session->unset_inpoint();
+ edl->unset_inoutpoint();
gui->timebar->update(1);
}
}
-void VWindow::clear_outpoint()
+void VWindow::copy(int all)
{
EDL *edl = get_edl();
if(edl)
{
- edl->local_session->unset_outpoint();
- gui->timebar->update(1);
- }
-}
-
-void VWindow::copy()
-{
- EDL *edl = get_edl();
- if(edl)
- {
- double start = edl->local_session->get_selectionstart();
- double end = edl->local_session->get_selectionend();
+ double start = all ? 0 :
+ edl->local_session->get_selectionstart();
+ double end = all ? edl->tracks->total_length() :
+ edl->local_session->get_selectionend();
+ EDL *copy_edl = new EDL; // no parent or assets wont be copied
+ copy_edl->create_objects();
+ copy_edl->copy_all(edl);
FileXML file;
- edl->copy(start,
- end,
- 0,
- 0,
- 0,
- &file,
- "",
- 1);
+ copy_edl->copy(start, end, 0, &file, "", 1);
+ copy_edl->remove_user();
const char *file_string = file.string();
long file_length = strlen(file_string);
mwindow->gui->lock_window();