SimCenterCommon
Common functionality used within different SimCenter projects
QCPAxisTickerPi Class Reference

Specialized axis ticker to display ticks in units of an arbitrary constant, for example pi. More...

#include <qcustomplot.h>

Inheritance diagram for QCPAxisTickerPi:
Collaboration diagram for QCPAxisTickerPi:

Public Types

enum  FractionStyle { fsFloatingPoint, fsAsciiFractions, fsUnicodeFractions }
 
- Public Types inherited from QCPAxisTicker
enum  TickStepStrategy { tssReadability, tssMeetTickCount }
 

Public Member Functions

 QCPAxisTickerPi ()
 
QString piSymbol () const
 
double piValue () const
 
bool periodicity () const
 
FractionStyle fractionStyle () const
 
void setPiSymbol (QString symbol)
 
void setPiValue (double pi)
 
void setPeriodicity (int multiplesOfPi)
 
void setFractionStyle (FractionStyle style)
 
- Public Member Functions inherited from QCPAxisTicker
 QCPAxisTicker ()
 
virtual ~QCPAxisTicker ()
 
TickStepStrategy tickStepStrategy () const
 
int tickCount () const
 
double tickOrigin () const
 
void setTickStepStrategy (TickStepStrategy strategy)
 
void setTickCount (int count)
 
void setTickOrigin (double origin)
 
virtual void generate (const QCPRange &range, const QLocale &locale, QChar formatChar, int precision, QVector< double > &ticks, QVector< double > *subTicks, QVector< QString > *tickLabels)
 

Protected Member Functions

virtual double getTickStep (const QCPRange &range) Q_DECL_OVERRIDE
 
virtual int getSubTickCount (double tickStep) Q_DECL_OVERRIDE
 
virtual QString getTickLabel (double tick, const QLocale &locale, QChar formatChar, int precision) Q_DECL_OVERRIDE
 
void simplifyFraction (int &numerator, int &denominator) const
 
QString fractionToString (int numerator, int denominator) const
 
QString unicodeFraction (int numerator, int denominator) const
 
QString unicodeSuperscript (int number) const
 
QString unicodeSubscript (int number) const
 
- Protected Member Functions inherited from QCPAxisTicker
virtual QVector< double > createTickVector (double tickStep, const QCPRange &range)
 
virtual QVector< double > createSubTickVector (int subTickCount, const QVector< double > &ticks)
 
virtual QVector< QString > createLabelVector (const QVector< double > &ticks, const QLocale &locale, QChar formatChar, int precision)
 
void trimTicks (const QCPRange &range, QVector< double > &ticks, bool keepOneOutlier) const
 
double pickClosest (double target, const QVector< double > &candidates) const
 
double getMantissa (double input, double *magnitude=0) const
 
double cleanMantissa (double input) const
 

Protected Attributes

QString mPiSymbol
 
double mPiValue
 
int mPeriodicity
 
FractionStyle mFractionStyle
 
double mPiTickStep
 
- Protected Attributes inherited from QCPAxisTicker
TickStepStrategy mTickStepStrategy
 
int mTickCount
 
double mTickOrigin
 

Detailed Description

Specialized axis ticker to display ticks in units of an arbitrary constant, for example pi.

axisticker-pi.png

This QCPAxisTicker subclass generates ticks that are expressed with respect to a given symbolic constant with a numerical value specified with setPiValue and an appearance in the tick labels specified with setPiSymbol.

Ticks may be generated at fractions of the symbolic constant. How these fractions appear in the tick label can be configured with setFractionStyle.

The ticker can be created and assigned to an axis like this:

Definition at line 1746 of file qcustomplot.h.

Member Enumeration Documentation

Defines how fractions should be displayed in tick labels.

See also
setFractionStyle
Enumerator
fsFloatingPoint 

Fractions are displayed as regular decimal floating point numbers, e.g. "0.25" or "0.125".

fsAsciiFractions 

Fractions are written as rationals using ASCII characters only, e.g. "1/4" or "1/8".

fsUnicodeFractions 

Fractions are written using sub- and superscript UTF-8 digits and the fraction symbol.

Definition at line 1755 of file qcustomplot.h.

