/* gBarChart Implementation Copyright (c)2011 Mark Watkins License: GPL */ #include #include #include "gBarChart.h" gBarChart::gBarChart(ChannelID code,QColor color,Qt::Orientation o) :Layer(code),m_orientation(o) { addGLBuf(quads=new GLBuffer(color,20000,GL_QUADS)); quads->forceAntiAlias(true); m_empty=true; } gBarChart::~gBarChart() { //delete Xaxis; } void gBarChart::SetDay(Day * day) { m_maxx=m_minx=0; m_maxy=m_miny=0; m_empty=true; } void gBarChart::paint(gGraph & w,int left, int top, int width, int height) { if (!m_visible) return; //if (!m_day) return; GLBuffer *lines=w.lines(); QColor blk=Qt::black; lines->add(left, top, left, top+height, blk); lines->add(left, top+height, left+width,top+height, blk); lines->add(left+width,top+height, left+width, top, blk); lines->add(left+width, top, left, top, blk); qint64 minx=w.min_x, maxx=w.max_x; //qint64 minx=m_minx, maxx=m_maxx; qint64 xx=maxx - minx; float days=double(xx)/86400000.0; EventDataType maxy=m_maxy; EventDataType miny=m_miny; w.roundY(miny,maxy); EventDataType yy=maxy-miny; EventDataType ymult=float(height-2)/yy; float barw=(float(width)/float(days)); qint64 ts; float px=left; float py; EventDataType total; int daynum=0; float h,tmp; qint64 offs=(minx) % 86400000L; //zz*=86400000L; float offset=(offs)/86400000.0; //offset+=float(utcoff)/86400000.0; offset*=barw; px=left-offset; int total_days=0; double total_val=0; for (qint64 Q=minx;Q<=maxx+86400000L;Q+=86400000L) { int zd=Q/86400000L; QHash >::iterator d=m_values.find(zd); if (Qmaxx+86400000) continue; // break; // out of order if I end up using a hash instead.?? if (d!=m_values.end()) { int x1=px,x2=px+barw; if (x1left+width) x2=left+width; if (x20) { total_val+=total; total_days++; } py=top+height; for (QHash::iterator g=d.value().begin();g!=d.value().end();g++) { short j=g.key(); if (!j) continue; QColor & col=m_colors[j-1]; int cr,cg,cb; cr=col.red(); cg=col.green(); cb=col.blue(); if (cr<64) cr=64; if (cg<64) cg=64; if (cb<64) cb=64; cr*=2; cg*=2; cb*=2; if (cr>255) cr=255; if (cg>255) cg=255; if (cb>255) cb=255; QColor col2=QColor(cr,cg,cb,255); //col2=QColor(220,220,220,255); tmp=g.value(); //(g.value()/float(total)); h=tmp*ymult; //(float(total)*ymult); // height of chunk quads->add(x1,py,col); quads->add(x1,py-h,col); quads->add(x2,py-h,col2); quads->add(x2,py,col2); lines->add(x1,py,x1,py-h,blk); lines->add(x1,py-h,x2,py-h,blk); lines->add(x1,py,x2,py,blk); lines->add(x2,py,x2,py-h,blk); py-=h; } } px+=barw; daynum++; } if (total_days>0) { float val=total_val/float(total_days); QString z=m_label+"="+QString::number(val,'f',2)+" days="+QString::number(total_days,'f',0)+" This is going in overview later"; w.renderText(z,left,top-1); // val = AHI for selected area. } } UsageChart::UsageChart(Profile *profile) :gBarChart() { m_profile=profile; m_colors.push_back(Qt::green); m_label="Hours"; } void UsageChart::SetDay(Day * day) { if (!m_profile) { qWarning() << "Forgot to set profile for gBarChart dummy!"; m_day=NULL; return; } Layer::SetDay(day); //m_empty=true; // if (!day) return; m_empty=false; m_values.clear(); m_miny=9999999; m_maxy=-9999999; m_minx=0; m_maxx=0; int dn; EventDataType tmp,total; ChannelID code; m_fday=0; qint64 tt; for (QMap >::iterator d=m_profile->daylist.begin();d!=m_profile->daylist.end();d++) { tt=QDateTime(d.key(),QTime(0,0,0),Qt::UTC).toTime_t(); dn=tt/86400; tt*=1000L; // there could possibly may be a bug by doing this.. if charts don't match up.. come back here and enable the m_minx right down the bottom of this function. if (!m_minx || ttm_maxx) m_maxx=tt; Day *day=m_profile->GetDay(d.key(),MT_CPAP); if (day) { total=day->hours(); m_values[dn][0]=total; m_values[dn][1]=total; if (totalm_maxy) m_maxy=total; } } m_maxy=ceil(m_maxy); //m_miny=floor(m_miny); m_miny=0; // m_minx=qint64(QDateTime(m_profile->FirstDay(),QTime(0,0,0),Qt::UTC).toTime_t())*1000L; m_maxx=qint64(QDateTime(m_profile->LastDay().addDays(1),QTime(0,0,0),Qt::UTC).toTime_t())*1000L; } AHIChart::AHIChart(Profile *profile) :gBarChart() { m_label="AHI"; m_profile=profile; } void AHIChart::SetDay(Day * day) { if (!m_profile) { qWarning() << "Forgot to set profile for gBarChart dummy!"; m_day=NULL; return; } Layer::SetDay(day); m_values.clear(); m_miny=9999999; m_maxy=-9999999; m_minx=0; m_maxx=0; int dn; EventDataType tmp,total; ChannelID code; m_fday=0; qint64 tt; for (QMap >::iterator d=m_profile->daylist.begin();d!=m_profile->daylist.end();d++) { tt=QDateTime(d.key(),QTime(0,0,0),Qt::UTC).toTime_t(); //tt=QDateTime(d.key(),QTime(12,0,0)).toTime_t(); dn=tt/86400; tt*=1000L; if (!m_minx || ttm_maxx) m_maxx=tt; total=0; bool fnd=false; for (int j=0;jchannelExists(code)) { // too many lookups happening here.. stop the crap.. tmp=day->count(code)/day->hours(); if (tmp>0) { fnd=true; total+=tmp; m_values[dn][j+1]=tmp; break; } } } } if (fnd) { if (!m_fday) m_fday=dn; m_values[dn][0]=total; if (totalm_maxy) m_maxy=total; } } m_maxy=ceil(m_maxy); //m_miny=floor(m_miny); m_miny=0; // m_minx=qint64(QDateTime(m_profile->FirstDay(),QTime(0,0,0),Qt::UTC).toTime_t())*1000L; m_maxx=qint64(QDateTime(m_profile->LastDay().addDays(1),QTime(0,0,0),Qt::UTC).toTime_t())*1000L; m_empty=m_values.size()==0; }