Pixel alignment / Margin cleanups

This commit is contained in:
Mark Watkins 2011-05-31 14:28:11 +10:00
parent 40b00a3d14
commit 6b5ef70df9
4 changed files with 60 additions and 64 deletions

View File

@ -7875,7 +7875,7 @@
<sleeplib/machine.h> <sleeplib/machine.h>
<list> <list>
1306811240 /home/mark/projects/git/sleepyhead/version.h 1306815962 /home/mark/projects/git/sleepyhead/version.h
1306724655 /home/mark/projects/git/sleepyhead/libs/sleeplib/prs1_loader.h 1306724655 /home/mark/projects/git/sleepyhead/libs/sleeplib/prs1_loader.h
"machine.h" "machine.h"
@ -7892,7 +7892,7 @@
"preferences.h" "preferences.h"
"tinyxml/tinyxml.h" "tinyxml/tinyxml.h"
1306811240 source:/home/mark/projects/git/sleepyhead/SleepyHeadMain.cpp 1306815066 source:/home/mark/projects/git/sleepyhead/SleepyHeadMain.cpp
"wx_pch.h" "wx_pch.h"
"version.h" "version.h"
<wx/app.h> <wx/app.h>
@ -7910,7 +7910,7 @@
"sleeplib/profiles.h" "sleeplib/profiles.h"
"sleeplib/machine_loader.h" "sleeplib/machine_loader.h"
1306810919 source:/home/mark/projects/git/sleepyhead/graphs/graph.cpp 1306815882 source:/home/mark/projects/git/sleepyhead/graphs/graph.cpp
<wx/settings.h> <wx/settings.h>
<wx/dcbuffer.h> <wx/dcbuffer.h>
<wx/log.h> <wx/log.h>

View File

