mirror of
https://gitlab.com/pholy/OSCAR-code.git
synced 2025-04-06 11:10:44 +00:00
Internally store Time Deltas rather than full 64bit timestamps.. DB changesgit diff! DB change notification dialog
This commit is contained in:
parent
20a5fbd5e2
commit
36bdde4078
@ -1,150 +0,0 @@
|
|||||||
/********************************************************************
|
|
||||||
gCandleStick Graph Implementation
|
|
||||||
Copyright (c)2011 Mark Watkins <jedimark@users.sourceforge.net>
|
|
||||||
License: GPL
|
|
||||||
*********************************************************************/
|
|
||||||
|
|
||||||
#include <math.h>
|
|
||||||
#include "gCandleStick.h"
|
|
||||||
|
|
||||||
gCandleStick::gCandleStick(Qt::Orientation o)
|
|
||||||
:gLayer(MC_UNKNOWN)
|
|
||||||
{
|
|
||||||
m_orientation=o;
|
|
||||||
}
|
|
||||||
gCandleStick::~gCandleStick()
|
|
||||||
{
|
|
||||||
}
|
|
||||||
void gCandleStick::SetDay(Day * d)
|
|
||||||
{
|
|
||||||
gLayer::SetDay(d);
|
|
||||||
m_total=0;
|
|
||||||
if (!m_day) return;
|
|
||||||
int cnt;
|
|
||||||
for (map<MachineCode,int>::iterator c=m_counts.begin();c!=m_counts.end();c++) {
|
|
||||||
c->second=0;
|
|
||||||
for (vector<Session *>::iterator s=m_day->begin();s!=m_day->end();s++) {
|
|
||||||
// check summary objects first..
|
|
||||||
//if (*s)->summary_exists(c->first) {
|
|
||||||
cnt=(*s)->count(c->first);
|
|
||||||
//} else
|
|
||||||
cnt=(*s)->summary[c->first].toInt();
|
|
||||||
//}
|
|
||||||
c->second+=cnt;
|
|
||||||
m_total+=cnt;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
void gCandleStick::AddSlice(MachineCode code, QColor color, QString name)
|
|
||||||
{
|
|
||||||
m_counts[code]=0;
|
|
||||||
m_names[code]=name;
|
|
||||||
m_colors[code]=color;
|
|
||||||
}
|
|
||||||
void gCandleStick::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())-1;
|
|
||||||
int height=scry-(w.GetTopMargin()+w.GetBottomMargin())-1;
|
|
||||||
|
|
||||||
|
|
||||||
for (map<MachineCode,int>::iterator m=m_counts.begin();m!=m_counts.end();m++) {
|
|
||||||
if (!m->second) continue;
|
|
||||||
int j=float(m->second)/float(m_total); // ratio of this pie slice
|
|
||||||
//QColor & col1 = m_colors[m->first];
|
|
||||||
//QColor & col2 = m_gradient_color;
|
|
||||||
}
|
|
||||||
/* float sum=0;
|
|
||||||
for (int i=0;i<data->np[0];i++)
|
|
||||||
sum+=data->point[0][i].y();
|
|
||||||
|
|
||||||
float pxr;
|
|
||||||
float px;
|
|
||||||
if (m_orientation==Qt::Vertical) {
|
|
||||||
pxr=height/sum;
|
|
||||||
px=start_py;
|
|
||||||
} else {
|
|
||||||
pxr=width/sum;
|
|
||||||
px=start_px;
|
|
||||||
}
|
|
||||||
|
|
||||||
float x,y;
|
|
||||||
|
|
||||||
float t1,t2;
|
|
||||||
int barwidth;
|
|
||||||
if (m_orientation==Qt::Vertical) {
|
|
||||||
barwidth=width;
|
|
||||||
} else {
|
|
||||||
barwidth=height;
|
|
||||||
}
|
|
||||||
|
|
||||||
QColor col2=QColor("light grey");
|
|
||||||
QColor c(0,0,0,255);
|
|
||||||
QString str,st;
|
|
||||||
QRect rect;
|
|
||||||
|
|
||||||
//Qt::AlignmDirection dir;
|
|
||||||
|
|
||||||
glLineWidth(1);
|
|
||||||
|
|
||||||
// glDisable(GL_LINE_SMOOTH);
|
|
||||||
for (int i=0;i<data->np[0];i++) {
|
|
||||||
t1=floor(px);
|
|
||||||
t2=data->point[0][i].y()*pxr;
|
|
||||||
px+=t2;
|
|
||||||
t2=ceil(t2);
|
|
||||||
if (m_orientation==Qt::Vertical) {
|
|
||||||
rect=QRect(start_px,t1,barwidth,t2);
|
|
||||||
//dir=wxEAST;
|
|
||||||
} else {
|
|
||||||
rect=QRect(t1,start_py,t2,barwidth);
|
|
||||||
//dir=wxSOUTH;
|
|
||||||
}
|
|
||||||
|
|
||||||
QColor col1=color[i % color.size()];
|
|
||||||
|
|
||||||
glBegin(GL_QUADS);
|
|
||||||
glColor4ub(col1.red(),col1.green(),col1.blue(),col1.alpha());
|
|
||||||
glVertex2f(rect.x()+1, rect.y()+height);
|
|
||||||
glVertex2f(rect.x()+rect.width(), rect.y()+height);
|
|
||||||
|
|
||||||
glColor4ub(col2.red(),col2.green(),col2.blue(),col2.alpha());
|
|
||||||
glVertex2f(rect.x()+rect.width(), rect.y()+1);
|
|
||||||
glVertex2f(rect.x()+1, rect.y()+1);
|
|
||||||
glEnd();
|
|
||||||
|
|
||||||
glColor4ub(0,0,0,255);
|
|
||||||
glBegin(GL_LINE_LOOP);
|
|
||||||
glVertex2f(rect.x()+1, rect.y()+height);
|
|
||||||
glVertex2f(rect.x()+rect.width(), rect.y()+height);
|
|
||||||
|
|
||||||
glVertex2f(rect.x()+rect.width(), rect.y()+1);
|
|
||||||
glVertex2f(rect.x()+1, rect.y()+1);
|
|
||||||
glEnd();
|
|
||||||
//LinedRoundedRectangle(rect.x,rect.y,rect.width,rect.height,0,1,c);
|
|
||||||
|
|
||||||
str="";
|
|
||||||
if ((int)m_names.size()>i) {
|
|
||||||
// str=m_names[i]+" ";
|
|
||||||
}
|
|
||||||
st.sprintf("%0.1f",data->point[0][i].x());
|
|
||||||
str+=st;
|
|
||||||
GetTextExtent(str, x, y);
|
|
||||||
//x+=5;
|
|
||||||
if (t2>x+5) {
|
|
||||||
int j=t1+((t2/2.0)-(x/2.0));
|
|
||||||
if (m_orientation==Qt::Vertical) {
|
|
||||||
DrawText(str,start_px+barwidth+2+y,scry-j,270.0);
|
|
||||||
} else {
|
|
||||||
//w.renderText(j,float(scry)-(float(start_py)+(barwidth/2.0)-(y/2.0)),str);
|
|
||||||
DrawText(str,j,float(scry)-(float(start_py)+(barwidth/2.0)-(y/2.0)));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} // for (int i
|
|
||||||
glFlush(); */
|
|
||||||
}
|
|
||||||
|
|
@ -1,35 +0,0 @@
|
|||||||
/********************************************************************
|
|
||||||
gCandleStick Graph Header
|
|
||||||
Copyright (c)2011 Mark Watkins <jedimark@users.sourceforge.net>
|
|
||||||
License: GPL
|
|
||||||
*********************************************************************/
|
|
||||||
|
|
||||||
#ifndef GCANDLESTICK_H
|
|
||||||
#define GCANDLESTICK_H
|
|
||||||
|
|
||||||
#include "graphlayer.h"
|
|
||||||
|
|
||||||
class gCandleStick:public gLayer
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
gCandleStick(Qt::Orientation o=Qt::Horizontal);
|
|
||||||
virtual ~gCandleStick();
|
|
||||||
virtual void SetDay(Day *d);
|
|
||||||
|
|
||||||
virtual void Plot(gGraphWindow & w,float scrx,float scry);
|
|
||||||
void AddSlice(MachineCode code,QColor color,QString name="");
|
|
||||||
|
|
||||||
void setGradientColor(QColor & color) { m_gradient_color=color; }
|
|
||||||
void setOutlineColor(QColor & color) { m_outline_color=color; }
|
|
||||||
protected:
|
|
||||||
Qt::Orientation m_orientation;
|
|
||||||
map<MachineCode,int> m_counts;
|
|
||||||
map<MachineCode,QString> m_names;
|
|
||||||
map<MachineCode,QColor> m_colors;
|
|
||||||
QColor m_gradient_color;
|
|
||||||
QColor m_outline_color;
|
|
||||||
int m_total;
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
#endif // GCANDLESTICK_H
|
|
@ -135,7 +135,8 @@ void gLineChart::Plot(gGraphWindow & w,float scrx,float scry)
|
|||||||
for (unsigned n=0;n<evec.size();n++) { // for each segment
|
for (unsigned n=0;n<evec.size();n++) { // for each segment
|
||||||
EventList & el=*evec[n];
|
EventList & el=*evec[n];
|
||||||
|
|
||||||
accel=!m_disable_accel && (el.type()==EVL_Waveform); // Turn on acceleration if this is a waveform.
|
accel=(el.type()==EVL_Waveform); // Turn on acceleration if this is a waveform.
|
||||||
|
if (m_disable_accel) accel=false;
|
||||||
|
|
||||||
|
|
||||||
square_plot=m_square_plot;
|
square_plot=m_square_plot;
|
||||||
@ -262,7 +263,7 @@ void gLineChart::Plot(gGraphWindow & w,float scrx,float scry)
|
|||||||
EventDataType ymin=miny/gain;
|
EventDataType ymin=miny/gain;
|
||||||
|
|
||||||
const vector<EventStoreType> & dat=el.getData();
|
const vector<EventStoreType> & dat=el.getData();
|
||||||
const vector<qint64> & tim=el.getTime();
|
//const vector<qint32> & tim=el.getTime();
|
||||||
|
|
||||||
done=false;
|
done=false;
|
||||||
first=true;
|
first=true;
|
||||||
@ -350,13 +351,13 @@ void gLineChart::Plot(gGraphWindow & w,float scrx,float scry)
|
|||||||
//////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////
|
||||||
first=true;
|
first=true;
|
||||||
for (int i=idx;i<siz;i+=sam) {
|
for (int i=idx;i<siz;i+=sam) {
|
||||||
time=tim[i]; //el.time(i);
|
time=el.time(i);
|
||||||
|
|
||||||
if (first) {
|
if (first) {
|
||||||
if (num_points>5 && (time < minx)) continue; // Skip stuff before the start of our data window
|
if (num_points>5 && (time < minx)) continue; // Skip stuff before the start of our data window
|
||||||
first=false;
|
first=false;
|
||||||
if (i>=sam) i-=sam; // Start with the previous sample (which will be in clipping area)
|
if (i>=sam) i-=sam; // Start with the previous sample (which will be in clipping area)
|
||||||
time=tim[i]; //el.time(i);
|
time=el.time(i); //el.time(i);
|
||||||
}
|
}
|
||||||
data=dat[i]*gain; //
|
data=dat[i]*gain; //
|
||||||
//data=el.data(i); // raw access is faster
|
//data=el.data(i); // raw access is faster
|
||||||
|
@ -28,11 +28,10 @@ EventList::~EventList()
|
|||||||
}
|
}
|
||||||
qint64 EventList::time(int i)
|
qint64 EventList::time(int i)
|
||||||
{
|
{
|
||||||
if (m_type==EVL_Waveform) {
|
if (m_type==EVL_Event) {
|
||||||
qint64 t=m_first+(double(i)*m_rate);
|
return m_first+qint64(m_time[i]);
|
||||||
return t;
|
|
||||||
}
|
}
|
||||||
return m_time[i];
|
return m_first+(EventDataType(i)*m_rate);
|
||||||
}
|
}
|
||||||
|
|
||||||
EventDataType EventList::data(int i)
|
EventDataType EventList::data(int i)
|
||||||
@ -44,22 +43,31 @@ void EventList::AddEvent(qint64 time, EventStoreType data)
|
|||||||
{
|
{
|
||||||
// Apply gain & offset
|
// Apply gain & offset
|
||||||
m_data.push_back(data);
|
m_data.push_back(data);
|
||||||
EventDataType val=data;
|
EventDataType val=EventDataType(data)*m_gain+m_offset;
|
||||||
val*=m_gain;
|
|
||||||
val+=m_offset;
|
|
||||||
m_count++;
|
|
||||||
if (m_update_minmax) {
|
if (m_update_minmax) {
|
||||||
if (m_min>val) m_min=val;
|
if (m_min>val) m_min=val;
|
||||||
if (m_max<val) m_max=val;
|
if (m_max<val) m_max=val;
|
||||||
}
|
}
|
||||||
|
|
||||||
m_time.push_back(time);
|
|
||||||
if (!m_first) {
|
if (!m_first) {
|
||||||
m_first=time;
|
m_first=time;
|
||||||
m_last=time;
|
m_last=time;
|
||||||
}
|
}
|
||||||
if (m_first>time) m_first=time;
|
if (m_first>time) {
|
||||||
if (m_last<time) m_last=time;
|
// Crud.. Update all the previous records
|
||||||
|
// This really shouldn't happen.
|
||||||
|
|
||||||
|
qint64 t=(m_first-time);
|
||||||
|
for (int i=0;i<m_count;i++) {
|
||||||
|
m_time[i]-=t & 0xffffffff;
|
||||||
|
}
|
||||||
|
m_first=time;
|
||||||
|
}
|
||||||
|
if (m_last < time) m_last=time;
|
||||||
|
quint32 t=(time-m_first) & 0xffffffff;
|
||||||
|
|
||||||
|
m_time.push_back(t);
|
||||||
|
m_count++;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Adds a consecutive waveform chunk
|
// Adds a consecutive waveform chunk
|
||||||
|
@ -54,9 +54,9 @@ public:
|
|||||||
inline const bool & update_minmax() { return m_update_minmax; }
|
inline const bool & update_minmax() { return m_update_minmax; }
|
||||||
|
|
||||||
vector<EventStoreType> & getData() { return m_data; }
|
vector<EventStoreType> & getData() { return m_data; }
|
||||||
vector<qint64> & getTime() { return m_time; }
|
vector<quint32> & getTime() { return m_time; }
|
||||||
protected:
|
protected:
|
||||||
vector<qint64> m_time; // 32bitalize this.. add offsets to m_first
|
vector<quint32> m_time; // 32bitalize this.. add offsets to m_first
|
||||||
vector<EventStoreType> m_data;
|
vector<EventStoreType> m_data;
|
||||||
MachineCode m_code;
|
MachineCode m_code;
|
||||||
EventListType m_type;
|
EventListType m_type;
|
||||||
|
@ -247,7 +247,7 @@ bool Machine::Purge(int secret)
|
|||||||
bool ok;
|
bool ok;
|
||||||
ext_s.toInt(&ok,10);
|
ext_s.toInt(&ok,10);
|
||||||
if (ok) {
|
if (ok) {
|
||||||
qDebug() << "TestMe: Deleting " << fullpath;
|
qDebug() << "Deleting " << fullpath;
|
||||||
dir.remove(fullpath);
|
dir.remove(fullpath);
|
||||||
} else could_not_kill++;
|
} else could_not_kill++;
|
||||||
|
|
||||||
|
@ -16,10 +16,11 @@ typedef long MachineID;
|
|||||||
typedef long SessionID;
|
typedef long SessionID;
|
||||||
|
|
||||||
class BoundsError {};
|
class BoundsError {};
|
||||||
|
class OldDBVersion {};
|
||||||
|
|
||||||
// This is the uber important database version for SleepyHeads internal storage
|
// This is the uber important database version for SleepyHeads internal storage
|
||||||
// Increment this after stuffing with Session's save & load code.
|
// Increment this after stuffing with Session's save & load code.
|
||||||
const quint16 dbversion=4;
|
const quint16 dbversion=5;
|
||||||
|
|
||||||
const int max_number_event_fields=10;
|
const int max_number_event_fields=10;
|
||||||
|
|
||||||
|
@ -49,6 +49,26 @@ Profile::~Profile()
|
|||||||
delete i->second;
|
delete i->second;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
void Profile::DataFormatError(Machine *m)
|
||||||
|
{
|
||||||
|
QString msg="Software changes have been made that require the reimporting of the following machines data:\n\n";
|
||||||
|
msg=msg+m->properties["Brand"]+" "+m->properties["Model"]+" "+m->properties["Serial"];
|
||||||
|
msg=msg+"\n\nThis is still only alpha software and these changes are sometimes necessary.\n\n";
|
||||||
|
msg=msg+"I can automatically purge this data for you, or you can cancel now and continue to run in a previous version.\n\n";
|
||||||
|
msg=msg+"Would you like me to purge this data this for you so you can run the new version?";
|
||||||
|
|
||||||
|
if (QMessageBox::warning(NULL,"Machine Database Changes",msg,QMessageBox::Yes | QMessageBox::Cancel,QMessageBox::Yes)==QMessageBox::Yes) {
|
||||||
|
|
||||||
|
if (!m->Purge(3478216)) { // Do not copy this line without thinking.. You will be eaten by a Grue if you do
|
||||||
|
QMessageBox::critical(NULL,"Purge Failed","Sorry, I could not purge this data, which means this version of SleepyHead can't start.. SleepyHead's Data folder needs to be removed manually\n\nThis folder currently resides at the following location:\n"+pref["DataFolder"].toString(),QMessageBox::Ok);
|
||||||
|
exit(-1);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
exit(-1);
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
|
||||||
|
}
|
||||||
void Profile::LoadMachineData()
|
void Profile::LoadMachineData()
|
||||||
{
|
{
|
||||||
for (map<MachineID,Machine *>::iterator i=machlist.begin(); i!=machlist.end(); i++) {
|
for (map<MachineID,Machine *>::iterator i=machlist.begin(); i!=machlist.end(); i++) {
|
||||||
@ -64,21 +84,18 @@ void Profile::LoadMachineData()
|
|||||||
bool ok;
|
bool ok;
|
||||||
cv=m->properties["DataVersion"].toLong(&ok);
|
cv=m->properties["DataVersion"].toLong(&ok);
|
||||||
if (!ok || cv<v) {
|
if (!ok || cv<v) {
|
||||||
QString msg="Software changes have been made that require the reimporting of the following machines data:\n\n";
|
DataFormatError(m);
|
||||||
msg=msg+m->properties["Brand"]+" "+m->properties["Model"]+" "+m->properties["Serial"];
|
// It may exit above and not return here..
|
||||||
msg=msg+"\n\nNo attempt will be made to load previous data.\n\n";
|
QString s;
|
||||||
msg=msg+"Importing ALL of your data for this machine again will rectify this problem.\n\n";
|
s.sprintf("%li",v);
|
||||||
msg=msg+"However, if you have more than one seperate datacard/stash for this machine, it would be best if the machine data was purged first.\n\nWould you like me to do this for you?";
|
m->properties["DataVersion"]=s; // Dont need to nag again if they are too lazy.
|
||||||
|
} else {
|
||||||
if (QMessageBox::warning(NULL,"Machine Database Changes",msg,QMessageBox::Yes | QMessageBox::No,QMessageBox::Yes)==QMessageBox::Yes) {
|
try {
|
||||||
|
m->Load();
|
||||||
if (m->Purge(3478216)) { // Do not copy this line without thinking.. You will be eaten by a Grue if you do
|
} catch (OldDBVersion e){
|
||||||
QString s;
|
DataFormatError(m);
|
||||||
s.sprintf("%li",v);
|
|
||||||
m->properties["DataVersion"]=s; // Dont need to nag again if they are too lazy.
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
} else m->Load();
|
}
|
||||||
} else {
|
} else {
|
||||||
m->Load();
|
m->Load();
|
||||||
}
|
}
|
||||||
|
@ -36,6 +36,7 @@ public:
|
|||||||
void AddMachine(Machine *m);
|
void AddMachine(Machine *m);
|
||||||
void DelMachine(Machine *m);
|
void DelMachine(Machine *m);
|
||||||
void LoadMachineData();
|
void LoadMachineData();
|
||||||
|
void DataFormatError(Machine *m);
|
||||||
int Import(QString path);
|
int Import(QString path);
|
||||||
|
|
||||||
void AddDay(QDate date,Day *day,MachineType mt);
|
void AddDay(QDate date,Day *day,MachineType mt);
|
||||||
|
@ -53,6 +53,11 @@ void Session::TrashEvents()
|
|||||||
bool Session::OpenEvents() {
|
bool Session::OpenEvents() {
|
||||||
if (s_events_loaded)
|
if (s_events_loaded)
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
|
s_events_loaded=eventlist.size() > 0;
|
||||||
|
if (s_events_loaded)
|
||||||
|
return true;
|
||||||
|
|
||||||
bool b=LoadEvents(s_eventfile);
|
bool b=LoadEvents(s_eventfile);
|
||||||
if (!b) {
|
if (!b) {
|
||||||
qWarning() << "Error Unkpacking Events" << s_eventfile;
|
qWarning() << "Error Unkpacking Events" << s_eventfile;
|
||||||
@ -75,11 +80,11 @@ bool Session::Store(QString path)
|
|||||||
base.sprintf("%08lx",s_session);
|
base.sprintf("%08lx",s_session);
|
||||||
base=path+"/"+base;
|
base=path+"/"+base;
|
||||||
//qDebug() << "Storing Session: " << base;
|
//qDebug() << "Storing Session: " << base;
|
||||||
bool a,b=false;
|
bool a;
|
||||||
a=StoreSummary(base+".000"); // if actually has events
|
a=StoreSummary(base+".000"); // if actually has events
|
||||||
//qDebug() << " Summary done";
|
//qDebug() << " Summary done";
|
||||||
if (eventlist.size()>0)
|
if (eventlist.size()>0)
|
||||||
b=StoreEvents(base+".001");
|
StoreEvents(base+".001");
|
||||||
//qDebug() << " Events done";
|
//qDebug() << " Events done";
|
||||||
s_changed=false;
|
s_changed=false;
|
||||||
s_eventfile=base+".001";
|
s_eventfile=base+".001";
|
||||||
@ -119,8 +124,8 @@ bool Session::StoreSummary(QString filename)
|
|||||||
out << (quint16)dbversion;
|
out << (quint16)dbversion;
|
||||||
out << (quint16)filetype_summary;
|
out << (quint16)filetype_summary;
|
||||||
out << (quint32)s_machine->id();
|
out << (quint32)s_machine->id();
|
||||||
out << (quint32)s_session;
|
|
||||||
|
|
||||||
|
out << (quint32)s_session;
|
||||||
out << s_first; // Session Start Time
|
out << s_first; // Session Start Time
|
||||||
out << s_last; // Duration of sesion in seconds.
|
out << s_last; // Duration of sesion in seconds.
|
||||||
out << (quint16)summary.size();
|
out << (quint16)summary.size();
|
||||||
@ -152,12 +157,9 @@ bool Session::LoadSummary(QString filename)
|
|||||||
in.setVersion(QDataStream::Qt_4_6);
|
in.setVersion(QDataStream::Qt_4_6);
|
||||||
in.setByteOrder(QDataStream::LittleEndian);
|
in.setByteOrder(QDataStream::LittleEndian);
|
||||||
|
|
||||||
quint64 t64;
|
|
||||||
quint32 t32;
|
quint32 t32;
|
||||||
quint16 t16;
|
quint16 t16;
|
||||||
quint8 t8;
|
|
||||||
|
|
||||||
qint16 sumsize;
|
|
||||||
map<MachineCode,MCDataType> mctype;
|
map<MachineCode,MCDataType> mctype;
|
||||||
vector<MachineCode> mcorder;
|
vector<MachineCode> mcorder;
|
||||||
in >> t32;
|
in >> t32;
|
||||||
@ -168,7 +170,8 @@ bool Session::LoadSummary(QString filename)
|
|||||||
|
|
||||||
in >> t16; // DB Version
|
in >> t16; // DB Version
|
||||||
if (t16!=dbversion) {
|
if (t16!=dbversion) {
|
||||||
qWarning() << "Old dbversion "<< t16 << "summary file.. Sorry, you need to purge and reimport";
|
throw OldDBVersion();
|
||||||
|
//qWarning() << "Old dbversion "<< t16 << "summary file.. Sorry, you need to purge and reimport";
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -179,13 +182,19 @@ bool Session::LoadSummary(QString filename)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
in >> t32; // MachineID (dont need this result)
|
qint32 ts32;
|
||||||
|
in >> ts32; // MachineID (dont need this result)
|
||||||
|
if (ts32!=s_machine->id()) {
|
||||||
|
qWarning() << "Machine ID does not match in" << filename << " I will try to load anyway in case you know what your doing.";
|
||||||
|
}
|
||||||
|
|
||||||
in >> t32; // Sessionid;
|
in >> t32; // Sessionid;
|
||||||
s_session=t32;
|
s_session=t32;
|
||||||
|
|
||||||
in >> s_first; // Start time
|
in >> s_first; // Start time
|
||||||
in >> s_last; // Duration // (16bit==Limited to 18 hours)
|
in >> s_last; // Duration // (16bit==Limited to 18 hours)
|
||||||
|
|
||||||
|
qint16 sumsize;
|
||||||
in >> sumsize; // Summary size (number of Machine Code lists)
|
in >> sumsize; // Summary size (number of Machine Code lists)
|
||||||
|
|
||||||
for (int i=0; i<sumsize; i++) {
|
for (int i=0; i<sumsize; i++) {
|
||||||
@ -210,8 +219,8 @@ bool Session::StoreEvents(QString filename)
|
|||||||
out << (quint16)dbversion; // File Version
|
out << (quint16)dbversion; // File Version
|
||||||
out << (quint16)filetype_data; // File type 1 == Event
|
out << (quint16)filetype_data; // File type 1 == Event
|
||||||
out << (quint32)s_machine->id();// Machine ID
|
out << (quint32)s_machine->id();// Machine ID
|
||||||
out << (quint32)s_session; // This session's ID
|
|
||||||
|
|
||||||
|
out << (quint32)s_session; // This session's ID
|
||||||
out << s_first;
|
out << s_first;
|
||||||
out << s_last;
|
out << s_last;
|
||||||
|
|
||||||
@ -237,8 +246,6 @@ bool Session::StoreEvents(QString filename)
|
|||||||
out << e.max();
|
out << e.max();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
qint64 t,last;
|
|
||||||
quint32 x;
|
|
||||||
for (i=eventlist.begin(); i!=eventlist.end(); i++) {
|
for (i=eventlist.begin(); i!=eventlist.end(); i++) {
|
||||||
for (unsigned j=0;j<i->second.size();j++) {
|
for (unsigned j=0;j<i->second.size();j++) {
|
||||||
EventList &e=*i->second[j];
|
EventList &e=*i->second[j];
|
||||||
@ -247,12 +254,8 @@ bool Session::StoreEvents(QString filename)
|
|||||||
out << e.raw(c);
|
out << e.raw(c);
|
||||||
}
|
}
|
||||||
if (e.type()!=EVL_Waveform) {
|
if (e.type()!=EVL_Waveform) {
|
||||||
last=e.first();
|
|
||||||
for (int c=0;c<e.count();c++) {
|
for (int c=0;c<e.count();c++) {
|
||||||
t=e.time(c);
|
out << e.getTime()[c];
|
||||||
x=(t-last);
|
|
||||||
out << x;
|
|
||||||
last=e.time(c);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -288,7 +291,8 @@ bool Session::LoadEvents(QString filename)
|
|||||||
}
|
}
|
||||||
in >> t16; // File Version
|
in >> t16; // File Version
|
||||||
if (t16!=dbversion) {
|
if (t16!=dbversion) {
|
||||||
qWarning() << "Old dbversion "<< t16 << "summary file.. Sorry, you need to purge and reimport";
|
throw OldDBVersion();
|
||||||
|
//qWarning() << "Old dbversion "<< t16 << "summary file.. Sorry, you need to purge and reimport";
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -298,10 +302,14 @@ bool Session::LoadEvents(QString filename)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
in >> t32; // MachineID
|
qint32 ts32;
|
||||||
in >> t32; // Sessionid;
|
in >> ts32; // MachineID
|
||||||
s_session=t32;
|
if (ts32!=s_machine->id()) {
|
||||||
|
qWarning() << "Machine ID does not match in" << filename << " I will try to load anyway in case you know what your doing.";
|
||||||
|
}
|
||||||
|
|
||||||
|
in >> t32; // Sessionid
|
||||||
|
s_session=t32;
|
||||||
in >> s_first;
|
in >> s_first;
|
||||||
in >> s_last;
|
in >> s_last;
|
||||||
|
|
||||||
@ -343,25 +351,26 @@ bool Session::LoadEvents(QString filename)
|
|||||||
}
|
}
|
||||||
|
|
||||||
EventStoreType t;
|
EventStoreType t;
|
||||||
qint64 last;
|
|
||||||
quint32 x;
|
quint32 x;
|
||||||
for (int i=0;i<mcsize;i++) {
|
for (int i=0;i<mcsize;i++) {
|
||||||
code=mcorder[i];
|
code=mcorder[i];
|
||||||
size2=sizevec[i];
|
size2=sizevec[i];
|
||||||
for (int j=0;j<size2;j++) {
|
for (int j=0;j<size2;j++) {
|
||||||
EventList &evec=*eventlist[code][j];
|
EventList &evec=*eventlist[code][j];
|
||||||
evec.m_data.resize(evec.m_count);
|
evec.m_data.reserve(evec.m_count);
|
||||||
for (int c=0;c<evec.m_count;c++) {
|
for (int c=0;c<evec.m_count;c++) {
|
||||||
in >> t;
|
in >> t;
|
||||||
evec.m_data[c]=t;
|
//evec.m_data[c]=t;
|
||||||
|
evec.m_data.push_back(t);
|
||||||
}
|
}
|
||||||
last=evec.first();
|
//last=evec.first();
|
||||||
if (evec.type()!=EVL_Waveform) {
|
if (evec.type()!=EVL_Waveform) {
|
||||||
evec.m_time.resize(evec.m_count);
|
evec.m_time.reserve(evec.m_count);
|
||||||
for (int c=0;c<evec.m_count;c++) {
|
for (int c=0;c<evec.m_count;c++) {
|
||||||
in >> x;
|
in >> x;
|
||||||
last+=x;
|
//last+=x;
|
||||||
evec.m_time[c]=last;
|
evec.m_time.push_back(x);
|
||||||
|
//evec.m_time[c]=x;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -65,7 +65,6 @@ public:
|
|||||||
void SetChanged(bool val) {
|
void SetChanged(bool val) {
|
||||||
s_changed=val;
|
s_changed=val;
|
||||||
s_events_loaded=val; // dirty hack putting this here
|
s_events_loaded=val; // dirty hack putting this here
|
||||||
s_waves_loaded=val;
|
|
||||||
};
|
};
|
||||||
bool IsChanged() {
|
bool IsChanged() {
|
||||||
return s_changed;
|
return s_changed;
|
||||||
@ -76,7 +75,6 @@ public:
|
|||||||
bool IsLoneSession() { return s_lonesession; }
|
bool IsLoneSession() { return s_lonesession; }
|
||||||
void SetLoneSession(bool b) { s_lonesession=b; }
|
void SetLoneSession(bool b) { s_lonesession=b; }
|
||||||
void SetEventFile(QString & filename) { s_eventfile=filename; }
|
void SetEventFile(QString & filename) { s_eventfile=filename; }
|
||||||
void SetWaveFile(QString & filename) { s_wavefile=filename; }
|
|
||||||
|
|
||||||
inline void UpdateFirst(qint64 v) { if (!s_first) s_first=v; else if (s_first>v) s_first=v; }
|
inline void UpdateFirst(qint64 v) { if (!s_first) s_first=v; else if (s_first>v) s_first=v; }
|
||||||
inline void UpdateLast(qint64 v) { if (!s_last) s_last=v; else if (s_last<v) s_last=v; }
|
inline void UpdateLast(qint64 v) { if (!s_last) s_last=v; else if (s_last<v) s_last=v; }
|
||||||
@ -102,9 +100,7 @@ protected:
|
|||||||
bool _first_session;
|
bool _first_session;
|
||||||
|
|
||||||
bool s_events_loaded;
|
bool s_events_loaded;
|
||||||
bool s_waves_loaded;
|
|
||||||
QString s_eventfile;
|
QString s_eventfile;
|
||||||
QString s_wavefile;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@ -52,7 +52,6 @@ SOURCES += main.cpp\
|
|||||||
Graphs/gFlagsLine.cpp \
|
Graphs/gFlagsLine.cpp \
|
||||||
Graphs/glcommon.cpp \
|
Graphs/glcommon.cpp \
|
||||||
Graphs/gTitle.cpp \
|
Graphs/gTitle.cpp \
|
||||||
Graphs/gCandleStick.cpp \
|
|
||||||
Graphs/gBarChart.cpp \
|
Graphs/gBarChart.cpp \
|
||||||
Graphs/gSegmentChart.cpp \
|
Graphs/gSegmentChart.cpp \
|
||||||
Graphs/gSessionTime.cpp \
|
Graphs/gSessionTime.cpp \
|
||||||
|
@ -33,7 +33,7 @@
|
|||||||
</property>
|
</property>
|
||||||
<property name="windowIcon">
|
<property name="windowIcon">
|
||||||
<iconset resource="Resources.qrc">
|
<iconset resource="Resources.qrc">
|
||||||
<normaloff>:/icons/moon.png</normaloff>:/icons/moon.png</iconset>
|
<normaloff>:/docs/sheep.png</normaloff>:/docs/sheep.png</iconset>
|
||||||
</property>
|
</property>
|
||||||
<property name="iconSize">
|
<property name="iconSize">
|
||||||
<size>
|
<size>
|
||||||
|
@ -74,11 +74,12 @@ Oximetry::Oximetry(QWidget *parent,QGLWidget * shared) :
|
|||||||
}
|
}
|
||||||
Graphs[i]->AddLayer(new gYAxis());
|
Graphs[i]->AddLayer(new gYAxis());
|
||||||
Graphs[i]->AddLayer(new gXAxis());
|
Graphs[i]->AddLayer(new gXAxis());
|
||||||
Graphs[i]->AddLayer(new gFooBar());
|
//Graphs[i]->AddLayer(new gFooBar());
|
||||||
|
|
||||||
gSplitter->addWidget(Graphs[i]);
|
gSplitter->addWidget(Graphs[i]);
|
||||||
}
|
}
|
||||||
PLETHY->AddLayer(plethy);
|
PLETHY->AddLayer(plethy);
|
||||||
|
PLETHY->AddLayer(new gFooBar());
|
||||||
PULSE->AddLayer(pulse);
|
PULSE->AddLayer(pulse);
|
||||||
SPO2->AddLayer(spo2);
|
SPO2->AddLayer(spo2);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user