Browse Source

Fixup virtual scrolling.

tags/non-daw-v1.1.0
Jonathan Moore Liles 17 years ago
parent
commit
5e0e95cc0a
3 changed files with 41 additions and 6 deletions
  1. +33
    -3
      Region.C
  2. +6
    -2
      Region.H
  3. +2
    -1
      Track.C

+ 33
- 3
Region.C View File

@@ -297,8 +297,32 @@ Region::resize ( void )
void
Region::draw ( int X, int Y, int W, int H )
{
int rx = timeline.ts_to_x( _offset ) - X;
int rw = min( timeline.ts_to_x( _end - _start ), W );
if ( ! ( W > 0 && H > 0 ) )
return;

if ( _offset > timeline.xoffset + timeline.x_to_ts( _track->w() ) ||
( _offset < timeline.xoffset &&
_offset + (_end - _start) < timeline.xoffset ) )
return;

int rw = timeline.ts_to_x( _end - _start );

nframes_t end = _offset + ( _end - _start );

/* calculate waveform offset due to scrolling */
nframes_t offset = 0;
if ( _offset < timeline.xoffset )
{
offset = timeline.xoffset - _offset;

rw = timeline.ts_to_x( (_end - _start) - offset );
}

rw = min( rw, _track->w() );

int rx = x();

printf( "rx %d, rw %d\n", rx, rw );

fl_push_clip( rx, Y, rw, H );

@@ -307,7 +331,7 @@ Region::draw ( int X, int Y, int W, int H )

// fl_push_clip( x() + Fl::box_dx( box() ), y(), w() - Fl::box_dw( box() ), h() );

draw_waveform( rx, Y, rw, H, _clip, _start, _end, _scale, _color );
draw_waveform( rx, Y, rw, H, _clip, _start + offset, _end - offset, _scale, _color );

fl_color( FL_BLACK );
fl_line( rx, Y, rx, Y + H );
@@ -332,4 +356,10 @@ Region::draw ( int X, int Y, int W, int H )
// fl_draw( _clip->name(), X, Y );

//(Fl_Align)FL_ALIGN_LEFT | FL_ALIGN_BOTTOM );


fl_color( FL_RED );
fl_line( x(), y(), x(), y() + h() );


}

+ 6
- 2
Region.H View File

@@ -27,7 +27,8 @@
#include "Track.H"
#include "Timeline.H"


#include <algorithm>
using namespace std;
/* 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 */
@@ -56,8 +57,11 @@ public:

int y ( void ) const { return _track->y(); }
int h ( void ) const { return _track->h(); }
int x ( void ) const { return _track->x() + timeline.ts_to_x( _offset - timeline.xoffset ); }
int x ( void ) const { return _offset < timeline.xoffset ? -1 : min( 32767, _track->x() + timeline.ts_to_x( _offset - timeline.xoffset ) ); }
// int x ( void ) const { return (short)( _track->x() + timeline.ts_to_x( _offset - timeline.xoffset )); }

int w ( void ) const { return timeline.ts_to_x( _end - _start ); }
// int w ( void ) const { return timeline.ts_to_x( (_end - _start) - ( timeline.xoffset - _offset) ); }

Fl_Color color ( void ) { return _color; }
Fl_Color box_color ( void ) { return _box_color; }


+ 2
- 1
Track.C View File

@@ -33,7 +33,8 @@ Track::draw ( void )

for ( list <Region *>::iterator r = _regions.begin(); r != _regions.end(); r++ )
{
(*r)->draw( timeline.xoffset + x(), y(), w(), h() );
// (*r)->draw( timeline.xoffset + x(), y(), w(), h() );
(*r)->draw( x(), y(), w(), h() );
}

fl_pop_clip();


Loading…
Cancel
Save