VTK
Public Types | Public Member Functions | Static Public Member Functions | Protected Member Functions | Protected Attributes
vtkAxis Class Reference

takes care of drawing 2D axes More...

#include <vtkAxis.h>

Inheritance diagram for vtkAxis:
Inheritance graph
[legend]
Collaboration diagram for vtkAxis:
Collaboration graph
[legend]

List of all members.

Public Types

enum  { TICK_SIMPLE = 0, TICK_WILKINSON_EXTENDED }
typedef vtkContextItem Superclass
enum  {
  LEFT = 0, BOTTOM, RIGHT, TOP,
  PARALLEL
}
enum  { AUTO = 0, FIXED, CUSTOM }

Public Member Functions

virtual int IsA (const char *type)
vtkAxisNewInstance () const
virtual void PrintSelf (ostream &os, vtkIndent indent)
virtual void SetNumberOfTicks (int numberOfTicks)
virtual void SetMinimum (double minimum)
virtual void SetMaximum (double maximum)
virtual void SetUnscaledMinimum (double minimum)
virtual void SetUnscaledMaximum (double maximum)
virtual void SetMinimumLimit (double lowest)
virtual void SetMaximumLimit (double highest)
virtual void SetUnscaledMinimumLimit (double lowest)
virtual void SetUnscaledMaximumLimit (double highest)
virtual void Update ()
virtual bool Paint (vtkContext2D *painter)
virtual void AutoScale ()
virtual void RecalculateTickSpacing ()
virtual vtkDoubleArrayGetTickPositions ()
virtual vtkFloatArrayGetTickScenePositions ()
virtual vtkStringArrayGetTickLabels ()
virtual void SetTickPositions (vtkDoubleArray *positions)
virtual void SetTickLabels (vtkStringArray *labels)
vtkRectf GetBoundingRect (vtkContext2D *painter)
virtual void SetPosition (int position)
virtual int GetPosition ()
void SetPoint1 (const vtkVector2f &pos)
void SetPoint1 (float x, float y)
virtual floatGetPoint1 ()
virtual void GetPoint1 (float &, float &)
virtual void GetPoint1 (float[2])
vtkVector2f GetPosition1 ()
void SetPoint2 (const vtkVector2f &pos)
void SetPoint2 (float x, float y)
virtual floatGetPoint2 ()
virtual void GetPoint2 (float &, float &)
virtual void GetPoint2 (float[2])
vtkVector2f GetPosition2 ()
virtual int GetNumberOfTicks ()
virtual vtkTextPropertyGetLabelProperties ()
virtual double GetMinimum ()
virtual double GetMaximum ()
virtual double GetUnscaledMinimum ()
virtual double GetUnscaledMaximum ()
virtual void SetRange (double minimum, double maximum)
virtual void SetRange (double range[2])
virtual void SetUnscaledRange (double minimum, double maximum)
virtual void SetUnscaledRange (double range[2])
virtual void GetRange (double *range)
virtual void GetUnscaledRange (double *range)
virtual double GetMinimumLimit ()
virtual double GetMaximumLimit ()
virtual double GetUnscaledMinimumLimit ()
virtual double GetUnscaledMaximumLimit ()
virtual intGetMargins ()
virtual void GetMargins (int &, int &)
virtual void GetMargins (int[2])
virtual void SetMargins (int, int)
void SetMargins (int[2])
virtual void SetTitle (const vtkStdString &title)
virtual vtkStdString GetTitle ()
virtual vtkTextPropertyGetTitleProperties ()
virtual bool GetLogScaleActive ()
virtual bool GetLogScale ()
virtual void SetLogScale (bool logScale)
virtual void LogScaleOn ()
virtual void LogScaleOff ()
virtual void SetGridVisible (bool)
virtual bool GetGridVisible ()
virtual void SetLabelsVisible (bool)
virtual bool GetLabelsVisible ()
virtual void SetTicksVisible (bool)
virtual bool GetTicksVisible ()
virtual void SetPrecision (int precision)
virtual int GetPrecision ()
virtual void SetBehavior (int)
virtual int GetBehavior ()
virtual vtkPenGetPen ()
virtual vtkPenGetGridPen ()
virtual void SetTickLabelAlgorithm (int)
virtual int GetTickLabelAlgorithm ()
virtual void SetScalingFactor (double)
virtual double GetScalingFactor ()
virtual void SetShift (double)
virtual double GetShift ()
virtual bool SetCustomTickPositions (vtkDoubleArray *positions, vtkStringArray *labels=0)

