@@ -105,7 +105,7 @@ Audio_Region::init ( void ) | |||
/* copy constructor */ | |||
Audio_Region::Audio_Region ( const Audio_Region & rhs ) | |||
{ | |||
*((Sequence_Widget*)this) = (Sequence_Widget &)rhs; | |||
*((Sequence_Region*)this) = (Sequence_Region &)rhs; | |||
_clip = rhs._clip; | |||
_scale = rhs._scale; | |||
@@ -166,59 +166,6 @@ Audio_Region::Audio_Region ( Audio_File *c, Sequence *t, nframes_t o ) | |||
log_create(); | |||
} | |||
void | |||
Audio_Region::trim ( enum trim_e t, int X ) | |||
{ | |||
X -= _track->x(); | |||
redraw(); | |||
switch ( t ) | |||
{ | |||
case LEFT: | |||
{ | |||
/* if ( d < 0 ) */ | |||
/* // _track->damage( FL_DAMAGE_EXPOSE, x() + d, y(), 1 - d, h() ); */ | |||
/* _track->damage( FL_DAMAGE_EXPOSE, x(), y(), w(), h() ); */ | |||
/* else */ | |||
/* _track->damage( FL_DAMAGE_EXPOSE, x(), y(), d, h() ); */ | |||
int d = X - ( abs_x() - scroll_x() ); | |||
long td = timeline->x_to_ts( d ); | |||
if ( td < 0 && _r->start < 0 - td ) | |||
td = 0 - _r->start; | |||
if ( _r->start + td >= _r->end ) | |||
td = (_r->end - _r->start) - timeline->x_to_ts( 1 ); | |||
_r->start += td; | |||
_r->offset += td; | |||
break; | |||
} | |||
case RIGHT: | |||
{ | |||
int d = (( abs_x() - scroll_x() ) + abs_w() ) - X; | |||
/* _track->damage( FL_DAMAGE_EXPOSE, x() + w(), y(), d, h() ); */ | |||
long td = timeline->x_to_ts( d ); | |||
// printf( "%li %li\n", td, _r->end - _r->start ); | |||
if ( td >= 0 && _r->end - _r->start < td ) | |||
_r->end = _r->start + timeline->x_to_ts( 1 ); | |||
else | |||
_r->end -= td; | |||
break; | |||
} | |||
default: | |||
return; | |||
} | |||
} | |||
int | |||
Audio_Region::handle ( int m ) | |||
@@ -239,19 +186,14 @@ Audio_Region::handle ( int m ) | |||
int ret; | |||
if ( Sequence_Region::handle( m ) ) | |||
return 1; | |||
Logger _log( this ); | |||
//log_r->start(); | |||
switch ( m ) | |||
{ | |||
case FL_ENTER: | |||
Sequence_Widget::handle( m ); | |||
// redraw(); | |||
break; | |||
case FL_LEAVE: | |||
Sequence_Widget::handle( m ); | |||
// redraw(); | |||
break; | |||
case FL_KEYBOARD: | |||
{ | |||
if ( Fl::event_key() == FL_F + 3 ) | |||
@@ -286,22 +228,11 @@ Audio_Region::handle ( int m ) | |||
} | |||
case FL_PUSH: | |||
{ | |||
/* trimming / splitting */ | |||
/* splitting */ | |||
if ( Fl::event_shift() && ! Fl::event_ctrl() ) | |||
{ | |||
switch ( Fl::event_button() ) | |||
{ | |||
case 1: | |||
trim( trimming = LEFT, X ); | |||
begin_drag( Drag( x() - X, y() - Y ) ); | |||
_log.hold(); | |||
break; | |||
case 3: | |||
trim( trimming = RIGHT, X ); | |||
begin_drag( Drag( x() - X, y() - Y ) ); | |||
_log.hold(); | |||
break; | |||
case 2: | |||
{ | |||
/* split */ | |||
@@ -327,7 +258,6 @@ Audio_Region::handle ( int m ) | |||
break; | |||
} | |||
fl_cursor( FL_CURSOR_WE ); | |||
return 1; | |||
} | |||
else | |||
@@ -354,7 +284,7 @@ Audio_Region::handle ( int m ) | |||
} | |||
redraw(); | |||
goto changed; | |||
return 1; | |||
} | |||
else if ( Fl::event_button1() && Fl::event_ctrl() ) | |||
{ | |||
@@ -411,10 +341,8 @@ Audio_Region::handle ( int m ) | |||
Sequence_Widget::handle( m ); | |||
copied = false; | |||
if ( trimming != NO ) | |||
trimming = NO; | |||
goto changed; | |||
return 1; | |||
} | |||
case FL_DRAG: | |||
@@ -444,16 +372,6 @@ Audio_Region::handle ( int m ) | |||
return 1; | |||
} | |||
/* trimming */ | |||
if ( Fl::event_state() & FL_SHIFT ) | |||
if ( trimming ) | |||
{ | |||
trim( trimming, X ); | |||
return 1; | |||
} | |||
else | |||
return 0; | |||
/* duplication */ | |||
if ( Fl::event_state() & FL_CTRL ) | |||
{ | |||
@@ -465,36 +383,12 @@ Audio_Region::handle ( int m ) | |||
} | |||
} | |||
/* track jumping */ | |||
if ( ! selected() ) | |||
{ | |||
if ( Y > y() + h() || Y < y() ) | |||
{ | |||
printf( "wants to jump tracks\n" ); | |||
Track *t = timeline->track_under( Y ); | |||
fl_cursor( (Fl_Cursor)1 ); | |||
if ( t ) | |||
t->handle( FL_ENTER ); | |||
return 0; | |||
} | |||
} | |||
ret = Sequence_Widget::handle( m ); | |||
return ret | 1; | |||
default: | |||
return Sequence_Widget::handle( m ); | |||
break; | |||
} | |||
changed: | |||
return 1; | |||
} | |||
@@ -16,21 +16,20 @@ | |||
/* 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. */ | |||
/*******************************************************************************/ | |||
#pragma once | |||
#include "Audio_File.H" | |||
#include "Sequence.H" | |||
#include "Timeline.H" | |||
/* Audio_Regions are "virtual" FLTK widgets; this is necessary because the | |||
* dimensions of real FLTK widgets are limited to 16-bits, which is | |||
* far too little for our purposes */ | |||
#include "Sequence_Widget.H" | |||
#include "Loggable.H" | |||
#include "Sequence_Region.H" | |||
class Audio_Region : public Sequence_Widget | |||
class Audio_Region : public Sequence_Region | |||
{ | |||
public: | |||
@@ -158,8 +157,6 @@ public: | |||
Fl_Color selection_color ( void ) const { return _selection_color; } | |||
void selection_color ( Fl_Color v ) { _selection_color = v; } | |||
enum trim_e { NO, LEFT, RIGHT }; | |||
void trim ( enum trim_e t, int X ); | |||
void init ( void ); | |||
Audio_Region ( ) | |||
@@ -171,7 +168,6 @@ public: | |||
public: | |||
const char *source_name ( void ) const { return _clip->name(); } | |||
LOG_CREATE_FUNC( Audio_Region ); | |||
@@ -190,9 +186,10 @@ public: | |||
Audio_Region ( Audio_File *c ); | |||
Audio_Region ( Audio_File *c, Sequence *t, nframes_t o ); | |||
int handle ( int m ); | |||
void draw_fade ( const Fade &fade, Fade::fade_dir_e dir, bool filled, int X, int W ); | |||
int handle ( int m ); | |||
void draw_box( void ); | |||
void draw ( void ); | |||
void resize ( void ); | |||
@@ -0,0 +1,217 @@ | |||
/*******************************************************************************/ | |||
/* 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 "Sequence_Region.H" | |||
#include "Track.H" | |||
void | |||
Sequence_Region::draw_box ( void ) | |||
{ | |||
fl_draw_box( box(), x(), y(), w(), h(), color() ); | |||
} | |||
void | |||
Sequence_Region::draw ( void ) | |||
{ | |||
} | |||
void | |||
Sequence_Region::trim ( enum trim_e t, int X ) | |||
{ | |||
X -= _track->x(); | |||
redraw(); | |||
switch ( t ) | |||
{ | |||
case LEFT: | |||
{ | |||
/* if ( d < 0 ) */ | |||
/* // _track->damage( FL_DAMAGE_EXPOSE, x() + d, y(), 1 - d, h() ); */ | |||
/* _track->damage( FL_DAMAGE_EXPOSE, x(), y(), w(), h() ); */ | |||
/* else */ | |||
/* _track->damage( FL_DAMAGE_EXPOSE, x(), y(), d, h() ); */ | |||
int d = X - ( abs_x() - scroll_x() ); | |||
long td = timeline->x_to_ts( d ); | |||
if ( td < 0 && _r->start < 0 - td ) | |||
td = 0 - _r->start; | |||
if ( _r->start + td >= _r->end ) | |||
td = (_r->end - _r->start) - timeline->x_to_ts( 1 ); | |||
_r->start += td; | |||
_r->offset += td; | |||
break; | |||
} | |||
case RIGHT: | |||
{ | |||
int d = (( abs_x() - scroll_x() ) + abs_w() ) - X; | |||
/* _track->damage( FL_DAMAGE_EXPOSE, x() + w(), y(), d, h() ); */ | |||
long td = timeline->x_to_ts( d ); | |||
// printf( "%li %li\n", td, _r->end - _r->start ); | |||
if ( td >= 0 && _r->end - _r->start < td ) | |||
_r->end = _r->start + timeline->x_to_ts( 1 ); | |||
else | |||
_r->end -= td; | |||
break; | |||
} | |||
default: | |||
return; | |||
} | |||
} | |||
int | |||
Sequence_Region::handle ( int m ) | |||
{ | |||
static int ox, oy; | |||
static enum trim_e trimming; | |||
static bool copied = false; | |||
static nframes_t os; | |||
/* if ( ! active_r() ) */ | |||
/* return 0; */ | |||
// int X = Fl::event_x() - _track->x(); | |||
int X = Fl::event_x(); | |||
int Y = Fl::event_y(); | |||
int ret; | |||
Logger _log( this ); | |||
//log_r->start(); | |||
switch ( m ) | |||
{ | |||
case FL_PUSH: | |||
{ | |||
/* trimming */ | |||
if ( Fl::event_shift() && ! Fl::event_ctrl() ) | |||
{ | |||
switch ( Fl::event_button() ) | |||
{ | |||
case 1: | |||
trim( trimming = LEFT, X ); | |||
begin_drag( Drag( x() - X, y() - Y ) ); | |||
_log.hold(); | |||
break; | |||
case 3: | |||
trim( trimming = RIGHT, X ); | |||
begin_drag( Drag( x() - X, y() - Y ) ); | |||
_log.hold(); | |||
break; | |||
default: | |||
return 0; | |||
break; | |||
} | |||
fl_cursor( FL_CURSOR_WE ); | |||
return 1; | |||
} | |||
else if ( Fl::test_shortcut( FL_BUTTON3 ) ) | |||
{ | |||
if ( Sequence_Widget::current() == this ) | |||
{ | |||
if ( selected() ) | |||
deselect(); | |||
else | |||
select(); | |||
} | |||
redraw(); | |||
return 1; | |||
} | |||
else if ( Fl::test_shortcut( FL_CTRL + FL_BUTTON1 ) ) | |||
{ | |||
/* duplication */ | |||
return 1; | |||
} | |||
else | |||
return Sequence_Widget::handle( m ); | |||
break; | |||
} | |||
case FL_RELEASE: | |||
{ | |||
Sequence_Widget::handle( m ); | |||
copied = false; | |||
if ( trimming != NO ) | |||
trimming = NO; | |||
return 1; | |||
} | |||
case FL_DRAG: | |||
{ | |||
if ( ! _drag ) | |||
{ | |||
begin_drag( Drag( x() - X, y() - Y, x_to_offset( X ) ) ); | |||
_log.hold(); | |||
} | |||
/* trimming */ | |||
if ( Fl::event_state() & FL_SHIFT ) | |||
if ( trimming ) | |||
{ | |||
trim( trimming, X ); | |||
return 1; | |||
} | |||
else | |||
return 0; | |||
/* track jumping */ | |||
if ( ! selected() ) | |||
{ | |||
if ( Y > y() + h() || Y < y() ) | |||
{ | |||
printf( "wants to jump tracks\n" ); | |||
Track *t = timeline->track_under( Y ); | |||
fl_cursor( (Fl_Cursor)1 ); | |||
if ( t ) | |||
t->handle( FL_ENTER ); | |||
return 0; | |||
} | |||
} | |||
ret = Sequence_Widget::handle( m ); | |||
return ret | 1; | |||
} | |||
default: | |||
return Sequence_Widget::handle( m ); | |||
break; | |||
} | |||
} |
@@ -0,0 +1,78 @@ | |||
/*******************************************************************************/ | |||
/* 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. */ | |||
/*******************************************************************************/ | |||
#pragma once | |||
#include "Sequence.H" | |||
#include "Sequence_Widget.H" | |||
/* Base class representing a /region/ of time on a /sequence/, with | |||
controls for the start and end points. */ | |||
class Sequence_Region : public Sequence_Widget | |||
{ | |||
protected: | |||
virtual void get ( Log_Entry &e ) const | |||
{ | |||
e.add( ":color", (int)_box_color ); | |||
Sequence_Widget::get( e ); | |||
} | |||
void | |||
set ( Log_Entry &e ) | |||
{ | |||
for ( int i = 0; i < e.size(); ++i ) | |||
{ | |||
const char *s, *v; | |||
e.get( i, &s, &v ); | |||
if ( ! strcmp( s, ":color" ) ) | |||
_box_color = (Fl_Color)atoll( v ); | |||
} | |||
Sequence_Widget::set( e ); | |||
} | |||
Sequence_Region ( ) | |||
{ | |||
} | |||
virtual ~Sequence_Region ( ) | |||
{ | |||
} | |||
public: | |||
LOG_NAME_FUNC( Region ); | |||
enum trim_e { NO, LEFT, RIGHT }; | |||
void trim ( enum trim_e t, int X ); | |||
int handle ( int m ); | |||
void draw_box( void ); | |||
void draw ( void ); | |||
}; |
@@ -1,3 +1,4 @@ | |||
# -*- mode: makefile; -*- | |||
Timeline_VERSION := 0.5.0 | |||
@@ -19,6 +20,7 @@ Timeline/Audio_Region.C \ | |||
Timeline/Sequence.C \ | |||
Timeline/Sequence_Point.C \ | |||
Timeline/Sequence_Widget.C \ | |||
Timeline/Sequence_Region.C \ | |||
Timeline/TLE.C \ | |||
Timeline/Tempo_Point.C \ | |||
Timeline/Time_Point.C \ | |||