2019-02-08 00:24:46 +08:00
/*
2020-08-26 18:58:23 +08:00
Copyright ( c ) 2008 - 2020 Jan W . Krieger ( < jan @ jkrieger . de > )
2019-02-08 00:24:46 +08:00
This software is free software : you can redistribute it and / or modify
it under the terms of the GNU Lesser General Public License ( LGPL ) as published by
the Free Software Foundation , either version 2.1 of the License , or
( at your option ) any later version .
This program is distributed in the hope that it will be useful ,
but WITHOUT ANY WARRANTY ; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
GNU Lesser General Public License ( LGPL ) for more details .
You should have received a copy of the GNU Lesser General Public License ( LGPL )
along with this program . If not , see < http : //www.gnu.org/licenses/>.
*/
# ifndef JKQTPCOORDINATEAXES_H
# define JKQTPCOORDINATEAXES_H
# include <QString>
# include <QPainter>
# include <QPair>
# include <QSettings>
2019-05-30 04:40:02 +08:00
# include "jkqtplotter/jkqtptools.h"
2019-02-08 00:24:46 +08:00
# include "jkqtmathtext/jkqtmathtext.h"
2019-06-22 20:21:32 +08:00
# include "jkqtplotter/jkqtplotter_imexport.h"
2019-02-08 00:24:46 +08:00
# include "jkqtplotter/jkqtpcoordinateaxesstyle.h"
// forward declarations
class JKQTBasePlotter ;
/*! \brief this virtual class is the base for any type of coordinate axis, to be drawn by JKQTBasePlotter.
\ ingroup jkqtpbaseplotter_elements
This class implements all the functionality needed for a coordinate axis :
- transform world to screen coordinates and vice versa
- draw the axis ( implemented by child classes ! ) with these elements : axis lines , JKQTPCoordinateAxisStyle : : ticks , tick labels , axis label , x / y = 0 axis
- measure the axes in screen coordinates
- load and save the settings to an ini file
.
Most of the actual draw and measure functions have to be implemented in descendents of this class ( namely
JKQTPHorizontalAxis and JKQTPVerticalAxis , as they are specific to whether the axis is drawn horizontally or
vertically .
Each axis is split up into several parts , as depicted in this image :
\ image html jkqtpcoordinateaxis1 . png
Which parts to actually draw is set by the diverse properties .
\ section jkqtplotter_base_systems_baseelements Coordinate Systems and Transformations
The plot itself is positioned inside the widget ( see \ ref jkqtplotter_base_plotsize for details ) .
You simply supply the widget dimensions and the border
widths between the plot and the widget . The Object then calculates the size of the plot :
\ image html plot_widget_orientation . png
The plot shows the parameter range xmin . . . xmax and ymin . . . ymax . Note that if you plot logarithmic plots
you may only plot positive ( > 0 ) values . Any other value may lead to an error or unpredictable behaviour .
From these parameters the object calculates the scaling laws for plotting pints to the screen . The next paragraphs
show all calculations for x - and y - coordinates , ahough this class only implements a generic form . The actual calculation
is also influenced by the parameters set in the child classes !
- # < tt > width = xmax - xmin < / tt >
- # < tt > height = ymax - ymin < / tt >
- # < tt > plotWidth = widgetWidth - plotBorderLeft - plotBorderRight < / tt >
- # < tt > plotHeight = widgetHeight - plotBorderTop - plotBorderBottom < / tt >
- # < tt > xPlotOffset = plotBorderLeft < / tt >
- # < tt > yPlotOffset = plotBorderTop < / tt >
.
These parameters are common to all scaling laws . The next image explains these formulas :
\ image html plot_coordinates . png
The actual scaling laws \ f $ ( x_p ( x ) , y_p ( y ) ) \ f $ may be derived from these equations :
\ f [ x_p ( \ mbox { xmin } ) = \ mbox { xPlotOffset } , \ \ \ \ \ x_p ( \ mbox { xmax } ) = \ mbox { xPlotOffset } + \ mbox { plotWidth } \ f ]
\ f [ y_p ( \ mbox { ymax } ) = \ mbox { yPlotOffset } , \ \ \ \ \ y_p ( \ mbox { ymin } ) = \ mbox { yPlotOffset } + \ mbox { plotHeight } \ f ]
Here \ f $ ( x_p , y_p ) \ f $ denotes a point in pixel coordinates ( green coordinate system ) and \ f $ ( x , y ) \ f $ denotes a point in the
plotting coordinate system .
If you assume a < b > linear scaling law < / b > . \ f [ x_p ( x ) = \ mbox { xoffset } + x \ cdot \ mbox { xscale } \ \ \ \ \ \ \ \ \ y_p ( y ) = \ mbox { yoffset } - y \ cdot \ mbox { yscale } \ f ]
you can derive :
\ f [ \ mbox { xscale } = \ frac { \ mbox { plotWidth } } { \ mbox { xwidth } } , \ \ \ \ \ \ \ mbox { xoffset } = \ mbox { xPlotOffset } - \ mbox { xmin } \ cdot \ mbox { xscale } \ f ]
\ f [ \ mbox { yscale } = \ frac { \ mbox { plotHeight } } { \ mbox { ywidth } } , \ \ \ \ \ \ \ mbox { yoffset } = \ mbox { yPlotOffset } + \ mbox { ymax } \ cdot \ mbox { yscale } \ f ]
If you have a < b > logarithmic axis < / b > ( i . e . we plot \ f $ \ log_b ( x ) \ f $ insetad of \ f $ x \ f $ for a given base \ f $ b \ f $ ) we get the same
formulas , but with \ f $ x \ f $ exchanged by \ f $ \ log_b ( x ) \ f $ . If we use the equation \ f $ \ log_b ( x ) = \ log ( x ) / \ log ( b ) \ f $ we finally get
the scaling laws :
\ f [ x_p ( x ) = \ mbox { xoffset } + \ frac { \ log ( x ) } { \ log ( \ mbox { logXAxisBase } ) } \ cdot \ mbox { xscale } \ \ \ \ \ \ \ \ \ y_p ( y ) = \ mbox { yoffset } - \ frac { \ log ( y ) } { \ log ( \ mbox { logYAxisBase } ) } \ cdot \ mbox { yscale } \ f ]
From these we can calculate their parameters with the same defining equations as above :
\ f [ \ mbox { xscale } = \ frac { \ mbox { plotWidth } \ cdot \ log ( \ mbox { logXAxisBase } ) } { \ log ( \ mbox { xmax } ) - \ log ( \ mbox { xmin } ) } , \ \ \ \ \ \ \ mbox { xoffset } = \ mbox { xPlotOffset } - \ frac { \ log ( \ mbox { xmin } ) } { \ log ( \ mbox { logXAxisBase } ) } \ cdot \ mbox { xscale } \ f ]
\ f [ \ mbox { yscale } = \ frac { \ mbox { plotHeight } \ cdot \ log ( \ mbox { logYAxisBase } ) } { \ log ( \ mbox { ymax } ) - \ log ( \ mbox { ymin } ) } , \ \ \ \ \ \ \ mbox { yoffset } = \ mbox { yPlotOffset } + \ frac { \ log ( \ mbox { ymax } ) } { \ log ( \ mbox { logYAxisBase } ) } \ cdot \ mbox { yscale } \ f ]
The object implements the above coordinate transformations in the ( inline ) method x2p ( ) . The inverse transformations
are implemented in p2x ( ) . They can be used to show the system coordinates of the current mouse position .
2019-02-10 05:17:01 +08:00
\ section jkqtplotter_coordinateaxes_inverted Inverted Coordinate Axes
In some cases it may be necessary to invert the direction of increasing coordinates on an axis . One such case is image analysis , as computer images usually
have coordinates starting with ( 0 , 0 ) at the top left and increasing to the right ( x ) and down ( y ) . You can invert any axis by setting \ c setInverted ( true ) .
\ image html jkqtplotter_inverted_yaxis . png
\ see You can find example here : \ ref JKQTPlotterImagePlotQImageRGB and \ ref JKQTPlotterImagePlotRGBOpenCV
2019-02-08 00:24:46 +08:00
\ section jkqtplotter_base_grids_baseelemenets Axis JKQTPCoordinateAxisStyle : : Ticks and Grids
This section explains how this component draws the JKQTPCoordinateAxisStyle : : ticks on coordinate axes and the grids that may be drawn below
the plots . In principle both - grids and axes - are drawn the same way , i . e . with the same step widths . There are
two types of JKQTPCoordinateAxisStyle : : ticks and grids : The major and the minor JKQTPCoordinateAxisStyle : : ticks / grids . The major JKQTPCoordinateAxisStyle : : ticks also show a label that denotes the
value they represent . Between two major JKQTPCoordinateAxisStyle : : ticks the axis shows \ a JKQTPCoordinateAxisStyle : : minorTicks small JKQTPCoordinateAxisStyle : : ticks that are not
accompanied by a label . The next image shows an example of an axis :
\ image html plot_axis_ticksandlabels . png
For the labels this class also uses an algorithm that extimates the number of valid digits ( after the comma ) that are
needed so that two adjacent labels do not show the same text , so if you plot the range 1.10 . . 1.15 The algorithm will
show at least two valid digits , as with one digit the labels would be 1.1 , 1.1 , 1.1 , 1.1 , 1.1 , 1.1 . With two digits they
are 1.10 , 1.11 , 1.12 , 1.13 , 1.14 , 1.15 . The class may also use a method that can write \ c 1 m instead of \ c 0.001 and \ c 1 k
instead of \ c 1000 ( the algorithm supports the " exponent letters " f , p , n , u , m , k , M , G , T , P . The latter option may
( de ) activated by using showXExponentCharacter and showYExponentCharacter .
For grids applies the same . There are two grids that are drawn in different styles ( often the major grid is drawn
thicker and darker than the minor grid ) .
The minor JKQTPCoordinateAxisStyle : : ticks and grid lines are generated automatically , depending in the setting of \ a JKQTPCoordinateAxisStyle : : minorTicks .
These properties give the number of minor JKQTPCoordinateAxisStyle : : ticks between two major JKQTPCoordinateAxisStyle : : ticks , so if the major JKQTPCoordinateAxisStyle : : ticks are at 1 , 2 , 3 , . . . and you
want minor JKQTPCoordinateAxisStyle : : ticks at 1.1 , 1.2 , 1.3 , . . . then you will have to set \ c JKQTPCoordinateAxisStyle : : minorTicks = 9 as there are nine JKQTPCoordinateAxisStyle : : ticks between two major
JKQTPCoordinateAxisStyle : : ticks . So the minor tick spacing is calculated as : \ f [ \ Delta \ mbox { MinorTicks } = \ frac { \ Delta \ mbox { ticks } } { \ mbox { minorTicks } + 1 } \ f ]
The same applies for logarithmic axes . If the major JKQTPCoordinateAxisStyle : : ticks are at 1 , 10 , 100 , . . . and you set \ c JKQTPCoordinateAxisStyle : : minorTicks = 9 the program will
generate 9 equally spaced minor JKQTPCoordinateAxisStyle : : ticks in between , so you have minor JKQTPCoordinateAxisStyle : : ticks at 2 , 3 , 4 , . . . , 11 , 12 , 13 , . . . This results in a standard
logarithmic axis . If you set \ c JKQTPCoordinateAxisStyle : : minorTicks = 1 then you will get minor JKQTPCoordinateAxisStyle : : ticks at 5 , 15 , 150 , . . .
\ image html plot_logaxis_ticksandlabels . png
The major tick - tick distances of linear axes may be calculated automatically in a way that the axis shows at least a given
number of JKQTPCoordinateAxisStyle : : ticks \ c JKQTPCoordinateAxisStyle : : minTicks . The algorithm takes that tick spacing that will give a number of JKQTPCoordinateAxisStyle : : ticks per axis
nearest but \ c " >= " to the given \ c JKQTPCoordinateAxisStyle : : minTicks . The Algorithm is described in detail with the function
calcLinearTickSpacing ( ) . To activate this automatic tick spacing you have to set < code > autoAxisSpacing = true < / code > .
*/
2019-06-22 20:21:32 +08:00
class JKQTPLOTTER_LIB_EXPORT JKQTPCoordinateAxis : public QObject {
2019-02-08 00:24:46 +08:00
Q_OBJECT
protected :
public :
/** \brief class constructor */
explicit JKQTPCoordinateAxis ( JKQTBasePlotter * parent ) ;
/** \brief class destructor */
virtual ~ JKQTPCoordinateAxis ( ) ;
virtual void setParent ( JKQTBasePlotter * parent ) ;
/** \brief loads the plot properties from a QSettings object */
virtual void loadSettings ( const QSettings & settings , const QString & group = QString ( " plots/axes/ " ) ) ;
/** \brief saves the plot properties into a QSettings object.
*
* This method only saves those properties that differ from their default value .
*/
virtual void saveSettings ( QSettings & settings , const QString & group = QString ( " plots/axes/ " ) ) const ;
/** \brief return x-pixel coordinate from time coordinate */
inline double x2p ( double x ) const {
double r = 0 ;
if ( logAxis ) {
if ( x < = 0 ) r = offset + scaleSign * log ( axismin ) / log ( logAxisBase ) * scale ;
else r = offset + scaleSign * log ( x ) / log ( logAxisBase ) * scale ;
} else {
r = offset + scaleSign * x * scale ;
}
if ( inverted ) {
return 2.0 * getParentPlotOffset ( ) + getParentPlotWidth ( ) - r ; //getParentPlotOffset()+getParentPlotWidth()-(r-getParentPlotOffset());
} else {
return r ;
}
}
/** \brief return time coordinate coordinate from x-pixel */
inline double p2x ( double x ) const {
double xx = x ;
if ( inverted ) {
xx = 2.0 * getParentPlotOffset ( ) + getParentPlotWidth ( ) - x ;
}
xx = xx - offset ;
if ( logAxis ) {
return exp ( log ( logAxisBase ) * ( xx ) / ( scaleSign * scale ) ) ;
} else {
return xx / ( scaleSign * scale ) ;
}
}
/** \brief clear axis tick labels. This switches back to automatic labels mode for the axis. */
void clearAxisTickLabels ( ) ;
/** \brief add a new tick label to the axis */
void addAxisTickLabel ( double x , const QString & label ) ;
/** \brief add a new tick label to the axis */
void addAxisTickLabels ( const QVector < double > & x , const QStringList & label ) ;
/** \brief add a new tick label to the axis */
void addAxisTickLabels ( const double * x , const QStringList & label ) ;
/** \brief add a new tick label to the axis */
void addAxisTickLabels ( const QVector < double > & x , const QString * label ) ;
/** \brief add a new tick label to the axis */
void addAxisTickLabels ( const double * x , const QString * label , int items ) ;
/** \brief returns the size of the left/bottom axis in pt */
virtual QSizeF getSize1 ( JKQTPEnhancedPainter & painter ) = 0 ;
/** \brief returns the size of the right/top axis in pt */
virtual QSizeF getSize2 ( JKQTPEnhancedPainter & painter ) = 0 ;
/** \brief draw axes */
virtual void drawAxes ( JKQTPEnhancedPainter & painter ) = 0 ;
/** \brief draw grids */
virtual void drawGrids ( JKQTPEnhancedPainter & painter ) = 0 ;
2019-05-18 02:46:52 +08:00
/*! \copydoc tickSpacing */
2019-02-08 00:24:46 +08:00
inline double getTickSpacing ( ) const { return this - > tickSpacing ; }
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::labelDigits */
2019-02-08 00:24:46 +08:00
inline int getLabelDigits ( ) const { return this - > axisStyle . labelDigits ; }
2019-05-18 02:46:52 +08:00
/*! \copydoc autoAxisSpacing */
2019-02-08 00:24:46 +08:00
inline bool getAutoAxisSpacing ( ) const { return this - > autoAxisSpacing ; }
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::minorTickLabelsEnabled */
2019-02-08 00:24:46 +08:00
inline bool getMinorTickLabelsEnabled ( ) const { return this - > axisStyle . minorTickLabelsEnabled ; }
2019-05-18 02:46:52 +08:00
/*! \copydoc logAxis */
2019-02-08 00:24:46 +08:00
inline bool getLogAxis ( ) const { return this - > logAxis ; }
2019-05-18 02:46:52 +08:00
/*! \copydoc inverted */
2019-02-08 00:24:46 +08:00
inline bool getInverted ( ) const { return this - > inverted ; }
2019-05-18 02:46:52 +08:00
/*! \copydoc logAxisBase */
2019-02-08 00:24:46 +08:00
inline double getLogAxisBase ( ) const { return this - > logAxisBase ; }
2019-05-18 02:46:52 +08:00
/*! \copydoc userTickSpacing */
2019-02-08 00:24:46 +08:00
inline double getUserTickSpacing ( ) const { return this - > userTickSpacing ; }
2019-05-18 02:46:52 +08:00
/*! \copydoc userLogTickSpacing */
2019-02-08 00:24:46 +08:00
inline double getUserLogTickSpacing ( ) const { return this - > userLogTickSpacing ; }
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::labelType */
2019-02-08 00:24:46 +08:00
inline JKQTPCALabelType getLabelType ( ) const { return this - > axisStyle . labelType ; }
2019-05-18 02:46:52 +08:00
/*! \copydoc axisLabel */
2019-02-08 00:24:46 +08:00
inline QString getAxisLabel ( ) const { return this - > axisLabel ; }
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::labelPosition */
2019-02-08 00:24:46 +08:00
inline JKQTPLabelPosition getLabelPosition ( ) const { return this - > axisStyle . labelPosition ; }
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::labelFontSize */
2019-02-08 00:24:46 +08:00
inline double getLabelFontSize ( ) const { return this - > axisStyle . labelFontSize ; }
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::tickLabelFontSize */
2019-02-08 00:24:46 +08:00
inline double getTickLabelFontSize ( ) const { return this - > axisStyle . tickLabelFontSize ; }
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::minorTickLabelFontSize */
2019-02-08 00:24:46 +08:00
inline double getMinorTickLabelFontSize ( ) const { return this - > axisStyle . minorTickLabelFontSize ; }
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::minorTickLabelFullNumber */
2019-02-08 00:24:46 +08:00
inline bool getMinorTickLabelFullNumber ( ) const { return this - > axisStyle . minorTickLabelFullNumber ; }
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::tickLabelAngle */
2019-02-08 00:24:46 +08:00
inline double getTickLabelAngle ( ) const { return this - > axisStyle . tickLabelAngle ; }
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::minTicks */
2019-02-08 00:24:46 +08:00
inline unsigned int getMinTicks ( ) const { return this - > axisStyle . minTicks ; }
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::minorTicks */
2019-02-08 00:24:46 +08:00
inline unsigned int getMinorTicks ( ) const { return this - > axisStyle . minorTicks ; }
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::tickOutsideLength */
2019-02-08 00:24:46 +08:00
inline double getTickOutsideLength ( ) const { return this - > axisStyle . tickOutsideLength ; }
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::minorTickOutsideLength */
2019-02-08 00:24:46 +08:00
inline double getMinorTickOutsideLength ( ) const { return this - > axisStyle . minorTickOutsideLength ; }
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::axisColor */
2019-02-08 00:24:46 +08:00
inline QColor getAxisColor ( ) const { return this - > axisStyle . axisColor ; }
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::showZeroAxis */
2019-02-08 00:24:46 +08:00
inline bool getShowZeroAxis ( ) const { return this - > axisStyle . showZeroAxis ; }
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::gridColor */
2019-02-08 00:24:46 +08:00
inline QColor getGridColor ( ) const { return this - > axisStyle . gridColor ; }
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::minorGridColor */
2019-02-08 00:24:46 +08:00
inline QColor getMinorGridColor ( ) const { return this - > axisStyle . minorGridColor ; }
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::gridWidth */
2019-02-08 00:24:46 +08:00
inline double getGridWidth ( ) const { return this - > axisStyle . gridWidth ; }
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::gridStyle */
2019-02-08 00:24:46 +08:00
inline Qt : : PenStyle getGridStyle ( ) const { return this - > axisStyle . gridStyle ; }
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::minorGridWidth */
2019-02-08 00:24:46 +08:00
inline double getMinorGridWidth ( ) const { return this - > axisStyle . minorGridWidth ; }
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::minorGridStyle */
2019-02-08 00:24:46 +08:00
inline Qt : : PenStyle getMinorGridStyle ( ) const { return this - > axisStyle . minorGridStyle ; }
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::tickTimeFormat */
2019-02-08 00:24:46 +08:00
inline QString getTickTimeFormat ( ) const { return this - > axisStyle . tickTimeFormat ; }
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::tickDateFormat */
2019-02-08 00:24:46 +08:00
inline QString getTickDateFormat ( ) const { return this - > axisStyle . tickDateFormat ; }
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::tickDateTimeFormat */
2019-02-08 00:24:46 +08:00
inline QString getTickDateTimeFormat ( ) const { return this - > axisStyle . tickDateTimeFormat ; }
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::tickMode */
2019-02-08 00:24:46 +08:00
inline JKQTPLabelTickMode getTickMode ( ) const { return this - > axisStyle . tickMode ; }
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::drawMode1 */
2019-02-08 00:24:46 +08:00
inline JKQTPCADrawMode getDrawMode1 ( ) const { return this - > axisStyle . drawMode1 ; }
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::drawMode2 */
2019-02-08 00:24:46 +08:00
inline JKQTPCADrawMode getDrawMode2 ( ) const { return this - > axisStyle . drawMode2 ; }
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::minorTickWidth */
2019-02-08 00:24:46 +08:00
inline double getMinorTickWidth ( ) const { return this - > axisStyle . minorTickWidth ; }
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::tickWidth */
2019-02-08 00:24:46 +08:00
inline double getTickWidth ( ) const { return this - > axisStyle . tickWidth ; }
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::lineWidth */
2019-02-08 00:24:46 +08:00
inline double getLineWidth ( ) const { return this - > axisStyle . lineWidth ; }
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::lineWidthZeroAxis */
2019-02-08 00:24:46 +08:00
inline double getLineWidthZeroAxis ( ) const { return this - > axisStyle . lineWidthZeroAxis ; }
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::tickLabelDistance */
2019-02-08 00:24:46 +08:00
inline double getTickLabelDistance ( ) const { return this - > axisStyle . tickLabelDistance ; }
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::labelDistance */
2019-02-08 00:24:46 +08:00
inline double getLabelDistance ( ) const { return this - > axisStyle . labelDistance ; }
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::drawGrid */
2019-02-08 00:24:46 +08:00
inline bool getDrawGrid ( ) const { return this - > axisStyle . drawGrid ; }
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::drawMinorGrid */
2019-02-08 00:24:46 +08:00
inline bool getDrawMinorGrid ( ) const { return this - > axisStyle . drawMinorGrid ; }
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::autoLabelDigits */
2019-02-08 00:24:46 +08:00
inline void setAutoLabelDigits ( bool __value )
{
this - > axisStyle . autoLabelDigits = __value ;
}
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::autoLabelDigits */
2019-02-08 00:24:46 +08:00
inline bool getAutoLabelDigits ( ) const
{
return this - > axisStyle . autoLabelDigits ;
}
2019-05-18 02:46:52 +08:00
/*! \copydoc parent */
2019-02-08 00:24:46 +08:00
inline const JKQTBasePlotter * getParent ( ) const { return this - > parent ; }
2019-05-19 04:41:38 +08:00
/*! \copydoc parent */
2019-02-08 00:24:46 +08:00
inline JKQTBasePlotter * getParent ( ) { return this - > parent ; }
2019-05-19 04:41:38 +08:00
/*! \copydoc doUpdateScaling */
2019-02-08 00:24:46 +08:00
inline void setDoUpdateScaling ( bool __value )
{
this - > doUpdateScaling = __value ;
}
2019-05-19 04:41:38 +08:00
/*! \copydoc doUpdateScaling */
2019-02-08 00:24:46 +08:00
inline bool getDoUpdateScaling ( ) const
{
return this - > doUpdateScaling ;
}
/** \brief returns the current min */
inline double getMin ( ) const { return axismin ; }
/** \brief returns the current max */
inline double getMax ( ) const { return axismax ; }
/** \brief returns the current absolute min */
inline double getAbsoluteMin ( ) const { return axisabsoultemin ; }
/** \brief returns the current absolute max */
inline double getAbsoluteMax ( ) const { return axisabsoultemax ; }
/** \brief calculate the scaling and offset values from axis min/max values
*
* This is only executed when \ c paramChanged = = true , as otherwise the data has to be still
* correct . recalculating may be forced by caling calcPlotScaing ( true ) ;
*/
void calcPlotScaling ( bool force = false ) ;
/** \brief returns whether this axis uses logarithmic scaling */
bool isLogAxis ( ) const ;
2020-09-04 04:56:38 +08:00
/** \brief returns whether this axis uses linear scaling (is false e.g. for isLogAxis()==true) */
bool isLinearAxis ( ) const ;
2019-02-08 00:24:46 +08:00
/** \brief current style properties for this JKQTBasePlotter
*
* \ see JKQTPSetSystemDefaultBaseStyle ( ) , JKQTPSetSystemDefaultBaseStyle ( ) , setCurrentAxisStyle ( ) , getCurrentAxisStyle ( ) , \ ref jkqtpplotter_styling
*/
const JKQTPCoordinateAxisStyle & getCurrentAxisStyle ( ) const ;
/** \brief replace the current style properties for this JKQTBasePlotter
*
* \ see JKQTPSetSystemDefaultBaseStyle ( ) , JKQTPSetSystemDefaultBaseStyle ( ) , setCurrentAxisStyle ( ) , getCurrentAxisStyle ( ) , \ ref jkqtpplotter_styling
*/
void setCurrentAxisStyle ( const JKQTPCoordinateAxisStyle & style ) ;
/** \brief replace the current style properties for this JKQTBasePlotter with properties loaded from \a settings
*
* \ param settings the QSettings object to read from
* \ param group group in \ a settings to read from
*
* \ see JKQTPCoordinateAxisStyle getCurrentAxisStyle ( ) , \ ref jkqtpplotter_styling
*/
void loadCurrentAxisStyle ( const QSettings & settings , const QString & group = " plot/axes/ " ) ;
/** \brief store the current style properties for this JKQTBasePlotter with properties loaded from \a settings
*
* \ param settings the QSettings object to write to
* \ param group group in \ a settings to write to
*
* \ see JKQTPSetSystemDefaultBaseStyle ( ) , JKQTPSetSystemDefaultBaseStyle ( ) , setCurrentAxisStyle ( ) , getCurrentAxisStyle ( ) , \ ref jkqtpplotter_styling
*/
void saveCurrentAxisStyle ( QSettings & settings , const QString & group = " plot/axes/ " ) const ;
2020-09-11 18:09:11 +08:00
/** \brief width of the plot in the direction of the axis */
virtual double getParentPlotWidth ( ) const = 0 ;
/** \brief offset of the plot in the direction of the axis */
virtual double getParentPlotOffset ( ) const = 0 ;
/** \brief width of other (perpendicular) axis (needed for grids) */
virtual double getParentOtheraxisWidth ( ) const = 0 ;
/** \brief is other (perpendicular) axis inverted (needed for grids) */
virtual bool getParentOtheraxisInverted ( ) const = 0 ;
/** \brief pixel offset of (perpendicular) other axis (needed for grids) */
virtual double getParentOtheraxisOffset ( ) const = 0 ;
2019-02-08 00:24:46 +08:00
public slots :
/** \brief set range of plot axis */
void setRange ( double amin , double amax ) ;
/** \brief set absolute range of plot axis */
void setAbsoluteRange ( double aamin , double aamax ) ;
/** \brief do not use an absolute range of plot axis */
void setNoAbsoluteRange ( ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc tickSpacing */
2019-02-08 00:24:46 +08:00
void setTickSpacing ( double __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc axisMinWidth */
2019-02-08 00:24:46 +08:00
void setAxisMinWidth ( double __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc autoAxisSpacing */
2019-02-08 00:24:46 +08:00
void setAutoAxisSpacing ( bool __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::minorTickLabelsEnabled */
2019-02-08 00:24:46 +08:00
void setMinorTickLabelsEnabled ( bool __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc logAxis */
2019-02-08 00:24:46 +08:00
void setLogAxis ( bool __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc logAxisBase */
2019-02-08 00:24:46 +08:00
void setLogAxisBase ( double __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc userTickSpacing */
2019-02-08 00:24:46 +08:00
void setUserTickSpacing ( double __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc userLogTickSpacing */
2019-02-08 00:24:46 +08:00
void setUserLogTickSpacing ( double __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::labelType */
2019-02-08 00:24:46 +08:00
void setLabelType ( JKQTPCALabelType __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::tickMode */
2019-02-08 00:24:46 +08:00
void setTickMode ( JKQTPLabelTickMode __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::tickMode */
2019-02-08 00:24:46 +08:00
void setTickMode ( int __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc axisLabel */
2019-02-08 00:24:46 +08:00
void setAxisLabel ( const QString & __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::labelPosition */
2019-02-08 00:24:46 +08:00
void setLabelPosition ( JKQTPLabelPosition __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::labelFontSize */
2019-02-08 00:24:46 +08:00
void setLabelFontSize ( double __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::tickTimeFormat */
2019-02-08 00:24:46 +08:00
void setTickTimeFormat ( const QString & __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::tickDateFormat */
2019-02-08 00:24:46 +08:00
void setTickDateFormat ( const QString & __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::tickDateTimeFormat */
2019-02-08 00:24:46 +08:00
void setTickDateTimeFormat ( const QString & __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::tickLabelFontSize */
2019-02-08 00:24:46 +08:00
void setTickLabelFontSize ( double __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::minorTickLabelFontSize */
2019-02-08 00:24:46 +08:00
void setMinorTickLabelFontSize ( double __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::minorTickLabelFullNumber */
2019-02-08 00:24:46 +08:00
void setMinorTickLabelFullNumber ( bool __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::minTicks */
2019-02-08 00:24:46 +08:00
void setMinTicks ( unsigned int __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::minorTicks */
2019-02-08 00:24:46 +08:00
void setMinorTicks ( unsigned int __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::minorTicks */
2019-02-08 00:24:46 +08:00
void setMinorTicks ( int __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::tickOutsideLength */
2019-02-08 00:24:46 +08:00
void setTickOutsideLength ( double __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::minorTickOutsideLength */
2019-02-08 00:24:46 +08:00
void setMinorTickOutsideLength ( double __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::tickInsideLength */
2019-02-08 00:24:46 +08:00
void setTickInsideLength ( double __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::minorTickInsideLength */
2019-02-08 00:24:46 +08:00
void setMinorTickInsideLength ( double __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::axisColor */
2019-02-08 00:24:46 +08:00
void setAxisColor ( const QColor & __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::showZeroAxis */
2019-02-08 00:24:46 +08:00
void setShowZeroAxis ( bool __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc inverted */
2019-02-08 00:24:46 +08:00
void setInverted ( bool __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::gridColor */
2019-02-08 00:24:46 +08:00
void setGridColor ( const QColor & __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::minorGridColor */
2019-02-08 00:24:46 +08:00
void setMinorGridColor ( const QColor & __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::gridWidth */
2019-02-08 00:24:46 +08:00
void setGridWidth ( double __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::gridStyle */
2019-02-08 00:24:46 +08:00
void setGridStyle ( Qt : : PenStyle __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::minorGridWidth */
2019-02-08 00:24:46 +08:00
void setMinorGridWidth ( double __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::minorGridStyle */
2019-02-08 00:24:46 +08:00
void setMinorGridStyle ( Qt : : PenStyle __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::drawMode1 */
2019-02-08 00:24:46 +08:00
void setDrawMode1 ( JKQTPCADrawMode __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::drawMode2 */
2019-02-08 00:24:46 +08:00
void setDrawMode2 ( JKQTPCADrawMode __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::minorTickWidth */
2019-02-08 00:24:46 +08:00
void setMinorTickWidth ( double __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::tickWidth */
2019-02-08 00:24:46 +08:00
void setTickWidth ( double __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::lineWidth */
2019-02-08 00:24:46 +08:00
void setLineWidth ( double __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::lineWidthZeroAxis */
2019-02-08 00:24:46 +08:00
void setLineWidthZeroAxis ( double __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::tickLabelDistance */
2019-02-08 00:24:46 +08:00
void setTickLabelDistance ( double __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::labelDistance */
2019-02-08 00:24:46 +08:00
void setLabelDistance ( double __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::labelDigits */
2019-02-08 00:24:46 +08:00
void setLabelDigits ( int __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::drawGrid */
2019-02-08 00:24:46 +08:00
void setDrawGrid ( bool __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::drawMinorGrid */
2019-02-08 00:24:46 +08:00
void setDrawMinorGrid ( bool __value ) ;
2019-05-18 02:46:52 +08:00
/*! \copydoc JKQTPCoordinateAxisStyle::tickLabelAngle */
2019-02-08 00:24:46 +08:00
void setTickLabelAngle ( double __value ) ;
protected :
/** \brief indicates whether one of the parameters has changed sinse the last recalculation of tickSpacing ... */
bool paramsChanged ;
2020-09-19 04:03:12 +08:00
/** \brief can be used to switch off calcPlotScaling() temporarily, while modifying some properties
*
* use setDoUpdateScaling ( ) to set this property
*
* \ see setDoUpdateScaling ( ) and getDoUpdateScaling ( )
*/
2019-02-08 00:24:46 +08:00
bool doUpdateScaling ;
/** \brief simply calls the redrawPlot method of the parent plotter class */
void redrawPlot ( ) ;
/** \brief a list of tick labels.
*
* If this list contains items , this class will NOT plot a standard x - axis ,
* but only mark the positions in this list . Every item is a x - position together with
* the label to be plotted there . The label may contain LaTeX markup .
*/
QVector < QPair < double , QString > > tickLabels ;
/** \brief retun parents JKQTMathText* object */
2020-09-19 04:03:12 +08:00
JKQTMathText * getParentMathText ( ) ;
/** \brief retun parents JKQTMathText* object */
const JKQTMathText * getParentMathText ( ) const ;
2019-02-08 00:24:46 +08:00
/** \brief convert a float to a tick label string */
2020-09-19 04:03:12 +08:00
QString floattolabel ( double data ) const ;
2019-02-08 00:24:46 +08:00
/** \brief convert a float to a tick label string with a given precision */
2020-09-19 04:03:12 +08:00
QString floattolabel ( double data , int past_comma ) const ;
2019-02-08 00:24:46 +08:00
/** \brief parent plotter class */
JKQTBasePlotter * parent ;
/** \brief current view: minimum of time axis */
double axismin ;
/** \brief current view: maximum of time axis */
double axismax ;
/** \brief absoulte minimum of axis (axismin/axismax xan not be set below this) */
double axisabsoultemin ;
/** \brief absoulte maximum of axis (axismin/axismax xan not be set above this) */
double axisabsoultemax ;
/** \brief current style properties for this coordinate axis instance
*
* \ see JKQTBasePlotterStyle , JKQTPSetSystemDefaultBaseStyle ( ) , JKQTPSetSystemDefaultBaseStyle ( ) , setCurrentAxisStyle ( ) , getCurrentAxisStyle ( ) , \ ref jkqtpplotter_styling
*/
JKQTPCoordinateAxisStyle axisStyle ;
/** \brief absolute minimum range width, feature switched off when <0 */
double axisMinWidth ;
/** \brief <b>calculated property:</b> width of plot on time axis (calculated by calcPlotScaling() )
*
* \ see calcPlotScaling ( ) , calcTickSpacing ( )
*/
double width ;
/** \brief <b>calculated property:</b> time axis scaling factor (calculated by calcPlotScaling() )
*
* \ see calcPlotScaling ( ) , calcTickSpacing ( )
*/
double scale ;
/** \brief <b>calculated property:</b> time axis offset (calculated by calcPlotScaling() )
*
* \ see calcPlotScaling ( ) , calcTickSpacing ( )
*/
double offset ;
2019-02-10 05:17:01 +08:00
/** \brief indicates whether the axis is to be inverted or not
*
* \ image html jkqtplotter_inverted_yaxis . png
*/
2019-02-08 00:24:46 +08:00
bool inverted ;
/** \brief <b>calculated property:</b> x position of the first tick (calculated by calcPlotScaling() ). Given in system coordinates, not pixel coordinates.
*
* \ see calcPlotScaling ( ) , calcTickSpacing ( )
*/
double tickStart ;
/** \brief <b>calculated property:</b> indicates whether the object should use automatic tick spacing for the x axis (calculated by calcPlotScaling() )
*
* \ see calcPlotScaling ( ) , calcTickSpacing ( )
*/
bool autoAxisSpacing ;
/** \brief indicates whether the y axis has a logarithmic scale */
bool logAxis ;
/** \brief the base for a logarithmic x axis */
double logAxisBase ;
/** \brief if autoXAxisSpacing is \c false then this value is used for xTickSpacing. So this is the property which
* is editable by use of public access methods .
*/
double userTickSpacing ;
/** \brief if autoXAxisSpacing is \c false then this value is used for xTickSpacing. So this is the property which
* is editable by use of public access methods .
*/
double userLogTickSpacing ;
/** \brief <b>calculated property:</b> axis tick spacing (calculated by calcPlotScaling() and calcTickSpacing() ) for logarithmic/linear axes.
*
* \ see calcPlotScaling ( ) , calcTickSpacing ( )
*/
double tickSpacing ;
/** \brief <b>calculated property:</b> axis tick spacing for logarithmic JKQTPCoordinateAxisStyle::ticks (calculated by calcPlotScaling() and calcTickSpacing() ) axes.
*
* \ see calcPlotScaling ( )
*/
double tickSpacingLog ;
/** \brief axis label of the axis */
QString axisLabel ;
/** \brief calculates the tick spacing for a linear axis that spans \a awidth and that should
* show at least \ a JKQTPCoordinateAxisStyle : : minTicks JKQTPCoordinateAxisStyle : : ticks .
*
* The < b > algorithm < / b > used in here works as follows :
*
* There is only a limited subset of allowed tick distances . These distances are 1 ( resulting in 10 JKQTPCoordinateAxisStyle : : ticks per decade , i . e . 0 , 1 , 2 , 3 , 4 , . . . ) ,
* 2 ( 5 JKQTPCoordinateAxisStyle : : ticks / decade , i . e . 0 , 2 , 4 , . . . ) , 2.5 ( 4 JKQTPCoordinateAxisStyle : : ticks / decade , i . e . 0 , 2.5 , 5 , . . . ) and 5 ( 2 JKQTPCoordinateAxisStyle : : ticks / decade , i . e . 0 , 5 , 10 , 15 , . . . ) . So the
* axis is divided into decades that each is divided into JKQTPCoordinateAxisStyle : : ticks , as defined above . With these preconditions the algorithm tries
* to find a tick increment \ f $ \ Delta \ mbox { tick } \ f $ which is one of the above distances multiplied by a power \ f $ \ rho \ f $ of 10.
* This increment is determined in a way , that the axis contains at least \ a JKQTPCoordinateAxisStyle : : minTicks JKQTPCoordinateAxisStyle : : ticks :
* \ f [ \ Delta \ mbox { tick } = f \ cdot 10 ^ \ rho , \ \ \ \ \ f \ in \ { 1 , 2 , 2.5 , 5 \ } \ f ]
*
* - # The algorithm starts by finding a start exponent \ f $ \ rho_s = \ left \ lfloor \ log_ { 10 } ( \ mbox { awidth } ) \ right \ rfloor + 3 \ f $ . This
* is a good ( over ) estimate for the biggest possible power \ f $ \ rho \ f $ .
* - # now we set \ f $ \ rho = \ rho_0 \ f $ and \ f $ f = 10 \ f $ .
* - # now the algorithm cycles through all possible factors \ f $ f \ in \ { 1 , 2 , 2.5 , 5 , 10 \ } \ f $ ( starting from 10 ) and calculates
* \ f $ \ Delta \ mbox { tick } = f \ cdot 10 ^ \ rho \ f $ . Then it checks whether \ f $ \ mbox { tickcount } = \ mbox { round } \ left ( \ frac { \ mbox { awidth } } { \ Delta \ mbox { tick } } \ right ) \ f $
* is smaller than \ a JKQTPCoordinateAxisStyle : : minTicks ( if yes the algorithm reached its end and \ f $ \ Delta \ mbox { tick } \ f $ can be used .
* - # if \ f $ f = 1 \ f $ is reached and checked \ c false , then the algorithm decreases the exponent \ f $ \ rho \ leftarrow \ rho - 1 \ f $ and returns to step 3.
*
*/
double calcLinearTickSpacing ( ) ;
/** \brief same as calcLinearTickSpacing(), but for logarithmic scaling
*
* \ see calcLinearTickSpacing ( )
* */
double calcLogTickSpacing ( ) ;
/** \brief Calculate the number of digits needed for the labels of an axis that starts at
* \ a minval and where the tick spacing is \ a tickSpacing .
*
* This method determines how many digits to output for the labels on a coordinate axis .
* This is done by testing different digit numbers and comparing subsequent labels . If two labels
* are equal , then we need more valid digits to distinguish them .
*/
int calcLinearUnitDigits ( ) ;
/** \brief axis prefix for storage of parameters */
QString axisPrefix ;
/** \brief this is used by x2p() and p2x() to determine the sign */
double scaleSign ;
/** \brief calculates the next label from the given parameters.
*
* \ return \ c true on success and \ c false if there is no more label
* \ param x \ b before \ b call : the position of the label for which the text should be returned ( or JKQTPCoordinateAxisStyle : : tickStart for first call ) ,
* \ b after \ b call : position of the next label ( given in world coordinates ! )
* \ param label \ b after \ b call : text of the ( input ) tick label This is an empty string , if the label is not visible !
* \ param init call this function with \ c init = true to obtain the first label ( at JKQTPCoordinateAxisStyle : : tickStart )
*/
bool getNextLabel ( double & x , QString & label , bool init = false ) ;
/** \brief returns the distance from the current tick position (x before call) to the next tick position */
double getNextLabelDistance ( double x ) ;
/** \brief calculates the maximum width and height (returned as QSize) of all tick labels.
* Ascent and descent may also be returned in the two additional pointer arguments - */
QSizeF getMaxTickLabelSize ( JKQTPEnhancedPainter & painter , double * ascent = nullptr , double * descent = nullptr ) ;
} ;
/*! \brief implements a vertical axis, based on JKQTPCoordinateAxis (for most of documentation: see JKQTPCoordinateAxis).
\ ingroup jkqtpbaseplotter_elements
*/
2019-06-22 20:21:32 +08:00
class JKQTPLOTTER_LIB_EXPORT JKQTPVerticalAxis : public JKQTPCoordinateAxis {
2019-02-08 00:24:46 +08:00
Q_OBJECT
protected :
public :
/** \brief class constructor */
JKQTPVerticalAxis ( JKQTBasePlotter * parent ) ;
/** \brief returns the size of the left/bottom axis in pt */
virtual QSizeF getSize1 ( JKQTPEnhancedPainter & painter ) override ;
/** \brief returns the size of the right/top axis in pt */
virtual QSizeF getSize2 ( JKQTPEnhancedPainter & painter ) override ;
/** \brief draw axes */
virtual void drawAxes ( JKQTPEnhancedPainter & painter ) override ;
/** \brief draw grids */
virtual void drawGrids ( JKQTPEnhancedPainter & painter ) override ;
/** \brief width of the plot in the direction of the axis */
virtual double getParentPlotWidth ( ) const override ;
/** \brief offset of the plot in the direction of the axis */
virtual double getParentPlotOffset ( ) const override ;
/** \brief pixel of other (perpendicular) axis (needed for grids) */
virtual double getParentOtheraxisWidth ( ) const override ;
virtual bool getParentOtheraxisInverted ( ) const override ;
/** \brief pixel offset of (perpendicular) other axis (needed for grids) */
virtual double getParentOtheraxisOffset ( ) const override ;
2020-09-11 18:09:11 +08:00
protected :
2019-02-08 00:24:46 +08:00
virtual void drawTickLabel1 ( JKQTPEnhancedPainter & painter , double xx , double yy , const QString & label , double fontSize ) ;
virtual void drawTickLabel2 ( JKQTPEnhancedPainter & painter , double xx , double yy , const QString & label , double fontSize ) ;
} ;
/*! \brief implements a position-indipendent vertical axis, based on JKQTPCoordinateAxis (for most of documentation: see JKQTPCoordinateAxis).
\ ingroup jkqtpbaseplotter_elements
This axis may be draw at a user - supplied position ( used e . g . for color bar axes )
*/
2019-06-22 20:21:32 +08:00
class JKQTPLOTTER_LIB_EXPORT JKQTPVerticalIndependentAxis : public JKQTPVerticalAxis {
2019-02-08 00:24:46 +08:00
Q_OBJECT
protected :
public :
/** \brief class constructor */
JKQTPVerticalIndependentAxis ( double axisOffset , double axisWidth , double otherAxisOffset , double otherAxisWidth , JKQTBasePlotter * parent ) ;
2020-09-11 18:09:11 +08:00
/** \brief width of the plot in the direction of the axis */
virtual double getParentPlotWidth ( ) const override ;
/** \brief offset of the plot in the direction of the axis */
virtual double getParentPlotOffset ( ) const override ;
/** \brief pixel of other (perpendicular) axis (needed for grids) */
virtual double getParentOtheraxisWidth ( ) const override ;
/** \brief returns whether the other axis is inverted */
virtual bool getParentOtheraxisInverted ( ) const override ;
/** \brief pixel offset of (perpendicular) other axis (needed for grids) */
virtual double getParentOtheraxisOffset ( ) const override ;
public slots :
2019-02-08 00:24:46 +08:00
/** \brief set the axis offset */
virtual void setAxisOffset ( double __value ) ;
/** \brief set the axis width */
virtual void setAxisWidth ( double __value ) ;
/** \brief set the other axis offset */
virtual void setOtherAxisOffset ( double __value ) ;
/** \brief set the other axis width */
virtual void setOtherAxisWidth ( double __value ) ;
2020-09-11 18:09:11 +08:00
/** \brief set whether the other axis is inverted */
2019-02-08 00:24:46 +08:00
virtual void setOtherAxisInverted ( bool __value ) ;
2020-09-11 18:09:11 +08:00
protected :
/** \brief the offset of the axis */
2019-02-08 00:24:46 +08:00
double axisOffset ;
2020-09-11 18:09:11 +08:00
/** \brief the width of the axis */
2019-02-08 00:24:46 +08:00
double axisWidth ;
2020-09-11 18:09:11 +08:00
/** \brief the width of the other axis */
2019-02-08 00:24:46 +08:00
double otherAxisWidth ;
2020-09-11 18:09:11 +08:00
/** \brief the offset of the other axis */
2019-02-08 00:24:46 +08:00
double otherAxisOffset ;
2020-09-11 18:09:11 +08:00
/** \brief indicates whether the other axis is inverted */
2019-02-08 00:24:46 +08:00
bool otherAxisInverted ;
} ;
/*! \brief implements a horizontal axis, based on JKQTPCoordinateAxis (for most of documentation: see JKQTPCoordinateAxis).
\ ingroup jkqtpbaseplotter_elements
*/
2019-06-22 20:21:32 +08:00
class JKQTPLOTTER_LIB_EXPORT JKQTPHorizontalAxis : public JKQTPCoordinateAxis {
2019-02-08 00:24:46 +08:00
Q_OBJECT
protected :
public :
/** \brief class constructor */
JKQTPHorizontalAxis ( JKQTBasePlotter * parent ) ;
/** \brief returns the size of the left/bottom axis in pt */
virtual QSizeF getSize1 ( JKQTPEnhancedPainter & painter ) override ;
/** \brief returns the size of the right/top axis in pt */
virtual QSizeF getSize2 ( JKQTPEnhancedPainter & painter ) override ;
/** \brief draw axes */
virtual void drawAxes ( JKQTPEnhancedPainter & painter ) override ;
/** \brief draw grids */
virtual void drawGrids ( JKQTPEnhancedPainter & painter ) override ;
/** \brief width of the plot in the direction of the axis */
virtual double getParentPlotWidth ( ) const override ;
/** \brief offset of the plot in the direction of the axis */
virtual double getParentPlotOffset ( ) const override ;
/** \brief pixel of other (perpendicular) axis (needed for grids) */
virtual double getParentOtheraxisWidth ( ) const override ;
2020-09-11 18:09:11 +08:00
/** \brief returns whether the other axis is inverted */
2019-02-08 00:24:46 +08:00
virtual bool getParentOtheraxisInverted ( ) const override ;
/** \brief pixel offset of (perpendicular) other axis (needed for grids) */
virtual double getParentOtheraxisOffset ( ) const override ;
2020-09-11 18:09:11 +08:00
protected :
2019-02-08 00:24:46 +08:00
virtual void drawTickLabel1 ( JKQTPEnhancedPainter & painter , double xx , double yy , const QString & label , double fontSize , double ascentMax , double descentMax ) ;
virtual void drawTickLabel2 ( JKQTPEnhancedPainter & painter , double xx , double yy , const QString & label , double fontSize , double ascentMax , double descentMax ) ;
} ;
/*! \brief implements a position-indipendent horizontal axis, based on JKQTPCoordinateAxis (for most of documentation: see JKQTPCoordinateAxis).
\ ingroup jkqtpbaseplotter_elements
This axis may be draw at a user - supplied position ( used e . g . for color bar axes )
*/
2019-06-22 20:21:32 +08:00
class JKQTPLOTTER_LIB_EXPORT JKQTPHorizontalIndependentAxis : public JKQTPHorizontalAxis {
2019-02-08 00:24:46 +08:00
Q_OBJECT
protected :
public :
/** \brief class constructor */
JKQTPHorizontalIndependentAxis ( double axisOffset , double axisWidth , double otherAxisOffset , double otherAxisWidth , JKQTBasePlotter * parent ) ;
2020-09-11 18:09:11 +08:00
public slots :
/** \brief set the axis offset */
2019-02-08 00:24:46 +08:00
virtual void setAxisOffset ( double __value ) ;
2020-09-11 18:09:11 +08:00
/** \brief set the axis width */
2019-02-08 00:24:46 +08:00
virtual void setAxisWidth ( double __value ) ;
/** \brief set the other axis offset */
virtual void setOtherAxisOffset ( double __value ) ;
/** \brief set the other axis width */
virtual void setOtherAxisWidth ( double __value ) ;
virtual void setOtherAxisInverted ( bool __value ) ;
protected :
/** \brief width of the plot in the direction of the axis */
virtual double getParentPlotWidth ( ) const override ;
/** \brief offset of the plot in the direction of the axis */
virtual double getParentPlotOffset ( ) const override ;
/** \brief pixel of other (perpendicular) axis (needed for grids) */
virtual double getParentOtheraxisWidth ( ) const override ;
2020-09-11 18:09:11 +08:00
/** \brief returns whether the other axis is inverted */
2019-02-08 00:24:46 +08:00
virtual bool getParentOtheraxisInverted ( ) const override ;
/** \brief pixel offset of (perpendicular) other axis (needed for grids) */
virtual double getParentOtheraxisOffset ( ) const override ;
2020-09-11 18:09:11 +08:00
/** \brief the offset of the axis */
2019-02-08 00:24:46 +08:00
double axisOffset ;
2020-09-11 18:09:11 +08:00
/** \brief the width of the axis */
2019-02-08 00:24:46 +08:00
double axisWidth ;
2020-09-11 18:09:11 +08:00
/** \brief the width of the other axis */
2019-02-08 00:24:46 +08:00
double otherAxisWidth ;
2020-09-11 18:09:11 +08:00
/** \brief the offset of the other axis */
2019-02-08 00:24:46 +08:00
double otherAxisOffset ;
2020-09-11 18:09:11 +08:00
/** \brief indicates whether the other axis is inverted */
2019-02-08 00:24:46 +08:00
bool otherAxisInverted ;
} ;
# endif // JKQTPCOORDINATEAXES_H