X-Git-Url: https://git.cinelerra-gg.org/git/?a=blobdiff_plain;f=cinelerra-5.1%2Fcinelerra%2Fpanautos.C;fp=cinelerra-5.1%2Fcinelerra%2Fpanautos.C;h=a333ad9956068ee600ea40572e1f61536abf8477;hb=30bdb85eb33a8ee7ba675038a86c6be59c43d7bd;hp=0000000000000000000000000000000000000000;hpb=52fcc46226f9df46f9ce9d0566dc568455a7db0b;p=goodguy%2Fhistory.git diff --git a/cinelerra-5.1/cinelerra/panautos.C b/cinelerra-5.1/cinelerra/panautos.C new file mode 100644 index 00000000..a333ad99 --- /dev/null +++ b/cinelerra-5.1/cinelerra/panautos.C @@ -0,0 +1,88 @@ + +/* + * CINELERRA + * Copyright (C) 2008 Adam Williams + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA + * + */ + +#include "automation.inc" +#include "panauto.h" +#include "panautos.h" +#include "transportque.inc" + +PanAutos::PanAutos(EDL *edl, Track *track) + : Autos(edl, track) +{ + type = AUTOMATION_TYPE_PAN; +} + +PanAutos::~PanAutos() +{ +} + + +Auto* PanAutos::new_auto() +{ + return new PanAuto(edl, this); +} + +void PanAutos::get_handle(int &handle_x, + int &handle_y, + int64_t position, + int direction, + PanAuto* &previous, + PanAuto* &next) +{ + previous = (PanAuto*)get_prev_auto(position, direction, (Auto* &)previous); + next = (PanAuto*)get_next_auto(position, direction, (Auto* &)next); + +// Constant + if(previous->handle_x == next->handle_x && + previous->handle_y == next->handle_y) + { + handle_x = previous->handle_x; + handle_y = previous->handle_y; + return; + } + +// Interpolate + int64_t total = labs(next->position - previous->position); + double fraction; + if(direction == PLAY_FORWARD) + { + fraction = (double)(position - previous->position) / total; + } + else + { + fraction = (double)(previous->position - position) / total; + } + + handle_x = (int)(previous->handle_x + (next->handle_x - previous->handle_x) * fraction); + handle_y = (int)(previous->handle_y + (next->handle_y - previous->handle_y) * fraction); +} + +void PanAutos::dump() +{ + printf(" PanAutos::dump %p\n", this); + printf(" Default: position %jd\n", default_auto->position); + ((PanAuto*)default_auto)->dump(); + for(Auto* current = first; current; current = NEXT) + { + printf(" position %jd\n", current->position); + ((PanAuto*)current)->dump(); + } +}