projects
/
goodguy
/
history.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
arch bld deps, opus bld fix, add render beep, shortcut filebox ctrl a/z, batchrender...
[goodguy/history.git]
/
cinelerra-5.1
/
cinelerra
/
mwindow.C
diff --git
a/cinelerra-5.1/cinelerra/mwindow.C
b/cinelerra-5.1/cinelerra/mwindow.C
index c65f99f21167bf5c15932b3cd44c4196638d3c5e..992e9f342823dff1d3cec31537a08a3269725982 100644
(file)
--- a/
cinelerra-5.1/cinelerra/mwindow.C
+++ b/
cinelerra-5.1/cinelerra/mwindow.C
@@
-230,6
+230,7
@@
MWindow::MWindow()
screens = 1;
in_destructor = 0;
speed_edl = 0;
screens = 1;
in_destructor = 0;
speed_edl = 0;
+ proxy_beep = 0;
}
}
@@
-244,6
+245,7
@@
MWindow::~MWindow()
#ifdef HAVE_DVB
gui->channel_info->stop();
#endif
#ifdef HAVE_DVB
gui->channel_info->stop();
#endif
+ delete proxy_beep;
delete create_bd; create_bd = 0;
delete create_dvd; create_dvd = 0;
delete batch_render; batch_render = 0;
delete create_bd; create_bd = 0;
delete create_dvd; create_dvd = 0;
delete batch_render; batch_render = 0;
@@
-1155,7
+1157,6
@@
void MWindow::del_mixer(ZWindow *zwindow)
{
zwindows_lock->lock("MWindow::del_mixer 0");
edl->mixers.del_mixer(zwindow->idx);
{
zwindows_lock->lock("MWindow::del_mixer 0");
edl->mixers.del_mixer(zwindow->idx);
- zwindow->idx = -1;
if( session->selected_zwindow >= 0 ) {
int i = zwindows.number_of(zwindow);
if( i >= 0 && i < session->selected_zwindow )
if( session->selected_zwindow >= 0 ) {
int i = zwindows.number_of(zwindow);
if( i >= 0 && i < session->selected_zwindow )
@@
-1267,12
+1268,13
@@
void MWindow::stop_mixers()
}
}
}
}
-void MWindow::close_mixers()
+void MWindow::close_mixers(
int destroy
)
{
zwindows_lock->lock("MWindow::close_mixers");
{
zwindows_lock->lock("MWindow::close_mixers");
- for( int i=
0; i<zwindows.size(); ++i
) {
+ for( int i=
zwindows.size(); --i>=0;
) {
ZWindow *zwindow = zwindows[i];
if( zwindow->idx < 0 ) continue;
ZWindow *zwindow = zwindows[i];
if( zwindow->idx < 0 ) continue;
+ zwindow->destroy = destroy;
ZWindowGUI *zgui = zwindow->zgui;
zgui->lock_window("MWindow::select_zwindow 0");
zgui->set_done(0);
ZWindowGUI *zgui = zwindow->zgui;
zgui->lock_window("MWindow::select_zwindow 0");
zgui->set_done(0);
@@
-1327,11
+1329,13
@@
void MWindow::create_mixers()
for( int i=0; i<session->drag_assets->size(); ++i ) {
Indexable *indexable = session->drag_assets->get(i);
for( int i=0; i<session->drag_assets->size(); ++i ) {
Indexable *indexable = session->drag_assets->get(i);
+ if( !indexable->have_video() ) continue;
ZWindow *zwindow = create_mixer(indexable);
new_mixers.append(zwindow);
}
for( int i=0; i<session->drag_clips->size(); ++i ) {
Indexable *indexable = (Indexable*)session->drag_clips->get(i);
ZWindow *zwindow = create_mixer(indexable);
new_mixers.append(zwindow);
}
for( int i=0; i<session->drag_clips->size(); ++i ) {
Indexable *indexable = (Indexable*)session->drag_clips->get(i);
+ if( !indexable->have_video() ) continue;
ZWindow *zwindow = create_mixer(indexable);
new_mixers.append(zwindow);
}
ZWindow *zwindow = create_mixer(indexable);
new_mixers.append(zwindow);
}
@@
-1757,6
+1761,12
@@
void MWindow::stop_transport()
gui->stop_transport(gui->get_window_lock() ? "MWindow::stop_transport" : 0);
}
gui->stop_transport(gui->get_window_lock() ? "MWindow::stop_transport" : 0);
}
+void MWindow::beep(double freq, double secs, double gain)
+{
+ if( !proxy_beep ) proxy_beep = new ProxyBeep(this);
+ proxy_beep->tone(freq, secs, gain);
+}
+
int MWindow::load_filenames(ArrayList<char*> *filenames,
int load_mode,
int update_filename)
int MWindow::load_filenames(ArrayList<char*> *filenames,
int load_mode,
int update_filename)
@@
-2126,6
+2136,7
@@
if(debug) printf("MWindow::load_filenames %d\n", __LINE__);
edl->session->proxy_scale = 1;
edl->session->proxy_use_scaler = 0;
edl->session->proxy_auto_scale = 0;
edl->session->proxy_scale = 1;
edl->session->proxy_use_scaler = 0;
edl->session->proxy_auto_scale = 0;
+ edl->session->proxy_beep = 0;
edl->local_session->preview_start = 0;
edl->local_session->preview_end = 0;
edl->local_session->loop_playback = 0;
edl->local_session->preview_start = 0;
edl->local_session->preview_end = 0;
edl->local_session->loop_playback = 0;
@@
-2155,8
+2166,14
@@
if(debug) printf("MWindow::load_filenames %d\n", __LINE__);
}
}
gui->unlock_window(); // to update progress bar
}
}
gui->unlock_window(); // to update progress bar
- render_proxy(orig_idxbls);
+
int ret =
render_proxy(orig_idxbls);
gui->lock_window("MWindow::load_filenames");
gui->lock_window("MWindow::load_filenames");
+ if( ret >= 0 && edl->session->proxy_beep ) {
+ if( ret > 0 )
+ beep(2000., 1.5, 0.5);
+ else
+ beep(4000., 0.25, 0.5);
+ }
}
// need to update undo before project, since mwindow is unlocked & a new load
}
// need to update undo before project, since mwindow is unlocked & a new load
@@
-2203,7
+2220,7
@@
if(debug) printf("MWindow::load_filenames %d\n", __LINE__);
return 0;
}
return 0;
}
-
void
MWindow::render_proxy(ArrayList<Indexable *> &new_idxbls)
+
int
MWindow::render_proxy(ArrayList<Indexable *> &new_idxbls)
{
Asset *format_asset = new Asset;
format_asset->format = FILE_FFMPEG;
{
Asset *format_asset = new Asset;
format_asset->format = FILE_FFMPEG;
@@
-2231,6
+2248,7
@@
void MWindow::render_proxy(ArrayList<Indexable *> &new_idxbls)
&proxy_render.orig_idxbls, &proxy_render.orig_proxies);
}
format_asset->remove_user();
&proxy_render.orig_idxbls, &proxy_render.orig_proxies);
}
format_asset->remove_user();
+ return !result ? proxy_render.needed_proxies.size() : -1;
}
void MWindow::test_plugins(EDL *new_edl, char *path)
}
void MWindow::test_plugins(EDL *new_edl, char *path)
@@
-3284,7
+3302,7
@@
void MWindow::update_project(int load_mode)
}
if(debug) PRINT_TRACE
select_zwindow(0);
}
if(debug) PRINT_TRACE
select_zwindow(0);
- close_mixers();
+ close_mixers(
0
);
for( int i=0; i<edl->mixers.size(); ++i ) {
Mixer *mixer = edl->mixers[i];
for( int i=0; i<edl->mixers.size(); ++i ) {
Mixer *mixer = edl->mixers[i];