Static Public Member Functions

static int IsTypeOf (const char *type)
static vtkAxisSafeDownCast (vtkObjectBase *o)
static vtkAxisNew ()
static double NiceNumber (double number, bool roundUp)
static double NiceMinMax (double &min, double &max, float pixelRange, float tickPixelSpacing)

Protected Member Functions

virtual vtkObjectBaseNewInstanceInternal () const
 vtkAxis ()
 ~vtkAxis ()
void UpdateLogScaleActive (bool updateMinMaxFromUnscaled)
void GenerateTickLabels (double min, double max)
void GenerateTickLabels ()
void GenerateLabelFormat (int notation, double n)
double CalculateNiceMinMax (double &min, double &max)
void GenerateLogSpacedLinearTicks (int order, double min, double max)
double LogScaleTickMark (double number, bool roundUp, bool &niceValue, int &order)
void GenerateLogScaleTickMarks (int order, double min=1.0, double max=9.0, bool detailLabels=true)

Protected Attributes

int Position
floatPoint1
floatPoint2
vtkVector2f Position1
vtkVector2f Position2
double TickInterval
int NumberOfTicks
vtkTextPropertyLabelProperties
double Minimum
double Maximum
double MinimumLimit
double MaximumLimit
double UnscaledMinimum
double UnscaledMaximum
double UnscaledMinimumLimit
double UnscaledMaximumLimit
double NonLogUnscaledMinLimit
double NonLogUnscaledMaxLimit
int Margins [2]
vtkStdString Title
vtkTextPropertyTitleProperties
bool LogScale
bool LogScaleActive
bool GridVisible
bool LabelsVisible
bool TicksVisible
int Precision
int Notation
int Behavior
float MaxLabel [2]
bool TitleAppended
bool CustomTickLabels
vtkPenPen
vtkPenGridPen
vtkSmartPointer< vtkDoubleArrayTickPositions
vtkSmartPointer< vtkFloatArrayTickScenePositions
vtkSmartPointer< vtkStringArrayTickLabels
bool UsingNiceMinMax
bool TickMarksDirty
bool Resized
int TickLabelAlgorithm
vtkTimeStamp BuildTime
double ScalingFactor
double Shift
enum  {
  STANDARD_NOTATION = 0, SCIENTIFIC_NOTATION, FIXED_NOTATION, STANDARD = STANDARD_NOTATION,
  SCIENTIFIC = SCIENTIFIC_NOTATION, MIXED = FIXED_NOTATION
}
virtual void SetNotation (int notation)
virtual int GetNotation ()

Detailed Description

takes care of drawing 2D axes

The vtkAxis is drawn in screen coordinates. It is usually one of the last elements of a chart to be drawn. It renders the axis label, tick marks and tick labels. The tick marks and labels span the range of values between Minimum and Maximum. The Minimum and Maximum values are not allowed to extend beyond the MinimumLimit and MaximumLimit values, respectively.

Note that many other chart elements (e.g., vtkPlotPoints) refer to vtkAxis instances to determine how to scale raw data for presentation. In particular, care must be taken with logarithmic scaling. The axis Minimum, Maximum, and Limit values are stored both unscaled and scaled (with log(x) applied when GetLogScaleActive() returns true). User interfaces will most likely present the unscaled values as they represent the values provided by the user. Other chart elements may need the scaled values in order to draw in the same coordinate system.

Just because LogScale is set to true does not guarantee that the axis will use logarithmic scaling -- the Minimum and Maximum values for the axis must both lie to the same side of origin (and not include the origin). Also, this switch from linear- to log-scaling may occur during a rendering pass if autoscaling is enabled. Because the log and pow functions are not invertible and the axis itself decides when to switch between them without offering any external class managing the axis a chance to save the old values, it saves old Limit values in NonLogUnscaled{Min,Max}Limit so that behavior is consistent when LogScale is changed from false to true and back again.

