Translation preparation work, Oximetry time selection queries

This commit is contained in:
Mark Watkins 2013-09-10 01:56:02 +10:00
parent 0344257b7f
commit 1e466ca6bf
14 changed files with 4796 additions and 308 deletions

View File

@ -2277,6 +2277,8 @@ gGraphView::~gGraphView()
}
delete masterlock;
#endif
// Note: This will cause a crash if two graphs accidentally have the same name
for (int i=0;i<m_graphs.size();i++) {
delete m_graphs[i];
}

View File

@ -3,6 +3,7 @@
#include <QString>
#include <QObject>
#include "version.h"
#if QT_VERSION >= QT_VERSION_CHECK(4,8,0)
@ -37,18 +38,9 @@ QString weightString(float kg, UnitSystem us=US_Undefined);
//! \brief Mercilessly trash a directory
bool removeDir(const QString & path);
const QString STR_UNIT_CM=QObject::tr("cm");
const QString STR_UNIT_INCH=QObject::tr("\"");
const QString STR_UNIT_FOOT=QObject::tr("ft");
const QString STR_UNIT_POUND=QObject::tr("lb");
const QString STR_UNIT_OUNCE=QObject::tr("oz");
const QString STR_UNIT_KG=QObject::tr("Kg");
const QString STR_UNIT_CMH2O=QObject::tr("cmH2O");
const QString STR_UNIT_Hours=QObject::tr("Hours");
const QString STR_MESSAGE_ERROR=QObject::tr("Error");
const QString STR_MESSAGE_WARNING=QObject::tr("Warning");
///////////////////////////////////////////////////////////////////////////////////////////////
// Preference Name Strings
///////////////////////////////////////////////////////////////////////////////////////////////
const QString STR_GEN_Profile="Profile";
const QString STR_GEN_SkipLogin="SkipLoginScreen";
@ -81,18 +73,154 @@ const QString STR_MACH_MSeries="MSeries";
const QString STR_MACH_CMS50="CMS50";
const QString STR_MACH_ZEO="Zeo";
const QString STR_TR_BMI=QObject::tr("BMI");
const QString STR_PREF_VersionString="VersionString";
///////////////////////////////////////////////////////////////////////////////////////////////
// Commonly used translatable text strings
///////////////////////////////////////////////////////////////////////////////////////////////
const QString STR_UNIT_CM=QObject::tr("cm");
const QString STR_UNIT_INCH=QObject::tr("\"");
const QString STR_UNIT_FOOT=QObject::tr("ft");
const QString STR_UNIT_POUND=QObject::tr("lb");
const QString STR_UNIT_OUNCE=QObject::tr("oz");
const QString STR_UNIT_KG=QObject::tr("Kg");
const QString STR_UNIT_CMH2O=QObject::tr("cmH2O");
const QString STR_UNIT_Hours=QObject::tr("Hours");
const QString STR_UNIT_BPM=QObject::tr("bpm"); // Beats per Minute
const QString STR_UNIT_LPM=QObject::tr("L/m"); // Litres per Minute
const QString STR_MESSAGE_ERROR=QObject::tr("Error");
const QString STR_MESSAGE_WARNING=QObject::tr("Warning");
const QString STR_TR_BMI=QObject::tr("BMI"); // Short form of Body Mass Index
const QString STR_TR_Weight=QObject::tr("Weight");
const QString STR_TR_PulseRate=QObject::tr("Pulse Rate");
const QString STR_TR_Zombie=QObject::tr("Zombie");
const QString STR_TR_PulseRate=QObject::tr("Pulse Rate"); // Pulse / Heart rate
const QString STR_TR_SpO2=QObject::tr("SpO2");
const QString STR_TR_Plethy=QObject::tr("Plethy");
const QString STR_TR_FlowRate=QObject::tr("Flow Rate");
const QString STR_TR_Plethy=QObject::tr("Plethy"); // Plethysomogram
const QString STR_TR_Pressure=QObject::tr("Pressure");
const QString STR_TR_Daily=QObject::tr("Daily");
const QString STR_TR_Overview=QObject::tr("Overview");
const QString STR_TR_Oximetry=QObject::tr("Oximetry");
const QString STR_TR_Oximeter=QObject::tr("Oximeter");
const QString STR_TR_EventFlags=QObject::tr("Event Flags");
// Machine type names.
const QString STR_TR_CPAP=QObject::tr("CPAP"); // Constant Positive Airway Pressure
const QString STR_TR_BIPAP=QObject::tr("BiPAP"); // Bi-Level Positive Airway Pressure
const QString STR_TR_BiLevel=QObject::tr("Bi-Level"); // Another name for BiPAP
const QString STR_TR_EPAP=QObject::tr("EPAP"); // Expiratory Positive Airway Pressure
const QString STR_TR_IPAP=QObject::tr("IPAP"); // Inspiratory Positive Airway Pressure
const QString STR_TR_IPAPLo=QObject::tr("IPAPLo"); // Inspiratory Positive Airway Pressure, Low
const QString STR_TR_IPAPHi=QObject::tr("IPAPHi"); // Inspiratory Positive Airway Pressure, High
const QString STR_TR_APAP=QObject::tr("APAP"); // Automatic Positive Airway Pressure
const QString STR_TR_ASV=QObject::tr("ASV"); // Assisted Servo Ventilator
const QString STR_TR_STASV=QObject::tr("ST/ASV");
const QString STR_TR_Humidifier=QObject::tr("Humidifier");
const QString STR_TR_H=QObject::tr("H"); // Short form of Hypopnea
const QString STR_TR_OA=QObject::tr("OA"); // Short form of Obstructive Apnea
const QString STR_TR_UA=QObject::tr("A"); // Short form of Unspecified Apnea
const QString STR_TR_CA=QObject::tr("CA"); // Short form of Clear Airway Apnea
const QString STR_TR_FL=QObject::tr("FL"); // Short form of Flow Limitation
const QString STR_TR_LE=QObject::tr("LE"); // Short form of Leak Event
const QString STR_TR_EP=QObject::tr("EP"); // Short form of Expiratory Puff
const QString STR_TR_VS=QObject::tr("VS"); // Short form of Vibratory Snore
const QString STR_TR_VS2=QObject::tr("VS2"); // Short form of Secondary Vibratory Snore (Some Philips Respironics Machines have two sources)
const QString STR_TR_RERA=QObject::tr("RERA"); // Acronym for Respiratory Effort Related Arousal
const QString STR_TR_PP=QObject::tr("PP"); // Short form for Pressure Pulse
const QString STR_TR_RE=QObject::tr("RE"); // Short form of Respiratory Effort Related Arousal
const QString STR_TR_NRI=QObject::tr("NRI"); // Sorry I Forgot.. it's a flag on Intellipap machines
const QString STR_TR_O2=QObject::tr("O2"); // SpO2 Desaturation
const QString STR_TR_PC=QObject::tr("PC"); // Short form for Pulse Change
const QString STR_TR_PS=QObject::tr("PS"); // Short form of Pressure Support
const QString STR_TR_AHI=QObject::tr("AHI"); // Short form of Apnea Hypopnea Index
const QString STR_TR_RDI=QObject::tr("RDI"); // Short form of Respiratory Distress Index
const QString STR_TR_AI=QObject::tr("AI"); // Short form of Apnea Index
const QString STR_TR_HI=QObject::tr("HI"); // Short form of Hypopnea Index
const QString STR_TR_UAI=QObject::tr("UAI"); // Short form of Uncatagorized Apnea Index
const QString STR_TR_CAI=QObject::tr("CAI"); // Short form of Clear Airway Index
const QString STR_TR_FLI=QObject::tr("FLI"); // Short form of Flow Limitation Index
const QString STR_TR_REI=QObject::tr("REI"); // Short form of RERA Index
const QString STR_TR_EPI=QObject::tr("EPI"); // Short form of Expiratory Puff Index
const QString STR_TR_CSR=QObject::tr("ÇSR"); // Short form of Cheyne Stokes Respiration
const QString STR_TR_PB=QObject::tr("PB"); // Short form of Periodic Breathing
// Graph Titles
const QString STR_TR_IE=QObject::tr("IE"); // Inspiratory Expiratory Ratio
const QString STR_TR_InspTime=QObject::tr("Insp. Time"); // Inspiratory Time
const QString STR_TR_ExpTime=QObject::tr("Exp. Time"); // Expiratory Time
const QString STR_TR_RespEvent=QObject::tr("Resp. Event"); // Respiratory Event
const QString STR_TR_FlowLimitation=QObject::tr("Flow Limitation");
const QString STR_TR_FlowLimit=QObject::tr("Flow Limit");
const QString STR_TR_PatTrigBreath=QObject::tr("Pat. Trig. Breath"); // Patient Triggered Breath
const QString STR_TR_TgtMinVent=QObject::tr("Tgt. Min. Vent"); // Target Minute Ventilation
const QString STR_TR_TargetVent=QObject::tr("Target Vent."); // Target Ventilation
const QString STR_TR_MinuteVent=QObject::tr("Minute Vent."); // Minute Ventilation
const QString STR_TR_TidalVolume=QObject::tr("Tidal Volume");
const QString STR_TR_RespRate=QObject::tr("Resp. Rate"); // Respiratory Rate
const QString STR_TR_Snore=QObject::tr("Snore");
const QString STR_TR_Leak=QObject::tr("Leak");
const QString STR_TR_Leaks=QObject::tr("Leaks");
const QString STR_TR_TotalLeaks=QObject::tr("Total Leaks");
const QString STR_TR_UnintentionalLeaks=QObject::tr("Unintentional Leaks");
const QString STR_TR_MaskPressure=QObject::tr("MaskPressure");
const QString STR_TR_FlowRate=QObject::tr("Flow Rate");
const QString STR_TR_SleepStage=QObject::tr("Sleep Stage");
const QString STR_TR_Usage=QObject::tr("Usage");
const QString STR_TR_Sessions=QObject::tr("Sessions");
const QString STR_TR_PrRelief=QObject::tr("Pr. Relief"); // Pressure Relief
const QString STR_TR_NoData=QObject::tr("No Data");
const QString STR_TR_Bookmarks=QObject::tr("Bookmarks");
const QString STR_TR_SleepyHead=QObject::tr("SleepyHead");
const QString STR_TR_SleepyHeadVersion=STR_TR_SleepyHead+" v"+VersionString;
const QString STR_TR_Mode=QObject::tr("Mode");
const QString STR_TR_Model=QObject::tr("Model");
const QString STR_TR_Brand=QObject::tr("Brand");
const QString STR_TR_Serial=QObject::tr("Serial");
const QString STR_TR_Machine=QObject::tr("Machine");
const QString STR_TR_Channel=QObject::tr("Channel");
const QString STR_TR_Settings=QObject::tr("Settings");
const QString STR_TR_Name=QObject::tr("Name");
const QString STR_TR_DOB=QObject::tr("DOB"); // Date of Birth
const QString STR_TR_Phone=QObject::tr("Phone");
const QString STR_TR_Address=QObject::tr("Address");
const QString STR_TR_Email=QObject::tr("Email");
const QString STR_TR_PatientID=QObject::tr("Patient ID");
const QString STR_TR_Date=QObject::tr("Date");
const QString STR_TR_BedTime=QObject::tr("Bedtime");
const QString STR_TR_WakeUp=QObject::tr("Wake-up");
const QString STR_TR_MaskTime=QObject::tr("Mask Time");
const QString STR_TR_Unknown=QObject::tr("Unknown");
const QString STR_TR_None=QObject::tr("None");
const QString STR_TR_First=QObject::tr("First");
const QString STR_TR_Last=QObject::tr("Last");
const QString STR_TR_Start=QObject::tr("Start");
const QString STR_TR_End=QObject::tr("End");
const QString STR_TR_On=QObject::tr("On");
const QString STR_TR_Off=QObject::tr("Off");
const QString STR_TR_Min=QObject::tr("Min"); // Minimum
const QString STR_TR_Max=QObject::tr("Max"); // Maximum
const QString STR_TR_Average=QObject::tr("Average");
const QString STR_TR_Median=QObject::tr("Median");
const QString STR_TR_Avg=QObject::tr("Avg"); // Average
const QString STR_TR_WAvg=QObject::tr("W-Avg"); // Weighted Average
#endif // COMMON_H

View File

@ -183,6 +183,10 @@ FORMS += \
exportcsv.ui \
UpdaterWindow.ui
TRANSLATIONS += \
Translations/sleepyhead_nl.ts \
Translations/sleepyhead_fr.ts
RESOURCES += \
Resources.qrc
@ -203,7 +207,11 @@ OTHER_FILES += \
docs/changelog.txt \
docs/update_notes.html
mac {
TransFiles.files = Translations
TransFiles.path = Contents/MacOS
QMAKE_BUNDLE_DATA += TransFiles
}

File diff suppressed because it is too large Load Diff

158
daily.cpp
View File

