mirror of
https://gitlab.com/pholy/OSCAR-code.git
synced 2025-04-06 11:10:44 +00:00
Overview Report Printing Test. Warning: May be crashy..
This commit is contained in:
parent
f8704bb8f6
commit
11b59d1593
@ -18,7 +18,8 @@ SummaryChart::SummaryChart(Profile *p,QString label,GraphType type)
|
|||||||
addGLBuf(quads=new GLBuffer(color,20000,GL_QUADS));
|
addGLBuf(quads=new GLBuffer(color,20000,GL_QUADS));
|
||||||
addGLBuf(lines=new GLBuffer(color,20000,GL_LINES));
|
addGLBuf(lines=new GLBuffer(color,20000,GL_LINES));
|
||||||
quads->forceAntiAlias(true);
|
quads->forceAntiAlias(true);
|
||||||
//lines->setSize(2);
|
lines->setSize(2);
|
||||||
|
lines->forceAntiAlias(false);
|
||||||
m_empty=true;
|
m_empty=true;
|
||||||
hl_day=-1;
|
hl_day=-1;
|
||||||
}
|
}
|
||||||
@ -263,13 +264,14 @@ void SummaryChart::paint(gGraph & w,int left, int top, int width, int height)
|
|||||||
quads->add(x2,py-h,col2);
|
quads->add(x2,py-h,col2);
|
||||||
quads->add(x2,py,col2);
|
quads->add(x2,py,col2);
|
||||||
if (barw>2) {
|
if (barw>2) {
|
||||||
lines->add(x1,py,x1,py-h,blk);
|
outlines->add(x1,py,x1,py-h,blk);
|
||||||
lines->add(x1,py-h,x2,py-h,blk);
|
outlines->add(x1,py-h,x2,py-h,blk);
|
||||||
lines->add(x1,py,x2,py,blk);
|
outlines->add(x1,py,x2,py,blk);
|
||||||
lines->add(x2,py,x2,py-h,blk);
|
outlines->add(x2,py,x2,py-h,blk);
|
||||||
} // if (bar
|
} // if (bar
|
||||||
py-=h;
|
py-=h;
|
||||||
} else if (m_graphtype==GT_LINE) { // if (m_graphtype==GT_BAR
|
} else if (m_graphtype==GT_LINE) { // if (m_graphtype==GT_BAR
|
||||||
|
col.setAlpha(128);
|
||||||
short px2=px+barw;
|
short px2=px+barw;
|
||||||
short py2=top+height-1-h;
|
short py2=top+height-1-h;
|
||||||
if (lastdaygood) {
|
if (lastdaygood) {
|
||||||
@ -295,7 +297,7 @@ void SummaryChart::paint(gGraph & w,int left, int top, int width, int height)
|
|||||||
lines->scissor(left,w.flipY(top+height+2),width+1,height+1);
|
lines->scissor(left,w.flipY(top+height+2),width+1,height+1);
|
||||||
|
|
||||||
// Draw Ledgend
|
// Draw Ledgend
|
||||||
px=left+width-10;
|
px=left+width;
|
||||||
py=top+10;
|
py=top+10;
|
||||||
QString a;
|
QString a;
|
||||||
int x,y;
|
int x,y;
|
||||||
|
@ -675,6 +675,13 @@ void gGraphView::queGraph(gGraph * g,int left, int top, int width, int height)
|
|||||||
m_drawlist.push_back(g);
|
m_drawlist.push_back(g);
|
||||||
dl_mutex.unlock();
|
dl_mutex.unlock();
|
||||||
}
|
}
|
||||||
|
void gGraphView::TrashGraphs()
|
||||||
|
{
|
||||||
|
for (int i=0;i<m_graphs.size();i++) {
|
||||||
|
//delete m_graphs[i];
|
||||||
|
}
|
||||||
|
m_graphs.clear();
|
||||||
|
}
|
||||||
gGraph * gGraphView::popGraph()
|
gGraph * gGraphView::popGraph()
|
||||||
{
|
{
|
||||||
gGraph * g;
|
gGraph * g;
|
||||||
@ -1308,7 +1315,7 @@ void gGraphView::AddGraph(gGraph *g,short group)
|
|||||||
g->setGroup(group);
|
g->setGroup(group);
|
||||||
m_graphs.push_back(g);
|
m_graphs.push_back(g);
|
||||||
|
|
||||||
updateScrollBar();
|
// updateScrollBar();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
float gGraphView::totalHeight()
|
float gGraphView::totalHeight()
|
||||||
@ -1499,13 +1506,15 @@ void gGraphView::paintGL()
|
|||||||
|
|
||||||
queGraph(m_graphs[i],px,py,width()-titleWidth,h);
|
queGraph(m_graphs[i],px,py,width()-titleWidth,h);
|
||||||
|
|
||||||
// draw the splitter handle
|
if (m_showsplitter) {
|
||||||
QColor ca=QColor(128,128,128,255);
|
// draw the splitter handle
|
||||||
backlines->add(0, py+h, w, py+h, ca);
|
QColor ca=QColor(128,128,128,255);
|
||||||
ca=QColor(192,192,192,255);
|
backlines->add(0, py+h, w, py+h, ca);
|
||||||
backlines->add(0, py+h+1, w, py+h+1, ca);
|
ca=QColor(192,192,192,255);
|
||||||
ca=QColor(90,90,90,255);
|
backlines->add(0, py+h+1, w, py+h+1, ca);
|
||||||
backlines->add(0, py+h+2, w, py+h+2, ca);
|
ca=QColor(90,90,90,255);
|
||||||
|
backlines->add(0, py+h+2, w, py+h+2, ca);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
py=ceil(py+h+graphSpacer);
|
py=ceil(py+h+graphSpacer);
|
||||||
|
@ -363,9 +363,11 @@ public:
|
|||||||
bool useThreads() { return m_idealthreads>1; }
|
bool useThreads() { return m_idealthreads>1; }
|
||||||
GLBuffer * lines, * backlines, *quads;
|
GLBuffer * lines, * backlines, *quads;
|
||||||
|
|
||||||
|
void TrashGraphs();
|
||||||
gGraph * popGraph();
|
gGraph * popGraph();
|
||||||
QVector<gThread *> m_threads;
|
QVector<gThread *> m_threads;
|
||||||
|
void hideSplitter() { m_showsplitter=false; }
|
||||||
|
void showSplitter() { m_showsplitter=true; }
|
||||||
protected:
|
protected:
|
||||||
int m_idealthreads;
|
int m_idealthreads;
|
||||||
Day * m_day;
|
Day * m_day;
|
||||||
@ -418,6 +420,7 @@ protected:
|
|||||||
//volatile int m_threadsrunning;
|
//volatile int m_threadsrunning;
|
||||||
|
|
||||||
QString m_emptytext;
|
QString m_emptytext;
|
||||||
|
bool m_showsplitter;
|
||||||
signals:
|
signals:
|
||||||
|
|
||||||
|
|
||||||
|
@ -343,7 +343,7 @@ int PRS1Loader::OpenMachine(Machine *m,QString path,Profile *profile)
|
|||||||
sess->avg(a[i]);
|
sess->avg(a[i]);
|
||||||
sess->wavg(a[i]);
|
sess->wavg(a[i]);
|
||||||
sess->p90(a[i]); */
|
sess->p90(a[i]); */
|
||||||
sess->cph(a[i]);
|
//sess->cph(a[i]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -53,7 +53,8 @@ SOURCES += main.cpp\
|
|||||||
qextserialport/qextserialport.cpp \
|
qextserialport/qextserialport.cpp \
|
||||||
preferencesdialog.cpp \
|
preferencesdialog.cpp \
|
||||||
Graphs/gGraphView.cpp \
|
Graphs/gGraphView.cpp \
|
||||||
Graphs/gStatsLine.cpp
|
Graphs/gStatsLine.cpp \
|
||||||
|
report.cpp
|
||||||
|
|
||||||
unix:SOURCES += qextserialport/posix_qextserialport.cpp
|
unix:SOURCES += qextserialport/posix_qextserialport.cpp
|
||||||
unix:!macx:SOURCES += qextserialport/qextserialenumerator_unix.cpp
|
unix:!macx:SOURCES += qextserialport/qextserialenumerator_unix.cpp
|
||||||
@ -103,7 +104,8 @@ HEADERS += \
|
|||||||
qextserialport/qextserialenumerator.h \
|
qextserialport/qextserialenumerator.h \
|
||||||
preferencesdialog.h \
|
preferencesdialog.h \
|
||||||
Graphs/gGraphView.h \
|
Graphs/gGraphView.h \
|
||||||
Graphs/gStatsLine.h
|
Graphs/gStatsLine.h \
|
||||||
|
report.h
|
||||||
|
|
||||||
|
|
||||||
FORMS += \
|
FORMS += \
|
||||||
@ -111,7 +113,8 @@ FORMS += \
|
|||||||
overview.ui \
|
overview.ui \
|
||||||
mainwindow.ui \
|
mainwindow.ui \
|
||||||
oximetry.ui \
|
oximetry.ui \
|
||||||
preferencesdialog.ui
|
preferencesdialog.ui \
|
||||||
|
report.ui
|
||||||
|
|
||||||
RESOURCES += \
|
RESOURCES += \
|
||||||
Resources.qrc
|
Resources.qrc
|
||||||
|
@ -137,6 +137,7 @@ MainWindow::MainWindow(QWidget *parent) :
|
|||||||
if (!pref.Exists("AlwaysShowOverlayBars")) pref["AlwaysShowOverlayBars"]=true;
|
if (!pref.Exists("AlwaysShowOverlayBars")) pref["AlwaysShowOverlayBars"]=true;
|
||||||
ui->actionOverlay_Bars->setChecked(pref["AlwaysShowOverlayBars"].toBool());
|
ui->actionOverlay_Bars->setChecked(pref["AlwaysShowOverlayBars"].toBool());
|
||||||
|
|
||||||
|
|
||||||
ui->tabWidget->setCurrentWidget(ui->welcome);
|
ui->tabWidget->setCurrentWidget(ui->welcome);
|
||||||
|
|
||||||
netmanager = new QNetworkAccessManager(this);
|
netmanager = new QNetworkAccessManager(this);
|
||||||
@ -157,6 +158,10 @@ MainWindow::~MainWindow()
|
|||||||
oximetry->close();
|
oximetry->close();
|
||||||
delete oximetry;
|
delete oximetry;
|
||||||
}
|
}
|
||||||
|
if (report) {
|
||||||
|
report->close();
|
||||||
|
delete report;
|
||||||
|
}
|
||||||
DoneGraphs();
|
DoneGraphs();
|
||||||
Profiles::Done();
|
Profiles::Done();
|
||||||
mainwin=NULL;
|
mainwin=NULL;
|
||||||
@ -182,11 +187,16 @@ void MainWindow::Startup()
|
|||||||
oximetry=new Oximetry(ui->tabWidget,daily->SharedWidget());
|
oximetry=new Oximetry(ui->tabWidget,daily->SharedWidget());
|
||||||
ui->tabWidget->insertTab(3,oximetry,tr("Oximetry"));
|
ui->tabWidget->insertTab(3,oximetry,tr("Oximetry"));
|
||||||
|
|
||||||
|
report=new Report(ui->tabWidget,daily->SharedWidget(),daily,overview);
|
||||||
|
ui->tabWidget->insertTab(4,report,tr("Overview Report"));
|
||||||
|
|
||||||
|
|
||||||
if (daily) daily->ReloadGraphs();
|
if (daily) daily->ReloadGraphs();
|
||||||
|
|
||||||
if (overview) {
|
if (overview) {
|
||||||
overview->ReloadGraphs();
|
overview->ReloadGraphs();
|
||||||
}
|
}
|
||||||
|
//if (report) report->Reload();
|
||||||
|
|
||||||
qprogress->hide();
|
qprogress->hide();
|
||||||
qstatus->setText("");
|
qstatus->setText("");
|
||||||
|
@ -14,6 +14,7 @@
|
|||||||
#include "daily.h"
|
#include "daily.h"
|
||||||
#include "overview.h"
|
#include "overview.h"
|
||||||
#include "oximetry.h"
|
#include "oximetry.h"
|
||||||
|
#include "report.h"
|
||||||
|
|
||||||
const int major_version=0;
|
const int major_version=0;
|
||||||
const int minor_version=8;
|
const int minor_version=8;
|
||||||
@ -26,6 +27,7 @@ namespace Ui {
|
|||||||
extern QStatusBar *qstatusbar;
|
extern QStatusBar *qstatusbar;
|
||||||
|
|
||||||
class Daily;
|
class Daily;
|
||||||
|
class Report;
|
||||||
class MainWindow : public QMainWindow
|
class MainWindow : public QMainWindow
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
@ -96,6 +98,7 @@ private:
|
|||||||
Daily * daily;
|
Daily * daily;
|
||||||
Overview * overview;
|
Overview * overview;
|
||||||
Oximetry * oximetry;
|
Oximetry * oximetry;
|
||||||
|
Report * report;
|
||||||
bool first_load;
|
bool first_load;
|
||||||
Profile *profile;
|
Profile *profile;
|
||||||
QNetworkAccessManager *netmanager;
|
QNetworkAccessManager *netmanager;
|
||||||
|
@ -83,8 +83,8 @@ Overview::Overview(QWidget *parent,gGraphView * shared) :
|
|||||||
|
|
||||||
pr=new SummaryChart(profile,"cmH2O",GT_LINE);
|
pr=new SummaryChart(profile,"cmH2O",GT_LINE);
|
||||||
|
|
||||||
pr->addSlice(CPAP_Pressure,QColor("orange"),ST_MIN);
|
|
||||||
pr->addSlice(CPAP_Pressure,QColor("dark green"),ST_WAVG);
|
pr->addSlice(CPAP_Pressure,QColor("dark green"),ST_WAVG);
|
||||||
|
pr->addSlice(CPAP_Pressure,QColor("orange"),ST_MIN);
|
||||||
pr->addSlice(CPAP_Pressure,QColor("red"),ST_MAX);
|
pr->addSlice(CPAP_Pressure,QColor("red"),ST_MAX);
|
||||||
pr->addSlice(CPAP_EPAP,QColor("light green"),ST_MIN);
|
pr->addSlice(CPAP_EPAP,QColor("light green"),ST_MIN);
|
||||||
pr->addSlice(CPAP_IPAP,QColor("light blue"),ST_MAX);
|
pr->addSlice(CPAP_IPAP,QColor("light blue"),ST_MAX);
|
||||||
@ -97,8 +97,8 @@ Overview::Overview(QWidget *parent,gGraphView * shared) :
|
|||||||
PR->AddLayer(new gXGrid());
|
PR->AddLayer(new gXGrid());
|
||||||
|
|
||||||
lk=new SummaryChart(profile,"Avg Leak",GT_LINE);
|
lk=new SummaryChart(profile,"Avg Leak",GT_LINE);
|
||||||
lk->addSlice(CPAP_Leak,QColor("dark blue"),ST_WAVG);
|
|
||||||
lk->addSlice(CPAP_Leak,QColor("dark grey"),ST_90P);
|
lk->addSlice(CPAP_Leak,QColor("dark grey"),ST_90P);
|
||||||
|
lk->addSlice(CPAP_Leak,QColor("dark blue"),ST_WAVG);
|
||||||
//lk->addSlice(CPAP_Leak,QColor("dark yellow"));
|
//lk->addSlice(CPAP_Leak,QColor("dark yellow"));
|
||||||
//pr->addSlice(CPAP_IPAP,QColor("red"));
|
//pr->addSlice(CPAP_IPAP,QColor("red"));
|
||||||
LK->AddLayer(new gYAxis(),LayerLeft,gYAxis::Margin);
|
LK->AddLayer(new gYAxis(),LayerLeft,gYAxis::Margin);
|
||||||
|
@ -30,6 +30,8 @@ public:
|
|||||||
void ReloadGraphs();
|
void ReloadGraphs();
|
||||||
//void UpdateGraphs();
|
//void UpdateGraphs();
|
||||||
|
|
||||||
|
gGraph *AHI,*UC,*PR,*LK;
|
||||||
|
SummaryChart *bc,*uc,*pr,*lk;
|
||||||
|
|
||||||
private slots:
|
private slots:
|
||||||
/* void on_drStart_dateChanged(const QDate &date);
|
/* void on_drStart_dateChanged(const QDate &date);
|
||||||
@ -51,11 +53,6 @@ private:
|
|||||||
void UpdateHTML();
|
void UpdateHTML();
|
||||||
|
|
||||||
//SessionTimes *session_times;
|
//SessionTimes *session_times;
|
||||||
gGraph *AHI,*UC,*PR,*LK;
|
|
||||||
SummaryChart *bc;
|
|
||||||
SummaryChart *uc;
|
|
||||||
SummaryChart *pr;
|
|
||||||
SummaryChart *lk;
|
|
||||||
//,*PRESSURE,*LEAK,*SESSTIMES;
|
//,*PRESSURE,*LEAK,*SESSTIMES;
|
||||||
|
|
||||||
//Layer *prmax,*prmin,*iap,*eap,*pr,*sesstime;
|
//Layer *prmax,*prmin,*iap,*eap,*pr,*sesstime;
|
||||||
|
@ -26,6 +26,7 @@ PreferencesDialog::PreferencesDialog(QWidget *parent) :
|
|||||||
ui->heightEdit->setValue((*profile)["Height"].toDouble(&ok));
|
ui->heightEdit->setValue((*profile)["Height"].toDouble(&ok));
|
||||||
ui->dobEdit->setDate((*profile)["DOB"].toDate());
|
ui->dobEdit->setDate((*profile)["DOB"].toDate());
|
||||||
int i=ui->unitCombo->findText((*profile)["UnitSystem"].toString());
|
int i=ui->unitCombo->findText((*profile)["UnitSystem"].toString());
|
||||||
|
if (i<0) i=0;
|
||||||
ui->unitCombo->setCurrentIndex(i);
|
ui->unitCombo->setCurrentIndex(i);
|
||||||
|
|
||||||
i=ui->timeZoneCombo->findText((*profile)["TimeZone"].toString());
|
i=ui->timeZoneCombo->findText((*profile)["TimeZone"].toString());
|
||||||
|
232
report.cpp
Normal file
232
report.cpp
Normal file
@ -0,0 +1,232 @@
|
|||||||
|
#include "report.h"
|
||||||
|
#include "ui_report.h"
|
||||||
|
#include <QMessageBox>
|
||||||
|
#include <QBuffer>
|
||||||
|
#include <Graphs/gYAxis.h>
|
||||||
|
#include <Graphs/gXAxis.h>
|
||||||
|
#include <QTimer>
|
||||||
|
#include <QPrinter>
|
||||||
|
#include <QPrintDialog>
|
||||||
|
|
||||||
|
Report::Report(QWidget *parent, gGraphView * shared, Daily * daily, Overview * overview) :
|
||||||
|
QWidget(parent),
|
||||||
|
ui(new Ui::Report),
|
||||||
|
m_daily(daily),
|
||||||
|
m_overview(overview)
|
||||||
|
{
|
||||||
|
ui->setupUi(this);
|
||||||
|
QString prof=pref["Profile"].toString();
|
||||||
|
profile=Profiles::Get(prof);
|
||||||
|
if (!profile) {
|
||||||
|
QMessageBox::critical(this,"Profile Error",QString("Couldn't get profile '%1'.. Have to abort!").arg(pref["Profile"].toString()));
|
||||||
|
exit(-1);
|
||||||
|
}
|
||||||
|
GraphView=new gGraphView(this);
|
||||||
|
|
||||||
|
//GraphView->AddGraph(overview->AHI);
|
||||||
|
GraphView->hide();
|
||||||
|
ui->startDate->setDate(profile->FirstDay());
|
||||||
|
ui->endDate->setDate(profile->LastDay());
|
||||||
|
|
||||||
|
// Create a new graph, but reuse the layers..
|
||||||
|
int default_height=200;
|
||||||
|
UC=new gGraph(GraphView,"Usage",default_height,0);
|
||||||
|
/*uc=new SummaryChart(profile,"Hours",GT_BAR);
|
||||||
|
uc->addSlice(EmptyChannel,QColor("green"),ST_HOURS); */
|
||||||
|
UC->AddLayer(new gYAxis(),LayerLeft,gYAxis::Margin);
|
||||||
|
gXAxis *gx=new gXAxis();
|
||||||
|
gx->setUtcFix(true);
|
||||||
|
UC->AddLayer(gx,LayerBottom,0,gXAxis::Margin);
|
||||||
|
UC->AddLayer(m_overview->uc);
|
||||||
|
UC->AddLayer(new gXGrid());
|
||||||
|
|
||||||
|
AHI=new gGraph(GraphView,"AHI",default_height,0);
|
||||||
|
|
||||||
|
/* bc=new SummaryChart(profile,"AHI",GT_BAR);
|
||||||
|
bc->addSlice(CPAP_Hypopnea,QColor("blue"),ST_CPH);
|
||||||
|
bc->addSlice(CPAP_Apnea,QColor("dark green"),ST_CPH);
|
||||||
|
bc->addSlice(CPAP_Obstructive,QColor("#40c0ff"),ST_CPH);
|
||||||
|
bc->addSlice(CPAP_ClearAirway,QColor("purple"),ST_CPH);*/
|
||||||
|
AHI->AddLayer(new gYAxis(),LayerLeft,gYAxis::Margin);
|
||||||
|
gx=new gXAxis();
|
||||||
|
gx->setUtcFix(true);
|
||||||
|
AHI->AddLayer(gx,LayerBottom,0,gXAxis::Margin);
|
||||||
|
AHI->AddLayer(m_overview->bc);
|
||||||
|
AHI->AddLayer(new gXGrid());
|
||||||
|
|
||||||
|
PR=new gGraph(GraphView,"Pressure",default_height,0);
|
||||||
|
/*pr=new SummaryChart(profile,"cmH2O",GT_LINE);
|
||||||
|
pr->addSlice(CPAP_Pressure,QColor("orange"),ST_MIN);
|
||||||
|
pr->addSlice(CPAP_Pressure,QColor("red"),ST_MAX);
|
||||||
|
pr->addSlice(CPAP_EPAP,QColor("light green"),ST_MIN);
|
||||||
|
pr->addSlice(CPAP_IPAP,QColor("light blue"),ST_MAX); */
|
||||||
|
PR->AddLayer(new gYAxis(),LayerLeft,gYAxis::Margin);
|
||||||
|
gx=new gXAxis();
|
||||||
|
gx->setUtcFix(true);
|
||||||
|
PR->AddLayer(gx,LayerBottom,0,gXAxis::Margin);
|
||||||
|
PR->AddLayer(m_overview->pr);
|
||||||
|
PR->AddLayer(new gXGrid());
|
||||||
|
|
||||||
|
LK=new gGraph(GraphView,"Leaks",default_height,0);
|
||||||
|
/*lk=new SummaryChart(profile,"Avg Leak",GT_LINE);
|
||||||
|
lk->addSlice(CPAP_Leak,QColor("dark blue"),ST_WAVG);
|
||||||
|
lk->addSlice(CPAP_Leak,QColor("dark grey"),ST_90P); */
|
||||||
|
//lk->addSlice(CPAP_Leak,QColor("dark yellow"));
|
||||||
|
//pr->addSlice(CPAP_IPAP,QColor("red"));
|
||||||
|
LK->AddLayer(new gYAxis(),LayerLeft,gYAxis::Margin);
|
||||||
|
gx=new gXAxis();
|
||||||
|
gx->setUtcFix(true);
|
||||||
|
LK->AddLayer(gx,LayerBottom,0,gXAxis::Margin);
|
||||||
|
LK->AddLayer(m_overview->lk);
|
||||||
|
LK->AddLayer(new gXGrid());
|
||||||
|
|
||||||
|
GraphView->hideSplitter();
|
||||||
|
//ui->webView->hide();
|
||||||
|
m_ready=false;
|
||||||
|
// Reload();
|
||||||
|
}
|
||||||
|
|
||||||
|
Report::~Report()
|
||||||
|
{
|
||||||
|
delete ui;
|
||||||
|
}
|
||||||
|
void Report::showEvent (QShowEvent * event)
|
||||||
|
{
|
||||||
|
QTimer::singleShot(0,this,SLOT(on_refreshButton_clicked()));
|
||||||
|
}
|
||||||
|
|
||||||
|
void Report::resizeEvent(QResizeEvent *event)
|
||||||
|
{
|
||||||
|
QWidget::resizeEvent(event);
|
||||||
|
GraphView->setMinimumSize(event->size().width()-20,240);
|
||||||
|
GraphView->setMaximumSize(event->size().width()-20,240);
|
||||||
|
Reload();
|
||||||
|
}
|
||||||
|
|
||||||
|
QPixmap Report::Snapshot(gGraph * graph)
|
||||||
|
{
|
||||||
|
QDateTime d1(ui->startDate->date(),QTime(0,0,0),Qt::UTC);
|
||||||
|
qint64 first=qint64(d1.toTime_t())*1000L;
|
||||||
|
QDateTime d2(ui->endDate->date(),QTime(0,0,0),Qt::UTC);
|
||||||
|
qint64 last=qint64(d2.toTime_t())*1000L;
|
||||||
|
|
||||||
|
GraphView->TrashGraphs();
|
||||||
|
GraphView->AddGraph(graph);
|
||||||
|
GraphView->ResetBounds();
|
||||||
|
GraphView->SetXBounds(first,last);
|
||||||
|
|
||||||
|
int w=this->width()-20;
|
||||||
|
QPixmap pixmap=GraphView->renderPixmap(w,240,false); //gwwidth,gwheight,false);
|
||||||
|
|
||||||
|
|
||||||
|
return pixmap;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Report::Reload()
|
||||||
|
{
|
||||||
|
if (!m_ready) return;
|
||||||
|
|
||||||
|
//UC->ResetBounds();
|
||||||
|
QString html="<html><head><style type='text/css'>p,a,td,body { font-family: 'FreeSans', 'Sans Serif'; } p,a,td,body { font-size: 12px; } </style>"
|
||||||
|
"</head>"
|
||||||
|
"<body leftmargin=0 rightmargin=0 topmargin=0 marginwidth=0 marginheight=0>"
|
||||||
|
"<table width=100% cellpadding=0 cellspacing=0>"
|
||||||
|
"<tr><td valign=top>";
|
||||||
|
html+="<h2>CPAP Overview</h2>";
|
||||||
|
html+="<table border='1px'><tr><td valign=top><table border=0>";
|
||||||
|
|
||||||
|
//html+="<i>This is a temporary scratch pad tab so I can see what's going on while designing printing code. These graphs are images, and not controllable.</i>";
|
||||||
|
if (!((*profile).Exists("FirstName") && (*profile).Exists("LastName"))) html+="<h1>Please edit your profile (in Preferences)</h1>"; else {
|
||||||
|
html+="<tr><td>Name:</td><td>"+(*profile)["FirstName"].toString()+" "+(*profile)["LastName"].toString()+"</td></tr>";
|
||||||
|
}
|
||||||
|
if ((*profile).Exists("Address")&& !(*profile)["Address"].toString().isEmpty()) {
|
||||||
|
QString address=(*profile)["Address"].toString().replace("\n","<br/>");
|
||||||
|
html+="<tr><td valign=top>Address:</td><td valign=top>"+address+"</td></tr>";
|
||||||
|
}
|
||||||
|
if ((*profile).Exists("Phone") && !(*profile)["Phone"].toString().isEmpty()) {
|
||||||
|
html+="<tr><td>Phone:</td><td>"+(*profile)["Phone"].toString()+"</td></tr>";
|
||||||
|
}
|
||||||
|
if ((*profile).Exists("EmailAddress") && !(*profile)["EmailAddress"].toString().isEmpty()) {
|
||||||
|
html+="<tr><td>Email:</td><td>"+(*profile)["EmailAddress"].toString()+"</td></tr>";
|
||||||
|
}
|
||||||
|
html+="</table></td><td valign=top><table>";
|
||||||
|
if ((*profile).Exists("Gender")) {
|
||||||
|
QString gender=(*profile)["Gender"].toBool() ? "Male" : "Female";
|
||||||
|
html+="<tr><td>Gender:</td><td>"+gender+"</td></tr>";
|
||||||
|
}
|
||||||
|
if ((*profile).Exists("DOB") && !(*profile)["DOB"].toString().isEmpty()) {
|
||||||
|
QDate dob=(*profile)["DOB"].toDate();
|
||||||
|
//html+="<tr><td>D.O.B.:</td><td>"+dob.toString()+"</td></tr>";
|
||||||
|
QDateTime d1(dob,QTime(0,0,0));
|
||||||
|
QDateTime d2(QDate::currentDate(),QTime(0,0,0));
|
||||||
|
int years=d1.daysTo(d2)/365.25;
|
||||||
|
html+="<tr><td>Age:</td><td>"+QString::number(years)+" years</td></tr>";
|
||||||
|
|
||||||
|
}
|
||||||
|
if ((*profile).Exists("Height") && !(*profile)["Height"].toString().isEmpty()) {
|
||||||
|
html+="<tr><td>Height:</td><td>"+(*profile)["Height"].toString();
|
||||||
|
if (!(*profile).Exists("UnitSystem")) {
|
||||||
|
(*profile)["UnitSystem"]="Metric";
|
||||||
|
}
|
||||||
|
if ((*profile)["UnitSystem"].toString()=="Metric") html+="cm"; else html+="inches";
|
||||||
|
html+="</td></tr>";
|
||||||
|
}
|
||||||
|
|
||||||
|
html+="</table></td></tr></table>";
|
||||||
|
html+="<td ><div align=center><img src='qrc:/docs/sheep.png' width=100 height=100'><br/>SleepyHead v"+pref["VersionString"].toString()+"</div></td></tr></table> <br/>"
|
||||||
|
"Reporting from <b>"+ui->startDate->date().toString()+"</b> to <b>"+ui->endDate->date().toString()+"</b><br/>"
|
||||||
|
"<hr>";
|
||||||
|
|
||||||
|
|
||||||
|
QVector<gGraph *> graphs;
|
||||||
|
graphs.push_back(AHI);
|
||||||
|
graphs.push_back(UC);
|
||||||
|
graphs.push_back(PR);
|
||||||
|
graphs.push_back(LK);
|
||||||
|
|
||||||
|
for (int i=0;i<graphs.size();i++) {
|
||||||
|
QPixmap pixmap=Snapshot(graphs[i]);
|
||||||
|
QByteArray byteArray;
|
||||||
|
QBuffer buffer(&byteArray); // use buffer to store pixmap into byteArray
|
||||||
|
buffer.open(QIODevice::WriteOnly);
|
||||||
|
pixmap.save(&buffer, "PNG");
|
||||||
|
html += "<div align=center><img src=\"data:image/png;base64," + byteArray.toBase64() + "\" width=\"100%\"></div>\n"; //
|
||||||
|
}
|
||||||
|
|
||||||
|
html+="</body></html>";
|
||||||
|
ui->webView->setHtml(html);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Report::on_refreshButton_clicked()
|
||||||
|
{
|
||||||
|
m_ready=true;
|
||||||
|
Reload();
|
||||||
|
}
|
||||||
|
|
||||||
|
void Report::on_startDate_dateChanged(const QDate &date)
|
||||||
|
{
|
||||||
|
Reload();
|
||||||
|
}
|
||||||
|
|
||||||
|
void Report::on_endDate_dateChanged(const QDate &date)
|
||||||
|
{
|
||||||
|
Reload();
|
||||||
|
}
|
||||||
|
|
||||||
|
void Report::on_printButton_clicked()
|
||||||
|
{
|
||||||
|
QPrinter printer;
|
||||||
|
QPrintDialog *dialog = new QPrintDialog(&printer);
|
||||||
|
//printer.setPrinterName("Print to File (PDF)");
|
||||||
|
//printer.setOutputFormat(QPrinter::PdfFormat);
|
||||||
|
printer.setPrintRange(QPrinter::AllPages);
|
||||||
|
printer.setOrientation(QPrinter::Portrait);
|
||||||
|
printer.setPaperSize(QPrinter::A4);
|
||||||
|
printer.setResolution(QPrinter::HighResolution);
|
||||||
|
printer.setFullPage(false);
|
||||||
|
printer.setNumCopies(1);
|
||||||
|
//printer.setOutputFileName("printYou.pdf");
|
||||||
|
if ( dialog->exec() == QDialog::Accepted) {
|
||||||
|
ui->webView->print(&printer);
|
||||||
|
}
|
||||||
|
}
|
48
report.h
Normal file
48
report.h
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
#ifndef REPORT_H
|
||||||
|
#define REPORT_H
|
||||||
|
|
||||||
|
#include <QWidget>
|
||||||
|
#include "SleepLib/profiles.h"
|
||||||
|
#include "Graphs/gGraphView.h"
|
||||||
|
#include "daily.h"
|
||||||
|
#include "overview.h"
|
||||||
|
|
||||||
|
namespace Ui {
|
||||||
|
class Report;
|
||||||
|
}
|
||||||
|
|
||||||
|
class Daily;
|
||||||
|
class Report : public QWidget
|
||||||
|
{
|
||||||
|
Q_OBJECT
|
||||||
|
|
||||||
|
public:
|
||||||
|
explicit Report(QWidget *parent, gGraphView * shared, Daily * daily, Overview * overview);
|
||||||
|
~Report();
|
||||||
|
void Reload();
|
||||||
|
QPixmap Snapshot(gGraph * graph);
|
||||||
|
protected:
|
||||||
|
virtual void showEvent (QShowEvent * event);
|
||||||
|
private slots:
|
||||||
|
void on_refreshButton_clicked();
|
||||||
|
|
||||||
|
void on_startDate_dateChanged(const QDate &date);
|
||||||
|
|
||||||
|
void on_endDate_dateChanged(const QDate &date);
|
||||||
|
|
||||||
|
void on_printButton_clicked();
|
||||||
|
|
||||||
|
private:
|
||||||
|
Ui::Report *ui;
|
||||||
|
Profile * profile;
|
||||||
|
Daily * m_daily;
|
||||||
|
Overview * m_overview;
|
||||||
|
gGraphView * shared;
|
||||||
|
gGraphView * GraphView;
|
||||||
|
gGraph *AHI,*UC,*PR,*LK;
|
||||||
|
SummaryChart *bc,*uc,*pr,*lk;
|
||||||
|
bool m_ready;
|
||||||
|
virtual void resizeEvent(QResizeEvent *);
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif // REPORT_H
|
115
report.ui
Normal file
115
report.ui
Normal file
@ -0,0 +1,115 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<ui version="4.0">
|
||||||
|
<class>Report</class>
|
||||||
|
<widget class="QWidget" name="Report">
|
||||||
|
<property name="geometry">
|
||||||
|
<rect>
|
||||||
|
<x>0</x>
|
||||||
|
<y>0</y>
|
||||||
|
<width>549</width>
|
||||||
|
<height>338</height>
|
||||||
|
</rect>
|
||||||
|
</property>
|
||||||
|
<property name="windowTitle">
|
||||||
|
<string>Form</string>
|
||||||
|
</property>
|
||||||
|
<layout class="QVBoxLayout" name="verticalLayout">
|
||||||
|
<property name="spacing">
|
||||||
|
<number>0</number>
|
||||||
|
</property>
|
||||||
|
<property name="margin">
|
||||||
|
<number>0</number>
|
||||||
|
</property>
|
||||||
|
<item>
|
||||||
|
<widget class="QWebView" name="webView">
|
||||||
|
<property name="url">
|
||||||
|
<url>
|
||||||
|
<string>about:blank</string>
|
||||||
|
</url>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
<item>
|
||||||
|
<layout class="QHBoxLayout" name="horizontalLayout">
|
||||||
|
<item>
|
||||||
|
<widget class="QLabel" name="label">
|
||||||
|
<property name="text">
|
||||||
|
<string>Start</string>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
<item>
|
||||||
|
<widget class="QDateEdit" name="startDate">
|
||||||
|
<property name="displayFormat">
|
||||||
|
<string>d/MM/yyyy</string>
|
||||||
|
</property>
|
||||||
|
<property name="calendarPopup">
|
||||||
|
<bool>true</bool>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
<item>
|
||||||
|
<widget class="QLabel" name="label_2">
|
||||||
|
<property name="text">
|
||||||
|
<string>End</string>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
<item>
|
||||||
|
<widget class="QDateEdit" name="endDate">
|
||||||
|
<property name="displayFormat">
|
||||||
|
<string>d/MM/yyyy</string>
|
||||||
|
</property>
|
||||||
|
<property name="calendarPopup">
|
||||||
|
<bool>true</bool>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
<item>
|
||||||
|
<widget class="QPushButton" name="refreshButton">
|
||||||
|
<property name="text">
|
||||||
|
<string>&Refresh</string>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
<item>
|
||||||
|
<widget class="QLabel" name="label_3">
|
||||||
|
<property name="text">
|
||||||
|
<string>Temporary Page</string>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
<item>
|
||||||
|
<spacer name="horizontalSpacer">
|
||||||
|
<property name="orientation">
|
||||||
|
<enum>Qt::Horizontal</enum>
|
||||||
|
</property>
|
||||||
|
<property name="sizeHint" stdset="0">
|
||||||
|
<size>
|
||||||
|
<width>40</width>
|
||||||
|
<height>20</height>
|
||||||
|
</size>
|
||||||
|
</property>
|
||||||
|
</spacer>
|
||||||
|
</item>
|
||||||
|
<item>
|
||||||
|
<widget class="QPushButton" name="printButton">
|
||||||
|
<property name="text">
|
||||||
|
<string>&Print</string>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
</layout>
|
||||||
|
</item>
|
||||||
|
</layout>
|
||||||
|
</widget>
|
||||||
|
<customwidgets>
|
||||||
|
<customwidget>
|
||||||
|
<class>QWebView</class>
|
||||||
|
<extends>QWidget</extends>
|
||||||
|
<header>QtWebKit/QWebView</header>
|
||||||
|
</customwidget>
|
||||||
|
</customwidgets>
|
||||||
|
<resources/>
|
||||||
|
<connections/>
|
||||||
|
</ui>
|
Loading…
Reference in New Issue
Block a user