@ -330,15 +330,15 @@ Summary::Summary(wxWindow *win,Profile *_profile)
AddData(waketime=new UsageHistoryData(profile,UHD_Waketime)); AddData(waketime=new UsageHistoryData(profile,UHD_Waketime));
AddData(bedtime=new UsageHistoryData(profile,UHD_Bedtime)); AddData(bedtime=new UsageHistoryData(profile,UHD_Bedtime));
AHI=new gGraphWindow(ScrolledWindow,-1,wxT("AHI"),wxPoint(0,0), wxSize(400,200), wxNO_BORDER); AHI=new gGraphWindow(ScrolledWindow,-1,wxT("AHI"),wxPoint(0,0), wxSize(400,160), wxNO_BORDER);
AHI->SetMargins(10,15,60,80); AHI->SetMargins(10,15,65,80);
AHI->AddLayer(new gBarChart(ahidata,wxRED)); AHI->AddLayer(new gBarChart(ahidata,wxRED));
// AHI->AddLayer(new gXAxis(NULL,wxBLACK)); // AHI->AddLayer(new gXAxis(NULL,wxBLACK));
//AHI->AddLayer(new gLineChart(ahidata,wxRED)); //AHI->AddLayer(new gLineChart(ahidata,wxRED));
fgSizer->Add(AHI,1,wxEXPAND); fgSizer->Add(AHI,1,wxEXPAND);
PRESSURE=new gGraphWindow(ScrolledWindow,-1,wxT("Pressure"),wxPoint(0,0), wxSize(400,200), wxNO_BORDER); PRESSURE=new gGraphWindow(ScrolledWindow,-1,wxT("Pressure"),wxPoint(0,0), wxSize(400,160), wxNO_BORDER);
PRESSURE->SetMargins(10,15,60,80); PRESSURE->SetMargins(10,15,65,80);
//PRESSURE->AddLayer(new gBarChart(pressure,wxBLUE)); //PRESSURE->AddLayer(new gBarChart(pressure,wxBLUE));
PRESSURE->AddLayer(new gLineChart(pressure,wxDARK_GREEN,6192)); PRESSURE->AddLayer(new gLineChart(pressure,wxDARK_GREEN,6192));
PRESSURE->AddLayer(new gLineChart(pressure_eap,wxRED,6192,false,true)); PRESSURE->AddLayer(new gLineChart(pressure_eap,wxRED,6192,false,true));
@ -347,16 +347,16 @@ Summary::Summary(wxWindow *win,Profile *_profile)
fgSizer->Add(PRESSURE,1,wxEXPAND); fgSizer->Add(PRESSURE,1,wxEXPAND);
LEAK=new gGraphWindow(ScrolledWindow,-1,wxT("Mask Leak"),wxPoint(0,0), wxSize(400,200), wxNO_BORDER); LEAK=new gGraphWindow(ScrolledWindow,-1,wxT("Mask Leak"),wxPoint(0,0), wxSize(400,160), wxNO_BORDER);
LEAK->SetMargins(10,15,60,80); LEAK->SetMargins(10,15,65,80);
//LEAK->AddLayer(new gBarChart(leak,wxYELLOW)); //LEAK->AddLayer(new gBarChart(leak,wxYELLOW));
LEAK->AddLayer(new gLineChart(leak,wxPURPLE,6192)); LEAK->AddLayer(new gLineChart(leak,wxPURPLE,6192));
LEAK->AddLayer(new gXAxis(NULL,wxBLACK)); LEAK->AddLayer(new gXAxis(NULL,wxBLACK));
fgSizer->Add(LEAK,1,wxEXPAND); fgSizer->Add(LEAK,1,wxEXPAND);
USAGE=new gGraphWindow(ScrolledWindow,-1,wxT("Usage (Hours)"),wxPoint(0,0), wxSize(400,200), wxNO_BORDER); USAGE=new gGraphWindow(ScrolledWindow,-1,wxT("Usage (Hours)"),wxPoint(0,0), wxSize(400,160), wxNO_BORDER);
USAGE->SetMargins(10,15,60,80); USAGE->SetMargins(10,15,65,80);
USAGE->AddLayer(new gBarChart(usage,wxGREEN)); USAGE->AddLayer(new gBarChart(usage,wxGREEN));
//USAGE->AddLayer(new gXAxis(NULL,wxBLACK)); //USAGE->AddLayer(new gXAxis(NULL,wxBLACK));
@ -491,19 +491,19 @@ Daily::Daily(wxWindow *win,Profile *p)
AddData(tap_iap=new TAPData(CPAP_IAP)); AddData(tap_iap=new TAPData(CPAP_IAP));
AddData(tap=new TAPData(CPAP_Pressure)); AddData(tap=new TAPData(CPAP_Pressure));
TAP=new gGraphWindow(ScrolledWindow,-1,wxT("Time@Pressure"),wxPoint(0,0), wxSize(600,50), wxNO_BORDER); TAP=new gGraphWindow(ScrolledWindow,-1,wxT("Time@Pressure"),wxPoint(0,0), wxSize(600,60), wxNO_BORDER);
TAP->SetMargins(20,15,5,50); TAP->SetMargins(20,15,5,50);
TAP->AddLayer(new gCandleStick(tap)); TAP->AddLayer(new gCandleStick(tap));
TAP_IAP=new gGraphWindow(ScrolledWindow,-1,wxT("Time@IPAP"),wxPoint(0,0), wxSize(600,50), wxNO_BORDER); TAP_IAP=new gGraphWindow(ScrolledWindow,-1,wxT("Time@IPAP"),wxPoint(0,0), wxSize(600,60), wxNO_BORDER);
TAP_IAP->SetMargins(20,15,5,50); TAP_IAP->SetMargins(20,15,5,50);
TAP_IAP->AddLayer(new gCandleStick(tap_iap)); TAP_IAP->AddLayer(new gCandleStick(tap_iap));
TAP_EAP=new gGraphWindow(ScrolledWindow,-1,wxT("Time@EPAP"),wxPoint(0,0), wxSize(600,50), wxNO_BORDER); TAP_EAP=new gGraphWindow(ScrolledWindow,-1,wxT("Time@EPAP"),wxPoint(0,0), wxSize(600,60), wxNO_BORDER);
TAP_EAP->SetMargins(20,15,5,50); TAP_EAP->SetMargins(20,15,5,50);
TAP_EAP->AddLayer(new gCandleStick(tap_eap)); TAP_EAP->AddLayer(new gCandleStick(tap_eap));
G_AHI=new gGraphWindow(ScrolledWindow,-1,wxT("Event Breakdown"),wxPoint(0,0), wxSize(600,50), wxNO_BORDER); G_AHI=new gGraphWindow(ScrolledWindow,-1,wxT("Event Breakdown"),wxPoint(0,0), wxSize(600,60), wxNO_BORDER);
G_AHI->SetMargins(20,15,5,50); G_AHI->SetMargins(20,15,5,50);
AddData(g_ahi=new AHIData()); AddData(g_ahi=new AHIData());
gCandleStick *l=new gCandleStick(g_ahi); gCandleStick *l=new gCandleStick(g_ahi);
@ -562,7 +562,7 @@ Daily::Daily(wxWindow *win,Profile *p)
FRW->AddLayer(new gLineOverlayBar(flags[1],wxPURPLE,wxT("CA"))); FRW->AddLayer(new gLineOverlayBar(flags[1],wxPURPLE,wxT("CA")));
FRW->AddLayer(new gXAxis(NULL,wxBLACK)); FRW->AddLayer(new gXAxis(NULL,wxBLACK));
SF=new gGraphWindow(ScrolledWindow,-1,wxT("Event Flags"),wxPoint(0,0), wxSize(600,150), wxNO_BORDER); SF=new gGraphWindow(ScrolledWindow,-1,wxT("Event Flags"),wxPoint(0,0), wxSize(600,180), wxNO_BORDER);
// SF->SetMargins(10,15,20,80); // SF->SetMargins(10,15,20,80);
SF->LinkZoom(FRW); SF->LinkZoom(FRW);

