qchart.cpp
412 lines
| 10.9 KiB
| text/x-c
|
CppLexer
/ src / qchart.cpp
Michal Klocek
|
r746 | /**************************************************************************** | ||
** | ||||
** Copyright (C) 2012 Digia Plc | ||||
** All rights reserved. | ||||
** For any questions to Digia, please use contact form at http://qt.digia.com | ||||
** | ||||
** This file is part of the Qt Commercial Charts Add-on. | ||||
** | ||||
** $QT_BEGIN_LICENSE$ | ||||
** Licensees holding valid Qt Commercial licenses may use this file in | ||||
** accordance with the Qt Commercial License Agreement provided with the | ||||
** Software or, alternatively, in accordance with the terms contained in | ||||
** a written agreement between you and Digia. | ||||
** | ||||
** If you have questions regarding the use of this file, please use | ||||
** contact form at http://qt.digia.com | ||||
** $QT_END_LICENSE$ | ||||
** | ||||
****************************************************************************/ | ||||
Michal Klocek
|
r12 | #include "qchart.h" | ||
Michal Klocek
|
r740 | #include "qchart_p.h" | ||
Michal Klocek
|
r950 | #include "legendscroller_p.h" | ||
#include "qlegend_p.h" | ||||
Tero Ahola
|
r42 | #include <QGraphicsScene> | ||
Michal Klocek
|
r115 | #include <QGraphicsSceneResizeEvent> | ||
Michal Klocek
|
r12 | |||
Marek Rosa
|
r277 | QTCOMMERCIALCHART_BEGIN_NAMESPACE | ||
/*! | ||||
Michal Klocek
|
r740 | \enum QChart::ChartTheme | ||
Marek Rosa
|
r277 | |||
Michal Klocek
|
r740 | This enum describes the theme used by the chart. | ||
Marek Rosa
|
r277 | |||
Tero Ahola
|
r853 | \value ChartThemeLight The default theme | ||
Michal Klocek
|
r740 | \value ChartThemeBlueCerulean | ||
\value ChartThemeDark | ||||
\value ChartThemeBrownSand | ||||
\value ChartThemeBlueNcs | ||||
Tero Ahola
|
r757 | \value ChartThemeHighContrast | ||
\value ChartThemeBlueIcy | ||||
Michal Klocek
|
r740 | */ | ||
Marek Rosa
|
r277 | |||
Tero Ahola
|
r302 | /*! | ||
Michal Klocek
|
r740 | \enum QChart::AnimationOption | ||
Tero Ahola
|
r302 | |||
Michal Klocek
|
r740 | For enabling/disabling animations. Defaults to NoAnimation. | ||
Tero Ahola
|
r302 | |||
Michal Klocek
|
r740 | \value NoAnimation | ||
\value GridAxisAnimations | ||||
\value SeriesAnimations | ||||
\value AllAnimations | ||||
*/ | ||||
Tero Ahola
|
r302 | |||
Tero Ahola
|
r264 | /*! | ||
Michal Klocek
|
r740 | \class QChart | ||
\brief QtCommercial chart API. | ||||
Tero Ahola
|
r264 | |||
Michal Klocek
|
r740 | QChart is a QGraphicsWidget that you can show in a QGraphicsScene. It manages the graphical | ||
representation of different types of QChartSeries and other chart related objects like | ||||
QChartAxis and QChartLegend. If you simply want to show a chart in a layout, you can use the | ||||
convenience class QChartView instead of QChart. | ||||
\sa QChartView | ||||
*/ | ||||
Tero Ahola
|
r264 | |||
/*! | ||||
Michal Klocek
|
r740 | Constructs a chart object which is a child of a\a parent. Parameter \a wFlags is passed to the QGraphicsWidget constructor. | ||
*/ | ||||
Michal Klocek
|
r115 | QChart::QChart(QGraphicsItem *parent, Qt::WindowFlags wFlags) : QGraphicsWidget(parent,wFlags), | ||
Marek Rosa
|
r924 | d_ptr(new QChartPrivate()) | ||
Michal Klocek
|
r12 | { | ||
Michal Klocek
|
r740 | d_ptr->m_dataset = new ChartDataSet(this); | ||
d_ptr->m_presenter = new ChartPresenter(this,d_ptr->m_dataset); | ||||
Michal Klocek
|
r871 | d_ptr->createConnections(); | ||
Michal Klocek
|
r950 | d_ptr->m_legend = new LegendScroller(this); | ||
d_ptr->m_presenter->setTheme(QChart::ChartThemeLight, false); | ||||
Michal Klocek
|
r12 | } | ||
Tero Ahola
|
r264 | /*! | ||
Michal Klocek
|
r740 | Destroys the object and it's children, like QChartSeries and QChartAxis object added to it. | ||
*/ | ||||
Tero Ahola
|
r264 | QChart::~QChart() | ||
{ | ||||
Michal Klocek
|
r686 | //delete first presenter , since this is a root of all the graphical items | ||
Michal Klocek
|
r740 | delete d_ptr->m_presenter; | ||
d_ptr->m_presenter=0; | ||||
Tero Ahola
|
r264 | } | ||
Michal Klocek
|
r12 | |||
Tero Ahola
|
r264 | /*! | ||
Michal Klocek
|
r740 | Adds the \a series and optional \a axisY onto the chart and takes the ownership of the objects. | ||
If auto scaling is enabled, re-scales the axes the series is bound to (both the x axis and | ||||
the y axis). | ||||
*/ | ||||
Tero Ahola
|
r988 | void QChart::addSeries(QAbstractSeries *series, QChartAxis *axisY) | ||
Michal Klocek
|
r223 | { | ||
Michal Klocek
|
r895 | Q_ASSERT(series); | ||
Michal Klocek
|
r740 | d_ptr->m_dataset->addSeries(series, axisY); | ||
Michal Klocek
|
r223 | } | ||
Tero Ahola
|
r42 | |||
Marek Rosa
|
r274 | /*! | ||
Michal Klocek
|
r740 | Removes the \a series specified in a perameter from the QChartView. | ||
It releses its ownership of the specified QChartSeries object. | ||||
It does not delete the pointed QChartSeries data object | ||||
\sa addSeries(), removeAllSeries() | ||||
*/ | ||||
Tero Ahola
|
r988 | void QChart::removeSeries(QAbstractSeries *series) | ||
Michal Klocek
|
r223 | { | ||
Michal Klocek
|
r895 | Q_ASSERT(series); | ||
Michal Klocek
|
r740 | d_ptr->m_dataset->removeSeries(series); | ||
Tero Ahola
|
r42 | } | ||
Tero Ahola
|
r48 | |||
Marek Rosa
|
r274 | /*! | ||
Michal Klocek
|
r740 | Removes all the QChartSeries that have been added to the QChartView | ||
It also deletes the pointed QChartSeries data objects | ||||
\sa addSeries(), removeSeries() | ||||
*/ | ||||
Michal Klocek
|
r258 | void QChart::removeAllSeries() | ||
{ | ||||
Michal Klocek
|
r740 | d_ptr->m_dataset->removeAllSeries(); | ||
Michal Klocek
|
r258 | } | ||
Marek Rosa
|
r287 | /*! | ||
Michal Klocek
|
r740 | Sets the \a brush that is used for painting the background of the chart area. | ||
*/ | ||||
Michal Klocek
|
r645 | void QChart::setBackgroundBrush(const QBrush& brush) | ||
Michal Klocek
|
r122 | { | ||
Michal Klocek
|
r872 | //TODO: refactor me | ||
Michal Klocek
|
r855 | d_ptr->m_presenter->createChartBackgroundItem(); | ||
d_ptr->m_presenter->m_backgroundItem->setBrush(brush); | ||||
d_ptr->m_presenter->m_backgroundItem->update(); | ||||
Michal Klocek
|
r122 | } | ||
Marek Rosa
|
r924 | /*! | ||
Gets the brush that is used for painting the background of the chart area. | ||||
*/ | ||||
Michal Klocek
|
r645 | QBrush QChart::backgroundBrush() const | ||
{ | ||||
Michal Klocek
|
r872 | //TODO: refactor me | ||
Michal Klocek
|
r855 | if (!d_ptr->m_presenter->m_backgroundItem) return QBrush(); | ||
return (d_ptr->m_presenter->m_backgroundItem)->brush(); | ||||
Michal Klocek
|
r645 | } | ||
Marek Rosa
|
r287 | /*! | ||
Michal Klocek
|
r740 | Sets the \a pen that is used for painting the background of the chart area. | ||
*/ | ||||
Michal Klocek
|
r645 | void QChart::setBackgroundPen(const QPen& pen) | ||
Michal Klocek
|
r122 | { | ||
Michal Klocek
|
r872 | //TODO: refactor me | ||
Michal Klocek
|
r855 | d_ptr->m_presenter->createChartBackgroundItem(); | ||
d_ptr->m_presenter->m_backgroundItem->setPen(pen); | ||||
d_ptr->m_presenter->m_backgroundItem->update(); | ||||
Michal Klocek
|
r122 | } | ||
Marek Rosa
|
r924 | /*! | ||
Gets the pen that is used for painting the background of the chart area. | ||||
*/ | ||||
Michal Klocek
|
r645 | QPen QChart::backgroundPen() const | ||
{ | ||||
Michal Klocek
|
r872 | //TODO: refactor me | ||
Michal Klocek
|
r855 | if (!d_ptr->m_presenter->m_backgroundItem) return QPen(); | ||
return d_ptr->m_presenter->m_backgroundItem->pen(); | ||||
Michal Klocek
|
r645 | } | ||
Marek Rosa
|
r274 | /*! | ||
Michal Klocek
|
r740 | Sets the chart \a title. The description text that is drawn above the chart. | ||
*/ | ||||
Michal Klocek
|
r645 | void QChart::setTitle(const QString& title) | ||
Michal Klocek
|
r69 | { | ||
Michal Klocek
|
r872 | //TODO: refactor me | ||
Michal Klocek
|
r855 | d_ptr->m_presenter->createChartTitleItem(); | ||
d_ptr->m_presenter->m_titleItem->setText(title); | ||||
d_ptr->m_presenter->updateLayout(); | ||||
Michal Klocek
|
r476 | } | ||
/*! | ||||
Michal Klocek
|
r740 | Returns the chart title. The description text that is drawn above the chart. | ||
*/ | ||||
Michal Klocek
|
r645 | QString QChart::title() const | ||
Michal Klocek
|
r476 | { | ||
Michal Klocek
|
r872 | //TODO: refactor me | ||
Michal Klocek
|
r855 | if (d_ptr->m_presenter->m_titleItem) | ||
Michal Klocek
|
r895 | return d_ptr->m_presenter->m_titleItem->text(); | ||
Michal Klocek
|
r476 | else | ||
Michal Klocek
|
r895 | return QString(); | ||
Michal Klocek
|
r192 | } | ||
Marek Rosa
|
r274 | /*! | ||
Marek Rosa
|
r924 | Sets the \a font that is used for drawing the chart description text that is rendered above the chart. | ||
Michal Klocek
|
r740 | */ | ||
Michal Klocek
|
r645 | void QChart::setTitleFont(const QFont& font) | ||
Michal Klocek
|
r192 | { | ||
Michal Klocek
|
r872 | //TODO: refactor me | ||
Michal Klocek
|
r855 | d_ptr->m_presenter->createChartTitleItem(); | ||
d_ptr->m_presenter->m_titleItem->setFont(font); | ||||
d_ptr->m_presenter->updateLayout(); | ||||
Michal Klocek
|
r69 | } | ||
Marek Rosa
|
r924 | /*! | ||
Gets the font that is used for drawing the chart description text that is rendered above the chart. | ||||
*/ | ||||
Michal Klocek
|
r895 | QFont QChart::titleFont() const | ||
{ | ||||
if (d_ptr->m_presenter->m_titleItem) | ||||
return d_ptr->m_presenter->m_titleItem->font(); | ||||
else | ||||
return QFont(); | ||||
} | ||||
Tero Ahola
|
r495 | /*! | ||
Michal Klocek
|
r740 | Sets the \a brush used for rendering the title text. | ||
*/ | ||||
Michal Klocek
|
r645 | void QChart::setTitleBrush(const QBrush &brush) | ||
Tero Ahola
|
r495 | { | ||
Michal Klocek
|
r872 | //TODO: refactor me | ||
Michal Klocek
|
r855 | d_ptr->m_presenter->createChartTitleItem(); | ||
d_ptr->m_presenter->m_titleItem->setBrush(brush); | ||||
d_ptr->m_presenter->updateLayout(); | ||||
Tero Ahola
|
r495 | } | ||
/*! | ||||
Michal Klocek
|
r740 | Returns the brush used for rendering the title text. | ||
*/ | ||||
Michal Klocek
|
r645 | QBrush QChart::titleBrush() const | ||
Tero Ahola
|
r495 | { | ||
Michal Klocek
|
r872 | //TODO: refactor me | ||
Michal Klocek
|
r855 | if (!d_ptr->m_presenter->m_titleItem) return QBrush(); | ||
return d_ptr->m_presenter->m_titleItem->brush(); | ||||
Michal Klocek
|
r223 | } | ||
Marek Rosa
|
r277 | /*! | ||
Michal Klocek
|
r740 | Sets the \a theme used by the chart for rendering the graphical representation of the data | ||
Marek Rosa
|
r909 | \sa theme() | ||
Michal Klocek
|
r740 | */ | ||
void QChart::setTheme(QChart::ChartTheme theme) | ||||
Tero Ahola
|
r64 | { | ||
Michal Klocek
|
r740 | d_ptr->m_presenter->setTheme(theme); | ||
Tero Ahola
|
r64 | } | ||
Marek Rosa
|
r277 | /*! | ||
Michal Klocek
|
r740 | Returns the theme enum used by the chart. | ||
Marek Rosa
|
r909 | \sa ChartTheme, setTheme() | ||
Michal Klocek
|
r740 | */ | ||
QChart::ChartTheme QChart::theme() const | ||||
Tero Ahola
|
r120 | { | ||
Michal Klocek
|
r740 | return d_ptr->m_presenter->theme(); | ||
Tero Ahola
|
r120 | } | ||
Marek Rosa
|
r285 | /*! | ||
Michal Klocek
|
r740 | Zooms in the view by a factor of 2 | ||
*/ | ||||
Michal Klocek
|
r223 | void QChart::zoomIn() | ||
Michal Klocek
|
r67 | { | ||
Michal Klocek
|
r740 | d_ptr->m_presenter->zoomIn(); | ||
Michal Klocek
|
r67 | } | ||
Marek Rosa
|
r285 | /*! | ||
Michal Klocek
|
r740 | Zooms in the view to a maximum level at which \a rect is still fully visible. | ||
*/ | ||||
Michal Klocek
|
r223 | void QChart::zoomIn(const QRectF& rect) | ||
Michal Klocek
|
r67 | { | ||
Michal Klocek
|
r742 | if (!rect.isValid()) return; | ||
Michal Klocek
|
r740 | d_ptr->m_presenter->zoomIn(rect); | ||
Michal Klocek
|
r67 | } | ||
Marek Rosa
|
r285 | /*! | ||
Michal Klocek
|
r740 | Restores the view zoom level to the previous one. | ||
*/ | ||||
Michal Klocek
|
r67 | void QChart::zoomOut() | ||
{ | ||||
Michal Klocek
|
r740 | d_ptr->m_presenter->zoomOut(); | ||
Michal Klocek
|
r67 | } | ||
Marek Rosa
|
r277 | /*! | ||
Michal Klocek
|
r740 | Returns the pointer to the x axis object of the chart | ||
*/ | ||||
Michal Klocek
|
r223 | QChartAxis* QChart::axisX() const | ||
Michal Klocek
|
r176 | { | ||
Michal Klocek
|
r740 | return d_ptr->m_dataset->axisX(); | ||
Michal Klocek
|
r176 | } | ||
Marek Rosa
|
r277 | /*! | ||
Marek Rosa
|
r924 | Returns the pointer to the y axis object of the \a series | ||
If no \a series is provided then default Y axis of the chart is returned. | ||||
Michal Klocek
|
r740 | */ | ||
Tero Ahola
|
r988 | QChartAxis* QChart::axisY(QAbstractSeries *series) const | ||
Michal Klocek
|
r176 | { | ||
Michal Klocek
|
r899 | return d_ptr->m_dataset->axisY(series); | ||
Michal Klocek
|
r85 | } | ||
sauimone
|
r524 | /*! | ||
Michal Klocek
|
r740 | Returns the legend object of the chart. Ownership stays in chart. | ||
*/ | ||||
sauimone
|
r783 | QLegend* QChart::legend() const | ||
sauimone
|
r524 | { | ||
sauimone
|
r783 | return d_ptr->m_legend; | ||
sauimone
|
r524 | } | ||
Marek Rosa
|
r924 | /*! | ||
Returns the rect that contains information about margins (distance between chart widget edge and axes). | ||||
Individual margins can be obtained by calling left, top, right, bottom on the returned rect. | ||||
*/ | ||||
Michal Klocek
|
r874 | QRectF QChart::margins() const | ||
sauimone
|
r803 | { | ||
Michal Klocek
|
r855 | return d_ptr->m_presenter->margins(); | ||
sauimone
|
r803 | } | ||
Marek Rosa
|
r287 | /*! | ||
Michal Klocek
|
r740 | Resizes and updates the chart area using the \a event data | ||
*/ | ||||
Michal Klocek
|
r115 | void QChart::resizeEvent(QGraphicsSceneResizeEvent *event) | ||
{ | ||||
Michal Klocek
|
r740 | d_ptr->m_rect = QRectF(QPoint(0,0),event->newSize()); | ||
Michal Klocek
|
r117 | QGraphicsWidget::resizeEvent(event); | ||
Michal Klocek
|
r855 | d_ptr->m_presenter->setGeometry(d_ptr->m_rect); | ||
Michal Klocek
|
r115 | } | ||
Michal Klocek
|
r298 | /*! | ||
Michal Klocek
|
r740 | Sets animation \a options for the chart | ||
*/ | ||||
Michal Klocek
|
r298 | void QChart::setAnimationOptions(AnimationOptions options) | ||
{ | ||||
Michal Klocek
|
r740 | d_ptr->m_presenter->setAnimationOptions(options); | ||
Michal Klocek
|
r298 | } | ||
/*! | ||||
Michal Klocek
|
r740 | Returns animation options for the chart | ||
*/ | ||||
Michal Klocek
|
r298 | QChart::AnimationOptions QChart::animationOptions() const | ||
{ | ||||
Michal Klocek
|
r740 | return d_ptr->m_presenter->animationOptions(); | ||
Michal Klocek
|
r298 | } | ||
Marek Rosa
|
r924 | /*! | ||
Scrolls the visible area of the chart to the left by the distance between two x axis ticks | ||||
*/ | ||||
Michal Klocek
|
r600 | void QChart::scrollLeft() | ||
{ | ||||
Michal Klocek
|
r855 | d_ptr->m_presenter->scroll(-d_ptr->m_presenter->chartGeometry().width()/(axisX()->ticksCount()-1),0); | ||
Michal Klocek
|
r600 | } | ||
Marek Rosa
|
r924 | /*! | ||
Scrolls the visible area of the chart to the right by the distance between two x axis ticks | ||||
*/ | ||||
Michal Klocek
|
r600 | void QChart::scrollRight() | ||
{ | ||||
Michal Klocek
|
r855 | d_ptr->m_presenter->scroll(d_ptr->m_presenter->chartGeometry().width()/(axisX()->ticksCount()-1),0); | ||
Michal Klocek
|
r600 | } | ||
Michal Klocek
|
r740 | |||
Marek Rosa
|
r924 | /*! | ||
Scrolls the visible area of the chart up by the distance between two y axis ticks | ||||
*/ | ||||
Michal Klocek
|
r600 | void QChart::scrollUp() | ||
{ | ||||
Michal Klocek
|
r855 | d_ptr->m_presenter->scroll(0,d_ptr->m_presenter->chartGeometry().width()/(axisY()->ticksCount()-1)); | ||
Michal Klocek
|
r600 | } | ||
Michal Klocek
|
r740 | |||
Marek Rosa
|
r924 | /*! | ||
Scrolls the visible area of the chart down by the distance between two y axis ticks | ||||
*/ | ||||
Michal Klocek
|
r600 | void QChart::scrollDown() | ||
{ | ||||
Michal Klocek
|
r855 | d_ptr->m_presenter->scroll(0,-d_ptr->m_presenter->chartGeometry().width()/(axisY()->ticksCount()-1)); | ||
Michal Klocek
|
r531 | } | ||
Marek Rosa
|
r924 | /*! | ||
Sets the chart background visibility state to \a visible | ||||
*/ | ||||
Michal Klocek
|
r740 | void QChart::setBackgroundVisible(bool visible) | ||
{ | ||||
Michal Klocek
|
r872 | //TODO: refactor me | ||
Michal Klocek
|
r855 | d_ptr->m_presenter->createChartBackgroundItem(); | ||
d_ptr->m_presenter->m_backgroundItem->setVisible(visible); | ||||
Michal Klocek
|
r740 | } | ||
sauimone
|
r716 | |||
Marek Rosa
|
r924 | /*! | ||
Returns the chart's background visibility state | ||||
*/ | ||||
Michal Klocek
|
r740 | bool QChart::isBackgroundVisible() const | ||
{ | ||||
Michal Klocek
|
r872 | //TODO: refactor me | ||
Michal Klocek
|
r855 | if (!d_ptr->m_presenter->m_backgroundItem) return false; | ||
return d_ptr->m_presenter->m_backgroundItem->isVisible(); | ||||
sauimone
|
r716 | } | ||
Michal Klocek
|
r740 | ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// | ||
Michal Klocek
|
r639 | |||
Michal Klocek
|
r855 | QChartPrivate::QChartPrivate(): | ||
Marek Rosa
|
r924 | m_legend(0), | ||
m_dataset(0), | ||||
m_presenter(0) | ||||
Michal Klocek
|
r639 | { | ||
Michal Klocek
|
r740 | |||
Michal Klocek
|
r639 | } | ||
Michal Klocek
|
r740 | QChartPrivate::~QChartPrivate() | ||
Michal Klocek
|
r639 | { | ||
Michal Klocek
|
r740 | |||
Michal Klocek
|
r639 | } | ||
Michal Klocek
|
r871 | void QChartPrivate::createConnections() | ||
{ | ||||
Michal Klocek
|
r950 | |||
Tero Ahola
|
r988 | QObject::connect(m_dataset,SIGNAL(seriesAdded(QAbstractSeries *, Domain *)),m_presenter,SLOT(handleSeriesAdded(QAbstractSeries *, Domain *))); | ||
QObject::connect(m_dataset,SIGNAL(seriesRemoved(QAbstractSeries *)),m_presenter,SLOT(handleSeriesRemoved(QAbstractSeries *))); | ||||
Marek Rosa
|
r924 | QObject::connect(m_dataset,SIGNAL(axisAdded(QChartAxis*,Domain*)),m_presenter,SLOT(handleAxisAdded(QChartAxis*,Domain*))); | ||
QObject::connect(m_dataset,SIGNAL(axisRemoved(QChartAxis*)),m_presenter,SLOT(handleAxisRemoved(QChartAxis*))); | ||||
Michal Klocek
|
r871 | } | ||
Tero Ahola
|
r64 | #include "moc_qchart.cpp" | ||
Tero Ahola
|
r48 | |||
Tero Ahola
|
r30 | QTCOMMERCIALCHART_END_NAMESPACE | ||