217 lines
9.0 KiB
C
217 lines
9.0 KiB
C
|
/****************************************************************************
|
||
|
** Copyright (C) 2001-2011 Klaralvdalens Datakonsult AB. All rights reserved.
|
||
|
**
|
||
|
** This file is part of the KD Chart library.
|
||
|
**
|
||
|
** Licensees holding valid commercial KD Chart licenses may use this file in
|
||
|
** accordance with the KD Chart Commercial License Agreement provided with
|
||
|
** the Software.
|
||
|
**
|
||
|
**
|
||
|
** This file may be distributed and/or modified under the terms of the
|
||
|
** GNU General Public License version 2 and version 3 as published by the
|
||
|
** Free Software Foundation and appearing in the file LICENSE.GPL.txt included.
|
||
|
**
|
||
|
** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
|
||
|
** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
|
||
|
**
|
||
|
** Contact info@kdab.com if any conditions of this licensing are not
|
||
|
** clear to you.
|
||
|
**
|
||
|
**********************************************************************/
|
||
|
|
||
|
#ifndef KDCHARTRELATIVEPOSITION_H
|
||
|
#define KDCHARTRELATIVEPOSITION_H
|
||
|
|
||
|
#include <QDebug>
|
||
|
#include <QMetaType>
|
||
|
#include <Qt>
|
||
|
#include <QPointF>
|
||
|
#include <QSizeF>
|
||
|
#include "KDChartGlobal.h"
|
||
|
|
||
|
namespace KDChart {
|
||
|
|
||
|
class Position;
|
||
|
class PositionPoints;
|
||
|
class Measure;
|
||
|
|
||
|
/**
|
||
|
\class RelativePosition KDChartRelativePosition.h
|
||
|
\brief Defines relative position information: reference area, position
|
||
|
in this area, horizontal / vertical padding, and rotating.
|
||
|
|
||
|
Using RelativePosition you can specify the relative parts
|
||
|
of some position information, and you can specify the absolute parts:
|
||
|
the reference area, and the position in this area.
|
||
|
|
||
|
\note To get an absolute position, you have three options:
|
||
|
\li either you declare both, the relative and the absolute parts,
|
||
|
using setReferenceArea for the later,
|
||
|
\li or you specify a set of points, using setReferencePoints,
|
||
|
\li or you refrein from using either, but leave it to KD Chart to find
|
||
|
a matching reference area for you.
|
||
|
*/
|
||
|
class KDCHART_EXPORT RelativePosition
|
||
|
{
|
||
|
public:
|
||
|
RelativePosition();
|
||
|
RelativePosition( const RelativePosition& );
|
||
|
|
||
|
RelativePosition & operator=( const RelativePosition & other );
|
||
|
|
||
|
~RelativePosition();
|
||
|
|
||
|
/**
|
||
|
* \brief Specifies the reference area to be used to find the anchor point.
|
||
|
*
|
||
|
* The reference area's type can be either QWidget, or be derived from KDChart::AbstractArea.
|
||
|
*
|
||
|
* \note Usage of reference area and reference points works mutually exclusively:
|
||
|
* Only one setting can be valid, so any former specification of reference points is reset
|
||
|
* when you call setReferenceArea.
|
||
|
*
|
||
|
* Also note: In a few cases KD Chart will ignore your area (or points, resp.) settings!
|
||
|
* Relative positioning of data value texts is an example: For these
|
||
|
* the reference area is the respective data area taking precendence over your settings.
|
||
|
*
|
||
|
* \sa setReferencePosition, setAlignment, setHorizontalPadding, setVerticalPadding
|
||
|
*/
|
||
|
void setReferenceArea( QObject* area );
|
||
|
QObject* referenceArea() const;
|
||
|
|
||
|
/**
|
||
|
* \brief Specifies a set of points from which the anchor point will be selected.
|
||
|
*
|
||
|
* \note Usage of reference area and reference points works mutually exclusively:
|
||
|
* Only one setting can be valid, so any former specification of reference area is reset
|
||
|
* when you call setReferencePoints.
|
||
|
*
|
||
|
* Also note: In a few cases KD Chart will ignore your points (or area, resp.) settings!
|
||
|
* Relative positioning of data value texts is an example: For these
|
||
|
* the reference area is the respective data area taking precendence over your settings.
|
||
|
*
|
||
|
* \sa setReferenceArea, setReferencePosition, setAlignment, setHorizontalPadding, setVerticalPadding
|
||
|
*/
|
||
|
void setReferencePoints( const PositionPoints& points );
|
||
|
const PositionPoints referencePoints() const;
|
||
|
|
||
|
/**
|
||
|
* \brief Specifies the position of the anchor point.
|
||
|
*
|
||
|
* The anchor point of a RelativePosition may be one of the pre-defined
|
||
|
* points of it's reference area - for details see KDChart::Position.
|
||
|
*
|
||
|
* \sa resetReferencePosition, setReferenceArea, setAlignment, setHorizontalPadding, setVerticalPadding, KDChart::Position
|
||
|
*/
|
||
|
void setReferencePosition( Position position );
|
||
|
|
||
|
/**
|
||
|
* \brief Resets the position of the anchor point to the built-in default.
|
||
|
*
|
||
|
* If the anchor point of a RelativePosition is reset (or never changed from the
|
||
|
* default setting, resp.) KD Chart will choose an appropriate Position at run-time.
|
||
|
*
|
||
|
* e.g. BarDiagrams will use Position::NorthWest / Position::SouthEast for positive / negative values.
|
||
|
*
|
||
|
* \sa setReferencePosition, setReferenceArea, setAlignment, setHorizontalPadding, setVerticalPadding, KDChart::Position
|
||
|
*/
|
||
|
void resetReferencePosition();
|
||
|
Position referencePosition() const;
|
||
|
|
||
|
/**
|
||
|
* Specifies the location of the content, that is to be positioned by this RelativePosition.
|
||
|
*
|
||
|
* Aligning is applied, after horiz./vert. padding was retrieved to calculate the real
|
||
|
* reference point, so aligning is seen as relative to that point.
|
||
|
*
|
||
|
* \note When printing data value texts at a centered point you might want to call
|
||
|
* setAlignment( Qt::AlignCenter ) and also set the horizontal/vertical padding to Zero
|
||
|
* to have your texts centered more precisely.
|
||
|
*
|
||
|
* \sa setReferencePosition, setReferenceArea, setHorizontalPadding, setVerticalPadding
|
||
|
*/
|
||
|
void setAlignment( Qt::Alignment flags );
|
||
|
Qt::Alignment alignment() const;
|
||
|
|
||
|
/**
|
||
|
* Specifies the horizontal width of the gap between the anchor point and the content,
|
||
|
* that is to be positioned by this RelativePosition.
|
||
|
*
|
||
|
* \note When printing data value texts this Measure is used to find the alignment
|
||
|
* point to align the text to, then alignment() is looked at to determine the way how
|
||
|
* the text is to be aligned to that point. The font height is used as reference size
|
||
|
* for both, horizontal and vertical padding, if the respective padding's Measure is
|
||
|
* using automatic reference area detection.
|
||
|
*
|
||
|
* \sa setVerticalPadding, setReferencePosition, setReferenceArea
|
||
|
*/
|
||
|
void setHorizontalPadding( const Measure& padding );
|
||
|
Measure horizontalPadding() const;
|
||
|
|
||
|
/**
|
||
|
* Specifies the vertical width of the gap between the anchor point and the content,
|
||
|
* that is to be positioned by this RelativePosition.
|
||
|
*
|
||
|
* \note When printing data value texts this Measure is used to find the alignment
|
||
|
* point to align the text to, then alignment() is looked at to determine the way how
|
||
|
* the text is to be aligned to that point. The font height is used as reference size
|
||
|
* for both, horizontal and vertical padding, if the respective padding's Measure is
|
||
|
* using automatic reference area detection.
|
||
|
*
|
||
|
* \sa setHorizontalPadding, setReferencePosition, setReferenceArea
|
||
|
*/
|
||
|
void setVerticalPadding( const Measure& padding );
|
||
|
Measure verticalPadding() const;
|
||
|
|
||
|
void setRotation( qreal rot );
|
||
|
qreal rotation() const;
|
||
|
|
||
|
/**
|
||
|
* \brief Return the reference point, according to the reference area/position, but ignoring horiz/vert padding.
|
||
|
*
|
||
|
* This method is called at drawing time.
|
||
|
* The returned point is used to test if the label of a data value is to be printed: labels
|
||
|
* are printed only, if their reference points are either inside or touching the coordinate plane.
|
||
|
*
|
||
|
* If polarDegrees is set, the degree information will be returned that was stored for the
|
||
|
* respective point. This is used by the PieDiagram class to determin how vertical/horizontal
|
||
|
* padding settings should affect the position of the data value texts' reference points.
|
||
|
*
|
||
|
* \sa calculatedPoint, setReferenceArea, setReferencePosition, setHorizontalPadding, setVerticalPadding
|
||
|
*/
|
||
|
const QPointF referencePoint(qreal* polarDegrees=0) const;
|
||
|
|
||
|
/**
|
||
|
* \brief Calculate a point, according to the reference area/position and horiz/vert padding.
|
||
|
*
|
||
|
* This method is called at drawing time: The returned point is used as anchor point.
|
||
|
* Note that calculatedPoint ignores the alignment setting, it just returns the point,
|
||
|
* so the calling code needs to take alignment into account explicitly.
|
||
|
*
|
||
|
* \sa referencePoint, setReferenceArea, setReferencePosition, setHorizontalPadding, setVerticalPadding
|
||
|
*/
|
||
|
const QPointF calculatedPoint( const QSizeF& autoSize ) const;
|
||
|
|
||
|
bool operator==( const RelativePosition& ) const;
|
||
|
bool operator!=( const RelativePosition & other ) const;
|
||
|
|
||
|
private:
|
||
|
KDCHART_DECLARE_PRIVATE_BASE_VALUE( RelativePosition )
|
||
|
};
|
||
|
|
||
|
inline bool RelativePosition::operator!=( const RelativePosition & other ) const { return !operator==( other ); }
|
||
|
}
|
||
|
|
||
|
KDCHART_DECLARE_SWAP_SPECIALISATION( KDChart::RelativePosition )
|
||
|
|
||
|
Q_DECLARE_TYPEINFO( KDChart::RelativePosition, Q_MOVABLE_TYPE );
|
||
|
Q_DECLARE_METATYPE( KDChart::RelativePosition )
|
||
|
|
||
|
#if !defined(QT_NO_DEBUG_STREAM)
|
||
|
KDCHART_EXPORT QDebug operator<<(QDebug, const KDChart::RelativePosition& );
|
||
|
#endif /* QT_NO_DEBUG_STREAM */
|
||
|
|
||
|
|
||
|
#endif // KDCHARTRELATIVEPOSITION_H
|