wxMathPlot basic code formatting

This commit is contained in:
Maciej Suminski 2016-08-11 14:42:18 +02:00
parent 0667b7ba63
commit 557f9270c7
2 changed files with 250 additions and 256 deletions

View File

@ -3,9 +3,9 @@
// Purpose: Framework for plotting in wxWindows // Purpose: Framework for plotting in wxWindows
// Original Author: David Schalig // Original Author: David Schalig
// Maintainer: Davide Rondini // Maintainer: Davide Rondini
// Contributors: Jose Luis Blanco, Val Greene // Contributors: Jose Luis Blanco, Val Greene, Maciej Suminski, Tomasz Wlostowski
// Created: 21/07/2003 // Created: 21/07/2003
// Last edit: 09/09/2007 // Last edit: 05/08/2016
// Copyright: (c) David Schalig, Davide Rondini // Copyright: (c) David Schalig, Davide Rondini
// Licence: wxWindows licence // Licence: wxWindows licence
///////////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////////
@ -641,7 +641,7 @@ void mpFXY::Plot(wxDC & dc, mpWindow & w)
outUp = (c0 < minYpx) && (c1 < minYpx); outUp = (c0 < minYpx) && (c1 < minYpx);
if ( !outUp && !outDown ) { if ( !outUp && !outDown ) {
dc.DrawLine(x0, c0, x1, c1); dc.DrawLine(x0, c0, x1, c1);
// UpdateViewBoundary(x1, c1); // UpdateViewBoundary(x1, c1);
} }
} }
x0=x1; c0=c1; x0=x1; c0=c1;
@ -764,23 +764,23 @@ void mpScaleX::recalculateTicks ( wxDC & dc, mpWindow & w )
double minErr = 1000000000000.0; double minErr = 1000000000000.0;
double bestStep; double bestStep;
for(int i = 10; i <= 20; i+=2) for(int i = 10; i <= 20; i+=2)
{
double step = fabs(maxVvis - minVvis) / (double) i;
double base = pow(10, floor(log10(step)));
//printf("base %.3f\n", base);
double stepInt = floor(step / base) * base;
double err = fabs(step - stepInt);
if(err< minErr)
{ {
double step = fabs(maxVvis - minVvis) / (double) i; minErr = err;
double base = pow(10, floor(log10(step))); bestStep = stepInt;
//printf("base %.3f\n", base);
double stepInt = floor(step / base) * base;
double err = fabs(step - stepInt);
if(err< minErr)
{
minErr = err;
bestStep = stepInt;
}
//printf("step %d %.3f %.3f best %.3f\n",i, step, stepInt, bestStep);
} }
//printf("step %d %.3f %.3f best %.3f\n",i, step, stepInt, bestStep);
}
double v = floor(minVvis / bestStep) * bestStep; double v = floor(minVvis / bestStep) * bestStep;
@ -857,42 +857,42 @@ void mpScaleBase::updateTickLabels( wxDC & dc, mpWindow & w )
formatLabels(); formatLabels();
computeLabelExtents(dc, w); computeLabelExtents(dc, w);
// int gap = IsHorizontal() ? m_maxLabelWidth + 10 : m_maxLabelHeight + 5; // int gap = IsHorizontal() ? m_maxLabelWidth + 10 : m_maxLabelHeight + 5;
//if ( m_tickLabels.size() <= 2) //if ( m_tickLabels.size() <= 2)
// return; // return;
/* /*
fixme! fixme!
for ( auto &l : m_tickLabels ) for ( auto &l : m_tickLabels )
{ {
double p = TransformToPlot ( l.pos ); double p = TransformToPlot ( l.pos );
if ( !IsHorizontal() ) if ( !IsHorizontal() )
l.pixelPos = (int)(( w.GetPosY() - p ) * w.GetScaleY()); l.pixelPos = (int)(( w.GetPosY() - p ) * w.GetScaleY());
else else
l.pixelPos = (int)(( p - w.GetPosX()) * w.GetScaleX()); l.pixelPos = (int)(( p - w.GetPosX()) * w.GetScaleX());
} }
for (int i = 1; i < m_tickLabels.size() - 1; i++) for (int i = 1; i < m_tickLabels.size() - 1; i++)
{ {
int dist_prev; int dist_prev;
for(int j = i-1; j >= 1; j--) for(int j = i-1; j >= 1; j--)
{ {
if( m_tickLabels[j].visible) if( m_tickLabels[j].visible)
{ {
dist_prev = abs( m_tickLabels[j].pixelPos - m_tickLabels[i].pixelPos ); dist_prev = abs( m_tickLabels[j].pixelPos - m_tickLabels[i].pixelPos );
break; break;
} }
} }
if (dist_prev < gap) if (dist_prev < gap)
m_tickLabels[i].visible = false; m_tickLabels[i].visible = false;
} }
*/ */
} }
@ -909,12 +909,12 @@ int mpScaleX::labelCount() const
const wxString mpScaleX::getLabel( int n ) const wxString mpScaleX::getLabel( int n )
{ {
return wxT("L"); return wxT("L");
} }
double mpScaleX::getTickPos( int n ) double mpScaleX::getTickPos( int n )
{ {
return m_tickValues[n]; return m_tickValues[n];
} }
double mpScaleX::getLabelPos( int n ) double mpScaleX::getLabelPos( int n )
@ -940,52 +940,52 @@ void mpScaleY::getVisibleDataRange ( mpWindow& w, double &minV, double& maxV)
void mpScaleY::computeSlaveTicks( mpWindow& w ) void mpScaleY::computeSlaveTicks( mpWindow& w )
{ {
if( m_masterScale->m_tickValues.size() == 0) if( m_masterScale->m_tickValues.size() == 0)
return; return;
m_tickValues.clear(); m_tickValues.clear();
m_tickLabels.clear(); m_tickLabels.clear();
// printf("NTicks %d\n", m_masterScale->m_tickValues.size()); // printf("NTicks %d\n", m_masterScale->m_tickValues.size());
double p0 = m_masterScale->TransformToPlot(m_masterScale->m_tickValues[0]); double p0 = m_masterScale->TransformToPlot(m_masterScale->m_tickValues[0]);
double p1 = m_masterScale->TransformToPlot(m_masterScale->m_tickValues[1]); double p1 = m_masterScale->TransformToPlot(m_masterScale->m_tickValues[1]);
m_scale = 1.0 / ( m_maxV - m_minV ); m_scale = 1.0 / ( m_maxV - m_minV );
m_offset = -m_minV; m_offset = -m_minV;
double y_slave0 = p0 / m_scale; double y_slave0 = p0 / m_scale;
double y_slave1 = p1 / m_scale; double y_slave1 = p1 / m_scale;
double dy_slave = (y_slave1 - y_slave0); double dy_slave = (y_slave1 - y_slave0);
double exponent = floor(log10(dy_slave)); double exponent = floor(log10(dy_slave));
double base = dy_slave/ pow(10.0, exponent); double base = dy_slave/ pow(10.0, exponent);
double dy_scaled = ceil( 2.0* base ) / 2.0 * pow (10.0, exponent ); double dy_scaled = ceil( 2.0* base ) / 2.0 * pow (10.0, exponent );
double minvv, maxvv; double minvv, maxvv;
getVisibleDataRange( w,minvv, maxvv); getVisibleDataRange( w,minvv, maxvv);
minvv = floor(minvv / dy_scaled) * dy_scaled; minvv = floor(minvv / dy_scaled) * dy_scaled;
m_scale = 1.0 / ( m_maxV - m_minV ); m_scale = 1.0 / ( m_maxV - m_minV );
m_scale *= dy_slave / dy_scaled; m_scale *= dy_slave / dy_scaled;
m_offset = p0 / m_scale - minvv; m_offset = p0 / m_scale - minvv;
m_tickValues.clear(); m_tickValues.clear();
double m; double m;
m_absVisibleMaxV = 0; m_absVisibleMaxV = 0;
for (unsigned int i = 0; i < m_masterScale->m_tickValues.size(); i++) for (unsigned int i = 0; i < m_masterScale->m_tickValues.size(); i++)
{ {
m = TransformFromPlot ( m_masterScale->TransformToPlot(m_masterScale->m_tickValues[i]) ); m = TransformFromPlot ( m_masterScale->TransformToPlot(m_masterScale->m_tickValues[i]) );
m_tickValues.push_back(m); m_tickValues.push_back(m);
m_tickLabels.push_back( TickLabel (m) ); m_tickLabels.push_back( TickLabel (m) );
m_absVisibleMaxV = std::max(m_absVisibleMaxV, fabs(m)); m_absVisibleMaxV = std::max(m_absVisibleMaxV, fabs(m));
} }
} }
@ -1016,23 +1016,23 @@ void mpScaleY::recalculateTicks ( wxDC & dc, mpWindow & w )
double minErr = 1000000000000.0; double minErr = 1000000000000.0;
double bestStep; double bestStep;
for(int i = 10; i <= 20; i+=2) for(int i = 10; i <= 20; i+=2)
{
double step = fabs(maxVvis - minVvis) / (double) i;
double base = pow(10, floor(log10(step)));
//printf("base %.3f\n", base);
double stepInt = floor(step / base) * base;
double err = fabs(step - stepInt);
if(err< minErr)
{ {
double step = fabs(maxVvis - minVvis) / (double) i; minErr = err;
double base = pow(10, floor(log10(step))); bestStep = stepInt;
//printf("base %.3f\n", base);
double stepInt = floor(step / base) * base;
double err = fabs(step - stepInt);
if(err< minErr)
{
minErr = err;
bestStep = stepInt;
}
//printf("step %d %.3f %.3f best %.3f\n",i, step, stepInt, bestStep);
} }
//printf("step %d %.3f %.3f best %.3f\n",i, step, stepInt, bestStep);
}
double v = floor(minVvis / bestStep) * bestStep; double v = floor(minVvis / bestStep) * bestStep;
@ -1141,8 +1141,8 @@ void mpScaleXLog::recalculateTicks ( wxDC & dc, mpWindow & w )
IMPLEMENT_ABSTRACT_CLASS(mpScaleXBase, mpLayer) IMPLEMENT_ABSTRACT_CLASS(mpScaleXBase, mpLayer)
IMPLEMENT_DYNAMIC_CLASS(mpScaleX, mpScaleXBase) IMPLEMENT_DYNAMIC_CLASS(mpScaleX, mpScaleXBase)
IMPLEMENT_DYNAMIC_CLASS(mpScaleXLog, mpScaleXBase) IMPLEMENT_DYNAMIC_CLASS(mpScaleXLog, mpScaleXBase)
mpScaleXBase::mpScaleXBase(wxString name, int flags, bool ticks, unsigned int type) mpScaleXBase::mpScaleXBase(wxString name, int flags, bool ticks, unsigned int type)
@ -1199,7 +1199,7 @@ void mpScaleXBase::Plot(wxDC & dc, mpWindow & w)
if (m_flags == mpALIGN_BORDER_TOP ) if (m_flags == mpALIGN_BORDER_TOP )
orgy = 1;//-dc.LogicalToDeviceY(0); orgy = 1;//-dc.LogicalToDeviceY(0);
// dc.DrawLine( 0, orgy, w.GetScrX(), orgy); // dc.DrawLine( 0, orgy, w.GetScrX(), orgy);
#ifdef MATHPLOT_DO_LOGGING #ifdef MATHPLOT_DO_LOGGING
wxLogMessage(wxT("mpScaleX::Plot: dig: %f , step: %f, end: %f, n: %f"), dig, step, end, n0); wxLogMessage(wxT("mpScaleX::Plot: dig: %f , step: %f, end: %f, n: %f"), dig, step, end, n0);
@ -1308,7 +1308,7 @@ void mpScaleXBase::Plot(wxDC & dc, mpWindow & w)
case mpALIGN_BOTTOM: { case mpALIGN_BOTTOM: {
dc.DrawText( m_name, (endPx + startPx) / 2 - tx / 2, orgy + 6 + labelH); dc.DrawText( m_name, (endPx + startPx) / 2 - tx / 2, orgy + 6 + labelH);
} break; } break;
case mpALIGN_CENTER: case mpALIGN_CENTER:
@ -1354,7 +1354,7 @@ void mpScaleY::Plot(wxDC & dc, mpWindow & w)
m_offset = -m_minV; m_offset = -m_minV;
m_scale = 1.0 / ( m_maxV - m_minV ); m_scale = 1.0 / ( m_maxV - m_minV );
//printf("Plot Y-scale\n"); //printf("Plot Y-scale\n");
recalculateTicks(dc, w); recalculateTicks(dc, w);
if (m_visible) { if (m_visible) {
dc.SetPen( m_pen); dc.SetPen( m_pen);
@ -1381,9 +1381,9 @@ void mpScaleY::Plot(wxDC & dc, mpWindow & w)
if (m_flags == mpALIGN_BORDER_LEFT ) if (m_flags == mpALIGN_BORDER_LEFT )
orgx = 1; //-dc.LogicalToDeviceX(0); orgx = 1; //-dc.LogicalToDeviceX(0);
wxCoord endPx = m_drawOutsideMargins ? w.GetScrX() : w.GetScrX() - w.GetMarginRight(); wxCoord endPx = m_drawOutsideMargins ? w.GetScrX() : w.GetScrX() - w.GetMarginRight();
wxCoord minYpx = m_drawOutsideMargins ? 0 : w.GetMarginTop(); wxCoord minYpx = m_drawOutsideMargins ? 0 : w.GetMarginTop();
wxCoord maxYpx = m_drawOutsideMargins ? w.GetScrY() : w.GetScrY() - w.GetMarginBottom(); wxCoord maxYpx = m_drawOutsideMargins ? w.GetScrY() : w.GetScrY() - w.GetMarginBottom();
// Draw line // Draw line
dc.DrawLine( orgx, minYpx, orgx, maxYpx); dc.DrawLine( orgx, minYpx, orgx, maxYpx);
@ -1442,28 +1442,28 @@ void mpScaleY::Plot(wxDC & dc, mpWindow & w)
} }
//printf("Y-ticks: %d\n", tickCount()); //printf("Y-ticks: %d\n", tickCount());
for (n = 0; n < labelCount(); n++ ) { for (n = 0; n < labelCount(); n++ ) {
//printf("Tick %d\n", n); //printf("Tick %d\n", n);
double tp = getLabelPos(n); double tp = getLabelPos(n);
double py = TransformToPlot ( tp ); //( log10 ( tp ) - xlogmin) / (xlogmax - xlogmin); double py = TransformToPlot ( tp ); //( log10 ( tp ) - xlogmin) / (xlogmax - xlogmin);
const int p = (int)(( w.GetPosY() - py ) * w.GetScaleY()); const int p = (int)(( w.GetPosY() - py ) * w.GetScaleY());
if ( !m_tickLabels[n].visible ) if ( !m_tickLabels[n].visible )
continue; continue;
if ((p >= minYpx) && (p <= maxYpx)) { if ((p >= minYpx) && (p <= maxYpx)) {
s=getLabel(n); s=getLabel(n);
dc.GetTextExtent(s, &tx, &ty); dc.GetTextExtent(s, &tx, &ty);
if ((m_flags == mpALIGN_BORDER_LEFT) || (m_flags == mpALIGN_RIGHT)) if ((m_flags == mpALIGN_BORDER_LEFT) || (m_flags == mpALIGN_RIGHT))
dc.DrawText( s, orgx+4, p-ty/2); dc.DrawText( s, orgx+4, p-ty/2);
else else
dc.DrawText( s, orgx-4-tx, p-ty/2); //( s, orgx+4, p-ty/2); dc.DrawText( s, orgx-4-tx, p-ty/2); //( s, orgx+4, p-ty/2);
}
} }
// Draw axis name }
// Draw axis name
// Draw axis name // Draw axis name
dc.GetTextExtent(m_name, &tx, &ty); dc.GetTextExtent(m_name, &tx, &ty);
@ -1472,11 +1472,11 @@ void mpScaleY::Plot(wxDC & dc, mpWindow & w)
dc.DrawText( m_name, labelW + 8, 4); dc.DrawText( m_name, labelW + 8, 4);
break; break;
case mpALIGN_LEFT: { case mpALIGN_LEFT: {
// if ((!m_drawOutsideMargins) && (w.GetMarginLeft() > (ty + labelW + 8))) { // if ((!m_drawOutsideMargins) && (w.GetMarginLeft() > (ty + labelW + 8))) {
// dc.DrawRotatedText( m_name, orgx - 6 - labelW - ty, (maxYpx + minYpx) / 2 + tx / 2, 90); // dc.DrawRotatedText( m_name, orgx - 6 - labelW - ty, (maxYpx + minYpx) / 2 + tx / 2, 90);
// } else { // } else {
dc.DrawText( m_name, orgx + 4, minYpx - ty - 4); dc.DrawText( m_name, orgx + 4, minYpx - ty - 4);
// } // }
} break; } break;
case mpALIGN_CENTER: case mpALIGN_CENTER:
dc.DrawText( m_name, orgx + 4, 4); dc.DrawText( m_name, orgx + 4, 4);
@ -1485,9 +1485,9 @@ void mpScaleY::Plot(wxDC & dc, mpWindow & w)
//dc.DrawRotatedText( m_name, orgx + 6, (maxYpx + minYpx) / 2 + tx / 2, 90); //dc.DrawRotatedText( m_name, orgx + 6, (maxYpx + minYpx) / 2 + tx / 2, 90);
/*if ((!m_drawOutsideMargins) && (w.GetMarginRight() > (ty + labelW + 8))) { /*if ((!m_drawOutsideMargins) && (w.GetMarginRight() > (ty + labelW + 8))) {
dc.DrawRotatedText( m_name, orgx + 6 + labelW, (maxYpx - minYpx + tx)>>1, 90); dc.DrawRotatedText( m_name, orgx + 6 + labelW, (maxYpx - minYpx + tx)>>1, 90);
} else {*/ } else {*/
dc.DrawText( m_name, orgx - tx - 4, minYpx - ty - 4); dc.DrawText( m_name, orgx - tx - 4, minYpx - ty - 4);
//} //}
} break; } break;
case mpALIGN_BORDER_RIGHT: case mpALIGN_BORDER_RIGHT:
@ -1515,14 +1515,14 @@ IMPLEMENT_DYNAMIC_CLASS(mpWindow, wxWindow)
EVT_SCROLLWIN_LINEUP(mpWindow::OnScrollLineUp) EVT_SCROLLWIN_LINEUP(mpWindow::OnScrollLineUp)
EVT_SCROLLWIN_LINEDOWN(mpWindow::OnScrollLineDown) EVT_SCROLLWIN_LINEDOWN(mpWindow::OnScrollLineDown)
EVT_SCROLLWIN_TOP(mpWindow::OnScrollTop) EVT_SCROLLWIN_TOP(mpWindow::OnScrollTop)
EVT_SCROLLWIN_BOTTOM(mpWindow::OnScrollBottom) EVT_SCROLLWIN_BOTTOM(mpWindow::OnScrollBottom)
EVT_MIDDLE_DOWN(mpWindow::OnMouseMiddleDown) // JLB EVT_MIDDLE_DOWN(mpWindow::OnMouseMiddleDown) // JLB
EVT_RIGHT_UP(mpWindow::OnShowPopupMenu) EVT_RIGHT_UP(mpWindow::OnShowPopupMenu)
EVT_MOUSEWHEEL(mpWindow::OnMouseWheel ) // JLB EVT_MOUSEWHEEL(mpWindow::OnMouseWheel ) // JLB
EVT_MOTION(mpWindow::OnMouseMove ) // JLB EVT_MOTION(mpWindow::OnMouseMove ) // JLB
EVT_LEFT_DOWN(mpWindow::OnMouseLeftDown) EVT_LEFT_DOWN(mpWindow::OnMouseLeftDown)
EVT_LEFT_UP(mpWindow::OnMouseLeftRelease) EVT_LEFT_UP(mpWindow::OnMouseLeftRelease)
EVT_MENU( mpID_CENTER, mpWindow::OnCenter) EVT_MENU( mpID_CENTER, mpWindow::OnCenter)
EVT_MENU( mpID_FIT, mpWindow::OnFit) EVT_MENU( mpID_FIT, mpWindow::OnFit)
@ -1688,7 +1688,7 @@ void mpWindow::OnMouseMove(wxMouseEvent &event)
} }
UpdateAll(); UpdateAll();
} else { } else {
#if 0 #if 0
wxLayerList::iterator li; wxLayerList::iterator li;
for (li = m_layers.begin(); li != m_layers.end(); li++) { for (li = m_layers.begin(); li != m_layers.end(); li++) {
if ((*li)->IsInfo() && (*li)->IsVisible()) { if ((*li)->IsInfo() && (*li)->IsVisible()) {
@ -1698,7 +1698,7 @@ void mpWindow::OnMouseMove(wxMouseEvent &event)
RefreshRect(tmpLyr->GetRectangle()); RefreshRect(tmpLyr->GetRectangle());
} }
} }
#endif #endif
/* if (m_coordTooltip) { /* if (m_coordTooltip) {
wxString toolTipContent; wxString toolTipContent;
toolTipContent.Printf(_("X = %f\nY = %f"), p2x(event.GetX()), p2y(event.GetY())); toolTipContent.Printf(_("X = %f\nY = %f"), p2x(event.GetX()), p2y(event.GetY()));
@ -1778,7 +1778,7 @@ void mpWindow::Fit(double xMin, double xMax, double yMin, double yMax, wxCoord *
// Save desired borders: // Save desired borders:
m_desiredXmin=xMin; m_desiredXmax=xMax; m_desiredXmin=xMin; m_desiredXmax=xMax;
m_desiredYmin=yMin; m_desiredYmax=yMax; m_desiredYmin=yMin; m_desiredYmax=yMax;
// printf("minx %.1f miny %.1f maxx %.1f maxy %.1f\n", xMin, yMin, xMax, yMax); // printf("minx %.1f miny %.1f maxx %.1f maxy %.1f\n", xMin, yMin, xMax, yMax);
if (printSizeX!=NULL && printSizeY!=NULL) if (printSizeX!=NULL && printSizeY!=NULL)
{ {
@ -1943,7 +1943,7 @@ void mpWindow::AdjustLimitedView()
bool mpWindow::SetXView(double pos, double desiredMax, double desiredMin) bool mpWindow::SetXView(double pos, double desiredMax, double desiredMin)
{ {
//if(!CheckXLimits(desiredMax, desiredMin)) //if(!CheckXLimits(desiredMax, desiredMin))
//return false; //return false;
m_posX = pos; m_posX = pos;
m_desiredXmax = desiredMax; m_desiredXmax = desiredMax;
@ -1957,7 +1957,7 @@ bool mpWindow::SetXView(double pos, double desiredMax, double desiredMin)
bool mpWindow::SetYView(double pos, double desiredMax, double desiredMin) bool mpWindow::SetYView(double pos, double desiredMax, double desiredMin)
{ {
//if(!CheckYLimits(desiredMax, desiredMin)) //if(!CheckYLimits(desiredMax, desiredMin))
//return false; //return false;
m_posY = pos; m_posY = pos;
m_desiredYmax = desiredMax; m_desiredYmax = desiredMax;
@ -2399,7 +2399,7 @@ bool mpWindow::UpdateBBox()
return true; return true;
#if 0 #if 0
for (wxLayerList::iterator li = m_layers.begin(); li != m_layers.end(); li++) for (wxLayerList::iterator li = m_layers.begin(); li != m_layers.end(); li++)
{ {
@ -2431,7 +2431,7 @@ bool mpWindow::UpdateBBox()
//node = node->GetNext(); //node = node->GetNext();
} }
#endif #endif
#ifdef MATHPLOT_DO_LOGGING #ifdef MATHPLOT_DO_LOGGING
wxLogDebug(wxT("[mpWindow::UpdateBBox] Bounding box: Xmin = %f, Xmax = %f, Ymin = %f, YMax = %f"), m_minX, m_maxX, m_minY, m_maxY); wxLogDebug(wxT("[mpWindow::UpdateBBox] Bounding box: Xmin = %f, Xmax = %f, Ymin = %f, YMax = %f"), m_minX, m_maxX, m_minY, m_maxY);
@ -2685,7 +2685,7 @@ void mpWindow::GetBoundingBox(double* bbox)
} }
bool mpWindow::SaveScreenshot( const wxString& filename, wxBitmapType type, bool mpWindow::SaveScreenshot( const wxString& filename, wxBitmapType type,
wxSize imageSize, bool fit ) wxSize imageSize, bool fit )
{ {
int sizeX, sizeY; int sizeX, sizeY;
int bk_scrX, bk_scrY; int bk_scrX, bk_scrY;
@ -2875,7 +2875,7 @@ IMPLEMENT_DYNAMIC_CLASS(mpFXYVector, mpFXY)
mpFXYVector::mpFXYVector(wxString name, int flags ) : mpFXY(name,flags) mpFXYVector::mpFXYVector(wxString name, int flags ) : mpFXY(name,flags)
{ {
m_index = 0; m_index = 0;
//printf("FXYVector::FXYVector!\n"); //printf("FXYVector::FXYVector!\n");
m_minX = -1; m_minX = -1;
m_maxX = 1; m_maxX = 1;
m_minY = -1; m_minY = -1;
@ -2930,7 +2930,7 @@ double log10( double x)
#if 0 #if 0
mpFSemiLogXVector::mpFSemiLogXVector(wxString name, int flags ) : mpFSemiLogXVector::mpFSemiLogXVector(wxString name, int flags ) :
mpFXYVector ( name, flags ) mpFXYVector ( name, flags )
{} {}

View File

@ -3,9 +3,9 @@
// Purpose: Framework for plotting in wxWindows // Purpose: Framework for plotting in wxWindows
// Original Author: David Schalig // Original Author: David Schalig
// Maintainer: Davide Rondini // Maintainer: Davide Rondini
// Contributors: Jose Luis Blanco, Val Greene // Contributors: Jose Luis Blanco, Val Greene, Maciej Suminski, Tomasz Wlostowski
// Created: 21/07/2003 // Created: 21/07/2003
// Last edit: 22/02/2009 // Last edit: 05/08/2016
// Copyright: (c) David Schalig, Davide Rondini // Copyright: (c) David Schalig, Davide Rondini
// Licence: wxWindows licence // Licence: wxWindows licence
///////////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////////
@ -688,147 +688,147 @@ class WXDLLIMPEXP_MATHPLOT mpProfile : public mpLayer
class WXDLLIMPEXP_MATHPLOT mpScaleBase : public mpLayer class WXDLLIMPEXP_MATHPLOT mpScaleBase : public mpLayer
{ {
public: public:
mpScaleBase () { m_rangeSet = false; m_nameFlags = mpALIGN_BORDER_BOTTOM; }; mpScaleBase () { m_rangeSet = false; m_nameFlags = mpALIGN_BORDER_BOTTOM; };
virtual ~mpScaleBase () {}; virtual ~mpScaleBase () {};
virtual bool IsHorizontal() = 0; virtual bool IsHorizontal() = 0;
bool HasBBox() { return FALSE; } bool HasBBox() { return FALSE; }
/** Set X axis alignment. /** Set X axis alignment.
@param align alignment (choose between mpALIGN_BORDER_BOTTOM, mpALIGN_BOTTOM, mpALIGN_CENTER, mpALIGN_TOP, mpALIGN_BORDER_TOP */ @param align alignment (choose between mpALIGN_BORDER_BOTTOM, mpALIGN_BOTTOM, mpALIGN_CENTER, mpALIGN_TOP, mpALIGN_BORDER_TOP */
void SetAlign(int align) { m_flags = align; }; void SetAlign(int align) { m_flags = align; };
void SetNameAlign ( int align ) { m_nameFlags = align; } void SetNameAlign ( int align ) { m_nameFlags = align; }
/** Set X axis ticks or grid /** Set X axis ticks or grid
@param ticks TRUE to plot axis ticks, FALSE to plot grid. */ @param ticks TRUE to plot axis ticks, FALSE to plot grid. */
void SetTicks(bool enable) { m_ticks = enable; }; void SetTicks(bool enable) { m_ticks = enable; };
/** Get X axis ticks or grid /** Get X axis ticks or grid
@return TRUE if plot is drawing axis ticks, FALSE if the grid is active. */ @return TRUE if plot is drawing axis ticks, FALSE if the grid is active. */
bool GetTicks() { return m_ticks; }; bool GetTicks() { return m_ticks; };
//virtual double X2p( mpWindow &w, double x ) = 0; //virtual double X2p( mpWindow &w, double x ) = 0;
//virtual double P2x( mpWindow &w, double x ) = 0; //virtual double P2x( mpWindow &w, double x ) = 0;
void SetDataRange ( double minV, double maxV ) void SetDataRange ( double minV, double maxV )
{
m_rangeSet = true;
m_minV = minV;
m_maxV = maxV;
}
void GetDataRange ( double &minV, double& maxV)
{
minV = m_minV;
maxV = m_maxV;
}
void ExtendDataRange ( double minV, double maxV )
{
if(!m_rangeSet)
{ {
m_rangeSet = true;
m_minV = minV; m_minV = minV;
m_maxV = maxV; m_maxV = maxV;
m_rangeSet = true;
} else {
m_minV = std::min(minV, m_minV);
m_maxV = std::max(maxV, m_maxV);
} }
if (m_minV == m_maxV) void GetDataRange ( double &minV, double& maxV)
{ {
m_minV = -1.0; minV = m_minV;
m_maxV = 1.0; maxV = m_maxV;
} }
}
void ResetDataRange() void ExtendDataRange ( double minV, double maxV )
{ {
m_rangeSet = 0; if(!m_rangeSet)
} {
m_minV = minV;
m_maxV = maxV;
m_rangeSet = true;
} else {
m_minV = std::min(minV, m_minV);
m_maxV = std::max(maxV, m_maxV);
}
double AbsMaxValue() const if (m_minV == m_maxV)
{ {
return std::max(std::abs(m_maxV), std::abs(m_minV)); m_minV = -1.0;
} m_maxV = 1.0;
}
}
double AbsVisibleMaxValue() const void ResetDataRange()
{ {
m_rangeSet = 0;
}
double AbsMaxValue() const
{
return std::max(std::abs(m_maxV), std::abs(m_minV));
}
double AbsVisibleMaxValue() const
{
return m_absVisibleMaxV; return m_absVisibleMaxV;
} }
virtual double TransformToPlot ( double x ) { return 0.0; }; virtual double TransformToPlot ( double x ) { return 0.0; };
virtual double TransformFromPlot (double xplot ){ return 0.0; }; virtual double TransformFromPlot (double xplot ){ return 0.0; };
struct TickLabel { struct TickLabel {
TickLabel( double pos_=0.0, const wxString& label_ = wxT("") ) : TickLabel( double pos_=0.0, const wxString& label_ = wxT("") ) :
pos ( pos_ ), pos ( pos_ ),
label ( label_ ) {}; label ( label_ ) {};
double pos; double pos;
wxString label; wxString label;
int pixelPos; int pixelPos;
bool visible; bool visible;
}; };
std::vector<TickLabel>& TickLabels() { return m_tickLabels; }; std::vector<TickLabel>& TickLabels() { return m_tickLabels; };
protected: protected:
void updateTickLabels( wxDC & dc, mpWindow & w ); void updateTickLabels( wxDC & dc, mpWindow & w );
void computeLabelExtents ( wxDC & dc, mpWindow & w ); void computeLabelExtents ( wxDC & dc, mpWindow & w );
//virtual int getLabelDecimalDigits(int maxDigits); //virtual int getLabelDecimalDigits(int maxDigits);
virtual void getVisibleDataRange ( mpWindow& w, double &minV, double& maxV) {}; virtual void getVisibleDataRange ( mpWindow& w, double &minV, double& maxV) {};
virtual void recalculateTicks ( wxDC & dc, mpWindow & w ) {}; virtual void recalculateTicks ( wxDC & dc, mpWindow & w ) {};
int tickCount() const int tickCount() const
{ {
return m_tickValues.size(); return m_tickValues.size();
} }
virtual int labelCount() const virtual int labelCount() const
{ {
return m_tickLabels.size(); return m_tickLabels.size();
} }
virtual const wxString formatLabel( double value, int nDigits ) { return wxT(""); } virtual const wxString formatLabel( double value, int nDigits ) { return wxT(""); }
virtual void formatLabels( ) { }; virtual void formatLabels( ) { };
virtual double getTickPos( int n ) virtual double getTickPos( int n )
{ {
return m_tickValues [n]; return m_tickValues [n];
} }
virtual double getLabelPos( int n ) virtual double getLabelPos( int n )
{ {
return m_tickLabels[n].pos; return m_tickLabels[n].pos;
} }
virtual const wxString getLabel( int n ) virtual const wxString getLabel( int n )
{ {
return m_tickLabels[n].label; return m_tickLabels[n].label;
} }
std::vector<double> m_tickValues; std::vector<double> m_tickValues;
std::vector<TickLabel> m_tickLabels; std::vector<TickLabel> m_tickLabels;
double m_offset, m_scale; double m_offset, m_scale;
double m_absVisibleMaxV; double m_absVisibleMaxV;
int m_flags; //!< Flag for axis alignment int m_flags; //!< Flag for axis alignment
int m_nameFlags; int m_nameFlags;
bool m_ticks; //!< Flag to toggle between ticks or grid bool m_ticks; //!< Flag to toggle between ticks or grid
double m_minV, m_maxV; double m_minV, m_maxV;
bool m_rangeSet; bool m_rangeSet;
int m_maxLabelHeight; int m_maxLabelHeight;
int m_maxLabelWidth; int m_maxLabelWidth;
}; };
@ -850,8 +850,8 @@ class WXDLLIMPEXP_MATHPLOT mpScaleXBase : public mpScaleBase
virtual void getVisibleDataRange ( mpWindow& w, double &minV, double& maxV); virtual void getVisibleDataRange ( mpWindow& w, double &minV, double& maxV);
// unsigned int m_labelType; //!< Select labels mode: mpX_NORMAL for normal labels, mpX_TIME for time axis in hours, minutes, seconds // unsigned int m_labelType; //!< Select labels mode: mpX_NORMAL for normal labels, mpX_TIME for time axis in hours, minutes, seconds
// wxString m_labelFormat; //!< Format string used to print labels // wxString m_labelFormat; //!< Format string used to print labels
DECLARE_DYNAMIC_CLASS(mpScaleXBase) DECLARE_DYNAMIC_CLASS(mpScaleXBase)
}; };
@ -981,7 +981,7 @@ class WXDLLIMPEXP_MATHPLOT mpScaleY : public mpScaleBase
void computeSlaveTicks ( mpWindow& w ); void computeSlaveTicks ( mpWindow& w );
mpScaleY * m_masterScale; mpScaleY * m_masterScale;
// double m_minV, m_maxV; // double m_minV, m_maxV;
int m_maxLabelHeight; int m_maxLabelHeight;
int m_maxLabelWidth; int m_maxLabelWidth;
@ -1302,7 +1302,7 @@ class WXDLLIMPEXP_MATHPLOT mpWindow : public wxWindow
@param imageSize Set a size for the output image. Default is the same as the screen size @param imageSize Set a size for the output image. Default is the same as the screen size
@param fit Decide whether to fit the plot into the size*/ @param fit Decide whether to fit the plot into the size*/
bool SaveScreenshot(const wxString& filename, wxBitmapType type = wxBITMAP_TYPE_BMP, bool SaveScreenshot(const wxString& filename, wxBitmapType type = wxBITMAP_TYPE_BMP,
wxSize imageSize = wxDefaultSize, bool fit = false); wxSize imageSize = wxDefaultSize, bool fit = false);
/** This value sets the zoom steps whenever the user clicks "Zoom in/out" or performs zoom with the mouse wheel. /** This value sets the zoom steps whenever the user clicks "Zoom in/out" or performs zoom with the mouse wheel.
* It must be a number above unity. This number is used for zoom in, and its inverse for zoom out. Set to 1.5 by default. */ * It must be a number above unity. This number is used for zoom in, and its inverse for zoom out. Set to 1.5 by default. */
@ -1385,7 +1385,7 @@ class WXDLLIMPEXP_MATHPLOT mpWindow : public wxWindow
// void OnScroll2 (wxScrollWinEvent &event); //!< Scroll handler, will move canvas // void OnScroll2 (wxScrollWinEvent &event); //!< Scroll handler, will move canvas
void OnShowPopupMenu (wxMouseEvent &event); //!< Mouse handler, will show context menu void OnShowPopupMenu (wxMouseEvent &event); //!< Mouse handler, will show context menu
void OnMouseMiddleDown(wxMouseEvent &event); //!< Mouse handler, for detecting when the user void OnMouseMiddleDown(wxMouseEvent &event); //!< Mouse handler, for detecting when the user
//!< drags with the middle button or just "clicks" for the menu //!< drags with the middle button or just "clicks" for the menu
void OnCenter (wxCommandEvent &event); //!< Context menu handler void OnCenter (wxCommandEvent &event); //!< Context menu handler
void OnFit (wxCommandEvent &event); //!< Context menu handler void OnFit (wxCommandEvent &event); //!< Context menu handler
void OnZoomIn (wxCommandEvent &event); //!< Context menu handler void OnZoomIn (wxCommandEvent &event); //!< Context menu handler
@ -1414,14 +1414,14 @@ class WXDLLIMPEXP_MATHPLOT mpWindow : public wxWindow
{ {
return !(m_enableLimitedView return !(m_enableLimitedView
&& (desiredMax > m_maxX - m_marginRight / m_scaleX && (desiredMax > m_maxX - m_marginRight / m_scaleX
|| desiredMin < m_minX - m_marginLeft / m_scaleX)); || desiredMin < m_minX - m_marginLeft / m_scaleX));
} }
bool CheckYLimits(double& desiredMax, double& desiredMin) const bool CheckYLimits(double& desiredMax, double& desiredMin) const
{ {
return !(m_enableLimitedView return !(m_enableLimitedView
&& (desiredMax > m_maxY + m_marginBottom / m_scaleY && (desiredMax > m_maxY + m_marginBottom / m_scaleY
|| desiredMin < m_minY + m_marginTop / m_scaleY)); || desiredMin < m_minY + m_marginTop / m_scaleY));
} }
void AdjustLimitedView(); void AdjustLimitedView();
@ -1555,7 +1555,7 @@ class WXDLLIMPEXP_MATHPLOT mpFXYVector : public mpFXY
*/ */
bool GetNextXY(double & x, double & y); bool GetNextXY(double & x, double & y);
public: public:
/** Returns the actual minimum X data (loaded in SetData). /** Returns the actual minimum X data (loaded in SetData).
*/ */
double GetMinX() { return m_minX; } double GetMinX() { return m_minX; }
@ -1572,7 +1572,7 @@ public:
*/ */
double GetMaxY() { return m_maxY; } double GetMaxY() { return m_maxY; }
protected: protected:
int m_flags; //!< Holds label alignment int m_flags; //!< Holds label alignment
DECLARE_DYNAMIC_CLASS(mpFXYVector) DECLARE_DYNAMIC_CLASS(mpFXYVector)
@ -1953,19 +1953,13 @@ class WXDLLIMPEXP_MATHPLOT mpBitmapLayer : public mpLayer
wxBitmap m_scaledBitmap; wxBitmap m_scaledBitmap;
wxCoord m_scaledBitmap_offset_x,m_scaledBitmap_offset_y; wxCoord m_scaledBitmap_offset_x,m_scaledBitmap_offset_y;
bool m_validImg; bool m_validImg;
/** The shape of the bitmap: /** The shape of the bitmap:
*/ */
double m_min_x,m_max_x,m_min_y,m_max_y; double m_min_x,m_max_x,m_min_y,m_max_y;
}; };
/*@}*/ /*@}*/
#endif // _MP_MATHPLOT_H_ #endif // _MP_MATHPLOT_H_