View File

@ -123,6 +123,28 @@ BEGIN_EVENT_TABLE(gGraphWindow, wxWindow)
END_EVENT_TABLE() END_EVENT_TABLE()
gGraphWindow::gGraphWindow(wxWindow *parent, wxWindowID id,const wxString & title,const wxPoint &pos,const wxSize &size,long flags)
: wxWindow( parent, id, pos, size, flags, title )
{
m_scrX = m_scrY = 64;
m_title=title;
m_mouseRDown=m_mouseLDown=false;
SetBackgroundColour( *wxWHITE );
m_bgColour = *wxWHITE;
m_fgColour = *wxBLACK;
SetMargins(10, 15, 46, 80);
m_block_move=false;
m_block_zoom=false;
}
gGraphWindow::~gGraphWindow()
{
for (auto l=layers.begin();l!=layers.end();l++) delete (*l);
layers.clear();
}
void gGraphWindow::AddLayer(gLayer *l) { void gGraphWindow::AddLayer(gLayer *l) {
if (l) { if (l) {
l->NotifyGraphWindow(this); l->NotifyGraphWindow(this);
@ -337,26 +359,6 @@ void gGraphWindow::OnMouseLeftRelease(wxMouseEvent &event)
} }
gGraphWindow::gGraphWindow(wxWindow *parent, wxWindowID id,const wxString & title,const wxPoint &pos,const wxSize &size,long flags)
: wxWindow( parent, id, pos, size, flags, title )
{
m_scrX = m_scrY = 64;
m_title=title;
m_mouseRDown=m_mouseLDown=false;
SetBackgroundColour( *wxWHITE );
m_bgColour = *wxWHITE;
m_fgColour = *wxBLACK;
SetMargins(10, 15, 32, 80);
m_block_move=false;
m_block_zoom=false;
}
gGraphWindow::~gGraphWindow()
{
for (auto l=layers.begin();l!=layers.end();l++) delete (*l);
layers.clear();
}
void gGraphWindow::Update() void gGraphWindow::Update()
{ {
Refresh(); Refresh();
@ -706,12 +708,12 @@ void gXAxis::Plot(wxDC & dc, gGraphWindow & w)
} else { // Day ticks.. } else { // Day ticks..
show_time=false; show_time=false;
st=st2; st=st2;
min_tick=1; min_tick=1.0;
double mtiks=(x+20.0)/width; double mtiks=(x+20.0)/width;
double mt=mtiks*xx; double mt=mtiks*xx;
min_tick=mt; min_tick=mt;
if (min_tick<1) min_tick=1; //if (min_tick<1.0) min_tick=1.0;
if (min_tick>10) min_tick=10; //if (min_tick>10) min_tick=10;
} }
// dc.SetPen(*wxBLACK_PEN); // dc.SetPen(*wxBLACK_PEN);
@ -733,13 +735,13 @@ void gXAxis::Plot(wxDC & dc, gGraphWindow & w)
while (st<w.min_x) { while (st<w.min_x) {
st+=min_tick; st+=min_tick/10.0;
} }
int hour,minute,second,millisecond; int hour,minute,second,millisecond;
wxDateTime d; wxDateTime d;
for (double i=st; i<w.max_x; i+=min_tick) { //600.0/86400.0) { for (double i=st; i<=w.max_x; i+=min_tick) { //600.0/86400.0) {
d.Set(i+2400000.5+.000001+1); // JDN vs MJD vs Rounding errors d.Set(i+2400000.5+.000001+1); // JDN vs MJD vs Rounding errors
if (show_time) { if (show_time) {
@ -757,13 +759,9 @@ void gXAxis::Plot(wxDC & dc, gGraphWindow & w)
} }
} else { } else {
fd=d.Format(wxT("%d %b")); fd=d.Format(wxT("%d %b"));
//fd=wxT("ZZ FUNK");
} }
// dc.GetTextExtent(fd,&x,&y);
// px=x2p(w,i); px=w.x2p(i);
px=w.x2p(i); //w.GetLeftMargin()+((i - w.min_x) * xmult);
dc.DrawLine(px,py,px,py+6); dc.DrawLine(px,py,px,py+6);
y=x=0; y=x=0;
dc.GetTextExtent(fd,&x,&y); // This doesn't work properly on windows. dc.GetTextExtent(fd,&x,&y); // This doesn't work properly on windows.
@ -1370,6 +1368,9 @@ void gFlagsLine::Plot(wxDC & dc, gGraphWindow & w)
if (!m_visible) return; if (!m_visible) return;
if (!data) return; if (!data) return;
if (!data->IsReady()) return; if (!data->IsReady()) return;
double xx=w.max_x-w.min_x;
if (xx<=0) return;
//if (!data->NP()) return; //if (!data->NP()) return;
int scrx = w.GetScrX(); int scrx = w.GetScrX();
@ -1382,16 +1383,11 @@ void gFlagsLine::Plot(wxDC & dc, gGraphWindow & w)
int width=scrx-(w.GetLeftMargin()+w.GetRightMargin()); int width=scrx-(w.GetLeftMargin()+w.GetRightMargin());
int height=scry-(w.GetTopMargin()+w.GetBottomMargin()); int height=scry-(w.GetTopMargin()+w.GetBottomMargin());
double xx=w.max_x-w.min_x;
if (xx<=0) return;
static wxColor col1=wxColor(0xff,0xf0,0xd0,0x7f); static wxColor col1=wxColor(0xff,0xf0,0xd0,0x7f);
static wxColor col2=wxColor(0xe0,0xff,0xd0,0x7f); static wxColor col2=wxColor(0xe0,0xff,0xd0,0x7f);
static wxBrush linebr1(col1, wxSOLID); static wxBrush linebr1(col1, wxSOLID);
static wxBrush linebr2(col2, wxSOLID); static wxBrush linebr2(col2, wxSOLID);
static wxPen pen2(wxDARK_GREY, 1, wxDOT); static wxPen pen2(wxDARK_GREY, 1, wxDOT);
static wxPen pen3(*wxGREEN, 2, wxSOLID); static wxPen pen3(*wxGREEN, 2, wxSOLID);
@ -1405,15 +1401,15 @@ void gFlagsLine::Plot(wxDC & dc, gGraphWindow & w)
dc.DrawLine(start_px+px,start_py+height+8,start_px+px,start_py+height+12); dc.DrawLine(start_px+px,start_py+height+8,start_px+px,start_py+height+12);
dc.DrawLine(start_px+py,start_py+height+8,start_px+py,start_py+height+12); dc.DrawLine(start_px+py,start_py+height+8,start_px+py,start_py+height+12);
wxPen sfp1(*color[0], 1, wxSOLID);
wxPen sfp1(*color[0], 1, wxSOLID);
wxBrush brush(*color[0],wxSOLID); //FDIAGONAL_HATCH); wxBrush brush(*color[0],wxSOLID); //FDIAGONAL_HATCH);
double line_h=((height)/total_lines); double line_h=(height+1)/double(total_lines);
int r=int(height) % total_lines; int r=int(height) % total_lines;
double line_top=1+(start_py+(line_num*line_h)-r/2.0); double line_top=start_py+round(line_num*line_h)-1;
//double line_bottom=line_top+line_h; //double line_bottom=line_top+line_h;
dc.SetPen(*wxBLACK); dc.SetPen(*wxBLACK);
@ -1422,7 +1418,7 @@ void gFlagsLine::Plot(wxDC & dc, gGraphWindow & w)
} else { } else {
dc.SetBrush(linebr2); dc.SetBrush(linebr2);
} }
dc.DrawRectangle(start_px,line_top,width+1,line_h+1); dc.DrawRectangle(start_px,line_top,width+1,round(line_h+1));
int x,y; int x,y;
dc.GetTextExtent(label,&x,&y); dc.GetTextExtent(label,&x,&y);
dc.DrawText(label,start_px-x-6,line_top+(line_h/2)-(y/2)); dc.DrawText(label,start_px-x-6,line_top+(line_h/2)-(y/2));
@ -1792,7 +1788,7 @@ HistoryData::HistoryData(Profile * _profile)
AddSegment(max_points); AddSegment(max_points);
if (profile->LastDay().IsValid()) { if (profile->LastDay().IsValid()) {
real_min_x=profile->FirstDay().GetMJD(); real_min_x=profile->FirstDay().GetMJD();
real_max_x=profile->LastDay().GetMJD()+1; real_max_x=profile->LastDay().GetMJD()+0.5;
} }
} }
HistoryData::~HistoryData() HistoryData::~HistoryData()
@ -1802,7 +1798,7 @@ void HistoryData::ResetDateRange()
{ {
if (profile->LastDay().IsValid()) { if (profile->LastDay().IsValid()) {
real_min_x=profile->FirstDay().GetMJD(); real_min_x=profile->FirstDay().GetMJD();
real_max_x=profile->LastDay().GetMJD()+1; real_max_x=profile->LastDay().GetMJD()+0.5;
} }
Reload(NULL); Reload(NULL);
} }
@ -1874,7 +1870,7 @@ double HistoryData::GetAverage()
} }
void HistoryData::SetDateRange(wxDateTime start,wxDateTime end) void HistoryData::SetDateRange(wxDateTime start,wxDateTime end)
{ {
double x1=start.GetMJD()-1;//+1; double x1=start.GetMJD()-0.5;
double x2=end.GetMJD(); double x2=end.GetMJD();
if (x1 < real_min_x) x1=real_min_x; if (x1 < real_min_x) x1=real_min_x;
if (x2 > (real_max_x)) x2=(real_max_x); if (x2 > (real_max_x)) x2=(real_max_x);

View File

@ -16,14 +16,14 @@ namespace AutoVersion{
//Standard Version Type //Standard Version Type
static const long MAJOR = 0; static const long MAJOR = 0;
static const long MINOR = 7; static const long MINOR = 7;
static const long BUILD = 2441; static const long BUILD = 2474;
static const long REVISION = 8013; static const long REVISION = 8196;
//Miscellaneous Version Types //Miscellaneous Version Types
static const long BUILDS_COUNT = 7433; static const long BUILDS_COUNT = 7532;
#define RC_FILEVERSION 0,7,2441,8013 #define RC_FILEVERSION 0,7,2474,8196
#define RC_FILEVERSION_STRING "0, 7, 2441, 8013\0" #define RC_FILEVERSION_STRING "0, 7, 2474, 8196\0"
static const char FULLVERSION_STRING[] = "0.7.2441.8013"; static const char FULLVERSION_STRING[] = "0.7.2474.8196";
//These values are to keep track of your versioning state, don't modify them. //These values are to keep track of your versioning state, don't modify them.
static const long BUILD_HISTORY = 62; static const long BUILD_HISTORY = 62;