Tests:
vtkAxis (Tests)

Definition at line 70 of file vtkAxis.h.


Member Typedef Documentation

Reimplemented from vtkContextItem.

Definition at line 73 of file vtkAxis.h.


Member Enumeration Documentation

anonymous enum

Enumeration of the axis locations in a conventional XY chart. Other layouts are possible.

Enumerator:
LEFT 
BOTTOM 
RIGHT 
TOP 
PARALLEL 

Definition at line 79 of file vtkAxis.h.

anonymous enum
Enumerator:
TICK_SIMPLE 
TICK_WILKINSON_EXTENDED 

Definition at line 88 of file vtkAxis.h.

anonymous enum

Enumeration of the axis notations available.

Enumerator:
STANDARD_NOTATION 
SCIENTIFIC_NOTATION 
FIXED_NOTATION 
STANDARD 
SCIENTIFIC 
MIXED 

Definition at line 314 of file vtkAxis.h.

anonymous enum

Enumeration of the axis behaviors.

Enumerator:
AUTO 
FIXED 
CUSTOM 

Definition at line 337 of file vtkAxis.h.


Constructor & Destructor Documentation

vtkAxis::vtkAxis ( ) [protected]
vtkAxis::~vtkAxis ( ) [protected]

Member Function Documentation

static int vtkAxis::IsTypeOf ( const char *  name) [static]

Return 1 if this class type is the same type of (or a subclass of) the named class. Returns 0 otherwise. This method works in combination with vtkTypeMacro found in vtkSetGet.h.

Reimplemented from vtkContextItem.

virtual int vtkAxis::IsA ( const char *  name) [virtual]

Return 1 if this class is the same type of (or a subclass of) the named class. Returns 0 otherwise. This method works in combination with vtkTypeMacro found in vtkSetGet.h.

Reimplemented from vtkContextItem.

static vtkAxis* vtkAxis::SafeDownCast ( vtkObjectBase o) [static]

Reimplemented from vtkContextItem.

virtual vtkObjectBase* vtkAxis::NewInstanceInternal ( ) const [protected, virtual]

Reimplemented from vtkContextItem.

Reimplemented from vtkContextItem.

virtual void vtkAxis::PrintSelf ( ostream &  os,
vtkIndent  indent 
) [virtual]

Methods invoked by print to print information about the object including superclasses. Typically not called by the user (use Print() instead) but used in the hierarchical print process to combine the output of several classes.

Reimplemented from vtkContextItem.

static vtkAxis* vtkAxis::New ( ) [static]

Creates a 2D Chart object.

Reimplemented from vtkObject.

virtual void vtkAxis::SetPosition ( int  position) [virtual]

Get/set the position of the axis (LEFT, BOTTOM, RIGHT, TOP, PARALLEL).

virtual int vtkAxis::GetPosition ( ) [virtual]

Get/set the position of the axis (LEFT, BOTTOM, RIGHT, TOP, PARALLEL).

void vtkAxis::SetPoint1 ( const vtkVector2f pos)

Set point 1 of the axis (in pixels), this is usually the origin.

void vtkAxis::SetPoint1 ( float  x,
float  y 
)

Set point 1 of the axis (in pixels), this is usually the origin.

virtual float* vtkAxis::GetPoint1 ( ) [virtual]

Get point 1 of the axis (in pixels), this is usually the origin.

virtual void vtkAxis::GetPoint1 ( float ,
float  
) [virtual]

Get point 1 of the axis (in pixels), this is usually the origin.

virtual void vtkAxis::GetPoint1 ( float  [2]) [virtual]

Get point 1 of the axis (in pixels), this is usually the origin.

Get point 1 of the axis (in pixels), this is usually the origin.

void vtkAxis::SetPoint2 ( const vtkVector2f pos)

Set point 2 of the axis (in pixels), this is usually the terminus.

void vtkAxis::SetPoint2 ( float  x,
float  y 
)

Set point 2 of the axis (in pixels), this is usually the terminus.

