Clean up some focus and display issues.
This commit is contained in:
parent
82ada52b71
commit
754aa55af4
|
@ -42,7 +42,7 @@ public:
|
||||||
Fl_Input::draw();
|
Fl_Input::draw();
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
fl_color( FL_WHITE /* textcolor() */ );
|
fl_color( FL_FOREGROUND_COLOR /* textcolor() */ );
|
||||||
fl_font( textfont(), textsize() );
|
fl_font( textfont(), textsize() );
|
||||||
fl_draw( value(), x(), y(), w(), h(), FL_ALIGN_CENTER );
|
fl_draw( value(), x(), y(), w(), h(), FL_ALIGN_CENTER );
|
||||||
}
|
}
|
||||||
|
@ -65,47 +65,14 @@ public:
|
||||||
return r;
|
return r;
|
||||||
case FL_UNFOCUS:
|
case FL_UNFOCUS:
|
||||||
_editing = false;
|
_editing = false;
|
||||||
{
|
|
||||||
/* lame, but we have to find the next parent
|
|
||||||
* with a box in order to clear the background
|
|
||||||
* properly */
|
|
||||||
|
|
||||||
Fl_Group *g = parent();
|
if ( window() )
|
||||||
|
window()->damage( FL_DAMAGE_EXPOSE, x(), y(), w(), h() );
|
||||||
|
|
||||||
for ( ; g; g = g->parent() )
|
|
||||||
{
|
|
||||||
switch ( g->box() )
|
|
||||||
{
|
|
||||||
case FL_NO_BOX:
|
|
||||||
case FL_UP_FRAME:
|
|
||||||
case FL_DOWN_FRAME:
|
|
||||||
case FL_THIN_UP_FRAME:
|
|
||||||
case FL_THIN_DOWN_FRAME:
|
|
||||||
case FL_ENGRAVED_FRAME:
|
|
||||||
case FL_EMBOSSED_FRAME:
|
|
||||||
// case FL_SHADOW_FRAME:
|
|
||||||
// case FL_PLASTIC_UP_FRAME:
|
|
||||||
// case FL_PLASTIC_DOWN_FRAME:
|
|
||||||
// case FL_ROUNDED_FRAME:
|
|
||||||
// case FL_OVAL_FRAME:
|
|
||||||
continue;
|
|
||||||
default:
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ( g )
|
|
||||||
{
|
|
||||||
printf( "damaging parent\n" );
|
|
||||||
g->damage( FL_DAMAGE_EXPOSE, x(), y(), w(), h() );
|
|
||||||
}
|
|
||||||
}
|
|
||||||
redraw();
|
redraw();
|
||||||
return r;
|
return r;
|
||||||
default:
|
default:
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
|
@ -134,11 +134,11 @@ protected:
|
||||||
else if ( ! strcmp( s, ":fade-in-type" ) )
|
else if ( ! strcmp( s, ":fade-in-type" ) )
|
||||||
_fade_in.type = (Fade::fade_type_e)atoi( v );
|
_fade_in.type = (Fade::fade_type_e)atoi( v );
|
||||||
else if ( ! strcmp( s, ":fade-in-duration" ) )
|
else if ( ! strcmp( s, ":fade-in-duration" ) )
|
||||||
_fade_in.length = atol( v );
|
_fade_in.length = atoll( v );
|
||||||
else if ( ! strcmp( s, ":fade-out-type" ) )
|
else if ( ! strcmp( s, ":fade-out-type" ) )
|
||||||
_fade_out.type = (Fade::fade_type_e)atoi( v );
|
_fade_out.type = (Fade::fade_type_e)atoi( v );
|
||||||
else if ( ! strcmp( s, ":fade-out-duration" ) )
|
else if ( ! strcmp( s, ":fade-out-duration" ) )
|
||||||
_fade_out.length = atol( v );
|
_fade_out.length = atoll( v );
|
||||||
else if ( ! strcmp( s, ":source" ) )
|
else if ( ! strcmp( s, ":source" ) )
|
||||||
{
|
{
|
||||||
if ( ! ( _clip = Audio_File::from_file( v ) ) )
|
if ( ! ( _clip = Audio_File::from_file( v ) ) )
|
||||||
|
|
|
@ -179,7 +179,7 @@ exit( 0 );}
|
||||||
xywh {0 0 74 25}
|
xywh {0 0 74 25}
|
||||||
} {
|
} {
|
||||||
MenuItem {} {
|
MenuItem {} {
|
||||||
label Home
|
label Start
|
||||||
callback {transport->locate( 0 );}
|
callback {transport->locate( 0 );}
|
||||||
xywh {0 0 40 25} shortcut 0xff50
|
xywh {0 0 40 25} shortcut 0xff50
|
||||||
}
|
}
|
||||||
|
@ -200,6 +200,7 @@ exit( 0 );}
|
||||||
}
|
}
|
||||||
MenuItem {} {
|
MenuItem {} {
|
||||||
label Record
|
label Record
|
||||||
|
callback {transport->toggle_record();} selected
|
||||||
xywh {40 40 40 25} shortcut 0x50072
|
xywh {40 40 40 25} shortcut 0x50072
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -252,7 +253,7 @@ exit( 0 );}
|
||||||
} {
|
} {
|
||||||
MenuItem {} {
|
MenuItem {} {
|
||||||
label Bars
|
label Bars
|
||||||
callback {Timeline::snap_to = Timeline::Bars;} selected
|
callback {Timeline::snap_to = Timeline::Bars;}
|
||||||
xywh {0 0 40 25} type Radio value 1
|
xywh {0 0 40 25} type Radio value 1
|
||||||
}
|
}
|
||||||
MenuItem {} {
|
MenuItem {} {
|
||||||
|
|
|
@ -465,7 +465,7 @@ Timeline::draw ( void )
|
||||||
||
|
||
|
||||||
damage() & FL_DAMAGE_EXPOSE )
|
damage() & FL_DAMAGE_EXPOSE )
|
||||||
{
|
{
|
||||||
draw_box( box(), 0, 0, w(), h(), color() );
|
draw_box( box(), 0, 0, w(), h(), this == Fl::focus() ? color() : fl_darker( color() ) );
|
||||||
|
|
||||||
fl_push_clip( 0, rulers->y(), w(), rulers->h() );
|
fl_push_clip( 0, rulers->y(), w(), rulers->h() );
|
||||||
draw_child( *rulers );
|
draw_child( *rulers );
|
||||||
|
@ -717,8 +717,17 @@ Timeline::handle ( int m )
|
||||||
|
|
||||||
switch ( m )
|
switch ( m )
|
||||||
{
|
{
|
||||||
|
case FL_FOCUS:
|
||||||
|
case FL_UNFOCUS:
|
||||||
|
redraw();
|
||||||
|
return 1;
|
||||||
case FL_KEYBOARD:
|
case FL_KEYBOARD:
|
||||||
|
case FL_SHORTCUT:
|
||||||
{
|
{
|
||||||
|
if ( Fl::event_state() & ( FL_ALT || FL_CTRL || FL_SHIFT ) )
|
||||||
|
/* we don't want any keys with modifiers... */
|
||||||
|
return 0;
|
||||||
|
|
||||||
switch ( Fl::event_key() )
|
switch ( Fl::event_key() )
|
||||||
{
|
{
|
||||||
case FL_Delete:
|
case FL_Delete:
|
||||||
|
@ -727,14 +736,10 @@ Timeline::handle ( int m )
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
case FL_Home:
|
||||||
/* case FL_Home: */
|
case FL_End:
|
||||||
/* transport->locate( 0 ); */
|
/* keep scrollbar from eating these. */
|
||||||
/* return 1; */
|
return 0;
|
||||||
/* case ' ': */
|
|
||||||
/* transport->toggle(); */
|
|
||||||
/* return 1; */
|
|
||||||
|
|
||||||
case 'p':
|
case 'p':
|
||||||
{
|
{
|
||||||
int X = Fl::event_x() - Track::width();
|
int X = Fl::event_x() - Track::width();
|
||||||
|
@ -776,6 +781,10 @@ Timeline::handle ( int m )
|
||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
{
|
{
|
||||||
|
|
||||||
|
if ( m == FL_PUSH )
|
||||||
|
Fl::focus( this );
|
||||||
|
|
||||||
int r = Fl_Overlay_Window::handle( m );
|
int r = Fl_Overlay_Window::handle( m );
|
||||||
|
|
||||||
if ( m != FL_RELEASE && r )
|
if ( m != FL_RELEASE && r )
|
||||||
|
@ -788,7 +797,7 @@ Timeline::handle ( int m )
|
||||||
{
|
{
|
||||||
case FL_PUSH:
|
case FL_PUSH:
|
||||||
{
|
{
|
||||||
take_focus();
|
// take_focus();
|
||||||
|
|
||||||
if ( Fl::event_button1() )
|
if ( Fl::event_button1() )
|
||||||
{
|
{
|
||||||
|
|
|
@ -130,10 +130,10 @@ Track::init ( void )
|
||||||
o->color( ( Fl_Color ) 53 );
|
o->color( ( Fl_Color ) 53 );
|
||||||
{
|
{
|
||||||
Fl_Input *o = name_field = new Fl_Sometimes_Input( 2, 2, 144, 24 );
|
Fl_Input *o = name_field = new Fl_Sometimes_Input( 2, 2, 144, 24 );
|
||||||
o->color( ( Fl_Color ) 33 );
|
o->color( FL_BACKGROUND_COLOR );
|
||||||
o->labeltype( FL_NO_LABEL );
|
o->labeltype( FL_NO_LABEL );
|
||||||
o->labelcolor( FL_GRAY0 );
|
o->labelcolor( FL_GRAY0 );
|
||||||
o->textcolor( 32 );
|
o->textcolor( FL_FOREGROUND_COLOR );
|
||||||
|
|
||||||
o->callback( cb_input_field, (void*)this );
|
o->callback( cb_input_field, (void*)this );
|
||||||
}
|
}
|
||||||
|
|
|
@ -67,6 +67,17 @@ private:
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
|
void toggle_record ( void )
|
||||||
|
{
|
||||||
|
if ( _record_button->value() )
|
||||||
|
_record_button->value( 0 );
|
||||||
|
else
|
||||||
|
_record_button->value( 1 );
|
||||||
|
|
||||||
|
_record_button->do_callback();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
Transport ( int X, int Y, int W, int H, const char *L=0 )
|
Transport ( int X, int Y, int W, int H, const char *L=0 )
|
||||||
: Fl_Pack( X, Y, W, H, L )
|
: Fl_Pack( X, Y, W, H, L )
|
||||||
{
|
{
|
||||||
|
@ -104,6 +115,18 @@ public:
|
||||||
end();
|
end();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
handle ( int m )
|
||||||
|
{
|
||||||
|
/* FIXME: hack to avoid stealing focus */
|
||||||
|
|
||||||
|
if ( m == FL_FOCUS )
|
||||||
|
return 0;
|
||||||
|
else
|
||||||
|
return Fl_Pack::handle( m );
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
bool rolling;
|
bool rolling;
|
||||||
|
|
||||||
void poll ( void );
|
void poll ( void );
|
||||||
|
|
Loading…
Reference in New Issue