/*******************************************************************************/ /* Copyright (C) 2008 Jonathan Moore Liles */ /* */ /* 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; see the file COPYING. If not,write to the Free Software */ /* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ /*******************************************************************************/ #include "Track.H" #include "Region.H" #include "Timeline.H" #include #include #include #include #include extern Timeline timeline; Region::Region ( int X, int Y, int W, int H, const char *L ) : Waveform( X, Y, W, H, L ) { init(); } void Region::init ( void ) { align( FL_ALIGN_INSIDE | FL_ALIGN_LEFT | FL_ALIGN_BOTTOM | FL_ALIGN_CLIP ); labeltype( FL_SHADOW_LABEL ); labelcolor( FL_WHITE ); box( FL_PLASTIC_UP_BOX ); _track = NULL; } Region::Region ( const Region & rhs ) : Waveform( rhs ) { box( rhs.box() ); align( rhs.align() ); color( rhs.color() ); selection_color( rhs.selection_color() ); labelcolor( rhs.labelcolor() ); labeltype( rhs.labeltype() ); _track = rhs._track; } Region::Region ( Clip *c ) : Waveform( c ) { init(); } void Region::trim ( enum trim_e t, int X ) { switch ( t ) { case LEFT: { int d = X - x(); // _start += d; if ( d < 0 && _start < timeline.x_to_ts( x() + d ) ) { _start = 0; break; } else _start = timeline.x_to_ts( x() + d ); // _start += timeline.x_to_ts( d ); resize( x() + d, y(), w() - d, h() ); break; } case RIGHT: { int d = (x() + w()) - X; // _end = _start + w() - d; _end = timeline.x_to_ts( _start + w() - d ); resize( x(), y(), w() - d, h() ); break; } default: return; } redraw(); parent()->redraw(); } int Region::handle ( int m ) { if ( Fl_Widget::handle( m ) ) return 1; static int ox, oy; static enum trim_e trimming; static bool copied = false; int X = Fl::event_x(); int Y = Fl::event_y(); switch ( m ) { case FL_PUSH: { if ( Fl::event_state() & FL_SHIFT ) { switch ( Fl::event_button() ) { case 1: trim( trimming = LEFT, X ); break; case 3: trim( trimming = RIGHT, X ); break; default: return 0; } fl_cursor( FL_CURSOR_WE ); return 1; } else { ox = x() - X; oy = y() - Y; if ( Fl::event_button() == 2 ) normalize(); return 1; } return 0; break; } case FL_RELEASE: fl_cursor( FL_CURSOR_DEFAULT ); copied = false; trimming = NO; return 1; case FL_DRAG: if ( Fl::event_state() & FL_SHIFT ) if ( trimming ) { trim( trimming, X ); return 1; } else return 0; if ( Fl::event_state() & FL_CTRL ) { if ( ! copied ) { _track->add( new Region( *this ) ); copied = true; return 1; } } if ( ox + X >= _track->x() ) position( ox + X, y() ); if ( Y > y() + h() ) { if ( _track->next() ) _track->next()->add( this ); } else if ( Y < y() ) { if ( _track->prev() ) _track->prev()->add( this ); } parent()->redraw(); fl_cursor( FL_CURSOR_MOVE ); if ( X >= timeline.scroll->x() + timeline.scroll->w() || X <= timeline.scroll->x() ) { /* this drag needs to scroll */ long pos = timeline.scroll->xposition(); if ( X <= timeline.scroll->x() ) pos -= 100; else pos += 100; if ( pos < 0 ) pos = 0; timeline.scroll->position( pos, timeline.scroll->yposition() ); } _offset = timeline.x_to_ts( x() ); return 1; default: return 0; break; } } void Region::draw ( void ) { draw_box(); // fl_push_clip( x() + Fl::box_dx( box() ), y(), w() - Fl::box_dw( box() ), h() ); Waveform::draw(); // fl_pop_clip(); fl_color( FL_RED ); fl_line( x() - _start, y(), x() - _start, y() + h() ); fl_line( x() + w() - _end, y(), x() + w() - _end, y() + h() ); draw_label(); /* static char pat[200]; */ /* sprintf( pat, "start %lu, end %lu", _start, _end ); */ /* fl_draw( pat, x(), y() + h() / 2 ); */ }