virtual float* vtkAxis::GetPoint2 ( ) [virtual]

Get point 2 of the axis (in pixels), this is usually the terminus.

virtual void vtkAxis::GetPoint2 ( float ,
float  
) [virtual]

Get point 2 of the axis (in pixels), this is usually the terminus.

virtual void vtkAxis::GetPoint2 ( float  [2]) [virtual]

Get point 2 of the axis (in pixels), this is usually the terminus.

Get point 2 of the axis (in pixels), this is usually the terminus.

virtual void vtkAxis::SetNumberOfTicks ( int  numberOfTicks) [virtual]

Set the number of tick marks for this axis. Default is -1, which leads to automatic calculation of nicely spaced tick marks.

virtual int vtkAxis::GetNumberOfTicks ( ) [virtual]

Get the number of tick marks for this axis.

Get the vtkTextProperty that governs how the axis lables are displayed. Note that the alignment properties are not used.

virtual void vtkAxis::SetMinimum ( double  minimum) [virtual]

Set the logical minimum value of the axis, in plot coordinates. If LogScaleActive is true (not just LogScale), then this sets the minimum base-10 exponent.

virtual double vtkAxis::GetMinimum ( ) [virtual]

Get the logical minimum value of the axis, in plot coordinates. If LogScaleActive is true (not just LogScale), then this returns the minimum base-10 exponent.

virtual void vtkAxis::SetMaximum ( double  maximum) [virtual]

Set the logical maximum value of the axis, in plot coordinates. If LogScaleActive is true (not just LogScale), then this sets the maximum base-10 exponent.

virtual double vtkAxis::GetMaximum ( ) [virtual]

Get the logical maximum value of the axis, in plot coordinates. If LogScaleActive is true (not just LogScale), then this returns the maximum base-10 exponent.

virtual void vtkAxis::SetUnscaledMinimum ( double  minimum) [virtual]

Set the logical, unscaled minimum value of the axis, in plot coordinates. Use this instead of SetMinimum() if you wish to provide the actual minimum instead of log10(the minimum) as part of the axis scale.

virtual double vtkAxis::GetUnscaledMinimum ( ) [virtual]

Get the logical minimum value of the axis, in plot coordinates.

virtual void vtkAxis::SetUnscaledMaximum ( double  maximum) [virtual]

Set the logical maximum value of the axis, in plot coordinates.

virtual double vtkAxis::GetUnscaledMaximum ( ) [virtual]

Get the logical maximum value of the axis, in plot coordinates.

virtual void vtkAxis::SetRange ( double  minimum,
double  maximum 
) [virtual]

Set the logical range of the axis, in plot coordinates. The unscaled range will always be in the same coordinate system of the data being plotted, regardless of whether LogScale is true or false. When calling SetRange() and LogScale is true, the range must be specified in logarithmic coordinates. Using SetUnscaledRange(), you may ignore the value of LogScale.

virtual void vtkAxis::SetRange ( double  range[2]) [virtual]

Set the logical range of the axis, in plot coordinates. The unscaled range will always be in the same coordinate system of the data being plotted, regardless of whether LogScale is true or false. When calling SetRange() and LogScale is true, the range must be specified in logarithmic coordinates. Using SetUnscaledRange(), you may ignore the value of LogScale.

virtual void vtkAxis::SetUnscaledRange ( double  minimum,
double  maximum 
) [virtual]

Set the logical range of the axis, in plot coordinates. The unscaled range will always be in the same coordinate system of the data being plotted, regardless of whether LogScale is true or false. When calling SetRange() and LogScale is true, the range must be specified in logarithmic coordinates. Using SetUnscaledRange(), you may ignore the value of LogScale.

virtual void vtkAxis::SetUnscaledRange ( double  range[2]) [virtual]

Set the logical range of the axis, in plot coordinates. The unscaled range will always be in the same coordinate system of the data being plotted, regardless of whether LogScale is true or false. When calling SetRange() and LogScale is true, the range must be specified in logarithmic coordinates. Using SetUnscaledRange(), you may ignore the value of LogScale.

virtual void vtkAxis::GetRange ( double range) [virtual]