@ -91,29 +91,29 @@ Daily::Daily(QWidget *parent,gGraphView * shared)
int default_height=PROFILE.appearance->graphHeight();
SF=new gGraph(GraphView,STR_TR_EventFlags,STR_TR_EventFlags,default_height);
FRW=new gGraph(GraphView,tr("Flow Rate"),schema::channel[CPAP_FlowRate].description()+"\n("+schema::channel[CPAP_FlowRate].units()+")",default_height);
FRW=new gGraph(GraphView,STR_TR_FlowRate,schema::channel[CPAP_FlowRate].description()+"\n("+schema::channel[CPAP_FlowRate].units()+")",default_height);
if (PROFILE.general->calculateRDI()) {
AHI=new gGraph(GraphView,tr("RDI"),schema::channel[CPAP_RDI].description()+"\n("+schema::channel[CPAP_RDI].units()+")",default_height);
} else AHI=new gGraph(GraphView,tr("AHI"),schema::channel[CPAP_AHI].description()+"\n("+schema::channel[CPAP_AHI].units()+")",default_height);
AHI=new gGraph(GraphView,STR_TR_RDI,schema::channel[CPAP_RDI].description()+"\n("+schema::channel[CPAP_RDI].units()+")",default_height);
} else AHI=new gGraph(GraphView,STR_TR_AHI,schema::channel[CPAP_AHI].description()+"\n("+schema::channel[CPAP_AHI].units()+")",default_height);
MP=new gGraph(GraphView,tr("Mask Pressure"),schema::channel[CPAP_MaskPressure].description()+"\n("+schema::channel[CPAP_MaskPressure].units()+")",default_height);
PRD=new gGraph(GraphView,tr("Pressure"),schema::channel[CPAP_Pressure].description()+"\n("+schema::channel[CPAP_Pressure].units()+")",default_height);
LEAK=new gGraph(GraphView,tr("Leak"),schema::channel[CPAP_Leak].description()+"\n("+schema::channel[CPAP_Leak].units()+")",default_height);
SNORE=new gGraph(GraphView,tr("Snore"),schema::channel[CPAP_Snore].description()+"\n("+schema::channel[CPAP_Snore].units()+")",default_height);
RR=new gGraph(GraphView,tr("Resp. Rate"),schema::channel[CPAP_RespRate].description()+"\n("+schema::channel[CPAP_RespRate].units()+")",default_height);
TV=new gGraph(GraphView,tr("Tidal Volume"),schema::channel[CPAP_TidalVolume].description()+"\n("+schema::channel[CPAP_TidalVolume].units()+")",default_height);
MV=new gGraph(GraphView,tr("Minute Vent."),schema::channel[CPAP_MinuteVent].description()+"\n("+schema::channel[CPAP_MinuteVent].units()+")",default_height);
//TgMV=new gGraph(GraphView,tr("Tgt. Min. Vent"),schema::channel[CPAP_TgMV].description()+"\n("+schema::channel[CPAP_TgMV].units()+")",default_height);
FLG=new gGraph(GraphView,tr("Flow Limitation"),schema::channel[CPAP_FLG].description()+"\n("+schema::channel[CPAP_FLG].units()+")",default_height);
PTB=new gGraph(GraphView,tr("Pat. Trig. Breath"),schema::channel[CPAP_PTB].description()+"\n("+schema::channel[CPAP_PTB].units()+")",default_height);
RE=new gGraph(GraphView,tr("Resp. Event"),schema::channel[CPAP_RespEvent].description()+"\n("+schema::channel[CPAP_RespEvent].units()+")",default_height);
TI=new gGraph(GraphView,tr("Insp. Time"),schema::channel[CPAP_Ti].description()+"\n("+schema::channel[CPAP_Ti].units()+")",default_height);
TE=new gGraph(GraphView,tr("Exp. Time"),schema::channel[CPAP_Te].description()+"\n("+schema::channel[CPAP_Te].units()+")",default_height);
IE=new gGraph(GraphView,tr("IE"),schema::channel[CPAP_IE].description()+"\n("+schema::channel[CPAP_IE].units()+")",default_height);
MP=new gGraph(GraphView,STR_TR_MaskPressure,schema::channel[CPAP_MaskPressure].description()+"\n("+schema::channel[CPAP_MaskPressure].units()+")",default_height);
PRD=new gGraph(GraphView,STR_TR_Pressure,schema::channel[CPAP_Pressure].description()+"\n("+schema::channel[CPAP_Pressure].units()+")",default_height);
LEAK=new gGraph(GraphView,STR_TR_Leak,schema::channel[CPAP_Leak].description()+"\n("+schema::channel[CPAP_Leak].units()+")",default_height);
SNORE=new gGraph(GraphView,STR_TR_Snore,schema::channel[CPAP_Snore].description()+"\n("+schema::channel[CPAP_Snore].units()+")",default_height);
RR=new gGraph(GraphView,STR_TR_RespRate,schema::channel[CPAP_RespRate].description()+"\n("+schema::channel[CPAP_RespRate].units()+")",default_height);
TV=new gGraph(GraphView,STR_TR_TidalVolume,schema::channel[CPAP_TidalVolume].description()+"\n("+schema::channel[CPAP_TidalVolume].units()+")",default_height);
MV=new gGraph(GraphView,STR_TR_MinuteVent,schema::channel[CPAP_MinuteVent].description()+"\n("+schema::channel[CPAP_MinuteVent].units()+")",default_height);
//TgMV=new gGraph(GraphView,STR_TR_TgtMinVent,schema::channel[CPAP_TgMV].description()+"\n("+schema::channel[CPAP_TgMV].units()+")",default_height);
FLG=new gGraph(GraphView,STR_TR_FlowLimitation,schema::channel[CPAP_FLG].description()+"\n("+schema::channel[CPAP_FLG].units()+")",default_height);
PTB=new gGraph(GraphView,STR_TR_PatTrigBreath,schema::channel[CPAP_PTB].description()+"\n("+schema::channel[CPAP_PTB].units()+")",default_height);
RE=new gGraph(GraphView,STR_TR_RespEvent,schema::channel[CPAP_RespEvent].description()+"\n("+schema::channel[CPAP_RespEvent].units()+")",default_height);
TI=new gGraph(GraphView,STR_TR_InspTime,schema::channel[CPAP_Ti].description()+"\n("+schema::channel[CPAP_Ti].units()+")",default_height);
TE=new gGraph(GraphView,STR_TR_ExpTime,schema::channel[CPAP_Te].description()+"\n("+schema::channel[CPAP_Te].units()+")",default_height);
IE=new gGraph(GraphView,STR_TR_IE,schema::channel[CPAP_IE].description()+"\n("+schema::channel[CPAP_IE].units()+")",default_height);
STAGE=new gGraph(GraphView,tr("Sleep Stage"),schema::channel[ZEO_SleepStage].description()+"\n("+schema::channel[ZEO_SleepStage].units()+")",default_height);
STAGE=new gGraph(GraphView,STR_TR_SleepStage,schema::channel[ZEO_SleepStage].description()+"\n("+schema::channel[ZEO_SleepStage].units()+")",default_height);
int oxigrp=PROFILE.ExistsAndTrue("SyncOximetry") ? 0 : 1;
PULSE=new gGraph(GraphView,STR_TR_PulseRate,schema::channel[OXI_Pulse].description()+"\n("+schema::channel[OXI_Pulse].units()+")",default_height,oxigrp);
SPO2=new gGraph(GraphView,STR_TR_SpO2,schema::channel[OXI_SPO2].description()+"\n("+schema::channel[OXI_SPO2].units()+")",default_height,oxigrp);
@ -145,18 +145,18 @@ Daily::Daily(QWidget *parent,gGraphView * shared)
gFlagsGroup *fg=new gFlagsGroup();
SF->AddLayer(AddCPAP(fg));
fg->AddLayer((new gFlagsLine(CPAP_CSR,QColor("light green"),tr("PB"),false,FT_Span)));
fg->AddLayer((new gFlagsLine(CPAP_ClearAirway,QColor("purple"),tr("CA"),false)));
fg->AddLayer((new gFlagsLine(CPAP_Obstructive,QColor("#40c0ff"),tr("OA"),true)));
fg->AddLayer((new gFlagsLine(CPAP_Apnea,QColor("dark green"),tr("A"))));
fg->AddLayer((new gFlagsLine(CPAP_Hypopnea,QColor("blue"),tr("H"),true)));
fg->AddLayer((new gFlagsLine(CPAP_ExP,QColor("dark cyan"),tr("E"),false)));
fg->AddLayer((new gFlagsLine(CPAP_LeakFlag,QColor("dark blue"),tr("L"),false)));
fg->AddLayer((new gFlagsLine(CPAP_NRI,QColor("dark magenta"),tr("NRI"),false)));
fg->AddLayer((new gFlagsLine(CPAP_FlowLimit,QColor("black"),tr("FL"))));
fg->AddLayer((new gFlagsLine(CPAP_RERA,QColor("gold"),tr("RE"))));
fg->AddLayer((new gFlagsLine(CPAP_VSnore,QColor("red"),tr("VS"))));
fg->AddLayer((new gFlagsLine(CPAP_VSnore2,QColor("red"),tr("VS2"))));
fg->AddLayer((new gFlagsLine(CPAP_CSR,QColor("light green"),STR_TR_PB,false,FT_Span)));
fg->AddLayer((new gFlagsLine(CPAP_ClearAirway,QColor("purple"),STR_TR_CA,false)));
fg->AddLayer((new gFlagsLine(CPAP_Obstructive,QColor("#40c0ff"),STR_TR_OA,true)));
fg->AddLayer((new gFlagsLine(CPAP_Apnea,QColor("dark green"),STR_TR_UA)));
fg->AddLayer((new gFlagsLine(CPAP_Hypopnea,QColor("blue"),STR_TR_H,true)));
fg->AddLayer((new gFlagsLine(CPAP_ExP,QColor("dark cyan"),STR_TR_EP,false)));
fg->AddLayer((new gFlagsLine(CPAP_LeakFlag,QColor("dark blue"),STR_TR_LE,false)));
fg->AddLayer((new gFlagsLine(CPAP_NRI,QColor("dark magenta"),STR_TR_NRI,false)));
fg->AddLayer((new gFlagsLine(CPAP_FlowLimit,QColor("black"),STR_TR_FL)));
fg->AddLayer((new gFlagsLine(CPAP_RERA,QColor("gold"),STR_TR_RE)));
fg->AddLayer((new gFlagsLine(CPAP_VSnore,QColor("red"),STR_TR_VS)));
fg->AddLayer((new gFlagsLine(CPAP_VSnore2,QColor("red"),STR_TR_VS2)));
if (PROFILE.cpap->userEventFlagging()) {
fg->AddLayer((new gFlagsLine(CPAP_UserFlag1,QColor("yellow"),tr("UF1"))));
fg->AddLayer((new gFlagsLine(CPAP_UserFlag2,QColor("green"),tr("UF2"))));
@ -175,33 +175,33 @@ Daily::Daily(QWidget *parent,gGraphView * shared)
gLineOverlaySummary *los=new gLineOverlaySummary(tr("Selection AHI"),5,-4);
AddCPAP(l);
FRW->AddLayer(new gXGrid());
FRW->AddLayer(AddCPAP(new gLineOverlayBar(CPAP_CSR,QColor("light green"),tr("CSR"),FT_Span)));
FRW->AddLayer(AddCPAP(new gLineOverlayBar(CPAP_CSR,QColor("light green"),STR_TR_CSR,FT_Span)));
FRW->AddLayer(l);
FRW->AddLayer(new gYAxis(),LayerLeft,gYAxis::Margin);
FRW->AddLayer(new gXAxis(),LayerBottom,0,20);
FRW->AddLayer(AddCPAP(los->add(new gLineOverlayBar(CPAP_Hypopnea,QColor("blue"),tr("H")))));
FRW->AddLayer(AddCPAP(new gLineOverlayBar(CPAP_PressurePulse,QColor("red"),tr("PR"),FT_Dot)));
FRW->AddLayer(AddCPAP(los->add(new gLineOverlayBar(CPAP_Hypopnea,QColor("blue"),STR_TR_H))));
FRW->AddLayer(AddCPAP(new gLineOverlayBar(CPAP_PressurePulse,QColor("red"),STR_TR_PP,FT_Dot)));
//FRW->AddLayer(AddCPAP(new gLineOverlayBar(CPAP_Pressure,QColor("white"),tr("P"),FT_Dot)));
FRW->AddLayer(AddCPAP(new gLineOverlayBar(PRS1_0B,QColor("blue"),"0B",FT_Dot)));
FRW->AddLayer(AddCPAP(new gLineOverlayBar(PRS1_10,QColor("orange"),"10",FT_Dot)));
FRW->AddLayer(AddCPAP(new gLineOverlayBar(PRS1_0E,QColor("dark red"),"0E",FT_Dot)));
if (PROFILE.general->calculateRDI())
FRW->AddLayer(AddCPAP(los->add(new gLineOverlayBar(CPAP_RERA,QColor("gold"),tr("RE")))));
FRW->AddLayer(AddCPAP(los->add(new gLineOverlayBar(CPAP_RERA,QColor("gold"),STR_TR_RE))));
else
FRW->AddLayer(AddCPAP(new gLineOverlayBar(CPAP_RERA,QColor("gold"),tr("RE"))));
FRW->AddLayer(AddCPAP(new gLineOverlayBar(CPAP_RERA,QColor("gold"),STR_TR_RE)));
FRW->AddLayer(AddCPAP(los->add(new gLineOverlayBar(CPAP_Apnea,QColor("dark green"),tr("A")))));
FRW->AddLayer(AddCPAP(los->add(new gLineOverlayBar(CPAP_Apnea,QColor("dark green"),STR_TR_UA))));
FRW->AddLayer(AddCPAP(new gLineOverlayBar(CPAP_VSnore,QColor("red"),tr("VS"))));
FRW->AddLayer(AddCPAP(new gLineOverlayBar(CPAP_FlowLimit,QColor("black"),tr("FL"))));
FRW->AddLayer(AddCPAP(los->add(new gLineOverlayBar(CPAP_Obstructive,QColor("#40c0ff"),tr("OA")))));
FRW->AddLayer(AddCPAP(los->add(new gLineOverlayBar(CPAP_ClearAirway,QColor("purple"),tr("CA")))));
FRW->AddLayer(AddCPAP(los->add(new gLineOverlayBar(CPAP_Obstructive,QColor("#40c0ff"),STR_TR_OA))));
FRW->AddLayer(AddCPAP(los->add(new gLineOverlayBar(CPAP_ClearAirway,QColor("purple"),STR_TR_CA))));
if (PROFILE.cpap->userEventFlagging()) {
FRW->AddLayer(AddCPAP(new gLineOverlayBar(CPAP_UserFlag1,QColor("yellow"),tr("U1"),FT_Bar)));
FRW->AddLayer(AddCPAP(new gLineOverlayBar(CPAP_UserFlag2,QColor("orange"),tr("U2"),FT_Bar)));
FRW->AddLayer(AddCPAP(new gLineOverlayBar(CPAP_UserFlag3,QColor("brown"),tr("U3"),FT_Bar)));
}
FRW->AddLayer(AddOXI(new gLineOverlayBar(OXI_SPO2Drop,QColor("red"),tr("O2"))));
//FRW->AddLayer(AddOXI(new gLineOverlayBar(OXI_PulseChange,QColor("blue"),tr("PC"),FT_Dot)));
FRW->AddLayer(AddOXI(new gLineOverlayBar(OXI_SPO2Drop,QColor("red"),STR_TR_O2)));
//FRW->AddLayer(AddOXI(new gLineOverlayBar(OXI_PulseChange,QColor("blue"),STR_TR_PC,FT_Dot)));
FRW->AddLayer(AddCPAP(los));
@ -278,9 +278,9 @@ Daily::Daily(QWidget *parent,gGraphView * shared)
gLineOverlaySummary *los1=new gLineOverlaySummary(tr("Events/hour"),5,-4);
gLineOverlaySummary *los2=new gLineOverlaySummary(tr("Events/hour"),5,-4);
PULSE->AddLayer(AddOXI(los1->add(new gLineOverlayBar(OXI_PulseChange,QColor("light gray"),tr("PD"),FT_Span))));
PULSE->AddLayer(AddOXI(los1->add(new gLineOverlayBar(OXI_PulseChange,QColor("light gray"),STR_TR_PC,FT_Span))));
PULSE->AddLayer(AddOXI(los1));
SPO2->AddLayer(AddOXI(los2->add(new gLineOverlayBar(OXI_SPO2Drop,QColor("light blue"),tr("O2"),FT_Span))));
SPO2->AddLayer(AddOXI(los2->add(new gLineOverlayBar(OXI_SPO2Drop,QColor("light blue"),STR_TR_O2,FT_Span))));
SPO2->AddLayer(AddOXI(los2));
PULSE->AddLayer(AddOXI(new gLineChart(OXI_Pulse,Qt::red,square)));
@ -333,7 +333,7 @@ Daily::Daily(QWidget *parent,gGraphView * shared)
ui->weightSpinBox->setSuffix(STR_UNIT_KG);
}
GraphView->setCubeImage(images["nodata"]);
GraphView->setEmptyText(tr("No Data"));
GraphView->setEmptyText(STR_TR_NoData);
previous_date=QDate();
}
@ -774,16 +774,16 @@ void Daily::Load(QDate date)
if (mode==MODE_CPAP) {
EventDataType min=round(cpap->settings_wavg(CPAP_Pressure)*2)/2.0;
html+=tr("CPAP")+" "+QString::number(min)+STR_UNIT_CMH2O;
html+=STR_TR_CPAP+" "+QString::number(min)+STR_UNIT_CMH2O;
} else if (mode==MODE_APAP) {
EventDataType min=cpap->settings_min(CPAP_PressureMin);
EventDataType max=cpap->settings_max(CPAP_PressureMax);
html+=tr("APAP")+" "+QString::number(min)+"-"+QString::number(max)+STR_UNIT_CMH2O;
html+=STR_TR_APAP+" "+QString::number(min)+"-"+QString::number(max)+STR_UNIT_CMH2O;
} else if (mode==MODE_BIPAP) {
EventDataType epap=cpap->settings_min(CPAP_EPAP);
EventDataType ipap=cpap->settings_max(CPAP_IPAP);
EventDataType ps=cpap->settings_max(CPAP_PS);
html+=tr("Bi-Level")+QString("<br/>EPAP: %1 IPAP: %2 %3<br/> PS: %4")
html+=STR_TR_BiLevel+QString("<br/>"+STR_TR_EPAP+": %1 "+STR_TR_IPAP+": %2 %3<br/> "+STR_TR_PS+": %4")
.arg(epap,0,'f',1).arg(ipap,0,'f',1).arg(STR_UNIT_CMH2O).arg(ps,0,'f',1);
}
else if (mode==MODE_ASV) {
@ -792,7 +792,7 @@ void Daily::Load(QDate date)
EventDataType high=cpap->settings_max(CPAP_IPAPHi);
EventDataType psl=cpap->settings_min(CPAP_PSMin);
EventDataType psh=cpap->settings_max(CPAP_PSMax);
html+=tr("ASV")+QString("<br/>EPAP: %1 IPAP: %2 - %3 %4<br/> PS: %5 / %6")
html+=tr("ASV")+QString("<br/>"+STR_TR_EPAP+": %1 "+STR_TR_IPAP+": %2 - %3 %4<br/> "+STR_TR_PS+": %5 / %6")
.arg(epap,0,'f',1)
.arg(low,0,'f',1)
.arg(high,0,'f',1)
@ -800,12 +800,12 @@ void Daily::Load(QDate date)
.arg(psl,0,'f',1)
.arg(psh,0,'f',1);
}
else html+=tr("Unknown");
else html+=STR_TR_Unknown;
html+="</td></tr>\n";
if (hours>0) {
html+="<tr><td align='center'><b>"+tr("Date")+"</b></td><td align='center'><b>"+tr("Sleep")+"</b></td><td align='center'><b>"+tr("Wake")+"</b></td><td align='center'><b>"+STR_UNIT_Hours+"</b></td></tr>";
html+="<tr><td align='center'><b>"+STR_TR_Date+"</b></td><td align='center'><b>"+tr("Sleep")+"</b></td><td align='center'><b>"+tr("Wake")+"</b></td><td align='center'><b>"+STR_UNIT_Hours+"</b></td></tr>";
int tt=qint64(cpap->total_time())/1000L;
QDateTime date=QDateTime::fromTime_t(cpap->first()/1000L);
QDateTime date2=QDateTime::fromTime_t(cpap->last()/1000L);
@ -826,10 +826,10 @@ void Daily::Load(QDate date)
if (!isBrick && hours>0) {
if (PROFILE.general->calculateRDI()) {
html+=QString("<tr><td bgcolor='%1' align=center colspan=4><font size=+2 color='%2'><a class=info2 href='#'><font size=+2><b>%3</b></font><span>%4</span></a> <b>%5</b></font></td></tr>\n")
.arg("#F88017").arg("black").arg(tr("RDI")).arg(schema::channel[CPAP_RDI].description()).arg(ahi,0,'f',2);
.arg("#F88017").arg("black").arg(STR_TR_RDI).arg(schema::channel[CPAP_RDI].description()).arg(ahi,0,'f',2);
} else {
html+=QString("<tr><td bgcolor='%1' align=center colspan=4><font size=+2 color='%2'><a class=info2 href='#'><font size=+2><b>%3</b></font><span>%4</span></a> <b>%5</b></font></td></tr>\n")
.arg("#F88017").arg("black").arg(tr("AHI")).arg(schema::channel[CPAP_AHI].description()).arg(ahi,0,'f',2);
.arg("#F88017").arg("black").arg(STR_TR_AHI).arg(schema::channel[CPAP_AHI].description()).arg(ahi,0,'f',2);
}
if (cpap->machine->GetClass()==STR_MACH_ResMed || cpap->machine->GetClass()==STR_MACH_FPIcon) {
@ -857,7 +857,7 @@ void Daily::Load(QDate date)
if (cpap->machine->GetClass()==STR_MACH_Intellipap) {
html+=QString("<tr><td align='left' bgcolor='%1'><b><font color='%2'><a class=info href='event=%6'>%3<span>%4</span></a></font></b></td><td width=20% bgcolor='%1'><b><font color='%2'>%5%</font></b></td></tr>\n")
.arg(schema::channel[CPAP_NRI].defaultColor().name()).arg("black").arg(tr("NRI")).arg(schema::channel[CPAP_NRI].description()).arg(nri,0,'f',2).arg(CPAP_NRI);
.arg(schema::channel[CPAP_NRI].defaultColor().name()).arg("black").arg(STR_TR_NRI).arg(schema::channel[CPAP_NRI].description()).arg(nri,0,'f',2).arg(CPAP_NRI);
}
if (PROFILE.cpap->userEventFlagging()) {
EventDataType uf1=cpap->count(CPAP_UserFlag1) / cpap->hours();
@ -874,7 +874,7 @@ void Daily::Load(QDate date)
if (cpap->machine->GetClass()==STR_MACH_PRS1) {
html+="<td colspan=2 valign=top><table cellspacing=0 cellpadding=1 border=0 width='100%'>";
html+=QString("<tr><td align='left' bgcolor='%1'><b><font color='%2'><a class=info2 href='event=%6'>%3<span>%4</span></a></font></b></td><td width=20% bgcolor='%1'><b><font color='%2'>%5</font></b></td></tr>\n")
.arg("#ffff80").arg("black").arg(tr("RERA")).arg(schema::channel[CPAP_RERA].description()).arg(rei,0,'f',2).arg(CPAP_RERA);
.arg("#ffff80").arg("black").arg(STR_TR_RERA).arg(schema::channel[CPAP_RERA].description()).arg(rei,0,'f',2).arg(CPAP_RERA);
if (mode>MODE_CPAP) {
html+=QString("<tr><td align='left' bgcolor='%1'><b><font color='%2'><a class=info2 href='event=%6'>%3<span>%4</span></a></font></b></td><td width=20% bgcolor='%1'><b><font color='%2'>%5</font></b></td></tr>\n")
.arg("#404040").arg("white").arg(tr("Flow Limit")).arg(schema::channel[CPAP_FlowLimit].description()).arg(fli,0,'f',2).arg(CPAP_FlowLimit);
@ -893,7 +893,7 @@ void Daily::Load(QDate date)
} else if (cpap->machine->GetClass()==STR_MACH_Intellipap) {
html+="<td colspan=2 valign=top><table cellspacing=0 cellpadding=1 border=0 width='100%'>";
html+=QString("<tr><td align='left' bgcolor='%1'><b><font color='%2'><a class=info2 href='event=%6'>%3<span>%4</span></a></font></b></td><td width=20% bgcolor='%1'><b><font color='%2'>%5%</font></b></td></tr>\n")
.arg("#40c0c0").arg("black").arg(tr("Leak")).arg(schema::channel[CPAP_LeakFlag].description()).arg(lki,0,'f',2).arg(CPAP_LeakFlag);
.arg("#40c0c0").arg("black").arg(STR_TR_Leak).arg(schema::channel[CPAP_LeakFlag].description()).arg(lki,0,'f',2).arg(CPAP_LeakFlag);
html+=QString("<tr><td align='left' bgcolor='%1'><b><font color='%2'><a class=info2 href='event=%6'>%3<span>%4</span></a></font></b></td><td width=20% bgcolor='%1'><b><font color='%2'>%5</font></b></td></tr>\n")
.arg("#ff4040").arg("black").arg(tr("VSnore")).arg(schema::channel[CPAP_VSnore].description()).arg(cpap->count(CPAP_VSnore)/cpap->hours(),0,'f',2).arg(CPAP_VSnore);
@ -970,11 +970,11 @@ void Daily::Load(QDate date)
html+=QString("<tr><td colspan=5 align=center><b>%1</b></td></tr>\n").arg(tr("Statistics"));
html+="<tr height='2'><td colspan=5><hr></td></tr>\n";
html+=QString("<tr><td><b>%1</b></td><td><b>%2</b></td><td><b>%3</b></td><td><b>%4</b></td><td><b>%5</b></td></tr>")
.arg(tr("Channel"))
.arg(tr("Min"))
.arg(STR_TR_Channel)
.arg(STR_TR_Min)
.arg(midname)
.arg(tr("%1%").arg(percentile*100,0,'f',0))
.arg(tr("Max"));
.arg(STR_TR_Max);
ChannelID chans[]={
CPAP_Pressure,CPAP_EPAP,CPAP_IPAP,CPAP_PS,CPAP_PTB,
CPAP_MinuteVent, CPAP_RespRate, CPAP_RespEvent,CPAP_FLG,
@ -1005,24 +1005,24 @@ void Daily::Load(QDate date)
med=cpap->percentile(code,0.5);
tmp=cpap->wavg(code);
if (tmp>0 || mx==0) {
tooltip+=QString("<br/>W-Avg: %1").arg(tmp,0,'f',2);
tooltip+=QString("<br/>"+STR_TR_WAvg+": %1").arg(tmp,0,'f',2);
}
} else if (ST_mid==ST_WAVG) {
med=cpap->wavg(code);
tmp=cpap->percentile(code,0.5);
if (tmp>0 || mx==0) {
tooltip+=QString("<br/>Median: %1").arg(tmp,0,'f',2);
tooltip+=QString("<br/>"+STR_TR_Median+": %1").arg(tmp,0,'f',2);
}
} else if (ST_mid==ST_AVG) {
med=cpap->avg(code);
tmp=cpap->percentile(code,0.5);
if (tmp>0 || mx==0) {
tooltip+=QString("<br/>Median: %1").arg(tmp,0,'f',2);
tooltip+=QString("<br/>"+STR_TR_Median+": %1").arg(tmp,0,'f',2);
}
}
html+=QString("<tr><td align=left class='info' onmouseover=\"style.color='blue';\" onmouseout=\"style.color='black';\">%1<span>%6</span></td><td>%2</td><td>%3</td><td>%4</td><td>%5</td></tr>")
//.arg(QString("<a class='info' href='graph=%1'>%3<span>%2</span></a>") //<a class='tooltip' href='#'>"+tr("RDI")+"<span class='classic'>"+
//.arg(QString("<a class='info' href='graph=%1'>%3<span>%2</span></a>") //<a class='tooltip' href='#'>"+STR_TR_RDI+"<span class='classic'>"+
//.arg(QString::number(code)).arg(tooltip).arg(schema::channel[code].label()))
.arg(schema::channel[code].label())
.arg(mn,0,'f',2)
@ -1045,19 +1045,19 @@ void Daily::Load(QDate date)
med=oxi->percentile(code,0.5);
tmp=oxi->wavg(code);
if (tmp>0 || mx==0) {
tooltip+=QString("<br/>W-Avg: %1").arg(tmp,0,'f',2);
tooltip+=QString("<br/>"+STR_TR_WAvg+": %1").arg(tmp,0,'f',2);
}
} else if (ST_mid==ST_WAVG) {
med=oxi->wavg(code);
tmp=oxi->percentile(code,0.5);
if (tmp>0 || mx==0) {
tooltip+=QString("<br/>Median: %1").arg(tmp,0,'f',2);
tooltip+=QString("<br/>"+STR_TR_Median+": %1").arg(tmp,0,'f',2);
}
} else if (ST_mid==ST_AVG) {
med=oxi->avg(code);
tmp=oxi->percentile(code,0.5);
if (tmp>0 || mx==0) {
tooltip+=QString("<br/>Median: %1").arg(tmp,0,'f',2);
tooltip+=QString("<br/>"+STR_TR_Median+": %1").arg(tmp,0,'f',2);
}
}
@ -1105,16 +1105,15 @@ void Daily::Load(QDate date)
html+="<tr><td colspan=5><hr height=2></td></tr>";
int i=cpap->settings_max(CPAP_PresReliefType);
int j=cpap->settings_max(CPAP_PresReliefSet);
QString flexstr=(i>1) ? schema::channel[CPAP_PresReliefType].option(i)+" x"+QString::number(j) : "None";
QString flexstr=(i>1) ? schema::channel[CPAP_PresReliefType].option(i)+" x"+QString::number(j) : STR_TR_None;
html+=QString("<tr><td><a class='info' href='#'>%1<span>%2</span></a></td><td colspan=4>%3</td></tr>")
.arg(tr("Pr. Relief"))
.arg(STR_TR_PrRelief)
.arg(schema::channel[CPAP_PresReliefType].description())
.arg(flexstr);
QString mclass=cpap->machine->GetClass();
if (mclass==STR_MACH_PRS1 || mclass==STR_MACH_FPIcon) {
int humid=round(cpap->settings_wavg(CPAP_HumidSetting));
html+=QString("<tr><td><a class='info' href='#'>%1<span>%2</span></a></td><td colspan=4>%3</td></tr>")
.arg(tr("Humidifier"))
html+=QString("<tr><td><a class='info' href='#'>"+STR_TR_Humidifier+"<span>%1</span></a></td><td colspan=4>%2</td></tr>")
.arg(schema::channel[CPAP_HumidSetting].description())
.arg(humid==0 ? STR_GEN_Off : "x"+QString::number(humid));
}
@ -1125,19 +1124,14 @@ void Daily::Load(QDate date)
if (cpap || oxi) {
html+="<table cellpadding=0 cellspacing=0 border=0 width=100%>";
html+="<tr><td colspan=5 align=center>&nbsp;</td></tr>";
html+=QString("<tr><td colspan=4 align=center><b>%1</b></td></tr>").arg(tr("Session Information"));
html+=QString("<tr><td colspan=4 align=center><b>"+tr("Session Information")+"</b></td></tr>");
html+="<tr><td colspan=5><hr/></td></tr>";
QDateTime fd,ld;
bool corrupted_waveform=false;
QString tooltip;
html+=QString("<tr><td align=left><b>%1</b></td><td><b>%2</b></td><td align=center><b>%3</b></td><td align=center><b>%4</b></td><td align=center><b>%5</b></td></tr>")
.arg(tr("SessionID"))
.arg(tr("On"))
.arg(tr("Date"))
.arg(tr("Start"))
.arg(tr("End"));
html+=QString("<tr><td align=left><b>"+tr("SessionID")+"</b></td><td><b>"+STR_TR_On+"</b></td><td align=center><b>"+STR_TR_Date+"</b></td><td align=center><b>"+STR_TR_Start+"</b></td><td align=center><b>"+STR_TR_End+"</b></td></tr>");
if (cpap) {
html+=QString("<tr><td align=left colspan=5><i>%1</i></td></tr>").arg(tr("CPAP Sessions"));
html+=QString("<tr><td align=left colspan=5><i>"+tr("CPAP Sessions")+"</i></td></tr>");
for (QVector<Session *>::iterator s=cpap->begin();s!=cpap->end();s++) {
fd=QDateTime::fromTime_t((*s)->first()/1000L);
ld=QDateTime::fromTime_t((*s)->last()/1000L);
@ -1145,7 +1139,7 @@ void Daily::Load(QDate date)
int h=len/3600;
int m=(len/60) % 60;
int s1=len % 60;
tooltip=cpap->machine->GetClass()+"&nbsp;"+tr("CPAP")+"&nbsp;"+QString().sprintf("%2ih,&nbsp;%2im,&nbsp;%2is",h,m,s1);
tooltip=cpap->machine->GetClass()+"&nbsp;"+STR_TR_CPAP+"&nbsp;"+QString().sprintf("%2ih,&nbsp;%2im,&nbsp;%2is",h,m,s1);
// tooltip needs to lookup language.. :-/
QHash<ChannelID,QVariant>::iterator i=(*s)->settings.find(CPAP_BrokenWaveform);
@ -1167,7 +1161,7 @@ void Daily::Load(QDate date)
}
if (oxi) {
html+=QString("<tr><td align=left colspan=5><i>%1</i></td></tr>").arg(tr("Oximetry Sessions"));
html+=QString("<tr><td align=left colspan=5><i>"+tr("Oximetry Sessions")+"</i></td></tr>");
for (QVector<Session *>::iterator s=oxi->begin();s!=oxi->end();s++) {
fd=QDateTime::fromTime_t((*s)->first()/1000L);
ld=QDateTime::fromTime_t((*s)->last()/1000L);
@ -1175,7 +1169,7 @@ void Daily::Load(QDate date)
int h=len/3600;
int m=(len/60) % 60;
int s1=len % 60;
tooltip=oxi->machine->GetClass()+" "+tr("Oximeter")+" "+QString().sprintf("%2ih,&nbsp;%2im,&nbsp;%2is",h,m,s1);
tooltip=oxi->machine->GetClass()+" "+STR_TR_Oximeter+" "+QString().sprintf("%2ih,&nbsp;%2im,&nbsp;%2is",h,m,s1);
Session *sess=*s;
if (!sess->settings.contains(SESSION_ENABLED)) {
@ -1712,7 +1706,7 @@ void Daily::on_bookmarkTable_itemClicked(QTableWidgetItem *item)
et2=et3;
} else if (!day) return;
if ((et<st2) || (st>et2)) {
mainwin->Notify("This bookmarked is in a currently disabled area..");
mainwin->Notify(tr("This bookmarked is in a currently disabled area.."));
return;
}
@ -1730,7 +1724,7 @@ void Daily::on_addBookmarkButton_clicked()
QDateTime d=QDateTime::fromTime_t(st/1000L);
int row=ui->bookmarkTable->rowCount();
ui->bookmarkTable->insertRow(row);
QTableWidgetItem *tw=new QTableWidgetItem("Bookmark at "+d.time().toString("HH:mm:ss"));
QTableWidgetItem *tw=new QTableWidgetItem(tr("Bookmark at %1").arg(d.time().toString("HH:mm:ss")));
QTableWidgetItem *dw=new QTableWidgetItem(d.time().toString("HH:mm:ss"));
dw->setFlags(Qt::ItemIsSelectable|Qt::ItemIsEnabled);
ui->bookmarkTable->setItem(row,0,dw);
@ -1950,7 +1944,7 @@ void Daily::updateCube()
GraphView->setCubeImage(images["nographs"]);
} else {
GraphView->setEmptyText("No Data");
GraphView->setEmptyText(STR_TR_NoData);
GraphView->setCubeImage(images["nodata"]);
}
} else {

View File

@ -1,14 +1,26 @@
<html>
<body>
<h1><image src="qrc:/docs/sheep.png" width=64 height=64>SleepyHead v0.9.3 <b>BETA</b></h1>
<h1><image src="qrc:/docs/sheep.png" width=64 height=64>SleepyHead v0.9.4 <b>BETA</b></h1>
<p><h2><b>Release Notes</b></h2></p>
<p>Hi There!</p>
<p>Thanks for bearing with us this year - it has been a crazy year for some of us, and we're thankful for a few who have stepped up to help out. Anyone who wants to contribue to SleepyHead (whether with code, documentation, or just helping those with questions), please contact us or post one one of the lists/forums on our website.</p>
<b>New features & bugs fixes in this Update:</b></br>
<p>Greetings!</p>
<p>For a lot of you, this is a minor interim release mainly to bring the various platform builds in sync again and fix a couple of crashes.<br/>
To native Mac users this is a fairly large update because you missed out on the last one, if you weren't using the windows one in Parallels/etc.... (Thanks for being so patient!)</p>
<p>There is one caveat for this release on native Mac though, printing had to be disabled due to a change in MacOSX that broke something in the QT libraries which causes a consistent crash.
That bug is fixed in the next version of Qt, but something else broke there that's way worse.. Still waiting on upstream for a fix.
Hopefully next time I can switch it back on, but the feedback I've received indicates a lot of you would rather still have the software without it for now.<br/>
<p>Oximetry importing support has been improved, so now you should be able to import directly from your CMS50X oximeters without messing around with the windows software.<br/>
Please remember, for achieving the best sync, always start your oximeter at the same time as your CPAP machine!</br>
<p>I (Jedimark) am so very greatful for those who have stepped up to help out while I've been out of action.
Also like to thank</p>
<b>New features & bugs fixes in this Update:</b><br/>
<list>
<li>Improved Auto-Updater previously released in a test release.</li>
<li>Improved CMS50 Oximetry serial importing</li>
<li>Support for the PRS1 Series 60, in large part due to a patch from Keary Griffin.</li>
<li>A bunch of small PRS1 fixes, especially for the AutoSV.</li>
<li>Added Flow Limit to the summary and overview screens. This can be a useful indicator in certain types of apnea.</li>
@ -18,7 +30,9 @@
</list>
<p><b>Sleep Well, and have fun!</b></p>
<p>Mark Watkins (JediMark)<br/>
Richard Freeman (rich0)</p>
<p><b><i>The SleepyHead Team</i></b><br/>
Mark Watkins (JediMark)<br/>
Richard Freeman (rich0)<br/>
James Marshall (Breathe Jimbo)</p>
</body>
</html>

View File

@ -188,7 +188,7 @@ void ExportCSV::on_exportButton_clicked()
for (int i=0;i<countlist.size();i++)
header+=sep+schema::channel[countlist[i]].label()+tr(" Count");
for (int i=0;i<avglist.size();i++)
header+=sep+schema::channel[avglist[i]].label()+tr(" Avg");
header+=sep+schema::channel[avglist[i]].label()+" "+tr(" Avg");
for (int i=0;i<p90list.size();i++)
header+=sep+schema::channel[p90list[i]].label()+tr(" %1%").arg(percent,0,'f',0);
}

View File

@ -13,6 +13,8 @@
#include <QPushButton>
#include <QWebFrame>
#include <QWebView>
#include <QTranslator>
#include <QDir>
#include "SleepLib/schema.h"
#include "mainwindow.h"
@ -87,7 +89,7 @@ void initialize()
void release_notes()
{
QDialog relnotes;
relnotes.setWindowTitle(QObject::tr("SleepyHead Release Notes"));
relnotes.setWindowTitle(STR_TR_SleepyHead+" "+QObject::tr("Release Notes"));
QVBoxLayout layout(&relnotes);
QWebView web(&relnotes);
@ -109,10 +111,10 @@ void release_notes()
void build_notes()
{
QDialog relnotes;
relnotes.setWindowTitle(QObject::tr("SleepyHead Update Notes"));
relnotes.setWindowTitle(STR_TR_SleepyHead+" "+QObject::tr("SleepyHead Update Notes"));
QVBoxLayout layout(&relnotes);
QWebView web(&relnotes);
relnotes.setWindowTitle("SleepyHead v"+FullVersionString+" Update");
relnotes.setWindowTitle(STR_TR_SleepyHead+" v"+FullVersionString+QObject::tr(" Update"));
// Language???
web.load(QUrl("qrc:/docs/update_notes.html"));
@ -157,7 +159,27 @@ int main(int argc, char *argv[])
}
}
a.setApplicationName("SleepyHead");
QDir dir(QCoreApplication::applicationDirPath()+"/Translations/");
dir.setFilter(QDir::Files);
dir.setNameFilters(QStringList("*.qm"));
qDebug() << "Available Translations";
QFileInfoList list=dir.entryInfoList();
for (int i=0;i<list.size();++i) {
QFileInfo fi=list.at(i);
qDebug() << fi.fileName();
}
QTranslator translator;
//
//QString transfile="sleepyhead_nl";
//qDebug() << "Loading" << QCoreApplication::applicationDirPath()+"/Translations/"+transfile;
//translator.load(transfile,QCoreApplication::applicationDirPath()+"/Translations");
translator.load("sleepyhead_"+QLocale::system().name(),QCoreApplication::applicationDirPath()+"/Translations");
a.installTranslator(&translator);
a.setApplicationName(STR_TR_SleepyHead);
initialize();
@ -174,7 +196,7 @@ int main(int argc, char *argv[])
// Scan for user profiles
Profiles::Scan();
//qRegisterMetaType<Preference>("Preference");
PREF["AppName"]=QObject::tr("SleepyHead");
PREF["AppName"]=STR_TR_SleepyHead;
// Skip login screen, unless asked not to on the command line
@ -216,8 +238,8 @@ int main(int argc, char *argv[])
// Show New User wizard..
} else {
if (PREF.contains("VersionString")) {
QString V=PREF["VersionString"].toString();
if (PREF.contains(STR_PREF_VersionString)) {
QString V=PREF[STR_PREF_VersionString].toString();
if (FullVersionString>V) {
QString V2=V.section("-",0,0);
@ -245,7 +267,7 @@ int main(int argc, char *argv[])
}
}
}
PREF["VersionString"]=FullVersionString;
PREF[STR_PREF_VersionString]=FullVersionString;
p_profile=Profiles::Get(PREF[STR_GEN_Profile].toString());

View File

@ -25,11 +25,15 @@
#include <QProcess>
#include <QFontMetrics>
#include <QTextDocument>
#include <QTranslator>
#include <cmath>
// Custom loaders that don't autoscan..
#include <SleepLib/loader_plugins/zeo_loader.h>
#ifndef REMSTAR_M_SUPPORT
#include <SleepLib/loader_plugins/mseries_loader.h>
#endif
#include "mainwindow.h"
#include "ui_mainwindow.h"
@ -84,7 +88,7 @@ MainWindow::MainWindow(QWidget *parent) :
QString version=FullVersionString;
if (QString(GIT_BRANCH)!="master") version+=QString(" ")+QString(GIT_BRANCH);
this->setWindowTitle(tr("SleepyHead")+QString(" v%1 (Profile: %2)").arg(version).arg(PREF[STR_GEN_Profile].toString()));
this->setWindowTitle(tr("SleepyHead")+QString(" v%1 ("+tr("Profile")+": %2)").arg(version).arg(PREF[STR_GEN_Profile].toString()));
//ui->tabWidget->setCurrentIndex(1);
// Disable Screenshot on Mac Platform,as it doesn't work, and the system provides this functionality anyway.
@ -103,7 +107,7 @@ MainWindow::MainWindow(QWidget *parent) :
qstatusbar=ui->statusbar;
qprogress=new QProgressBar(this);
qprogress->setMaximum(100);
qstatus2=new QLabel("Welcome",this);
qstatus2=new QLabel(tr("Welcome"),this);
qstatus2->setFrameStyle(QFrame::Raised);
qstatus2->setFrameShadow(QFrame::Sunken);
qstatus2->setFrameShape(QFrame::Box);
@ -149,13 +153,13 @@ MainWindow::MainWindow(QWidget *parent) :
systray->show();
systraymenu=new QMenu(this);
systray->setContextMenu(systraymenu);
QAction *a=systraymenu->addAction("SleepyHead v"+VersionString);
QAction *a=systraymenu->addAction(STR_TR_SleepyHead+" v"+VersionString);
a->setEnabled(false);
systraymenu->addSeparator();
systraymenu->addAction("&About",this,SLOT(on_action_About_triggered()));
systraymenu->addAction("Check for &Updates",this,SLOT(on_actionCheck_for_Updates_triggered()));
systraymenu->addAction(tr("&About"),this,SLOT(on_action_About_triggered()));
systraymenu->addAction(tr("Check for &Updates"),this,SLOT(on_actionCheck_for_Updates_triggered()));
systraymenu->addSeparator();
systraymenu->addAction("E&xit",this,SLOT(close()));
systraymenu->addAction(tr("E&xit"),this,SLOT(close()));
} else { // if not available, the messages will popup in the taskbar
systray=NULL;
systraymenu=NULL;
@ -186,10 +190,13 @@ MainWindow::MainWindow(QWidget *parent) :
//"border-top-left-radius: 8px;"
//"border-top-right-radius: 8px;"
QString loadingtxt="<HTML><body style='text-align: center; vertical-align: center'><table width='100%' height='100%'><tr><td align=center><h1>Loading...</h1></td></tr></table></body></HTML>";
QString loadingtxt="<HTML><body style='text-align: center; vertical-align: center'><table width='100%' height='100%'><tr><td align=center><h1>"+tr("Loading...")+"</h1></td></tr></table></body></HTML>";
ui->summaryView->setHtml(loadingtxt);
on_tabWidget_currentChanged(0);
//ui->actionImport_RemStar_MSeries_Data->setVisible(false);
#ifndef REMSTAR_M_SUPPORT
ui->actionImport_RemStar_MSeries_Data->setVisible(false);
#endif
}
extern MainWindow *mainwin;
MainWindow::~MainWindow()
@ -280,7 +287,7 @@ void MainWindow::Startup()
void MainWindow::on_action_Import_Data_triggered()
{
if (m_inRecalculation) {
Notify("Access to Import has been blocked while recalculations are in progress.");
Notify(tr("Access to Import has been blocked while recalculations are in progress."));
return;
}
@ -311,7 +318,7 @@ void MainWindow::on_action_Import_Data_triggered()
if (importLocations.size()==0) {
asknew=true;
} else {
int res=QMessageBox::question(this,"Import from where?","Do you just want to Import from the usual (remembered) locations?\n","The Usual","New Location","Cancel",0,2);
int res=QMessageBox::question(this,tr("Import from where?"),tr("Do you just want to Import from the usual (remembered) locations?\n"),tr("The Usual"),tr("New Location"),tr("Cancel"),0,2);
if (res==1) {
asknew=true;
}
@ -380,7 +387,7 @@ void MainWindow::on_action_Import_Data_triggered()
if (overview) overview->ReloadGraphs();
on_summaryButton_clicked();
if (daily) daily->ReloadGraphs();
if ((goodlocations.size()>0) && (QMessageBox::question(this,"Remember this Location?","Would you like to remember this import location for next time?\n"+newdir,QMessageBox::Yes,QMessageBox::No)==QMessageBox::Yes)) {
if ((goodlocations.size()>0) && (QMessageBox::question(this,tr("Remember this Location?"),tr("Would you like to remember this import location for next time?")+"\n"+newdir,QMessageBox::Yes,QMessageBox::No)==QMessageBox::Yes)) {
for (int i=0;i<goodlocations.size();i++) {
importLocations.push_back(goodlocations[i]);
}
@ -433,7 +440,7 @@ QString htmlHeader()
"</head>"
"<body leftmargin=0 topmargin=0 rightmargin=0>"
"<div align=center><table cellpadding=3 cellspacing=0 border=0>"
"<tr><td><img src='qrc:/icons/bob-v3.0.png' width=140px height=140px><td valign=center align=center><h1>SleepyHead v"+VersionString+"</h1><i>This is a beta software and some functionality may not work as intended yet.<br/>Please report any bugs you find to SleepyHead's SourceForge page.</i></td></tr></table>"
"<tr><td><img src='qrc:/icons/bob-v3.0.png' width=140px height=140px><td valign=center align=center><h1>"+QObject::tr("SleepyHead")+" v"+VersionString+"</h1><i>"+QObject::tr("This is a beta software and some functionality may not work as intended yet.")+"<br/>"+QObject::tr("Please report any bugs you find to SleepyHead's SourceForge page.")+"</i></td></tr></table>"
"</div>"
"<hr/>");
}
@ -670,7 +677,7 @@ void MainWindow::on_summaryButton_clicked()
if (mach.size()==0) {
html+="<table cellpadding=2 cellspacing=0 border=0 width=100% height=60%>";
QString datacard;
html+="<tr><td align=center><h1>Please Import Some Data</h1><i>SleepyHead is pretty much useless without it.</i><br/><p>It might be a good idea to check preferences first,</br>as there are some options that affect import.</p><p>First import can take a few minutes.</p></td></tr></table>";
html+="<tr><td align=center><h1>"+tr("Please Import Some Data")+"</h1><i>"+tr("SleepyHead is pretty much useless without it.")+"</i><br/><p>"+tr("It might be a good idea to check preferences first,</br>as there are some options that affect import.")+"</p><p>"+tr("First import can take a few minutes.")+"</p></td></tr></table>";
html+=htmlFooter();
ui->summaryView->setHtml(html);
return;
@ -693,18 +700,18 @@ void MainWindow::on_summaryButton_clicked()
QString ahitxt;
if (PROFILE.general->calculateRDI()) {
ahitxt=tr("RDI");
ahitxt=STR_TR_RDI;
} else {
ahitxt=tr("AHI");
ahitxt=STR_TR_AHI;
}
int decimals=2;
html+="<div align=center>";
html+=QString("<table cellpadding=2 cellspacing=0 border=1 width=90%>");
if (cpapdays==0) {
html+="<tr><td colspan=6 align=center>No CPAP Machine Data Imported</td></tr>";
html+="<tr><td colspan=6 align=center>"+tr("No CPAP Machine Data Imported")+"</td></tr>";
} else {
html+=QString("<tr><td colspan=6 align=center><b>CPAP Statistics as of %1</b></td></tr>").arg(lastcpap.toString(Qt::SystemLocaleLongDate));
html+=QString("<tr><td colspan=6 align=center><b>")+tr("CPAP Statistics as of")+QString(" %1</b></td></tr>").arg(lastcpap.toString(Qt::SystemLocaleLongDate));
if (cpap_machines.size()>0) {
// html+=QString("<tr><td colspan=6 align=center><b>%1</b></td></tr>").arg(tr("CPAP Summary"));
@ -766,7 +773,7 @@ void MainWindow::on_summaryButton_clicked()
.arg(p_profile->calcMin(CPAP_EPAP,MT_CPAP,cpap6month,lastcpap),0,'f',decimals)
.arg(p_profile->calcMin(CPAP_EPAP,MT_CPAP,cpapyear,lastcpap),0,'f',decimals);
html+=QString("<tr><td>%1</td><td>%2</td><td>%3</td><td>%4</td><td>%5</td><td>%6</td></tr>")
.arg(tr("%1% EPAP").arg(percentile*100.0,0,'f',0))
.arg(QString("%1% "+STR_TR_EPAP).arg(percentile*100.0,0,'f',0))
.arg(p_profile->calcPercentile(CPAP_EPAP,percentile,MT_CPAP),0,'f',decimals)
.arg(p_profile->calcPercentile(CPAP_EPAP,percentile,MT_CPAP,cpapweek,lastcpap),0,'f',decimals)
.arg(p_profile->calcPercentile(CPAP_EPAP,percentile,MT_CPAP,cpapmonth,lastcpap),0,'f',decimals)
@ -780,7 +787,7 @@ void MainWindow::on_summaryButton_clicked()
.arg(p_profile->calcMax(CPAP_IPAP,MT_CPAP,cpap6month,lastcpap),0,'f',decimals)
.arg(p_profile->calcMax(CPAP_IPAP,MT_CPAP,cpapyear,lastcpap),0,'f',decimals);
html+=QString("<tr><td>%1</td><td>%2</td><td>%3</td><td>%4</td><td>%5</td><td>%6</td></tr>")
.arg(tr("%1% IPAP").arg(percentile*100.0,0,'f',0))
.arg(QString("%1% "+STR_TR_IPAP).arg(percentile*100.0,0,'f',0))
.arg(p_profile->calcPercentile(CPAP_IPAP,percentile,MT_CPAP),0,'f',decimals)
.arg(p_profile->calcPercentile(CPAP_IPAP,percentile,MT_CPAP,cpapweek,lastcpap),0,'f',decimals)
.arg(p_profile->calcPercentile(CPAP_IPAP,percentile,MT_CPAP,cpapmonth,lastcpap),0,'f',decimals)
@ -1117,34 +1124,34 @@ void MainWindow::on_summaryButton_clicked()
CPAPMode mode=(CPAPMode)(int)PROFILE.calcSettingsMax(CPAP_Mode,MT_CPAP,tmpRX[ls]->first,tmpRX[ls]->last);
if (mode<MODE_APAP) { // is CPAP?
minstr="Pressure";
minstr=STR_TR_Pressure;
maxstr="";
modestr=tr("CPAP");
modestr=STR_TR_CPAP;
} else if (mode<MODE_BIPAP) { // is AUTO?
minstr="Min";
maxstr="Max";
modestr=tr("APAP");
minstr=STR_TR_Min;
maxstr=STR_TR_Max;
modestr=STR_TR_APAP;
} else if (mode<MODE_ASV) { // BIPAP
minstr="EPAP";
maxstr="IPAP";
modestr=tr("Bi-Level");
minstr=STR_TR_EPAP;
maxstr=STR_TR_IPAP;
modestr=STR_TR_BiLevel;
} else {
minstr="EPAP";
maxstr="IPAPLo";
maxhistr="IPAPHi";
modestr=tr("ST/ASV");
minstr=STR_TR_EPAP;
maxstr=STR_TR_IPAPLo;
maxhistr=STR_TR_IPAPHi;
modestr=STR_TR_STASV;
}
recbox+=QString("<tr><td colspan=2><table width=100% border=0 cellpadding=1 cellspacing=0><tr><td colspan=2 align=center><b>%3</b></td></tr>")
.arg(tr("Best RX Setting"));
recbox+=QString("<tr><td valign=top>Start<br/>End</td><td align=right><a href='overview=%1,%2'>%3<br/>%4</a></td></tr>")
recbox+=QString("<tr><td valign=top>")+STR_TR_Start+"<br/>"+STR_TR_End+QString("</td><td align=right><a href='overview=%1,%2'>%3<br/>%4</a></td></tr>")
.arg(tmpRX[ls]->first.toString(Qt::ISODate))
.arg(tmpRX[ls]->last.toString(Qt::ISODate))
.arg(tmpRX[ls]->first.toString(Qt::SystemLocaleShortDate))
.arg(tmpRX[ls]->last.toString(Qt::SystemLocaleShortDate));
recbox+=QString("<tr><td><b>%1</b></td><td align=right><b>%2</b></td></tr>").arg(ahitxt).arg(tmpRX[ls]->ahi,0,'f',decimals);
recbox+=QString("<tr><td>%1</td><td align=right>%2</td></tr>").arg(tr("Mode")).arg(modestr);
recbox+=QString("<tr><td>%1</td><td align=right>%2</td></tr>").arg(STR_TR_Mode).arg(modestr);
recbox+=QString("<tr><td>%1</td><td align=right>%2%3</td></tr>").arg(minstr).arg(tmpRX[ls]->min,0,'f',1).arg(STR_UNIT_CMH2O);
if (!maxstr.isEmpty()) recbox+=QString("<tr><td>%1</td><td align=right>%2%3</td></tr>").arg(maxstr).arg(tmpRX[ls]->max,0,'f',1).arg(STR_UNIT_CMH2O);
if (!maxhistr.isEmpty()) recbox+=QString("<tr><td>%1</td><td align=right>%2%3</td></tr>").arg(maxhistr).arg(tmpRX[ls]->maxhi,0,'f',1).arg(STR_UNIT_CMH2O);
@ -1154,33 +1161,33 @@ void MainWindow::on_summaryButton_clicked()
mode=(CPAPMode)(int)PROFILE.calcSettingsMax(CPAP_Mode,MT_CPAP,tmpRX[0]->first,tmpRX[0]->last);
if (mode<MODE_APAP) { // is CPAP?
minstr="Pressure";
minstr=STR_TR_Pressure;
maxstr="";
modestr=tr("CPAP");
modestr=STR_TR_CPAP;
} else if (mode<MODE_BIPAP) { // is AUTO?
minstr="Min";
maxstr="Max";
modestr=tr("APAP");
minstr=STR_TR_Min;
maxstr=STR_TR_Max;
modestr=STR_TR_APAP;
} else if (mode<MODE_ASV) { // BIPAP or greater
minstr="EPAP";
maxstr="IPAP";
modestr=tr("Bi-Level");
minstr=STR_TR_EPAP;
maxstr=STR_TR_IPAP;
modestr=STR_TR_BiLevel;
} else {
minstr="EPAP";
maxstr="IPAPLo";
maxhistr="IPAPHi";
modestr=tr("ST/ASV");
minstr=STR_TR_EPAP;
maxstr=STR_TR_IPAPLo;
maxhistr=STR_TR_IPAPHi;
modestr=STR_TR_STASV;
}
recbox+=QString("<tr><td colspan=2><table width=100% border=0 cellpadding=1 cellspacing=0><tr><td colspan=2 align=center><b>%3</b></td></tr>")
.arg(tr("Worst RX Setting"));
recbox+=QString("<tr><td valign=top>Start<br/>End</td><td align=right><a href='overview=%1,%2'>%3<br/>%4</a></td></tr>")
recbox+=QString("<tr><td valign=top>")+STR_TR_Start+"<br/>"+STR_TR_End+QString("</td><td align=right><a href='overview=%1,%2'>%3<br/>%4</a></td></tr>")
.arg(tmpRX[0]->first.toString(Qt::ISODate))
.arg(tmpRX[0]->last.toString(Qt::ISODate))
.arg(tmpRX[0]->first.toString(Qt::SystemLocaleShortDate))
.arg(tmpRX[0]->last.toString(Qt::SystemLocaleShortDate));
recbox+=QString("<tr><td><b>%1</b></td><td align=right><b>%2</b></td></tr>").arg(ahitxt).arg(tmpRX[0]->ahi,0,'f',decimals);
recbox+=QString("<tr><td>%1</td><td align=right>%2</td></tr>").arg(tr("Mode")).arg(modestr);
recbox+=QString("<tr><td>%1</td><td align=right>%2</td></tr>").arg(STR_TR_Mode).arg(modestr);
recbox+=QString("<tr><td>%1</td><td align=right>%2%3</td></tr>").arg(minstr).arg(tmpRX[0]->min,0,'f',1).arg(STR_UNIT_CMH2O);
if (!maxstr.isEmpty()) recbox+=QString("<tr><td>%1</td><td align=right>%2%3</td></tr>").arg(maxstr).arg(tmpRX[0]->max,0,'f',1).arg(STR_UNIT_CMH2O);
if (!maxhistr.isEmpty()) recbox+=QString("<tr><td>%1</td><td align=right>%2%3</td></tr>").arg(maxhistr).arg(tmpRX[0]->maxhi,0,'f',1).arg(STR_UNIT_CMH2O);
@ -1195,32 +1202,32 @@ void MainWindow::on_summaryButton_clicked()
RXorder=true;
qSort(rxchange.begin(),rxchange.end());*/
html+="<div align=center>";
html+=QString("<br/><b>Changes to Prescription Settings</b>");
html+=QString("<br/><b>")+tr("Changes to Prescription Settings")+"</b>";
html+=QString("<table cellpadding=2 cellspacing=0 border=1 width=90%>");
QString extratxt;
if (cpapmode>=MODE_ASV) {
extratxt=QString("<td><b>%1</b></td><td><b>%2</b></td><td><b>%3</b></td><td><b>%4</b></td><td><b>%5</b></td>")
.arg(tr("EPAP")).arg(tr("IPAPLo")).arg(tr("IPAPHi")).arg(tr("PS Min")).arg(tr("PS Max"));
.arg(STR_TR_EPAP).arg(STR_TR_IPAPLo).arg(STR_TR_IPAPHi).arg(tr("PS Min")).arg(tr("PS Max"));
} else if (cpapmode>=MODE_BIPAP) {
extratxt=QString("<td><b>%1</b></td><td><b>%2</b></td><td><b>%3</b></td>")
.arg(tr("EPAP")).arg(tr("IPAP")).arg(tr("PS"));
.arg(STR_TR_EPAP).arg(STR_TR_IPAP).arg(STR_TR_PS);
} else if (cpapmode>MODE_CPAP) {
extratxt=QString("<td><b>%1</b></td><td><b>%2</b></td>")
.arg(tr("Min Pres.")).arg(tr("Max Pres."));
} else {
extratxt=QString("<td><b>%1</b></td>")
.arg(tr("Pressure"));
.arg(STR_TR_Pressure);
}
QString tooltip;
html+=QString("<tr><td><b>%1</b></td><td><b>%2</b></td><td><b>%3</b></td><td><b>%4</b></td><td><b>%5</b></td><td><b>%6</b></td><td><b>%7</td><td><b>%8</td>%9</tr>")
.arg(tr("First"))
.arg(tr("Last"))
.arg(STR_TR_First)
.arg(STR_TR_Last)
.arg(tr("Days"))
.arg(ahitxt)
.arg(tr("FL"))
.arg(tr("Machine"))
.arg(tr("Mode"))
.arg(STR_TR_Machine)
.arg(STR_TR_Mode)
.arg(tr("Pr. Rel."))
.arg(extratxt);
@ -1251,30 +1258,21 @@ void MainWindow::on_summaryButton_clicked()
extratxt=QString("<td>%1</td><td>%2</td><td>%3</td><td>%4</td>")
.arg(rx.max,0,'f',decimals).arg(rx.maxhi,0,'f',decimals).arg(rx.max-rx.min,0,'f',decimals).arg(rx.maxhi-rx.min,0,'f',decimals);
tooltip=tr("%5 %1% EPAP=%2<br/>%3% IPAP=%4")
.arg(percentile*100.0)
.arg(rx.per1,0,'f',decimals)
.arg(percentile*100.0)
.arg(rx.per2,0,'f',decimals)
.arg(machstr)
;
tooltip=QString("%1 %2% ").arg(machstr).arg(percentile*100.0)+STR_TR_EPAP+
QString("=%1<br/>%2% ").arg(rx.per1,0,'f',decimals).arg(percentile*100.0)+
STR_TR_IPAP+QString("=%1").arg(rx.per2,0,'f',decimals);
} else if (mode>=MODE_BIPAP) {
extratxt=QString("<td>%1</td><td>%2</td>")
.arg(rx.max,0,'f',decimals).arg(rx.max-rx.min,0,'f',decimals);
tooltip=tr("%5 %1% EPAP=%2<br/>%3% IPAP=%4")
tooltip=QString("%1 %2% ").arg(machstr).arg(percentile*100.0)+
STR_TR_EPAP+
QString("=%1<br/>%2% ").arg(rx.per1,0,'f',decimals)
.arg(percentile*100.0)
.arg(rx.per1,0,'f',decimals)
.arg(percentile*100.0)
.arg(rx.per2,0,'f',decimals)
.arg(machstr)
;
+STR_TR_IPAP+QString("=%1").arg(rx.per2,0,'f',decimals);
} else if (mode>MODE_CPAP) {
extratxt=QString("<td>%1</td>").arg(rx.max,0,'f',decimals);
tooltip=tr("%3 %1% Pressure=%2")
.arg(percentile*100.0)
.arg(rx.per1,0,'f',decimals)
.arg(machstr)
;
tooltip=QString("%1 %2% ").arg(machstr).arg(percentile*100.0)+STR_TR_Pressure+
QString("=%2").arg(rx.per1,0,'f',decimals);
} else {
if (cpapmode>MODE_CPAP) {
extratxt="<td>&nbsp;</td>";
@ -1288,7 +1286,7 @@ void MainWindow::on_summaryButton_clicked()
if (rx.prelset>0) {
presrel=schema::channel[CPAP_PresReliefType].option(int(rx.prelief));
presrel+=QString(" x%1").arg(rx.prelset);
} else presrel="None";
} else presrel=STR_TR_None;
QString tooltipshow,tooltiphide;
if (!tooltip.isEmpty()) {
tooltipshow=QString("tooltip.show(\"%1\");").arg(tooltip);
@ -1311,19 +1309,19 @@ void MainWindow::on_summaryButton_clicked()
.arg(tooltiphide);
}
html+="</table>";
html+=QString("<i>The above has a threshold which excludes day counts less than %1 from the best/worst highlighting</i><br/>").arg(rxthresh);
html+=QString("<i>")+tr("The above has a threshold which excludes day counts less than %1 from the best/worst highlighting").arg(rxthresh)+QString("</i><br/>");
html+="</div>";
}
if (mach.size()>0) {
html+="<div align=center>";
html+=QString("<br/><b>Machine Information</b>");
html+=QString("<br/><b>")+tr("Machine Information")+"</b>";
html+=QString("<table cellpadding=2 cellspacing=0 border=1 width=90%>");
html+=QString("<tr><td><b>%1</b></td><td><b>%2</b></td><td><b>%3</b></td><td><b>%4</b></td><td><b>%5</b></td></tr>")
.arg(tr("Brand"))
.arg(tr("Model"))
.arg(tr("Serial"))
.arg(STR_TR_Brand)
.arg(STR_TR_Model)
.arg(STR_TR_Serial)
.arg(tr("First Use"))
.arg(tr("Last Use"));
Machine *m;
@ -1499,24 +1497,24 @@ void MainWindow::on_action_About_triggered()
QString msg=QString(
"<span style=\"color:#000000; font-weight:600; vertical-align:middle;\">"
"<table width=100%><tr><td>"
"<p><h1>SleepyHead v%1.%2.%3-%4 (%8)</h1></p><font color=black><p>Build Date: %5 %6<br/>%7<br/>Data Folder: %9<hr>"
"Copyright &copy;2012 Mark Watkins (jedimark) <br> \n"
"This software is released under the GNU Public License v3.0<br>"
"<hr><p>SleepyHead Project Page: <a href=\"http://sourceforge.net/projects/sleepyhead\">http://sourceforge.net/projects/sleepyhead</a><br/>"
"SleepyHead Wiki: <a href=\"http://sleepyhead.sourceforge.net\">http://sleepyhead.sourceforge.net</a><br/>"
"Authors Twitter Feed: <a href=\"http://twitter.com/jedimark64\">http://twitter.com/jedimark64</a></p>"
"</td><td><img src=\"qrc:/icons/Bob Strikes Back.png\" width=150px height=150px></td></tr><tr colspan><td colspan=2>"
"<p>The author wishes to express thanks to James Marshall and Rich Freeman for their assistance with this project.</p>"
"<hr><p><i>This software comes with absolutely no warranty, either express of implied. It comes with no guarantee of fitness for any particular purpose. No guarantees are made regarding the accuracy of any data this program displays.</i></p>"
"<p><i>This is NOT medical software, it is merely a research tool that provides a visual interpretation of data recorded by supported devices. This software is NOT suitable for medical diagnosis, CPAP complaince reporting and other similar purposes.</i></p>"
"<p><i>The author and any associates of his accept NO responsibilty for damages, issues or non-issues resulting from the use or mis-use of this software<br/>Use this software entirely at your own risk.</i></p>"
"<hr><p><font color=\"blue\">If you find this free software to be of use, please consider supporting the development efforts by making a paypal donation to the Author</font></p>"
"<p><h1>"+tr("SleepyHead")+" v%1.%2.%3-%4 (%8)</h1></p><font color=black><p>"+tr("Build Date")+": %5 %6<br/>%7<br/>"+tr("Data Folder")+": %9<hr>"+
tr("Copyright")+" &copy;2012 Mark Watkins (jedimark) <br> \n"+
tr("This software is released under the GNU Public License v3.0<br>")+
"<hr><p>"+tr("SleepyHead Project Page")+": <a href=\"http://sourceforge.net/projects/sleepyhead\">http://sourceforge.net/projects/sleepyhead</a><br/>"+
tr("SleepyHead Wiki")+": <a href=\"http://sleepyhead.sourceforge.net\">http://sleepyhead.sourceforge.net</a><br/>"+
tr("Authors Twitter Feed")+": <a href=\"http://twitter.com/jedimark64\">http://twitter.com/jedimark64</a></p>"+
"</td><td><img src=\"qrc:/icons/Bob Strikes Back.png\" width=150px height=150px></td></tr><tr colspan><td colspan=2>"+
tr("<p>The author wishes to express thanks to James Marshall and Rich Freeman for their assistance with this project.</p>")+
"<hr><p><i>"+tr("This software comes with absolutely no warranty, either express of implied. It comes with no guarantee of fitness for any particular purpose. No guarantees are made regarding the accuracy of any data this program displays.")+"</i></p>"
"<p><i>"+tr("This is NOT medical software, it is merely a research tool that provides a visual interpretation of data recorded by supported devices. This software is NOT suitable for medical diagnosis, CPAP complaince reporting and other similar purposes.")+"</i></p>"
"<p><i>"+tr("The author and any associates of his accept NO responsibilty for damages, issues or non-issues resulting from the use or mis-use of this software<br/>Use this software entirely at your own risk.")+"</i></p>"
"<hr><p><font color=\"blue\">"+tr("If you find this free software to be of use, please consider supporting the development efforts by making a paypal donation to the Author")+"</font></p>"
"</font></td></tr></table></span>"
).arg(major_version).arg(minor_version).arg(revision_number).arg(release_number).arg(__DATE__).arg(__TIME__).arg(gitrev).arg(ReleaseStatus).arg(GetAppRoot());
).arg(major_version).arg(minor_version).arg(revision_number).arg(release_number).arg(__DATE__).arg(__TIME__).arg(gitrev).arg(ReleaseStatus).arg(GetAppRoot());
//"</div></body>"
QDialog aboutbox;
aboutbox.setWindowTitle(QObject::tr("About a"));
aboutbox.setWindowTitle(QObject::tr("About SleepyHead"));
QVBoxLayout layout(&aboutbox);
@ -1576,7 +1574,7 @@ void MainWindow::on_action_Reset_Graph_Layout_triggered()
void MainWindow::on_action_Preferences_triggered()
{
if (m_inRecalculation) {
mainwin->Notify("Access to Preferences has been blocked until recalculation completes.");
mainwin->Notify(tr("Access to Preferences has been blocked until recalculation completes."));
return;
}
PreferencesDialog pd(this,p_profile);
@ -1605,7 +1603,7 @@ void MainWindow::on_oximetryButton_clicked()
bool first=false;
if (!oximetry) {
if (!PROFILE.oxi->oximetryEnabled()) {
if (QMessageBox::question(this,"Question","Do you have a CMS50[x] Oximeter?\nOne is required to use this section.",QMessageBox::Yes,QMessageBox::No)==QMessageBox::No) return;
if (QMessageBox::question(this,tr("Question"),tr("Do you have a CMS50[x] Oximeter?\nOne is required to use this section."),QMessageBox::Yes,QMessageBox::No)==QMessageBox::No) return;
PROFILE.oxi->setOximetryEnabled(true);
}
oximetry=new Oximetry(ui->tabWidget,daily->graphView());
@ -1669,6 +1667,12 @@ void MainWindow::updatestatusBarMessage (const QString & text)
void MainWindow::on_actionPrint_Report_triggered()
{
#ifdef Q_WS_MAC
#if ((QT_VERSION <= QT_VERSION_CHECK(5, 0, 0)) && (QT_VERSION >= QT_VERSION_CHECK(4, 8, 0)))
QMessageBox::information(this,tr("Printing Broken"),tr("Sorry.. Printing is currently broken on the Mac platform :-(\n\nWe are currently waiting on a Qt Library bugfix"),QMessageBox::Ok);
return;
#endif
#endif
if (ui->tabWidget->currentWidget()==overview) {
PrintReport(overview->graphView(),STR_TR_Overview);
} else if (ui->tabWidget->currentWidget()==daily) {
@ -1779,7 +1783,7 @@ void MainWindow::PrintReport(gGraphView *gv,QString name, QDate date)
if (journal && journal->settings.contains(Bookmark_Start)) {
book_start=journal->settings[Bookmark_Start].toList();
if (book_start.size()>0) {
if (QMessageBox::question(this,tr("Bookmarks"),tr("Would you like to show bookmarked areas in this report?"),QMessageBox::Yes,QMessageBox::No)==QMessageBox::Yes) {
if (QMessageBox::question(this,STR_TR_Bookmarks,tr("Would you like to show bookmarked areas in this report?"),QMessageBox::Yes,QMessageBox::No)==QMessageBox::Yes) {
print_bookmarks=true;
}
}
@ -1858,12 +1862,12 @@ void MainWindow::PrintReport(gGraphView *gv,QString name, QDate date)
int maxy=0;
if (!PROFILE.user->firstName().isEmpty()) {
QString userinfo=tr("Name:\t %1, %2\n").arg(PROFILE.user->lastName()).arg(PROFILE.user->firstName());
userinfo+=tr("DOB:\t%1\n").arg(PROFILE.user->DOB().toString(Qt::SystemLocaleShortDate));
if (!PROFILE.doctor->patientID().isEmpty()) userinfo+=tr("Patient ID:\t%1\n").arg(PROFILE.doctor->patientID());
userinfo+=tr("Phone:\t%1\n").arg(PROFILE.user->phone());
userinfo+=tr("Email:\t%1\n").arg(PROFILE.user->email());
if (!PROFILE.user->address().isEmpty()) userinfo+=tr("\nAddress:\n%1").arg(PROFILE.user->address());
QString userinfo=STR_TR_Name+QString(":\t %1, %2\n").arg(PROFILE.user->lastName()).arg(PROFILE.user->firstName());
userinfo+=STR_TR_DOB+QString(":\t%1\n").arg(PROFILE.user->DOB().toString(Qt::SystemLocaleShortDate));
if (!PROFILE.doctor->patientID().isEmpty()) userinfo+=STR_TR_PatientID+QString(":\t%1\n").arg(PROFILE.doctor->patientID());
userinfo+=STR_TR_Phone+QString(":\t%1\n").arg(PROFILE.user->phone());
userinfo+=STR_TR_Email+QString(":\t%1\n").arg(PROFILE.user->email());
if (!PROFILE.user->address().isEmpty()) userinfo+="\n"+STR_TR_Address+QString(":\n%1").arg(PROFILE.user->address());
QRectF bounds=painter.boundingRect(QRectF(0,top,virt_width,0),userinfo,QTextOption(Qt::AlignLeft | Qt::AlignTop));
painter.drawText(bounds,userinfo,QTextOption(Qt::AlignLeft | Qt::AlignTop));
@ -1884,29 +1888,29 @@ void MainWindow::PrintReport(gGraphView *gv,QString name, QDate date)
int m=(tt/60)%60;
int s=tt % 60;
cpapinfo+=tr("Mask Time: ")+QString().sprintf("%2i hours, %2i minutes, %2i seconds",h,m,s)+"\n";
cpapinfo+=tr("Bedtime: ")+QDateTime::fromTime_t(f).time().toString("HH:mm:ss")+" ";
cpapinfo+=tr("Wake-up: ")+QDateTime::fromTime_t(l).time().toString("HH:mm:ss")+"\n\n";
cpapinfo+=STR_TR_MaskTime+tr(": %1 hours, %2 minutes, %3 seconds\n").arg(h).arg(m).arg(s);
cpapinfo+=STR_TR_BedTime+": "+QDateTime::fromTime_t(f).time().toString("HH:mm:ss")+" ";
cpapinfo+=STR_TR_WakeUp+": "+QDateTime::fromTime_t(l).time().toString("HH:mm:ss")+"\n\n";
QString submodel;
cpapinfo+=tr("Machine: ");
cpapinfo+=STR_TR_Machine+": ";
if (cpap->machine->properties.find(STR_PROP_SubModel)!=cpap->machine->properties.end())
submodel="\n"+cpap->machine->properties[STR_PROP_SubModel];
cpapinfo+=cpap->machine->properties[STR_PROP_Brand]+" "+cpap->machine->properties[STR_PROP_Model]+submodel;
CPAPMode mode=(CPAPMode)(int)cpap->settings_max(CPAP_Mode);
cpapinfo+=tr("\nMode: ");
cpapinfo+="\n"+STR_TR_Mode+": ";
if (mode==MODE_CPAP) {
EventDataType min=round(cpap->settings_wavg(CPAP_Pressure)*2)/2.0;
cpapinfo+=tr("CPAP")+" "+QString::number(min)+STR_UNIT_CMH2O;
cpapinfo+=STR_TR_CPAP+" "+QString::number(min)+STR_UNIT_CMH2O;
} else if (mode==MODE_APAP) {
EventDataType min=cpap->settings_min(CPAP_PressureMin);
EventDataType max=cpap->settings_max(CPAP_PressureMax);
cpapinfo+=tr("APAP")+" "+QString::number(min)+"-"+QString::number(max)+STR_UNIT_CMH2O;
cpapinfo+=STR_TR_APAP+" "+QString::number(min)+"-"+QString::number(max)+STR_UNIT_CMH2O;
} else if (mode==MODE_BIPAP) {
EventDataType epap=cpap->settings_min(CPAP_EPAP);
EventDataType ipap=cpap->settings_max(CPAP_IPAP);
EventDataType ps=cpap->settings_max(CPAP_PS);
cpapinfo+=tr("Bi-Level")+QString("\nEPAP: %1 IPAP: %2 %3\nPS: %4")
cpapinfo+=STR_TR_BiLevel+QString("\n"+STR_TR_EPAP+": %1 "+STR_TR_IPAP+": %2 %3\n"+STR_TR_PS+": %4")
.arg(epap,0,'f',1).arg(ipap,0,'f',1).arg(STR_UNIT_CMH2O).arg(ps,0,'f',1);
}
else if (mode==MODE_ASV) {
@ -1915,7 +1919,7 @@ void MainWindow::PrintReport(gGraphView *gv,QString name, QDate date)
EventDataType high=cpap->settings_max(CPAP_IPAPHi);
EventDataType psl=cpap->settings_min(CPAP_PSMin);
EventDataType psh=cpap->settings_max(CPAP_PSMax);
cpapinfo+=tr("ASV")+QString("\nEPAP: %1 IPAP: %2 - %3 %4\nPS: %5 / %6")
cpapinfo+=STR_TR_ASV+QString("\n"+STR_TR_EPAP+": %1 "+STR_TR_IPAP+": %2 - %3 %4\n"+STR_TR_PS+": %5 / %6")
.arg(epap,0,'f',1)
.arg(low,0,'f',1)
.arg(high,0,'f',1)
@ -1923,7 +1927,7 @@ void MainWindow::PrintReport(gGraphView *gv,QString name, QDate date)
.arg(psl,0,'f',1)
.arg(psh,0,'f',1);
}
else cpapinfo+=tr("Unknown");
else cpapinfo+=STR_TR_Unknown;
float ahi=(cpap->count(CPAP_Obstructive)+cpap->count(CPAP_Hypopnea)+cpap->count(CPAP_ClearAirway)+cpap->count(CPAP_Apnea));
if (PROFILE.general->calculateRDI()) ahi+=cpap->count(CPAP_RERA);
@ -1994,11 +1998,11 @@ void MainWindow::PrintReport(gGraphView *gv,QString name, QDate date)
if (journal) {
stats="";
if (journal->settings.contains(Journal_Weight))
stats+=tr("Weight %1 ").arg(weightString(journal->settings[Journal_Weight].toDouble()));
stats+=STR_TR_Weight+QString(" %1 ").arg(weightString(journal->settings[Journal_Weight].toDouble()));
if (journal->settings.contains(Journal_BMI))
stats+=tr("BMI %1 ").arg(journal->settings[Journal_BMI].toDouble(),0,'f',2);
stats+=STR_TR_BMI+QString(" %1 ").arg(journal->settings[Journal_BMI].toDouble(),0,'f',2);
if (journal->settings.contains(Journal_ZombieMeter))
stats+=tr("Zombie %1/10 ").arg(journal->settings[Journal_ZombieMeter].toDouble(),0,'f',0);
stats+=STR_TR_Zombie+QString(" %1/10 ").arg(journal->settings[Journal_ZombieMeter].toDouble(),0,'f',0);
if (!stats.isEmpty()) {
bounds=painter.boundingRect(QRectF(0,top+ttop,virt_width,0),stats,QTextOption(Qt::AlignHCenter));
@ -2096,6 +2100,7 @@ void MainWindow::PrintReport(gGraphView *gv,QString name, QDate date)
}
} else {
const QString EntireDay=tr("Entire Day");
if (journal) {
if (journal->settings.contains(Bookmark_Start)) {
QVariantList st1=journal->settings[Bookmark_Start].toList();
@ -2107,19 +2112,19 @@ void MainWindow::PrintReport(gGraphView *gv,QString name, QDate date)
if (cpap && flow && !flow->isEmpty() && flow->visible()) {
labels.push_back("Entire Day");
labels.push_back(EntireDay);
start.push_back(cpap->first());
end.push_back(cpap->last());
graphs.push_back(flow);
}
if (oxi && spo2 && !spo2->isEmpty() && spo2->visible()) {
labels.push_back("Entire Day");
labels.push_back(EntireDay);
start.push_back(oxi->first());
end.push_back(oxi->last());
graphs.push_back(spo2);
}
if (oxi && pulse && !pulse->isEmpty() && pulse->visible()) {
labels.push_back("Entire Day");
labels.push_back(EntireDay);
start.push_back(oxi->first());
end.push_back(oxi->last());
graphs.push_back(pulse);
@ -2733,11 +2738,11 @@ void MainWindow::doReprocessEvents()
qprogress->setVisible(false);
m_inRecalculation=false;
if (m_restartRequired) {
QMessageBox::information(this,"Restart Required",QString("Recalculations are complete, the application now needs to restart to display the changes."),QMessageBox::Ok);
QMessageBox::information(this,tr("Restart Required"),tr("Recalculations are complete, the application now needs to restart to display the changes."),QMessageBox::Ok);
RestartApplication();
return;
} else {
Notify("Recalculations are now complete.","Task Completed");
Notify(tr("Recalculations are now complete."),tr("Task Completed"));
FreeSessions();
QDate current=daily->getDate();
@ -2758,10 +2763,10 @@ void MainWindow::on_actionImport_ZEO_Data_triggered()
if (w.exec()==QFileDialog::Accepted) {
QString filename=w.selectedFiles()[0];
if (!zeo.OpenFile(filename)) {
Notify("There was a problem opening ZEO File: "+filename);
Notify(tr("There was a problem opening ZEO File: ")+filename);
return;
}
Notify("Zeo CSV Import complete");
Notify(tr("Zeo CSV Import complete"));
daily->LoadDate(daily->getDate());
}
@ -2770,6 +2775,7 @@ void MainWindow::on_actionImport_ZEO_Data_triggered()
void MainWindow::on_actionImport_RemStar_MSeries_Data_triggered()
{
#ifdef REMSTAR_M_SUPPORT
QFileDialog w;
w.setFileMode(QFileDialog::ExistingFiles);
w.setOption(QFileDialog::ShowDirsOnly, false);
@ -2780,12 +2786,13 @@ void MainWindow::on_actionImport_RemStar_MSeries_Data_triggered()
if (w.exec()==QFileDialog::Accepted) {
QString filename=w.selectedFiles()[0];
if (!mseries.Open(filename,p_profile)) {
Notify("There was a problem opening MSeries block File: "+filename);
Notify(tr("There was a problem opening MSeries block File: ")+filename);
return;
}
Notify("MSeries Import complete");
Notify(tr("MSeries Import complete"));
daily->LoadDate(daily->getDate());
}
#endif
}
void MainWindow::on_actionSleep_Disorder_Terms_Glossary_triggered()

View File

@ -72,7 +72,7 @@ Overview::Overview(QWidget *parent,gGraphView * shared) :
GraphView=new gGraphView(ui->graphArea,m_shared);
GraphView->setSizePolicy(QSizePolicy::Expanding,QSizePolicy::Expanding);
GraphView->setEmptyText("No Data");
GraphView->setEmptyText(STR_TR_NoData);
GraphView->setCubeImage(images["nodata"]);
// Create the custom scrollbar and attach to GraphView
@ -92,13 +92,13 @@ Overview::Overview(QWidget *parent,gGraphView * shared) :
ChannelID ahicode=PROFILE.general->calculateRDI() ? CPAP_RDI : CPAP_AHI;
if (ahicode==CPAP_RDI)
AHI=createGraph(tr("RDI"),"Respiratory\nDisturbance\nIndex");
AHI=createGraph(STR_TR_RDI,tr("Respiratory\nDisturbance\nIndex"));
else
AHI=createGraph(tr("AHI"),tr("Apnea\nHypopnea\nIndex"));
AHI=createGraph(STR_TR_AHI,tr("Apnea\nHypopnea\nIndex"));
UC=createGraph(tr("Usage"),tr("Usage\n(hours)"));
FL=createGraph(tr("Flow Limit"),tr("Flow Limit"));
FL=createGraph(STR_TR_FlowLimit,STR_TR_FlowLimit);
float percentile=PROFILE.general->prefCalcPercentile()/100.0;
int mididx=PROFILE.general->prefCalcMiddle();
@ -112,28 +112,28 @@ Overview::Overview(QWidget *parent,gGraphView * shared) :
US=createGraph(tr("Session Times"),tr("Session Times\n(hours)"),YT_Time);
PR=createGraph(STR_TR_Pressure,tr("Pressure\n(cmH2O)"));
SET=createGraph(tr("Settings"),("Settings"));
LK=createGraph(tr("Leaks"),tr("Unintentional Leaks\n(L/min)"));
TOTLK=createGraph(tr("Total Leaks"),tr("Total Leaks\n(L/min)"));
PR=createGraph(STR_TR_Pressure,STR_TR_Pressure+"\n("+STR_UNIT_CMH2O+")");
SET=createGraph(STR_TR_Settings,STR_TR_Settings);
LK=createGraph(STR_TR_Leaks,STR_TR_UnintentionalLeaks+"\n("+STR_UNIT_LPM+")");
TOTLK=createGraph(STR_TR_TotalLeaks,STR_TR_TotalLeaks+"\n("+STR_UNIT_LPM+")");
NPB=createGraph(tr("% in PB"),tr("Periodic\nBreathing\n(% of night)"));
if (ahicode==CPAP_RDI) {
AHIHR=createGraph(tr("Peak RDI"),tr("Peak RDI\nShows RDI Clusters\n(RDI/hr)"));
} else {
AHIHR=createGraph(tr("Peak AHI"),tr("Peak AHI\nShows AHI Clusters\n(AHI/hr)"));
}
RR=createGraph(tr("Resp. Rate"),tr("Respiratory\nRate\n(breaths/min)"));
TV=createGraph(tr("Tidal Volume"),tr("Tidal\nVolume\n(ml)"));
MV=createGraph(tr("Minute Vent."),tr("Minute\nVentilation\n(L/min)"));
TGMV=createGraph(tr("Target Vent."),tr("Target\nVentilation\n(L/min)"));
PTB=createGraph(tr("Pat. Trig. Br."),tr("Patient\nTriggered\nBreaths\n(%)"));
SES=createGraph(tr("Sessions"),tr("Sessions\n(count)"));
PULSE=createGraph(tr("Pulse Rate"),tr("Pulse Rate\n(bpm)"));
RR=createGraph(STR_TR_RespRate,tr("Respiratory\nRate\n(breaths/min)"));
TV=createGraph(STR_TR_TidalVolume,tr("Tidal\nVolume\n(ml)"));
MV=createGraph(STR_TR_MinuteVent,tr("Minute\nVentilation\n(L/min)"));
TGMV=createGraph(STR_TR_TargetVent,tr("Target\nVentilation\n(L/min)"));
PTB=createGraph(STR_TR_PatTrigBreath,tr("Patient\nTriggered\nBreaths\n(%)"));
SES=createGraph(STR_TR_Sessions,STR_TR_Sessions+tr("\n(count)"));
PULSE=createGraph(STR_TR_PulseRate,STR_TR_PulseRate+"\n("+STR_UNIT_BPM+")");
SPO2=createGraph(STR_TR_SpO2,tr("Oxygen Saturation\n(%)"));
WEIGHT=createGraph(STR_TR_Weight,STR_TR_Weight,YT_Weight);
BMI=createGraph(STR_TR_BMI,tr("Body\nMass\nIndex"));
ZOMBIE=createGraph(tr("Zombie"),tr("How you felt\n(0-10)"));
ZOMBIE=createGraph(STR_TR_Zombie,tr("How you felt\n(0-10)"));
ahihr=new SummaryChart(tr("Events/Hr"),GT_LINE);
ahihr->addSlice(ahicode,QColor("blue"),ST_MAX);
@ -155,7 +155,7 @@ Overview::Overview(QWidget *parent,gGraphView * shared) :
zombie->addSlice(Journal_ZombieMeter,QColor("dark red"),ST_SETAVG);
ZOMBIE->AddLayer(zombie);
pulse=new SummaryChart(tr("Pulse Rate"),GT_LINE);
pulse=new SummaryChart(STR_TR_PulseRate,GT_LINE);
pulse->setMachineType(MT_OXIMETER);
pulse->addSlice(OXI_Pulse,QColor("red"),ST_mid,0.5);
pulse->addSlice(OXI_Pulse,QColor("pink"),ST_MIN);
@ -173,7 +173,7 @@ Overview::Overview(QWidget *parent,gGraphView * shared) :
uc->addSlice(NoChannel,QColor("green"),ST_HOURS);
UC->AddLayer(uc);
fl=new SummaryChart(tr("FL"),GT_BAR);
fl=new SummaryChart(STR_TR_FL,GT_BAR);
fl->addSlice(CPAP_FlowLimit,QColor("brown"),ST_CPH);
FL->AddLayer(fl);
@ -182,14 +182,14 @@ Overview::Overview(QWidget *parent,gGraphView * shared) :
us->addSlice(NoChannel,QColor("blue"),ST_SESSIONS);
US->AddLayer(us);
ses=new SummaryChart(tr("Sessions"),GT_LINE);
ses=new SummaryChart(STR_TR_Sessions,GT_LINE);
ses->addSlice(NoChannel,QColor("blue"),ST_SESSIONS);
SES->AddLayer(ses);
if (ahicode==CPAP_RDI)
bc=new SummaryChart(tr("RDI"),GT_BAR);
bc=new SummaryChart(STR_TR_RDI,GT_BAR);
else
bc=new SummaryChart(tr("AHI"),GT_BAR);
bc=new SummaryChart(STR_TR_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);
@ -222,7 +222,7 @@ Overview::Overview(QWidget *parent,gGraphView * shared) :
tv->addSlice(CPAP_TidalVolume,QColor("green"),ST_max,maxperc);
TV->AddLayer(tv);
mv=new SummaryChart(tr("L/m"),GT_LINE);
mv=new SummaryChart(STR_UNIT_LPM,GT_LINE);
mv->addSlice(CPAP_MinuteVent,QColor("light blue"),ST_MIN);
mv->addSlice(CPAP_MinuteVent,QColor("blue"),ST_mid,0.5);
mv->addSlice(CPAP_MinuteVent,QColor("light green"),ST_PERC,percentile);
@ -230,7 +230,7 @@ Overview::Overview(QWidget *parent,gGraphView * shared) :
MV->AddLayer(mv);
// should merge...
tgmv=new SummaryChart(tr("L/m"),GT_LINE);
tgmv=new SummaryChart(STR_UNIT_LPM,GT_LINE);
tgmv->addSlice(CPAP_TgMV,QColor("light blue"),ST_MIN);
tgmv->addSlice(CPAP_TgMV,QColor("blue"),ST_mid,0.5);
tgmv->addSlice(CPAP_TgMV,QColor("light green"),ST_PERC,percentile);
@ -248,7 +248,7 @@ Overview::Overview(QWidget *parent,gGraphView * shared) :
// Added in summarychart.. Slightly annoying..
PR->AddLayer(pr);
lk=new SummaryChart(tr("Leaks"),GT_LINE);
lk=new SummaryChart(STR_TR_Leaks,GT_LINE);
lk->addSlice(CPAP_Leak,QColor("light blue"),ST_mid,0.5);
lk->addSlice(CPAP_Leak,QColor("dark grey"),ST_PERC,percentile);
//lk->addSlice(CPAP_Leak,QColor("dark blue"),ST_WAVG);
@ -256,7 +256,7 @@ Overview::Overview(QWidget *parent,gGraphView * shared) :
//lk->addSlice(CPAP_Leak,QColor("dark yellow"));
LK->AddLayer(lk);
totlk=new SummaryChart(tr("Total Leaks"),GT_LINE);
totlk=new SummaryChart(STR_TR_TotalLeaks,GT_LINE);
totlk->addSlice(CPAP_LeakTotal,QColor("light blue"),ST_mid,0.5);
totlk->addSlice(CPAP_LeakTotal,QColor("dark grey"),ST_PERC,percentile);
totlk->addSlice(CPAP_LeakTotal,QColor("grey"),ST_max,maxperc);
@ -579,7 +579,7 @@ void Overview::updateCube()
GraphView->setCubeImage(images["nographs"]);
} else {
GraphView->setEmptyText("No Data");
GraphView->setEmptyText(STR_TR_NoData);
GraphView->setCubeImage(images["nodata"]);
}
} else {

View File

@ -455,7 +455,7 @@ void CMS50Serial::import_process()
qDebug() << "User pushing import too many times in a row?";
return;
}
mainwin->getOximetry()->graphView()->setEmptyText("Processing...");
mainwin->getOximetry()->graphView()->setEmptyText(tr("Processing..."));
mainwin->getOximetry()->graphView()->redraw();
qDebug() << "CMS50 import complete. Processing" << data.size() << "bytes";
@ -466,7 +466,36 @@ void CMS50Serial::import_process()
EventList * pulse=(session->eventlist[OXI_Pulse][0]);
EventList * spo2=(session->eventlist[OXI_SPO2][0]);
lasttime=f2time.toTime_t();
int d=abs(oxitime.secsTo(cpaptime));
QDateTime seltime=oxitime;
if (!cpaptime.isNull()) {
if (QMessageBox::question(mainwin,tr("Question"),tr("Did you remember to start your oximeter recording at exactly the same time you started your CPAP machine?"),QMessageBox::Yes,QMessageBox::No)==QMessageBox::No) {
if (!cms50dplus) {
// Oximeter has a clock.. Hopefully the user remembered to set their clock on the device..
QMessageBox::information(mainwin,"Information","That's ok, I will use the time provided by your oximeter, however it will sync better next time if you start your oximeter recording at the same time your CPAP machine starts up.\n(Please note: If you haven't set your oximeter clock you will have to manually edit this time before saving this oximetry session.)",QMessageBox::Ok);
} else {
//CMS50D+, and the user didn't start at the same time.. Kludge it because they likely turned it on around about the same time anyway.
QMessageBox::information(mainwin,"Information","It looks like your oximeter doesn't provide a valid start time, I'm going to set this oximetry session starting time to the CPAP starting time anyway.\nYou may have to adjust it manually if you remember the real start time before saving this session. (Also, did you remember to import todays CPAP data first?)",QMessageBox::Ok);
seltime=cpaptime;
}
} else {
// The best solution.. the user (hopefully) started both devices at the same time, so we pick the cpap sessions start time for optimal sync.
QMessageBox::information(mainwin,tr("Information"),tr("The most recent CPAP Session time has been selected as the start of your oximetry session.\nIf you forgot to import todays CPAP data first, go and do that now, then import again from your oximeter."),QMessageBox::Ok);
seltime=cpaptime;
}
} else {
if (cms50dplus) {
// Worst case, CMS50D+ and no CPAP data.. the time is basically set to midnight the current day.
QMessageBox::information(mainwin,tr("Information"),tr("No valid start time was provided for this oximeter session. You will likely have to adjust your oximeter sessions start time before saving."),QMessageBox::Ok);
} else {
// No point nagging the user at all in this case.. they don't have any CPAP data loaded, so they are just using SleepyHead with the oximeter
}
}
lasttime=seltime.toTime_t();
session->SetSessionID(lasttime);
lasttime*=1000;
@ -690,33 +719,37 @@ void CMS50Serial::ReadyRead()
started_import=true;
started_reading=false;
mainwin->getOximetry()->graphView()->setEmptyText("Please Wait, Importing...");
mainwin->getOximetry()->graphView()->setEmptyText(tr("Please Wait, Importing..."));
mainwin->getOximetry()->graphView()->timedRedraw(50);
if ((hour!=0) && (minute!=0)) { // CMS50E/F's have a realtime clock
f2time=QDateTime(QDate::currentDate(),QTime(hour,minute));
f2time=f2time.toTimeSpec(Qt::UTC);
qDebug() << "Session start (according to CMS50)" << f2time << hex << buffer.at(i+1) << buffer.at(i+2) << ":" << dec << hour << minute ;
} else {
// otherwise pick the first session of the last days data..
Day *day=PROFILE.GetDay(PROFILE.LastDay(),MT_CPAP);
if (day) {
int ti=day->first()/1000L;
QDate oda=QDate::currentDate();
QTime oti=QTime(hour,minute); // Only CMS50E/F's have a realtime clock. CMS50D+ will set this to midnight
f2time=QDateTime::fromTime_t(ti);
qDebug() << "Guessing session starting from CPAP data" << f2time;
}
cms50dplus=(hour==0) && (minute==0); // Either a CMS50D+ or it's really midnight, set a flag anyway for later to help choose the right sync time
if (!f2time.isValid()) {
// CMS50D+ are rather stupid.
qDebug() << "Can't guess start time, defaulting to midnight" << f2time;
f2time=QDateTime::currentDateTime();
f2time.setTime(QTime(0,0,0));
//f2time.addDays(-1);
}
// If the oximeter record time is more than the current time, then assume it was from the day before
// Or should I use split time preference instead??? Foggy Confusements..
if (oti > QTime::currentTime())
oda=oda.addDays(-1);
}
qDebug() << "Record Import:" << f2time;
oxitime=QDateTime(oda,oti);
// Convert it to UTC
oxitime=oxitime.toTimeSpec(Qt::UTC);
qDebug() << "Session start (according to CMS50)" << oxitime<< hex << buffer.at(i+1) << buffer.at(i+2) << ":" << dec << hour << minute ;
// As an alternative, pick the first session of the last days data..
Day *day=PROFILE.GetDay(PROFILE.LastDay(),MT_CPAP);
if (day) {
int ti=day->first()/1000L;
cpaptime=QDateTime::fromTime_t(ti);
qDebug() << "Guessing session starting from CPAP data" << cpaptime;
} else cpaptime=QDateTime(); // null
qDebug() << "Record Import:" << oxitime << cpaptime;
i+=9;
} else {
started_reading=true; // Sometimes errornous crap is sent after data rec header
@ -884,11 +917,11 @@ void CMS50Serial::startImportTimeout()
m_mode=SO_WAIT;
cms50timer->stop();
emit(importAborted());
mainwin->getOximetry()->graphView()->setEmptyText("Import Failed");
mainwin->getOximetry()->graphView()->setEmptyText(tr("Import Failed"));
mainwin->getOximetry()->graphView()->timedRedraw(50);
return;
} else {
QString a="Waiting";
QString a=tr("Make Sure Oximeter is Ready");
for (int j=0;j<i;j++) a+=".";
mainwin->getOximetry()->graphView()->setEmptyText(a);
mainwin->getOximetry()->graphView()->timedRedraw(50);
@ -1001,8 +1034,8 @@ Oximetry::Oximetry(QWidget *parent,gGraphView * shared) :
PLETHY->AddLayer(plethy);
PULSE->AddLayer(lo1=new gLineOverlayBar(OXI_PulseChange,QColor("light gray"),"PD",FT_Span));
SPO2->AddLayer(lo2=new gLineOverlayBar(OXI_SPO2Drop,QColor("light blue"),"O2",FT_Span));
PULSE->AddLayer(lo1=new gLineOverlayBar(OXI_PulseChange,QColor("light gray"),STR_TR_PC,FT_Span));
SPO2->AddLayer(lo2=new gLineOverlayBar(OXI_SPO2Drop,QColor("light blue"),STR_TR_O2,FT_Span));
PULSE->AddLayer(pulse);
SPO2->AddLayer(spo2);
PULSE->setDay(day);
@ -1312,8 +1345,8 @@ void Oximetry::on_ImportButton_clicked()
PLETHY->setVisible(false);
day->getSessions().clear();
GraphView->setDay(day);
GraphView->setEmptyText("Make Sure Oximeter Is Ready");
GraphView->redraw();
//GraphView->setEmptyText(tr("Make Sure Oximeter is Ready"));
//GraphView->redraw();
if (!oximeter->startImport()) {
mainwin->Notify(tr("Oximeter Error\n\nThe device did not respond.. Make sure it's switched on."));
@ -1426,7 +1459,7 @@ void Oximetry::spo2_changed(float o2)
void Oximetry::on_saveButton_clicked()
{
if (QMessageBox::question(this,"Keep This Recording?","Would you like to save this oximetery session?",QMessageBox::Yes|QMessageBox::No)==QMessageBox::Yes) {
if (QMessageBox::question(this,tr("Keep This Recording?"),tr("Would you like to save this oximetery session?"),QMessageBox::Yes|QMessageBox::No)==QMessageBox::Yes) {
Session *session=oximeter->getSession();
// Process???
@ -1451,7 +1484,7 @@ void Oximetry::on_saveButton_clicked()
mainwin->getDaily()->LoadDate(mainwin->getDaily()->getDate());
mainwin->getOverview()->ReloadGraphs();
GraphView->setEmptyText("No Oximetry Data");
GraphView->setEmptyText(tr("No Oximetry Data"));
GraphView->redraw();
}
}
@ -1546,7 +1579,7 @@ bool Oximetry::openSPOFile(QString filename)
bool Oximetry::openSPORFile(QString filename)
{
//GraphView->setEmptyText("Please Wait");
//GraphView->setEmptyText(tr("Please Wait"));
//GraphView->redraw();
QFile f(filename);
if (!f.open(QFile::ReadOnly)) return false;
@ -1623,7 +1656,7 @@ bool Oximetry::openSPORFile(QString filename)
void Oximetry::on_openButton_clicked()
{
if (oximeter->getSession() && oximeter->getSession()->IsChanged()) {
int res=QMessageBox::question(this,"Save Session?","Opening this oximetry file will destroy the current session.\nWould you like to keep it?","Save","Destroy It","Cancel",0,2);
int res=QMessageBox::question(this,tr("Save Session?"),tr("Opening this oximetry file will destroy the current session.\nWould you like to keep it?"),tr("Save"),tr("Destroy It"),tr("Cancel"),0,2);
if (res==0) {
on_saveButton_clicked();
return;
@ -1633,7 +1666,7 @@ void Oximetry::on_openButton_clicked()
} // else it's already saved.
QString dir="";
QFileDialog fd(this,"Select an oximetry file",dir,"Oximetry Files (*.spo *.spoR)");
QFileDialog fd(this,tr("Select an oximetry file"),dir,tr("Oximetry Files (*.spo *.spoR)"));
fd.setAcceptMode(QFileDialog::AcceptOpen);
fd.setFileMode(QFileDialog::ExistingFile);
if (fd.exec()!=QFileDialog::Accepted) return;
@ -1647,7 +1680,7 @@ void Oximetry::on_openButton_clicked()
else if (filename.toLower().endsWith(".spor")) r=openSPORFile(filename);
if (!r) {
mainwin->Notify("Couldn't open oximetry file \""+filename+"\".");
mainwin->Notify(tr("Couldn't open oximetry file \"")+filename+"\".");
}
qDebug() << "opening" << filename;
}
@ -1678,7 +1711,7 @@ void Oximetry::on_dateEdit_dateTimeChanged(const QDateTime &date)
void Oximetry::openSession(Session * session)
{
if (oximeter->getSession() && oximeter->getSession()->IsChanged()) {
int res=QMessageBox::question(this,"Save Session?","Opening this oximetry session will destroy the unsavedsession in the oximetry tab.\nWould you like to store it first?","Save","Destroy It","Cancel",0,2);
int res=QMessageBox::question(this,tr("Save Session?"),tr("Opening this oximetry session will destroy the unsavedsession in the oximetry tab.\nWould you like to store it first?"),tr("Save"),tr("Destroy It"),tr("Cancel"),0,2);
if (res==0) {
on_saveButton_clicked();
return;

View File

@ -219,6 +219,7 @@ protected:
*/
class CMS50Serial:public SerialOximeter
{
Q_OBJECT
public:
explicit CMS50Serial(QObject * parent,QString portname);
virtual ~CMS50Serial();
@ -253,7 +254,9 @@ protected:
QByteArray data;
QByteArray buffer;
QDateTime f2time;
QDateTime oxitime,cpaptime;
bool cms50dplus;
int datasize;
int received_bytes;

View File

@ -660,8 +660,8 @@ void PreferencesDialog::resetGraphModel()
graphModel->setColumnCount(3);
QStringList headers;
headers.append(tr("Graph"));
headers.append(tr("Min"));
headers.append(tr("Max"));
headers.append(STR_TR_Min);
headers.append(STR_TR_Max);
graphModel->setHorizontalHeaderLabels(headers);
ui->graphView->setColumnWidth(0,250);
ui->graphView->setColumnWidth(1,50);
@ -815,7 +815,7 @@ void PreferencesDialog::on_createSDBackups_toggled(bool checked)
break;
}
}
if (haveS9 && QMessageBox::question(this,"This may not be a good idea","ResMed S9 machines routinely delete certain data from your SD card older than 7 and 30 days (depending on resolution). If you ever need to reimport this data again (whether in SleepyHead or ResScan) this data won't come back. If you need to conserve disk space, please remember to carry out manual backups. Are you sure you want to disable these backups?",QMessageBox::Yes,QMessageBox::No)==QMessageBox::No) {
if (haveS9 && QMessageBox::question(this,tr("This may not be a good idea"),tr("ResMed S9 machines routinely delete certain data from your SD card older than 7 and 30 days (depending on resolution).")+" "+tr("If you ever need to reimport this data again (whether in SleepyHead or ResScan) this data won't come back.")+" "+tr("If you need to conserve disk space, please remember to carry out manual backups.")+" "+tr("Are you sure you want to disable these backups?"),QMessageBox::Yes,QMessageBox::No)==QMessageBox::No) {
ui->createSDBackups->setChecked(true);
return;
}

View File

@ -169,7 +169,7 @@ void QuaZipFilePrivate::setZipError(int zipError) const
if(zipError==UNZ_OK)
q->setErrorString(QString());
else
q->setErrorString(q->tr("ZIP/UNZIP API error %1").arg(zipError));
q->setErrorString(QObject::tr("ZIP/UNZIP API error %1").arg(zipError));
}
bool QuaZipFile::open(OpenMode mode)