mirror of
https://gitlab.com/pholy/OSCAR-code.git
synced 2025-04-06 03:00:43 +00:00
Importer will be temporarily slow due to creating craploads of new indexes. Lots of bugs fixed.. Probably lots of new bugs too! Replaced slow map containers with fast QHash containers. Plus plenty of other mind numbing stuff.
171 lines
5.5 KiB
C++
171 lines
5.5 KiB
C++
/********************************************************************
|
|
gLineOverlayBar Implementation
|
|
Copyright (c)2011 Mark Watkins <jedimark@users.sourceforge.net>
|
|
License: GPL
|
|
*********************************************************************/
|
|
|
|
#include <math.h>
|
|
#include "SleepLib/profiles.h"
|
|
#include "gLineOverlay.h"
|
|
|
|
gLineOverlayBar::gLineOverlayBar(ChannelID code,QColor col,QString label,FlagType flt)
|
|
:gLayer(code),m_label(label),m_flt(flt)
|
|
{
|
|
color.clear();
|
|
color.push_back(col);
|
|
}
|
|
gLineOverlayBar::~gLineOverlayBar()
|
|
{
|
|
}
|
|
|
|
void gLineOverlayBar::Plot(gGraphWindow & w,float scrx,float scry)
|
|
{
|
|
if (!m_visible) return;
|
|
if (!m_day) return;
|
|
|
|
//int start_px=w.GetLeftMargin();
|
|
int start_py=w.GetBottomMargin();
|
|
int width=scrx-(w.GetLeftMargin()+w.GetRightMargin());
|
|
int height=scry-(w.GetTopMargin()+w.GetBottomMargin());
|
|
|
|
double xx=w.max_x-w.min_x;
|
|
if (xx<=0) return;
|
|
|
|
float x1,x2;
|
|
|
|
float x,y;
|
|
|
|
// Crop to inside the margins.
|
|
glScissor(w.GetLeftMargin(),w.GetBottomMargin(),width,height);
|
|
glEnable(GL_SCISSOR_TEST);
|
|
|
|
qint32 vertcnt=0;
|
|
GLshort * vertarray=vertex_array[0];
|
|
qint32 pointcnt=0;
|
|
GLshort * pointarray=vertex_array[1];
|
|
qint32 quadcnt=0;
|
|
GLshort * quadarray=vertex_array[2];
|
|
if (!vertarray || !quadarray || !pointarray) {
|
|
qWarning() << "VertArray/quadarray/pointarray==NULL";
|
|
return;
|
|
}
|
|
|
|
float bottom=start_py+25, top=start_py+height-25;
|
|
QColor & col=color[0];
|
|
|
|
qint64 X;
|
|
qint64 Y;
|
|
QHash<ChannelID,QVector<EventList *> >::iterator cei;
|
|
for (QVector<Session *>::iterator s=m_day->begin();s!=m_day->end(); s++) {
|
|
cei=(*s)->eventlist.find(m_code);
|
|
if (cei==(*s)->eventlist.end()) continue;
|
|
if (cei.value().size()==0) continue;
|
|
|
|
EventList & el=*cei.value()[0];
|
|
|
|
// bool done=false;
|
|
for (int i=0;i<el.count();i++) {
|
|
X=el.time(i);
|
|
if (m_flt==FT_Span) {
|
|
Y=X-(qint64(el.raw(i))*1000.0L); // duration
|
|
|
|
if (X < w.min_x) continue;
|
|
if (Y > w.max_x) break;
|
|
} else {
|
|
if (X < w.min_x) continue;
|
|
if (X > w.max_x) break;
|
|
}
|
|
|
|
x1=w.x2p(X);
|
|
if (m_flt==FT_Span) {
|
|
x2=w.x2p(Y);
|
|
//double w1=x2-x1;
|
|
quadarray[quadcnt++]=x1;
|
|
quadarray[quadcnt++]=start_py;
|
|
quadarray[quadcnt++]=x1;
|
|
quadarray[quadcnt++]=start_py+height;
|
|
quadarray[quadcnt++]=x2;
|
|
quadarray[quadcnt++]=start_py+height;
|
|
quadarray[quadcnt++]=x2;
|
|
quadarray[quadcnt++]=start_py;
|
|
} else if (m_flt==FT_Dot) {
|
|
//if (pref["AlwaysShowOverlayBars"].toBool()) {
|
|
|
|
if (pref["AlwaysShowOverlayBars"].toBool() || (xx<3600000.0)) {
|
|
// show the fat dots in the middle
|
|
pointarray[pointcnt++]=x1;
|
|
pointarray[pointcnt++]=w.y2p(20);
|
|
} else {
|
|
// thin lines down the bottom
|
|
vertarray[vertcnt++]=x1;
|
|
vertarray[vertcnt++]=start_py+1;
|
|
vertarray[vertcnt++]=x1;
|
|
vertarray[vertcnt++]=start_py+1+12;
|
|
}
|
|
} else if (m_flt==FT_Bar) {
|
|
int z=start_py+height;
|
|
if (pref["AlwaysShowOverlayBars"].toBool() || (xx<3600000)) {
|
|
z=top;
|
|
|
|
pointarray[pointcnt++]=x1;
|
|
pointarray[pointcnt++]=top; //z+2;
|
|
vertarray[vertcnt++]=x1;
|
|
vertarray[vertcnt++]=top;
|
|
vertarray[vertcnt++]=x1;
|
|
vertarray[vertcnt++]=bottom;
|
|
} else {
|
|
vertarray[vertcnt++]=x1;
|
|
vertarray[vertcnt++]=z;
|
|
vertarray[vertcnt++]=x1;
|
|
vertarray[vertcnt++]=z-12;
|
|
}
|
|
if (xx<(1800000)) {
|
|
GetTextExtent(m_label,x,y);
|
|
DrawText(w,m_label,x1-(x/2),scry-(start_py+height-30+y));
|
|
//w.renderText(x1-(x/2),scry-(start_py+height-30+y),label);
|
|
}
|
|
|
|
}
|
|
}
|
|
if ((vertcnt>=maxverts) || (quadcnt>=maxverts) || (pointcnt>=maxverts)) break;
|
|
|
|
}
|
|
|
|
bool antialias=pref["UseAntiAliasing"].toBool();
|
|
if (antialias) {
|
|
glEnable(GL_BLEND);
|
|
glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); //_MINUS_SRC_ALPHA);
|
|
glEnable(GL_LINE_SMOOTH);
|
|
glHint(GL_LINE_SMOOTH_HINT, GL_NICEST);
|
|
glLineWidth (1.5);
|
|
} else glLineWidth (1);
|
|
|
|
glColor4ub(col.red(),col.green(),col.blue(),col.alpha());
|
|
if (quadcnt>0) {
|
|
glEnableClientState(GL_VERTEX_ARRAY);
|
|
glVertexPointer(2, GL_SHORT, 0, quadarray);
|
|
glDrawArrays(GL_QUADS, 0, quadcnt>>1);
|
|
glDisableClientState(GL_VERTEX_ARRAY);
|
|
}
|
|
if (vertcnt>0) {
|
|
glEnableClientState(GL_VERTEX_ARRAY);
|
|
glVertexPointer(2, GL_SHORT, 0, vertarray);
|
|
glDrawArrays(GL_LINES, 0, vertcnt>>1);
|
|
glDisableClientState(GL_VERTEX_ARRAY);
|
|
}
|
|
if (pointcnt>0) {
|
|
glPointSize(4);
|
|
glEnableClientState(GL_VERTEX_ARRAY);
|
|
glVertexPointer(2, GL_SHORT, 0, pointarray);
|
|
glDrawArrays(GL_POINTS, 0, pointcnt>>1);
|
|
glDisableClientState(GL_VERTEX_ARRAY);
|
|
}
|
|
|
|
if (antialias) {
|
|
glDisable(GL_LINE_SMOOTH);
|
|
glDisable(GL_BLEND);
|
|
}
|
|
glDisable(GL_SCISSOR_TEST);
|
|
}
|
|
|