2011-08-31 05:24:48 +00:00
|
|
|
/*
|
2011-06-26 08:30:44 +00:00
|
|
|
gFlagsLine Implementation
|
|
|
|
Copyright (c)2011 Mark Watkins <jedimark@users.sourceforge.net>
|
|
|
|
License: GPL
|
2011-08-31 05:24:48 +00:00
|
|
|
*/
|
2011-06-26 08:30:44 +00:00
|
|
|
|
2011-07-11 04:54:53 +00:00
|
|
|
#include <cmath>
|
2011-07-31 20:24:43 +00:00
|
|
|
#include <QVector>
|
2011-06-26 08:30:44 +00:00
|
|
|
#include "SleepLib/profiles.h"
|
|
|
|
#include "gFlagsLine.h"
|
2011-08-25 06:11:44 +00:00
|
|
|
#include "gYAxis.h"
|
2011-06-26 08:30:44 +00:00
|
|
|
|
2011-07-11 04:54:53 +00:00
|
|
|
gFlagsGroup::gFlagsGroup()
|
|
|
|
{
|
2011-10-21 05:50:31 +00:00
|
|
|
//static QColor col=Qt::black;
|
2011-08-31 11:44:53 +00:00
|
|
|
|
2012-01-02 15:34:17 +00:00
|
|
|
addVertexBuffer(quads=new gVertexBuffer(512,GL_QUADS));
|
|
|
|
addVertexBuffer(lines=new gVertexBuffer(20,GL_LINE_LOOP));
|
2011-09-28 11:46:32 +00:00
|
|
|
quads->setAntiAlias(true);
|
2011-08-31 11:44:53 +00:00
|
|
|
lines->setAntiAlias(false);
|
2011-12-05 10:50:58 +00:00
|
|
|
m_barh=0;
|
2011-12-10 12:14:48 +00:00
|
|
|
m_empty=true;
|
2011-07-11 04:54:53 +00:00
|
|
|
}
|
|
|
|
gFlagsGroup::~gFlagsGroup()
|
|
|
|
{
|
|
|
|
}
|
2011-07-27 09:21:53 +00:00
|
|
|
qint64 gFlagsGroup::Minx()
|
|
|
|
{
|
|
|
|
if (m_day) {
|
|
|
|
return m_day->first();
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
qint64 gFlagsGroup::Maxx()
|
|
|
|
{
|
|
|
|
if (m_day) {
|
|
|
|
return m_day->last();
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
2011-09-01 03:37:25 +00:00
|
|
|
void gFlagsGroup::SetDay(Day * d)
|
2011-07-11 04:54:53 +00:00
|
|
|
{
|
2011-09-01 03:37:25 +00:00
|
|
|
LayerGroup::SetDay(d);
|
|
|
|
lvisible.clear();
|
2011-12-10 12:14:48 +00:00
|
|
|
int cnt=0;
|
2011-07-31 20:24:43 +00:00
|
|
|
for (int i=0;i<layers.size();i++) {
|
2011-07-20 16:01:31 +00:00
|
|
|
gFlagsLine *f=dynamic_cast<gFlagsLine *>(layers[i]);
|
|
|
|
if (!f) continue;
|
|
|
|
|
2011-12-10 12:14:48 +00:00
|
|
|
bool e=f->isEmpty();
|
|
|
|
if (!e || f->isAlwaysVisible()) {
|
2011-07-27 09:21:53 +00:00
|
|
|
lvisible.push_back(f);
|
2012-01-03 11:12:13 +00:00
|
|
|
if (!e)
|
|
|
|
cnt++;
|
2011-07-11 04:54:53 +00:00
|
|
|
}
|
|
|
|
}
|
2012-01-03 09:28:29 +00:00
|
|
|
m_empty=(cnt==0);
|
2012-01-10 02:34:44 +00:00
|
|
|
if (m_empty) {
|
|
|
|
if (d) {
|
|
|
|
m_empty=!d->channelExists(CPAP_Pressure);
|
|
|
|
}
|
|
|
|
}
|
2011-12-05 10:50:58 +00:00
|
|
|
m_barh=0;
|
2011-09-01 03:37:25 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void gFlagsGroup::paint(gGraph &w, int left, int top, int width, int height)
|
|
|
|
{
|
|
|
|
if (!m_visible) return;
|
|
|
|
if (!m_day) return;
|
|
|
|
|
2011-07-27 09:21:53 +00:00
|
|
|
int vis=lvisible.size();
|
2011-12-05 10:50:58 +00:00
|
|
|
m_barh=float(height)/float(vis);
|
2011-08-25 06:11:44 +00:00
|
|
|
float linetop=top;
|
|
|
|
|
2011-09-28 11:46:32 +00:00
|
|
|
static QColor col1=QColor(0xd0,0xff,0xd0,0xff);
|
|
|
|
static QColor col2=QColor(0xff,0xff,0xff,0xff);
|
|
|
|
QColor * barcol;
|
2011-07-31 20:24:43 +00:00
|
|
|
for (int i=0;i<lvisible.size();i++) {
|
2011-08-25 06:11:44 +00:00
|
|
|
// Alternating box color
|
2011-09-28 11:46:32 +00:00
|
|
|
if (i & 1) barcol=&col1; else barcol=&col2;
|
2012-01-02 15:34:17 +00:00
|
|
|
quads->add(left, linetop, left, linetop+m_barh, left+width-1, linetop+m_barh, left+width-1, linetop, barcol->rgba());
|
2011-08-31 11:44:53 +00:00
|
|
|
|
2011-08-25 06:11:44 +00:00
|
|
|
// Paint the actual flags
|
2011-12-05 10:50:58 +00:00
|
|
|
lvisible[i]->paint(w,left,linetop,width,m_barh);
|
|
|
|
linetop+=m_barh;
|
2011-07-11 04:54:53 +00:00
|
|
|
}
|
2011-08-25 06:11:44 +00:00
|
|
|
|
2012-01-02 15:34:17 +00:00
|
|
|
gVertexBuffer *outlines=w.lines();
|
2011-09-01 07:12:25 +00:00
|
|
|
QColor blk=Qt::black;
|
2012-01-02 15:34:17 +00:00
|
|
|
outlines->add(left-1, top, left-1, top+height, blk.rgba());
|
|
|
|
outlines->add(left-1, top+height, left+width,top+height, blk.rgba());
|
|
|
|
outlines->add(left+width,top+height, left+width, top,blk.rgba());
|
|
|
|
outlines->add(left+width, top, left-1, top, blk.rgba());
|
2011-09-01 07:12:25 +00:00
|
|
|
|
|
|
|
//lines->add(left-1, top, left-1, top+height);
|
|
|
|
//lines->add(left+width, top+height, left+width, top);
|
2011-07-11 04:54:53 +00:00
|
|
|
}
|
|
|
|
|
2011-08-02 04:20:26 +00:00
|
|
|
gFlagsLine::gFlagsLine(ChannelID code,QColor flag_color,QString label,bool always_visible,FlagType flt)
|
2011-08-25 06:11:44 +00:00
|
|
|
:Layer(code),m_label(label),m_always_visible(always_visible),m_flt(flt),m_flag_color(flag_color)
|
2011-06-26 08:30:44 +00:00
|
|
|
{
|
2012-01-02 15:34:17 +00:00
|
|
|
addVertexBuffer(quads=new gVertexBuffer(2048,GL_QUADS));
|
2011-09-01 07:12:25 +00:00
|
|
|
//addGLBuf(lines=new GLBuffer(flag_color,1024,GL_LINES));
|
2011-08-30 17:22:54 +00:00
|
|
|
quads->setAntiAlias(true);
|
2011-09-01 07:12:25 +00:00
|
|
|
//lines->setAntiAlias(true);
|
2011-12-06 14:39:14 +00:00
|
|
|
//GetTextExtent(m_label,m_lx,m_ly);
|
2011-09-01 03:37:25 +00:00
|
|
|
//m_static.setText(m_label);;
|
2011-06-26 08:30:44 +00:00
|
|
|
}
|
|
|
|
gFlagsLine::~gFlagsLine()
|
|
|
|
{
|
2011-09-01 07:12:25 +00:00
|
|
|
//delete lines;
|
2011-09-21 14:10:10 +00:00
|
|
|
//delete quads;
|
2011-06-26 08:30:44 +00:00
|
|
|
}
|
2011-08-25 06:11:44 +00:00
|
|
|
void gFlagsLine::paint(gGraph & w,int left, int top, int width, int height)
|
2011-06-26 08:30:44 +00:00
|
|
|
{
|
|
|
|
if (!m_visible) return;
|
2011-07-27 09:21:53 +00:00
|
|
|
if (!m_day) return;
|
2011-09-01 07:12:25 +00:00
|
|
|
lines=w.lines();
|
2011-06-26 08:30:44 +00:00
|
|
|
double minx;
|
|
|
|
double maxx;
|
|
|
|
|
2011-08-25 06:11:44 +00:00
|
|
|
if (w.blockZoom()) {
|
2011-06-26 08:30:44 +00:00
|
|
|
minx=w.rmin_x;
|
|
|
|
maxx=w.rmax_x;
|
|
|
|
} else {
|
|
|
|
minx=w.min_x;
|
|
|
|
maxx=w.max_x;
|
|
|
|
}
|
|
|
|
|
|
|
|
double xx=maxx-minx;
|
|
|
|
if (xx<=0) return;
|
|
|
|
|
|
|
|
double xmult=width/xx;
|
|
|
|
|
2011-12-06 14:39:14 +00:00
|
|
|
GetTextExtent(m_label,m_lx,m_ly);
|
2011-06-26 08:30:44 +00:00
|
|
|
|
|
|
|
// Draw text label
|
2011-09-01 03:37:25 +00:00
|
|
|
w.renderText(m_label,left-m_lx-10,top+(height/2)+(m_ly/2));
|
2011-09-01 13:07:26 +00:00
|
|
|
|
2011-06-26 08:30:44 +00:00
|
|
|
float x1,x2;
|
|
|
|
|
2011-08-25 06:11:44 +00:00
|
|
|
float bartop=top+2;
|
|
|
|
float bottom=top+height-2;
|
2011-08-02 04:51:49 +00:00
|
|
|
bool verts_exceeded=false;
|
2011-12-30 23:02:45 +00:00
|
|
|
qint64 X,X2,L;
|
2012-01-05 11:35:23 +00:00
|
|
|
lines->setColor(schema::channel[m_code].defaultColor());
|
|
|
|
|
|
|
|
qint64 start;
|
|
|
|
quint32 * tptr;
|
2012-01-10 02:34:44 +00:00
|
|
|
EventStoreType *dptr, * eptr;
|
2012-01-05 11:35:23 +00:00
|
|
|
int idx;
|
2012-01-10 02:34:44 +00:00
|
|
|
QHash<ChannelID,QVector<EventList *> >::iterator cei;
|
|
|
|
|
2011-07-31 20:24:43 +00:00
|
|
|
for (QVector<Session *>::iterator s=m_day->begin();s!=m_day->end(); s++) {
|
2012-01-10 02:34:44 +00:00
|
|
|
if (!(*s)->enabled())
|
|
|
|
continue;
|
|
|
|
|
|
|
|
cei=(*s)->eventlist.find(m_code);
|
|
|
|
if (cei==(*s)->eventlist.end())
|
|
|
|
continue;
|
|
|
|
|
|
|
|
QVector<EventList *> & evlist=cei.value();
|
|
|
|
for (int k=0;k<evlist.size();k++) {
|
|
|
|
EventList & el=*(evlist[k]);
|
|
|
|
start=el.first();
|
|
|
|
tptr=el.rawTime();
|
|
|
|
dptr=el.rawData();
|
|
|
|
int np=el.count();
|
|
|
|
eptr=dptr+np;
|
|
|
|
|
|
|
|
for (idx=0;dptr < eptr; dptr++, tptr++, idx++) {
|
|
|
|
X=start + *tptr;
|
|
|
|
L=*dptr * 1000;
|
|
|
|
if (X >= minx)
|
|
|
|
break;
|
|
|
|
X2=X-L;
|
|
|
|
if (X2 >= minx)
|
|
|
|
break;
|
|
|
|
|
|
|
|
}
|
|
|
|
np-=idx;
|
2012-01-05 11:35:23 +00:00
|
|
|
|
2012-01-10 02:34:44 +00:00
|
|
|
if (m_flt==FT_Bar) {
|
|
|
|
///////////////////////////////////////////////////////////////////////////
|
|
|
|
// Draw Event Flag Bars
|
|
|
|
///////////////////////////////////////////////////////////////////////////
|
2012-01-05 11:35:23 +00:00
|
|
|
|
2012-01-10 02:34:44 +00:00
|
|
|
// Check bounds outside of loop is faster..
|
|
|
|
// This will have to be reverted if multithreaded drawing is ever brought back
|
2012-01-05 11:35:23 +00:00
|
|
|
|
2012-01-10 02:34:44 +00:00
|
|
|
int rem=lines->Max() - lines->cnt();
|
|
|
|
if ((np<<1) > rem) {
|
|
|
|
qDebug() << "gFlagsLine would overfill lines for" << schema::channel[m_code].label();
|
|
|
|
np=rem >> 1;
|
|
|
|
verts_exceeded=true;
|
|
|
|
}
|
2012-01-05 11:35:23 +00:00
|
|
|
|
2012-01-10 02:34:44 +00:00
|
|
|
for (int i=0;i<np;i++) {
|
|
|
|
X=start + *tptr++;
|
2012-01-05 11:35:23 +00:00
|
|
|
|
2012-01-10 02:34:44 +00:00
|
|
|
if (X > maxx)
|
|
|
|
break;
|
2012-01-05 11:35:23 +00:00
|
|
|
|
2012-01-10 02:34:44 +00:00
|
|
|
x1=(X - minx) * xmult + left;
|
|
|
|
lines->add(x1,bartop,x1,bottom);
|
2012-01-05 11:35:23 +00:00
|
|
|
|
2012-01-10 02:34:44 +00:00
|
|
|
//if (lines->full()) { verts_exceeded=true; break; }
|
|
|
|
}
|
|
|
|
} else if (m_flt==FT_Span) {
|
|
|
|
///////////////////////////////////////////////////////////////////////////
|
|
|
|
// Draw Event Flag Spans
|
|
|
|
///////////////////////////////////////////////////////////////////////////
|
|
|
|
quads->setColor(m_flag_color);
|
|
|
|
int rem=quads->Max() - quads->cnt();
|
2012-01-05 11:35:23 +00:00
|
|
|
|
2012-01-10 02:34:44 +00:00
|
|
|
if ((np<<2) > rem) {
|
|
|
|
qDebug() << "gFlagsLine would overfill quads for" << schema::channel[m_code].label();
|
|
|
|
np=rem >> 2;
|
|
|
|
verts_exceeded=true;
|
|
|
|
}
|
2012-01-05 11:35:23 +00:00
|
|
|
|
2012-01-10 02:34:44 +00:00
|
|
|
for (; dptr < eptr; dptr++) {
|
|
|
|
X=start + * tptr++;
|
2012-01-05 11:35:23 +00:00
|
|
|
|
2012-01-10 02:34:44 +00:00
|
|
|
if (X > maxx)
|
|
|
|
break;
|
|
|
|
|
|
|
|
L=*dptr * 1000L;
|
|
|
|
X2=X-L;
|
2012-01-05 11:35:23 +00:00
|
|
|
|
2012-01-10 02:34:44 +00:00
|
|
|
x1=double(X - minx) * xmult + left;
|
|
|
|
x2=double(X2 - minx) * xmult + left;
|
2012-01-05 12:12:42 +00:00
|
|
|
|
2012-01-10 02:34:44 +00:00
|
|
|
quads->add(x2,bartop,x1,bartop, x1,bottom,x2,bottom);
|
|
|
|
//if (quads->full()) { verts_exceeded=true; break; }
|
2012-01-05 11:35:23 +00:00
|
|
|
|
2012-01-10 02:34:44 +00:00
|
|
|
}
|
2011-06-26 08:30:44 +00:00
|
|
|
}
|
2012-01-10 02:34:44 +00:00
|
|
|
if (verts_exceeded) break;
|
2011-06-26 08:30:44 +00:00
|
|
|
}
|
2011-09-01 03:37:25 +00:00
|
|
|
if (verts_exceeded) break;
|
2011-06-26 08:30:44 +00:00
|
|
|
}
|
2011-08-02 04:51:49 +00:00
|
|
|
if (verts_exceeded) {
|
|
|
|
qWarning() << "maxverts exceeded in gFlagsLine::plot()";
|
|
|
|
}
|
2011-06-26 08:30:44 +00:00
|
|
|
}
|