Get the logical range of the axis, in plot coordinates. The unscaled range will always be in the same coordinate system of the data being plotted, regardless of whether LogScale is true or false. Calling GetRange() when LogScale is true will return the log10({min, max}).

virtual void vtkAxis::GetUnscaledRange ( double range) [virtual]

Get the logical range of the axis, in plot coordinates. The unscaled range will always be in the same coordinate system of the data being plotted, regardless of whether LogScale is true or false. Calling GetRange() when LogScale is true will return the log10({min, max}).

virtual void vtkAxis::SetMinimumLimit ( double  lowest) [virtual]

Set the logical lowest possible value for Minimum, in plot coordinates.

virtual double vtkAxis::GetMinimumLimit ( ) [virtual]

Get the logical lowest possible value for Minimum, in plot coordinates.

virtual void vtkAxis::SetMaximumLimit ( double  highest) [virtual]

Set the logical highest possible value for Maximum, in plot coordinates.

virtual double vtkAxis::GetMaximumLimit ( ) [virtual]

Get the logical highest possible value for Maximum, in plot coordinates.

virtual void vtkAxis::SetUnscaledMinimumLimit ( double  lowest) [virtual]

Set the logical lowest possible value for Minimum, in plot coordinates.

Get the logical lowest possible value for Minimum, in plot coordinates.

virtual void vtkAxis::SetUnscaledMaximumLimit ( double  highest) [virtual]

Set the logical highest possible value for Maximum, in plot coordinates.

Get the logical highest possible value for Maximum, in plot coordinates.

virtual int* vtkAxis::GetMargins ( ) [virtual]

Get the margins of the axis, in pixels.

virtual void vtkAxis::GetMargins ( int ,
int  
) [virtual]

Get the margins of the axis, in pixels.

virtual void vtkAxis::GetMargins ( int  [2]) [virtual]

Get the margins of the axis, in pixels.

virtual void vtkAxis::SetMargins ( int  ,
int   
) [virtual]

Set the margins of the axis, in pixels.

void vtkAxis::SetMargins ( int  [2])

Set the margins of the axis, in pixels.

virtual void vtkAxis::SetTitle ( const vtkStdString title) [virtual]

Get/set the title text of the axis.

virtual vtkStdString vtkAxis::GetTitle ( ) [virtual]

Get/set the title text of the axis.

Get the vtkTextProperty that governs how the axis title is displayed.

virtual bool vtkAxis::GetLogScaleActive ( ) [virtual]

Get whether the axis is using a log scale. This will always be false when LogScale is false. It is only true when LogScale is true and the UnscaledRange does not cross or include the origin (zero). The limits (MinimumLimit, MaximumLimit, and their unscaled counterparts) do not prevent LogScaleActive from becoming true; they are adjusted if they cross or include the origin and the original limits are preserved for when LogScaleActive becomes false again.

virtual bool vtkAxis::GetLogScale ( ) [virtual]

Get/set whether the axis should attempt to use a log scale. The default is false.

See also:
{LogScaleActive}.
virtual void vtkAxis::SetLogScale ( bool  logScale) [virtual]

Get/set whether the axis should attempt to use a log scale. The default is false.

See also:
{LogScaleActive}.
virtual void vtkAxis::LogScaleOn ( ) [virtual]

Get/set whether the axis should attempt to use a log scale. The default is false.

See also:
{LogScaleActive}.
virtual void vtkAxis::LogScaleOff ( ) [virtual]

Get/set whether the axis should attempt to use a log scale. The default is false.

See also:
{LogScaleActive}.
virtual void vtkAxis::SetGridVisible ( bool  ) [virtual]

Get/set whether the axis grid lines should be drawn, default is true.

virtual bool vtkAxis::GetGridVisible ( ) [virtual]

Get/set whether the axis grid lines should be drawn, default is true.

virtual void vtkAxis::SetLabelsVisible ( bool  ) [virtual]

Get/set whether the axis labels should be visible.

virtual bool vtkAxis::GetLabelsVisible ( ) [virtual]

Get/set whether the axis labels should be visible.

virtual void vtkAxis::SetTicksVisible ( bool  ) [virtual]

