00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030 #include "KDChartTernaryLineDiagram.h"
00031 #include "KDChartTernaryLineDiagram_p.h"
00032
00033 #include <limits>
00034
00035 #include <QPainter>
00036
00037 #include <KDChartPaintContext>
00038
00039 #include "KDChartLineAttributes.h"
00040 #include "KDChartDataValueAttributes.h"
00041 #include "KDChartMarkerAttributes.h"
00042 #include "TernaryPoint.h"
00043 #include "TernaryConstants.h"
00044 #include "KDChartPainterSaver_p.h"
00045
00046 using namespace KDChart;
00047
00048 #define d d_func()
00049
00050 TernaryLineDiagram::Private::Private()
00051 : AbstractTernaryDiagram::Private()
00052 {
00053 }
00054
00055 TernaryLineDiagram::TernaryLineDiagram ( QWidget* parent,
00056 TernaryCoordinatePlane* plane )
00057 : AbstractTernaryDiagram( new Private(), parent, plane )
00058 {
00059 init();
00060 setDatasetDimensionInternal( 3 );
00061
00062 DataValueAttributes dataValueAttributes;
00063 dataValueAttributes.setVisible( true );
00064 MarkerAttributes markerAttributes;
00065 markerAttributes.setMarkerStyle( MarkerAttributes::MarkerCircle );
00066 markerAttributes.setVisible( true );
00067 dataValueAttributes.setMarkerAttributes( markerAttributes );
00068 attributesModel()->setDefaultForRole(
00069 KDChart::DataValueLabelAttributesRole,
00070 qVariantFromValue( dataValueAttributes ) );
00071 }
00072
00073 TernaryLineDiagram::~TernaryLineDiagram()
00074 {
00075 }
00076
00077 void TernaryLineDiagram::init()
00078 {
00079 }
00080
00081 void TernaryLineDiagram::resize (const QSizeF& area)
00082 {
00083 Q_UNUSED( area );
00084 }
00085
00086 void TernaryLineDiagram::paint (PaintContext *paintContext)
00087 {
00088 d->reverseMapper.clear();
00089
00090 d->paint( paintContext );
00091
00092 if ( model() == 0 ) return;
00093
00094 QPainter* p = paintContext->painter();
00095 PainterSaver s( p );
00096
00097 TernaryCoordinatePlane* plane =
00098 (TernaryCoordinatePlane*) paintContext->coordinatePlane();
00099 Q_ASSERT( plane );
00100
00101 double x, y, z;
00102
00103
00104
00105 const DataValueAttributes attrs( dataValueAttributes() );
00106
00107
00108 d->clearListOfAlreadyDrawnDataValueTexts();
00109
00110 int columnCount = model()->columnCount( rootIndex() );
00111 QPointF start;
00112 for(int column=0; column<columnCount; column+=datasetDimension() )
00113 {
00114 int numrows = model()->rowCount( rootIndex() );
00115 for( int row = 0; row < numrows; row++ )
00116 {
00117
00118 QModelIndex base = model()->index( row, column );
00119 if( ! model()->data( base ).isNull() )
00120 {
00121 p->setPen( PrintingParameters::scalePen( pen( base ) ) );
00122 p->setBrush( brush( base ) );
00123
00124
00125 x = qMax( model()->data( model()->index( row, column, rootIndex() ) ).toDouble(),
00126 0.0 );
00127 y = qMax( model()->data( model()->index( row, column+1, rootIndex() ) ).toDouble(),
00128 0.0 );
00129 z = qMax( model()->data( model()->index( row, column+2, rootIndex() ) ).toDouble(),
00130 0.0 );
00131
00132 double total = x + y + z;
00133 if ( fabs( total ) > 3 * std::numeric_limits<double>::epsilon() ) {
00134 TernaryPoint tPunkt( x / total, y / total );
00135 QPointF diagramLocation = translate( tPunkt );
00136 QPointF widgetLocation = plane->translate( diagramLocation );
00137
00138 if ( row > 0 ) {
00139 p->drawLine( start, widgetLocation );
00140 }
00141 paintMarker( p, model()->index( row, column, rootIndex() ), widgetLocation );
00142 start = widgetLocation;
00143
00144
00145 QString text = tr( "(%1, %2, %3)" )
00146 .arg( x * 100, 0, 'f', 0 )
00147 .arg( y * 100, 0, 'f', 0 )
00148 .arg( z * 100, 0, 'f', 0 );
00149 d->paintDataValueText( this, p, attrs, widgetLocation, text, true );
00150 } else {
00151
00152 qDebug() << "TernaryPointDiagram::paint: data point x/y/z:"
00153 << x << "/" << y << "/" << z << "ignored, unusable.";
00154 }
00155 }
00156 }
00157 }
00158 }
00159
00160 const QPair< QPointF, QPointF > TernaryLineDiagram::calculateDataBoundaries () const
00161 {
00162
00163 static QPair<QPointF, QPointF> Boundaries(
00164 TriangleBottomLeft,
00165 QPointF( TriangleBottomRight.x(), TriangleHeight ) );
00166 return Boundaries;
00167 }