You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

140 lines
4.2 KiB
C

/* -*- mode: C++ ; c-file-style: "stroustrup" -*- *****************************
* Qwt Widget Library
* Copyright (C) 1997 Josef Wilgen
* Copyright (C) 2002 Uwe Rathmann
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the Qwt License, Version 1.0
*****************************************************************************/
#ifndef QWT_PLOT_HISTOGRAM_H
#define QWT_PLOT_HISTOGRAM_H
#include "qwt_global.h"
#include "qwt_plot_seriesitem.h"
#include "qwt_column_symbol.h"
#include <qcolor.h>
#include <qvector.h>
class QwtIntervalData;
class QString;
class QPolygonF;
/*!
\brief QwtPlotHistogram represents a series of samples, where an interval
is associated with a value ( \f$y = f([x1,x2])\f$ ).
The representation depends on the style() and an optional symbol()
that is displayed for each interval.
\note The term "histogram" is used in a different way in the areas of
digital image processing and statistics. Wikipedia introduces the
terms "image histogram" and "color histogram" to avoid confusions.
While "image histograms" can be displayed by a QwtPlotCurve there
is no applicable plot item for a "color histogram" yet.
\sa QwtPlotBarChart, QwtPlotMultiBarChart
*/
class QWT_EXPORT QwtPlotHistogram:
public QwtPlotSeriesItem, public QwtSeriesStore<QwtIntervalSample>
{
public:
/*!
Histogram styles.
The default style is QwtPlotHistogram::Columns.
\sa setStyle(), style(), setSymbol(), symbol(), setBaseline()
*/
enum HistogramStyle
{
/*!
Draw an outline around the area, that is build by all intervals
using the pen() and fill it with the brush(). The outline style
requires, that the intervals are in increasing order and
not overlapping.
*/
Outline,
/*!
Draw a column for each interval. When a symbol() has been set
the symbol is used otherwise the column is displayed as
plain rectangle using pen() and brush().
*/
Columns,
/*!
Draw a simple line using the pen() for each interval.
*/
Lines,
/*!
Styles >= UserStyle are reserved for derived
classes that overload drawSeries() with
additional application specific ways to display a histogram.
*/
UserStyle = 100
};
explicit QwtPlotHistogram( const QString &title = QString() );
explicit QwtPlotHistogram( const QwtText &title );
virtual ~QwtPlotHistogram();
virtual int rtti() const;
void setPen( const QColor &, qreal width = 0.0, Qt::PenStyle = Qt::SolidLine );
void setPen( const QPen & );
const QPen &pen() const;
void setBrush( const QBrush & );
const QBrush &brush() const;
void setSamples( const QVector<QwtIntervalSample> & );
void setSamples( QwtSeriesData<QwtIntervalSample> * );
void setBaseline( double );
double baseline() const;
void setStyle( HistogramStyle style );
HistogramStyle style() const;
void setSymbol( const QwtColumnSymbol * );
const QwtColumnSymbol *symbol() const;
virtual void drawSeries( QPainter *,
const QwtScaleMap &xMap, const QwtScaleMap &yMap,
const QRectF &canvasRect, int from, int to ) const;
virtual QRectF boundingRect() const;
virtual QwtGraphic legendIcon( int index, const QSizeF & ) const;
protected:
virtual QwtColumnRect columnRect( const QwtIntervalSample &,
const QwtScaleMap &, const QwtScaleMap & ) const;
virtual void drawColumn( QPainter *, const QwtColumnRect &,
const QwtIntervalSample & ) const;
void drawColumns( QPainter *,
const QwtScaleMap &xMap, const QwtScaleMap &yMap,
int from, int to ) const;
void drawOutline( QPainter *,
const QwtScaleMap &xMap, const QwtScaleMap &yMap,
int from, int to ) const;
void drawLines( QPainter *,
const QwtScaleMap &xMap, const QwtScaleMap &yMap,
int from, int to ) const;
private:
void init();
void flushPolygon( QPainter *, double baseLine, QPolygonF & ) const;
class PrivateData;
PrivateData *d_data;
};
#endif