KissCount/lib/libkdchart/src/KDChartLineAttributes.h

106 lines
3.9 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 KDCHARTLINEATTRIBUTES_H
#define KDCHARTLINEATTRIBUTES_H
#include <QMetaType>
#include "KDChartGlobal.h"
namespace KDChart {
/**
* @brief Set of attributes for changing the appearance of line charts
*/
class KDCHART_EXPORT LineAttributes
{
public:
/**
\brief MissingValuesPolicy specifies how a missing value will be shown in a line diagram.
Missing value is assumed if the data cell contains a QVariant that can not be
interpreted as a double, or if the data cell is hidden while its dataset is not hidden.
\li \c MissingValuesAreBridged the default: No markers will be shown for missing values
but the line will be bridged if there is at least one valid cell before and after
the missing value(s), otherwise the segment will be hidden.
\li \c MissingValuesHideSegments Line segments starting with a missing value will
not be shown, and no markers will be shown for missing values, so this will look like
a piece of the line is missing.
\li \c MissingValuesShownAsZero Missing value(s) will be treated like normal zero values,
and markers will shown for them too, so there will be no visible difference between a
zero value and a missing value.
\li \c MissingValuesPolicyIgnored (internal value, do not use)
*/
enum MissingValuesPolicy {
MissingValuesAreBridged,
MissingValuesHideSegments,
MissingValuesShownAsZero,
MissingValuesPolicyIgnored };
LineAttributes();
LineAttributes( const LineAttributes& );
LineAttributes &operator= ( const LineAttributes& );
~LineAttributes();
/* line chart and area chart - all types */
void setMissingValuesPolicy( MissingValuesPolicy policy );
MissingValuesPolicy missingValuesPolicy() const;
/* area chart - all types */
/**
* Sets the lower or upper (depending on the displayed value being positive or
* negative, resp.) bounding line (i.e., the dataset with the line data). The area
* is then drawn between this line and the line of the specified dataset.
* Pass -1 to draw the area between this line and the zero line.
*/
void setAreaBoundingDataset( int dataset );
int areaBoundingDataset() const;
void setDisplayArea( bool display );
bool displayArea() const;
/*allows viewing the covered areas*/
void setTransparency( uint alpha );
uint transparency() const;
bool operator==( const LineAttributes& ) const;
inline bool operator!=( const LineAttributes& other ) const { return !operator==(other); }
private:
KDCHART_DECLARE_PRIVATE_BASE_VALUE( LineAttributes )
}; // End of class LineAttributes
}
#if !defined(QT_NO_DEBUG_STREAM)
KDCHART_EXPORT QDebug operator<<(QDebug, const KDChart::LineAttributes& );
#endif /* QT_NO_DEBUG_STREAM */
KDCHART_DECLARE_SWAP_SPECIALISATION( KDChart::LineAttributes )
Q_DECLARE_METATYPE( KDChart::LineAttributes )
Q_DECLARE_TYPEINFO( KDChart::LineAttributes, Q_MOVABLE_TYPE );
#endif // KDCHARTLINEATTRIBUTES_H