Get/set whether the tick marks should be visible.

virtual bool vtkAxis::GetTicksVisible ( ) [virtual]

Get/set whether the tick marks should be visible.

virtual void vtkAxis::SetPrecision ( int  precision) [virtual]

Get/set the numerical precision to use, default is 2.

virtual int vtkAxis::GetPrecision ( ) [virtual]

Get/set the numerical precision to use, default is 2.

virtual void vtkAxis::SetNotation ( int  notation) [virtual]

Get/set the numerical notation, standard, scientific or mixed (0, 1, 2).

virtual int vtkAxis::GetNotation ( ) [virtual]

Enumeration of the axis notations available.

virtual void vtkAxis::SetBehavior ( int  ) [virtual]

Get/set the behavior of the axis (auto or fixed). The default is 0 (auto).

virtual int vtkAxis::GetBehavior ( ) [virtual]

Get/set the behavior of the axis (auto or fixed). The default is 0 (auto).

virtual vtkPen* vtkAxis::GetPen ( ) [virtual]

Get a pointer to the vtkPen object that controls the way this axis is drawn.

virtual vtkPen* vtkAxis::GetGridPen ( ) [virtual]

Get a pointer to the vtkPen object that controls the way this axis is drawn.

virtual void vtkAxis::SetTickLabelAlgorithm ( int  ) [virtual]

Get/set the tick label algorithm that is used to calculate the min, max and tick spacing. There are currently two algoriths, vtkAxis::TICK_SIMPLE is the default and uses a simple algorithm. The second option is vtkAxis::TICK_WILKINSON which uses an extended Wilkinson algorithm to find the optimal range, spacing and font parameters.

virtual int vtkAxis::GetTickLabelAlgorithm ( ) [virtual]

Get/set the tick label algorithm that is used to calculate the min, max and tick spacing. There are currently two algoriths, vtkAxis::TICK_SIMPLE is the default and uses a simple algorithm. The second option is vtkAxis::TICK_WILKINSON which uses an extended Wilkinson algorithm to find the optimal range, spacing and font parameters.

virtual void vtkAxis::SetScalingFactor ( double  ) [virtual]

Get/set the scaling factor used for the axis, this defaults to 1.0 (no scaling), and is used to coordinate scaling with the plots, charts, etc.

virtual double vtkAxis::GetScalingFactor ( ) [virtual]

Get/set the scaling factor used for the axis, this defaults to 1.0 (no scaling), and is used to coordinate scaling with the plots, charts, etc.

virtual void vtkAxis::SetShift ( double  ) [virtual]

Get/set the scaling factor used for the axis, this defaults to 1.0 (no scaling), and is used to coordinate scaling with the plots, charts, etc.

virtual double vtkAxis::GetShift ( ) [virtual]

Get/set the scaling factor used for the axis, this defaults to 1.0 (no scaling), and is used to coordinate scaling with the plots, charts, etc.

virtual void vtkAxis::Update ( ) [virtual]

Update the geometry of the axis. Takes care of setting up the tick mark locations etc. Should be called by the scene before rendering.

Reimplemented from vtkAbstractContextItem.

virtual bool vtkAxis::Paint ( vtkContext2D painter) [virtual]

Paint event for the axis, called whenever the axis needs to be drawn.

Reimplemented from vtkAbstractContextItem.

virtual void vtkAxis::AutoScale ( ) [virtual]

Use this function to autoscale the axes after setting the minimum and maximum values. This will cause the axes to select the nicest numbers that enclose the minimum and maximum values, and to select an appropriate number of tick marks.

virtual void vtkAxis::RecalculateTickSpacing ( ) [virtual]

Recalculate the spacing of the tick marks - typically useful to do after scaling the axis.

virtual vtkDoubleArray* vtkAxis::GetTickPositions ( ) [virtual]

An array with the positions of the tick marks along the axis line. The positions are specified in the plot coordinates of the axis.

An array with the positions of the tick marks along the axis line. The positions are specified in scene coordinates.

virtual vtkStringArray* vtkAxis::GetTickLabels ( ) [virtual]

A string array containing the tick labels for the axis.

