Loopp/src/gui.cxx

77 lines
1.5 KiB
C++
Raw Normal View History

2013-04-20 12:50:30 +02:00
#include "gui.hxx"
#include "avtk/avtk_image.h"
#include <sstream>
#include "audiobuffer.hxx"
// include the header.c file in the planning dir:
// its the GIMP .c export of the LUPPP header image
#include "../planning/header.c"
// Hack, move to gtrack.cpp
int GTrack::privateID = 0;
int GMasterTrack::privateID = 0;
int AudioBuffer::privateID = 0;
using namespace std;
2013-04-20 12:50:30 +02:00
2013-05-16 19:03:58 +02:00
void close_cb(Fl_Widget*o, void*) {
if ((Fl::event() == FL_KEYDOWN || Fl::event() == FL_SHORTCUT)
&& Fl::event_key() == FL_Escape)
return; // ignore ESC
else o->hide();
}
static void gui_static_read_rb(void* inst)
{
//cout << "read gui" << endl;
handleGuiEvents();
Fl::repeat_timeout( 1 / 30.f, &gui_static_read_rb, inst);
}
Gui::Gui() :
2013-07-21 16:47:35 +02:00
window(1200,750)
{
window.color(FL_BLACK);
window.label("Luppp 5");
//window.callback( close_cb, 0 );
Avtk::Image* headerImage = new Avtk::Image(0,0,1200,36,"header.png");
headerImage->setPixbuf( header.pixel_data, 4 );
int i = 0;
for (; i < NTRACKS; i++ )
{
stringstream s;
s << "Track " << i+1;
2013-07-21 16:47:35 +02:00
tracks.push_back( new GTrack(8 + i * 118, 40, 110, 650, s.str().c_str() ) );
}
2013-04-20 13:20:46 +02:00
2013-07-21 17:08:15 +02:00
master = new GMasterTrack(9 + i * 118, 40, 150, 650, "Master");
2013-07-21 16:47:35 +02:00
/*
box = new Fl_Box(655, 5, 200, 60, "BPM = 120");
box->box(FL_UP_BOX);
box->labelsize(36);
box->labeltype(FL_SHADOW_LABEL);
*/
window.end();
2013-04-20 12:50:30 +02:00
}
GTrack* Gui::getTrack(int id)
{
return tracks.at(id);
}
2013-04-20 12:50:30 +02:00
int Gui::show()
{
window.show();
gui_static_read_rb( this);
2013-04-20 12:50:30 +02:00
return Fl::run();
}