KissCount/lib/libkdchart/src/KDChartMeasure.cpp

248 lines
7.6 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.
**
**********************************************************************/
#include "KDChartMeasure.h"
#include <QWidget>
#include <QtXml/QDomDocumentFragment>
#include <KDChartAbstractArea.h>
#include <KDChartCartesianCoordinatePlane.h>
#include <KDChartTextAttributes.h>
#include <KDChartFrameAttributes.h>
#include <KDChartBackgroundAttributes.h>
#include <KDABLibFakes>
namespace KDChart {
Measure::Measure()
: mValue( 0.0 ),
mMode( KDChartEnums::MeasureCalculationModeAuto ),
mArea( 0 ),
mOrientation( KDChartEnums::MeasureOrientationAuto )
{
// this bloc left empty intentionally
}
Measure::Measure( qreal value,
KDChartEnums::MeasureCalculationMode mode,
KDChartEnums::MeasureOrientation orientation )
: mValue( value ),
mMode( mode ),
mArea( 0 ),
mOrientation( orientation )
{
// this bloc left empty intentionally
}
Measure::Measure( const Measure& r )
: mValue( r.value() ),
mMode( r.calculationMode() ),
mArea( r.referenceArea() ),
mOrientation( r.referenceOrientation() )
{
// this bloc left empty intentionally
}
Measure & Measure::operator=( const Measure& r )
{
if( this != &r ){
mValue = r.value();
mMode = r.calculationMode();
mArea = r.referenceArea();
mOrientation = r.referenceOrientation();
}
return *this;
}
qreal Measure::calculatedValue( const QSizeF& autoSize,
KDChartEnums::MeasureOrientation autoOrientation) const
{
if( mMode == KDChartEnums::MeasureCalculationModeAbsolute ){
return mValue;
}else{
qreal value = 0.0;
const QObject theAutoArea;
const QObject* autoArea = &theAutoArea;
const QObject* area = mArea ? mArea : autoArea;
KDChartEnums::MeasureOrientation orientation = mOrientation;
switch( mMode ){
case KDChartEnums::MeasureCalculationModeAuto:
area = autoArea;
orientation = autoOrientation;
break;
case KDChartEnums::MeasureCalculationModeAutoArea:
area = autoArea;
break;
case KDChartEnums::MeasureCalculationModeAutoOrientation:
orientation = autoOrientation;
break;
case KDChartEnums::MeasureCalculationModeAbsolute: // fall through intended
case KDChartEnums::MeasureCalculationModeRelative:
break;
}
if( area ){
QSizeF size;
if( area == autoArea )
size = autoSize;
else
size = sizeOfArea( area );
//qDebug() << ( area == autoArea ) << "size" << size;
qreal referenceValue = 0;
switch( orientation ){
case KDChartEnums::MeasureOrientationAuto: // fall through intended
case KDChartEnums::MeasureOrientationMinimum:
referenceValue = qMin( size.width(), size.height() );
break;
case KDChartEnums::MeasureOrientationMaximum:
referenceValue = qMax( size.width(), size.height() );
break;
case KDChartEnums::MeasureOrientationHorizontal:
referenceValue = size.width();
break;
case KDChartEnums::MeasureOrientationVertical:
referenceValue = size.height();
break;
}
value = mValue / 1000.0 * referenceValue;
}
return value;
}
}
qreal Measure::calculatedValue( const QObject* autoArea,
KDChartEnums::MeasureOrientation autoOrientation) const
{
return calculatedValue( sizeOfArea( autoArea ), autoOrientation);
}
const QSizeF Measure::sizeOfArea( const QObject* area ) const
{
QSizeF size;
const CartesianCoordinatePlane* plane = dynamic_cast<const CartesianCoordinatePlane*>( area );
if ( false ) {
size = plane->visibleDiagramArea().size();
} else {
const AbstractArea* kdcArea = dynamic_cast<const AbstractArea*>(area);
if( kdcArea ){
size = kdcArea->geometry().size();
//qDebug() << "Measure::sizeOfArea() found kdcArea with size" << size;
}else{
const QWidget* widget = dynamic_cast<const QWidget*>(area);
if( widget ){
/* ATTENTION: Using the layout does not work: The Legend will never get the right size then!
const QLayout * layout = widget->layout();
if( layout ){
size = layout->geometry().size();
//qDebug() << "Measure::sizeOfArea() found widget with layout size" << size;
}else*/
{
size = widget->geometry().size();
//qDebug() << "Measure::sizeOfArea() found widget with size" << size;
}
}else if( mMode != KDChartEnums::MeasureCalculationModeAbsolute ){
size = QSizeF(1.0, 1.0);
//qDebug("Measure::sizeOfArea() got no valid area.");
}
}
}
const QPair< qreal, qreal > factors
= GlobalMeasureScaling::instance()->currentFactors();
return QSizeF(size.width() * factors.first, size.height() * factors.second);
}
bool Measure::operator==( const Measure& r ) const
{
return( mValue == r.value() &&
mMode == r.calculationMode() &&
mArea == r.referenceArea() &&
mOrientation == r.referenceOrientation() );
}
GlobalMeasureScaling::GlobalMeasureScaling()
{
mFactors.push( qMakePair(qreal(1.0), qreal(1.0)) );
}
GlobalMeasureScaling::~GlobalMeasureScaling()
{
// this space left empty intentionally
}
GlobalMeasureScaling* GlobalMeasureScaling::instance()
{
static GlobalMeasureScaling instance;
return &instance;
}
void GlobalMeasureScaling::setFactors(qreal factorX, qreal factorY)
{
instance()->mFactors.push( qMakePair(factorX, factorY) );
}
void GlobalMeasureScaling::resetFactors()
{
// never remove the initial (1.0. 1.0) setting
if( instance()->mFactors.count() > 1 )
instance()->mFactors.pop();
}
const QPair< qreal, qreal > GlobalMeasureScaling::currentFactors()
{
return instance()->mFactors.top();
}
void GlobalMeasureScaling::setPaintDevice( QPaintDevice* paintDevice )
{
instance()->m_paintDevice = paintDevice;
}
QPaintDevice* GlobalMeasureScaling::paintDevice()
{
return instance()->m_paintDevice;
}
}
#if !defined(QT_NO_DEBUG_STREAM)
QDebug operator<<(QDebug dbg, const KDChart::Measure& m)
{
dbg << "KDChart::Measure("
<< "value="<<m.value()
<< "calculationmode="<<m.calculationMode()
<< "referencearea="<<m.referenceArea()
<< "referenceorientation="<<m.referenceOrientation()
<< ")";
return dbg;
}
#endif /* QT_NO_DEBUG_STREAM */