virtual bool vtkAxis::SetCustomTickPositions ( vtkDoubleArray positions,
vtkStringArray labels = 0 
) [virtual]

Set the tick positions, and optionally custom tick labels. If the labels and positions are null then automatic tick labels will be assigned. If only positions are supplied then appropriate labels will be generated according to the axis settings. If positions and labels are supplied they must be of the same length. Returns true on success, false on failure.

virtual void vtkAxis::SetTickPositions ( vtkDoubleArray positions) [virtual]

Set the tick positions (in plot coordinates).

Deprecated:
6.0 Use the two parameter SetTickPositions function.
virtual void vtkAxis::SetTickLabels ( vtkStringArray labels) [virtual]

Set the tick labels for the axis.

Deprecated:
6.0 Use the two parameter SetTickPositions function.

Request the space the axes require to be drawn. This is returned as a vtkRectf, with the corner being the offset from Point1, and the width/ height being the total width/height required by the axis. In order to ensure the numbers are correct, Update() should be called on the axis.

static double vtkAxis::NiceNumber ( double  number,
bool  roundUp 
) [static]

Return a "nice number", often defined as 1, 2 or 5. If roundUp is true then the nice number will be rounded up, false it is rounded down. The supplied number should be between 0.0 and 9.9.

static double vtkAxis::NiceMinMax ( double min,
double max,
float  pixelRange,
float  tickPixelSpacing 
) [static]

Static function to calculate "nice" minimum, maximum, and tick spacing values.

void vtkAxis::UpdateLogScaleActive ( bool  updateMinMaxFromUnscaled) [protected]

Update whether log scaling will be used for layout and rendering. Log scaling is only active when LogScaling is true and the closed, unscaled range does not contain the origin. The boolean parameter determines whether the minimum and maximum values are set from their unscaled counterparts.

void vtkAxis::GenerateTickLabels ( double  min,
double  max 
) [protected]

Calculate and assign nice labels/logical label positions.

void vtkAxis::GenerateTickLabels ( ) [protected]

Generate tick labels from the supplied double array of tick positions.

void vtkAxis::GenerateLabelFormat ( int  notation,
double  n 
) [protected]
double vtkAxis::CalculateNiceMinMax ( double min,
double max 
) [protected]

Calculate the next "nicest" numbers above and below the current minimum.

Returns:
the "nice" spacing of the numbers.
double vtkAxis::LogScaleTickMark ( double  number,
bool  roundUp,
bool &  niceValue,
int order 
) [protected]

Return a tick mark for a logarithmic axis. If roundUp is true then the upper tick mark is returned. Otherwise the lower tick mark is returned. Tick marks will be: ... 0.1 0.2 .. 0.9 1 2 .. 9 10 20 .. 90 100 ... Parameter nicevalue will be set to true if tick mark is in: ... 0.1 0.2 0.5 1 2 5 10 20 50 100 ... Parameter order is set to the detected order of magnitude of the number.

void vtkAxis::GenerateLogSpacedLinearTicks ( int  order,
double  min,
double  max 
) [protected]

Generate logarithmically-spaced tick marks with linear-style labels. This is for the case when log scaling is active, but the axis min and max span less than an order of magnitude. In this case, the most significant digit that varies is identified and ticks generated for each value that digit may take on. If that results in only 2 tick marks, the next-most-significant digit is varied. If more than 20 tick marks would result, the stride for the varying digit is increased.

void vtkAxis::GenerateLogScaleTickMarks ( int  order,
double  min = 1.0,
double  max = 9.0,
bool  detailLabels = true 
) [protected]

Generate tick marks for logarithmic scale for specific order of magnitude. Mark generation is limited by parameters min and max. Tick marks will be: ... 0.1 0.2 .. 0.9 1 2 .. 9 10 20 .. 90 100 ... Tick labels will be: ... 0.1 0.2 0.5 1 2 5 10 20 50 100 ... If Parameter detaillabels is disabled tick labels will be: ... 0.1 1 10 100 ... If min/max is not in between 1.0 and 9.0 defaults will be used. If min and max do not differ 1 defaults will be used.


Member Data Documentation

int vtkAxis::Position [protected]

Definition at line 512 of file vtkAxis.h.

float* vtkAxis::Point1 [protected]

Definition at line 513 of file vtkAxis.h.

float* vtkAxis::Point2 [protected]

Definition at line 514 of file vtkAxis.h.

Definition at line 515 of file vtkAxis.h.

Definition at line 515 of file vtkAxis.h.

Definition at line 516 of file vtkAxis.h.

Definition at line 517 of file vtkAxis.h.

Definition at line 518 of file vtkAxis.h.

double vtkAxis::Minimum [protected]

Definition at line 519 of file vtkAxis.h.

double vtkAxis::Maximum [protected]

Definition at line 520 of file vtkAxis.h.

Definition at line 521 of file vtkAxis.h.

Definition at line 522 of file vtkAxis.h.

Definition at line 523 of file vtkAxis.h.

Definition at line 524 of file vtkAxis.h.

Definition at line 525 of file vtkAxis.h.

Definition at line 526 of file vtkAxis.h.

Definition at line 527 of file vtkAxis.h.

Definition at line 528 of file vtkAxis.h.

int vtkAxis::Margins[2] [protected]

Definition at line 529 of file vtkAxis.h.

Definition at line 530 of file vtkAxis.h.

Definition at line 531 of file vtkAxis.h.

bool vtkAxis::LogScale [protected]

Definition at line 532 of file vtkAxis.h.

bool vtkAxis::LogScaleActive [protected]

Definition at line 533 of file vtkAxis.h.

bool vtkAxis::GridVisible [protected]

Definition at line 534 of file vtkAxis.h.

bool vtkAxis::LabelsVisible [protected]

Definition at line 535 of file vtkAxis.h.

bool vtkAxis::TicksVisible [protected]

Definition at line 536 of file vtkAxis.h.

int vtkAxis::Precision [protected]

Definition at line 537 of file vtkAxis.h.

int vtkAxis::Notation [protected]

Definition at line 538 of file vtkAxis.h.

int vtkAxis::Behavior [protected]

Definition at line 539 of file vtkAxis.h.

float vtkAxis::MaxLabel[2] [protected]

Definition at line 540 of file vtkAxis.h.

bool vtkAxis::TitleAppended [protected]

Definition at line 541 of file vtkAxis.h.

Scaling factor used on this axis, this is used to accurately render very small/large numbers accurately by converting the underlying range by the scaling factor.

Definition at line 548 of file vtkAxis.h.

double vtkAxis::Shift [protected]

Scaling factor used on this axis, this is used to accurately render very small/large numbers accurately by converting the underlying range by the scaling factor.

Definition at line 549 of file vtkAxis.h.

bool vtkAxis::CustomTickLabels [protected]

Are we using custom tick labels, or should the axis generate them?

Definition at line 553 of file vtkAxis.h.

vtkPen* vtkAxis::Pen [protected]

This object stores the vtkPen that controls how the axis is drawn.

Definition at line 556 of file vtkAxis.h.

vtkPen* vtkAxis::GridPen [protected]

This object stores the vtkPen that controls how the grid lines are drawn.

Definition at line 560 of file vtkAxis.h.

Position of tick marks in screen coordinates

Definition at line 563 of file vtkAxis.h.

Position of tick marks in screen coordinates

Definition at line 566 of file vtkAxis.h.

The labels for the tick marks

Definition at line 569 of file vtkAxis.h.

bool vtkAxis::UsingNiceMinMax [protected]

Hint as to whether a nice min/max was set, otherwise labels may not be present at the top/bottom of the axis.

Definition at line 573 of file vtkAxis.h.

bool vtkAxis::TickMarksDirty [protected]

Mark the tick labels as dirty when the min/max value is changed.

Definition at line 576 of file vtkAxis.h.

bool vtkAxis::Resized [protected]

Flag to indicate that the axis has been resized.

Definition at line 579 of file vtkAxis.h.

The algorithm being used to tick label placement.

Definition at line 582 of file vtkAxis.h.

The point cache is marked dirty until it has been initialized.

Definition at line 585 of file vtkAxis.h.


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