Constructor & Destructor Documentation

QCPAxisTickerPi::QCPAxisTickerPi ( )

Constructs the ticker and sets reasonable default values. Axis tickers are commonly created managed by a QSharedPointer, which then can be passed to QCPAxis::setTicker.

Definition at line 6616 of file qcustomplot.cpp.

Member Function Documentation

FractionStyle QCPAxisTickerPi::fractionStyle ( ) const
inline

Definition at line 1767 of file qcustomplot.h.

QString QCPAxisTickerPi::fractionToString ( int  numerator,
int  denominator 
) const
protected

Definition at line 6769 of file qcustomplot.cpp.

int QCPAxisTickerPi::getSubTickCount ( double  tickStep)
protectedvirtual

Reimplemented from QCPAxisTicker.

Definition at line 6694 of file qcustomplot.cpp.

QString QCPAxisTickerPi::getTickLabel ( double  tick,
const QLocale &  locale,
QChar  formatChar,
int  precision 
)
protectedvirtual

Reimplemented from QCPAxisTicker.

Definition at line 6707 of file qcustomplot.cpp.

double QCPAxisTickerPi::getTickStep ( const QCPRange range)
protectedvirtual

Reimplemented from QCPAxisTicker.

Definition at line 6679 of file qcustomplot.cpp.

bool QCPAxisTickerPi::periodicity ( ) const
inline

Definition at line 1766 of file qcustomplot.h.

QString QCPAxisTickerPi::piSymbol ( ) const
inline

Definition at line 1764 of file qcustomplot.h.

double QCPAxisTickerPi::piValue ( ) const
inline

Definition at line 1765 of file qcustomplot.h.

void QCPAxisTickerPi::setFractionStyle ( QCPAxisTickerPi::FractionStyle  style)

Sets how the numerical/fractional part preceding the symbolic constant is displayed in tick labels. See FractionStyle for the various options.

Definition at line 6666 of file qcustomplot.cpp.

void QCPAxisTickerPi::setPeriodicity ( int  multiplesOfPi)

Sets whether the axis labels shall appear periodicly and if so, at which multiplicity of the symbolic constant.

To disable periodicity, set multiplesOfPi to zero.

For example, an axis that identifies 0 with 2pi would set multiplesOfPi to two.

Definition at line 6657 of file qcustomplot.cpp.

void QCPAxisTickerPi::setPiSymbol ( QString  symbol)

Sets how the symbol part (which is always a suffix to the number) shall appear in the axis tick label.

If a space shall appear between the number and the symbol, make sure the space is contained in symbol.

Definition at line 6633 of file qcustomplot.cpp.

void QCPAxisTickerPi::setPiValue ( double  pi)

Sets the numerical value that the symbolic constant has.

This will be used to place the appropriate fractions of the symbol at the respective axis coordinates.

Definition at line 6644 of file qcustomplot.cpp.

void QCPAxisTickerPi::simplifyFraction ( int numerator,
int denominator 
) const
protected

Definition at line 6742 of file qcustomplot.cpp.

QString QCPAxisTickerPi::unicodeFraction ( int  numerator,
int  denominator 
) const
protected

Definition at line 6825 of file qcustomplot.cpp.

QString QCPAxisTickerPi::unicodeSubscript ( int  number) const
protected

Definition at line 6861 of file qcustomplot.cpp.

QString QCPAxisTickerPi::unicodeSuperscript ( int  number) const
protected

Definition at line 6835 of file qcustomplot.cpp.

Member Data Documentation

FractionStyle QCPAxisTickerPi::mFractionStyle
protected

Definition at line 1780 of file qcustomplot.h.

int QCPAxisTickerPi::mPeriodicity
protected

Definition at line 1779 of file qcustomplot.h.

QString QCPAxisTickerPi::mPiSymbol
protected

Definition at line 1777 of file qcustomplot.h.

double QCPAxisTickerPi::mPiTickStep
protected

Definition at line 1783 of file qcustomplot.h.

double QCPAxisTickerPi::mPiValue
protected

Definition at line 1778 of file qcustomplot.h.


The documentation for this class was generated from the following files: