A class for drawing scales.  
 More...
#include <qwt_scale_draw.h>
A class for drawing scales. 
QwtScaleDraw can be used to draw linear or logarithmic scales. A scale has a position, an alignment and a length, which can be specified . The labels can be rotated and aligned to the ticks using setLabelRotation() and setLabelAlignment().
After a scale division has been specified as a QwtScaleDiv object using QwtAbstractScaleDraw::setScaleDiv(const QwtScaleDiv &s), the scale can be drawn with the QwtAbstractScaleDraw::draw() member. 
◆ Alignment
Alignment of the scale draw 
- See also
- setAlignment(), alignment() 
| Enumerator | 
|---|
| BottomScale | The scale is below.  | 
| TopScale | The scale is above.  | 
| LeftScale | The scale is left.  | 
| RightScale | The scale is right.  | 
 
 
◆ QwtScaleDraw()
      
        
          | QwtScaleDraw::QwtScaleDraw | ( |  | ) |  | 
      
 
Constructor. 
The range of the scale is initialized to [0, 100], The position is at (0, 0) with a length of 100. The orientation is QwtAbstractScaleDraw::Bottom. 
 
 
◆ alignment()
Return alignment of the scale 
- See also
- setAlignment() 
- Returns
- Alignment of the scale 
 
 
◆ boundingLabelRect()
      
        
          | QRect QwtScaleDraw::boundingLabelRect | ( | const QFont & | font, | 
        
          |  |  | double | value | 
        
          |  | ) |  | const | 
      
 
Find the bounding rectangle for the label. 
The coordinates of the rectangle are absolute ( calculated from pos() ). in direction of the tick.
- Parameters
- 
  
    | font | Font used for painting |  | value | Value |  
 
- Returns
- Bounding rectangle 
- See also
- labelRect() 
 
 
◆ drawBackbone()
  
  | 
        
          | void QwtScaleDraw::drawBackbone | ( | QPainter * | painter | ) | const |  | protectedvirtual | 
 
 
◆ drawLabel()
  
  | 
        
          | void QwtScaleDraw::drawLabel | ( | QPainter * | painter, |  
          |  |  | double | value |  
          |  | ) |  | const |  | protectedvirtual | 
 
 
◆ drawTick()
  
  | 
        
          | void QwtScaleDraw::drawTick | ( | QPainter * | painter, |  
          |  |  | double | value, |  
          |  |  | double | len |  
          |  | ) |  | const |  | protectedvirtual | 
 
 
◆ extent()
  
  | 
        
          | double QwtScaleDraw::extent | ( | const QFont & | font | ) | const |  | virtual | 
 
Calculate the width/height that is needed for a vertical/horizontal scale.
The extent is calculated from the pen width of the backbone, the major tick length, the spacing and the maximum width/height of the labels.
- Parameters
- 
  
    | font | Font used for painting the labels |  
 
- Returns
- Extent
- See also
- minLength() 
Implements QwtAbstractScaleDraw.
 
 
◆ getBorderDistHint()
      
        
          | void QwtScaleDraw::getBorderDistHint | ( | const QFont & | font, | 
        
          |  |  | int & | start, | 
        
          |  |  | int & | end | 
        
          |  | ) |  | const | 
      
 
Determine the minimum border distance. 
This member function returns the minimum space needed to draw the mark labels at the scale's endpoints.
- Parameters
- 
  
    | font | Font |  | start | Start border distance |  | end | End border distance |  
 
 
 
◆ labelAlignment()
      
        
          | Qt::Alignment QwtScaleDraw::labelAlignment | ( |  | ) | const | 
      
 
 
◆ labelPosition()
      
        
          | QPointF QwtScaleDraw::labelPosition | ( | double | value | ) | const | 
      
 
Find the position, where to paint a label
The position has a distance that depends on the length of the ticks in direction of the alignment().
- Parameters
- 
  
  
- Returns
- Position, where to paint a label 
 
 
◆ labelRect()
      
        
          | QRectF QwtScaleDraw::labelRect | ( | const QFont & | font, | 
        
          |  |  | double | value | 
        
          |  | ) |  | const | 
      
 
Find the bounding rectangle for the label. The coordinates of the rectangle are relative to spacing + tick length from the backbone in direction of the tick.
- Parameters
- 
  
    | font | Font used for painting |  | value | Value |  
 
- Returns
- Bounding rectangle that is needed to draw a label 
 
 
◆ labelRotation()
      
        
          | double QwtScaleDraw::labelRotation | ( |  | ) | const | 
      
 
 
◆ labelSize()
      
        
          | QSizeF QwtScaleDraw::labelSize | ( | const QFont & | font, | 
        
          |  |  | double | value | 
        
          |  | ) |  | const | 
      
 
Calculate the size that is needed to draw a label
- Parameters
- 
  
    | font | Label font |  | value | Value |  
 
- Returns
- Size that is needed to draw a label 
 
 
◆ labelTransformation()
  
  | 
        
          | QTransform QwtScaleDraw::labelTransformation | ( | const QPointF & | pos, |  
          |  |  | const QSizeF & | size |  
          |  | ) |  | const |  | protected | 
 
Calculate the transformation that is needed to paint a label depending on its alignment and rotation.
- Parameters
- 
  
    | pos | Position where to paint the label |  | size | Size of the label |  
 
- Returns
- Transformation matrix 
- See also
- setLabelAlignment(), setLabelRotation() 
 
 
◆ length()
      
        
          | double QwtScaleDraw::length | ( |  | ) | const | 
      
 
 
◆ maxLabelHeight()
      
        
          | int QwtScaleDraw::maxLabelHeight | ( | const QFont & | font | ) | const | 
      
 
- Parameters
- 
  
  
- Returns
- the maximum height of a label 
 
 
◆ maxLabelWidth()
      
        
          | int QwtScaleDraw::maxLabelWidth | ( | const QFont & | font | ) | const | 
      
 
- Parameters
- 
  
  
- Returns
- the maximum width of a label 
 
 
◆ minLabelDist()
      
        
          | int QwtScaleDraw::minLabelDist | ( | const QFont & | font | ) | const | 
      
 
Determine the minimum distance between two labels, that is necessary that the texts don't overlap.
- Parameters
- 
  
  
- Returns
- The maximum width of a label
- See also
- getBorderDistHint() 
 
 
◆ minLength()
      
        
          | int QwtScaleDraw::minLength | ( | const QFont & | font | ) | const | 
      
 
Calculate the minimum length that is needed to draw the scale
- Parameters
- 
  
    | font | Font used for painting the labels |  
 
- Returns
- Minimum length that is needed to draw the scale
- See also
- extent() 
 
 
◆ move() [1/2]
      
        
          | void QwtScaleDraw::move | ( | const QPointF & | pos | ) |  | 
      
 
Move the position of the scale. 
The meaning of the parameter pos depends on the alignment: 
- QwtScaleDraw::LeftScale 
- The origin is the topmost point of the backbone. The backbone is a vertical line. Scale marks and labels are drawn at the left of the backbone. 
- QwtScaleDraw::RightScale 
- The origin is the topmost point of the backbone. The backbone is a vertical line. Scale marks and labels are drawn at the right of the backbone. 
- QwtScaleDraw::TopScale 
- The origin is the leftmost point of the backbone. The backbone is a horizontal line. Scale marks and labels are drawn above the backbone. 
- QwtScaleDraw::BottomScale 
- The origin is the leftmost point of the backbone. The backbone is a horizontal line Scale marks and labels are drawn below the backbone. 
- Parameters
- 
  
  
- See also
- pos(), setLength() 
 
 
◆ move() [2/2]
  
  | 
        
          | void QwtScaleDraw::move | ( | double | x, |  
          |  |  | double | y |  
          |  | ) |  |  |  | inline | 
 
 
◆ orientation()
      
        
          | Qt::Orientation QwtScaleDraw::orientation | ( |  | ) | const | 
      
 
Return the orientation
TopScale, BottomScale are horizontal (Qt::Horizontal) scales, LeftScale, RightScale are vertical (Qt::Vertical) scales.
- Returns
- Orientation of the scale
- See also
- alignment() 
 
 
◆ pos()
      
        
          | QPointF QwtScaleDraw::pos | ( |  | ) | const | 
      
 
 
◆ setAlignment()
      
        
          | void QwtScaleDraw::setAlignment | ( | Alignment | align | ) |  | 
      
 
 
◆ setLabelAlignment()
      
        
          | void QwtScaleDraw::setLabelAlignment | ( | Qt::Alignment | alignment | ) |  | 
      
 
Change the label flags. 
Labels are aligned to the point tick length + spacing away from the backbone.
The alignment is relative to the orientation of the label text. In case of an flags of 0 the label will be aligned depending on the orientation of the scale: 
QwtScaleDraw::TopScale: Qt::AlignHCenter | Qt::AlignTop\n
QwtScaleDraw::BottomScale: Qt::AlignHCenter | Qt::AlignBottom\n
QwtScaleDraw::LeftScale: Qt::AlignLeft | Qt::AlignVCenter\n
QwtScaleDraw::RightScale: Qt::AlignRight | Qt::AlignVCenter\n
Changing the alignment is often necessary for rotated labels.
- Parameters
- 
  
    | alignment | Or'd Qt::AlignmentFlags see <qnamespace.h> |  
 
- See also
- setLabelRotation(), labelRotation(), labelAlignment() 
- Warning
- The various alignments might be confusing. The alignment of the label is not the alignment of the scale and is not the alignment of the flags ( QwtText::flags() ) returned from QwtAbstractScaleDraw::label(). 
 
 
◆ setLabelRotation()
      
        
          | void QwtScaleDraw::setLabelRotation | ( | double | rotation | ) |  | 
      
 
Rotate all labels.
When changing the rotation, it might be necessary to adjust the label flags too. Finding a useful combination is often the result of try and error.
- Parameters
- 
  
    | rotation | Angle in degrees. When changing the label rotation, the label flags often needs to be adjusted too. |  
 
- See also
- setLabelAlignment(), labelRotation(), labelAlignment(). 
 
 
◆ setLength()
      
        
          | void QwtScaleDraw::setLength | ( | double | length | ) |  | 
      
 
Set the length of the backbone.
The length doesn't include the space needed for overlapping labels.
- Parameters
- 
  
    | length | Length of the backbone |  
 
- See also
- move(), minLabelDist()