X-Git-Url: https://git.cinelerra-gg.org/git/?p=goodguy%2Fcinelerra.git;a=blobdiff_plain;f=cinelerra-5.1%2Fcinelerra%2Fautos.C;h=a48afbb508531f1abc99c477dbf9a6a46f853df5;hp=cb5a1bd265eb254ff165bd42a4c501f105614a24;hb=HEAD;hpb=47f71d004db08fb289428240fb87ce97c64382d2 diff --git a/cinelerra-5.1/cinelerra/autos.C b/cinelerra-5.1/cinelerra/autos.C index cb5a1bd2..a48afbb5 100644 --- a/cinelerra-5.1/cinelerra/autos.C +++ b/cinelerra-5.1/cinelerra/autos.C @@ -265,20 +265,21 @@ int Autos::auto_exists_for_editing(double position) Auto* Autos::get_auto_at_position(double position) { - int64_t unit_position = track->to_units(position, 0); - for(Auto *current = first; - current; - current = NEXT) - { - if(edl->equivalent(current->position, unit_position)) - { + for( Auto *current=first; current; current=NEXT ) { + double pos = track->from_units(current->position); + if( edl->equivalent(position, pos) ) return current; - } } return 0; } +Auto* Autos::get_auto(int id) +{ + Auto *current = first; + while( current && current->orig_id != id ) current = NEXT; + return current; +} Auto* Autos::get_auto_for_editing(double position, int create) { @@ -290,7 +291,7 @@ Auto* Autos::get_auto_for_editing(double position, int create) get_prev_auto(track->to_units(position, 0), PLAY_FORWARD, result); if( create > 0 ) create = edl->session->auto_keyframes; if( create && (!result || result->is_default || - !EQUIV(track->from_units(result->position), position)) ) { + !EQUIV(track->from_units(result->position), position)) ) { //printf("Autos::get_auto_for_editing %p %p %p\n", default_auto, first, result); position = edl->align_to_frame(position, 0); result = insert_auto(track->to_units(position, 0)); @@ -383,10 +384,11 @@ Auto* Autos::insert_auto(int64_t position, Auto *templ) // Set curve mode if( !templ && result->is_floatauto() ) { FloatAuto *floatauto = (FloatAuto *)result; - floatauto->curve_mode = + FloatAuto::t_mode new_mode = edl->local_session->playback_start >= 0 && edl->local_session->playback_end < 0 ? FloatAuto::SMOOTH : (FloatAuto::t_mode) edl->local_session->floatauto_type; + floatauto->change_curve_mode(new_mode, 0); } } else @@ -397,17 +399,11 @@ Auto* Autos::insert_auto(int64_t position, Auto *templ) return result; } -int Autos::clear_all() +void Autos::clear_all() { - Auto *current_, *current; - - for(current = first; current; current = current_) - { - current_ = NEXT; - remove(current); - } - append_auto(); - return 0; + while( last ) delete last; + delete default_auto; + create_objects(); } int Autos::insert(int64_t start, int64_t end)