##// END OF EJS Templates
Revert previous change to LineChartItem...
Revert previous change to LineChartItem The m_points private member in LineChartItem is needed after all. If the points from XYChart are used, the old line is not properly cleared with animations. The variable is now renamed to reduce confusion. Change-Id: I35fcb708017d1a423a6e42eb1721c0b332a3a995 Task-number: QTRD-3489 Reviewed-by: Miikka Heikkinen <miikka.heikkinen@theqtcompany.com>

File last commit:

r2818:d27e6a35ae04
r2818:d27e6a35ae04
Show More
linechartitem_p.h
95 lines | 2.7 KiB | text/x-c | CLexer
/****************************************************************************
**
** Copyright (C) 2015 The Qt Company Ltd
** All rights reserved.
** For any questions to The Qt Company, please use contact form at http://qt.io
**
** This file is part of the Qt Charts module.
**
** Licensees holding valid commercial license for Qt may use this file in
** accordance with the Qt License Agreement provided with the Software
** or, alternatively, in accordance with the terms contained in a written
** agreement between you and The Qt Company.
**
** If you have questions regarding the use of this file, please use
** contact form at http://qt.io
**
****************************************************************************/
// W A R N I N G
// -------------
//
// This file is not part of the Qt Chart API. It exists purely as an
// implementation detail. This header file may change from version to
// version without notice, or even be removed.
//
// We mean it.
#ifndef LINECHARTITEM_H
#define LINECHARTITEM_H
#include <QtCharts/QChartGlobal>
#include <private/xychart_p.h>
#include <QtCharts/QChart>
#include <QtGui/QPen>
QT_CHARTS_BEGIN_NAMESPACE
class QLineSeries;
class ChartPresenter;
class LineChartItem : public XYChart
{
Q_OBJECT
Q_INTERFACES(QGraphicsItem)
public:
explicit LineChartItem(QLineSeries *series, QGraphicsItem *item = 0);
~LineChartItem() {}
//from QGraphicsItem
QRectF boundingRect() const;
void paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget);
QPainterPath shape() const;
QPainterPath path() const { return m_fullPath; }
public Q_SLOTS:
void handleUpdated();
protected:
void updateGeometry();
void mousePressEvent(QGraphicsSceneMouseEvent *event);
void hoverEnterEvent(QGraphicsSceneHoverEvent *event);
void hoverLeaveEvent(QGraphicsSceneHoverEvent *event);
void mouseReleaseEvent(QGraphicsSceneMouseEvent *event);
void mouseDoubleClickEvent(QGraphicsSceneMouseEvent *event);
void suppressPoints() { m_pointsVisible = false; }
void forceChartType(QChart::ChartType chartType) { m_chartType = chartType; }
private:
QLineSeries *m_series;
QPainterPath m_linePath;
QPainterPath m_linePathPolarRight;
QPainterPath m_linePathPolarLeft;
QPainterPath m_fullPath;
QPainterPath m_shapePath;
QVector<QPointF> m_linePoints;
QRectF m_rect;
QPen m_linePen;
bool m_pointsVisible;
QChart::ChartType m_chartType;
bool m_pointLabelsVisible;
QString m_pointLabelsFormat;
QFont m_pointLabelsFont;
QColor m_pointLabelsColor;
bool m_pointLabelsClipping;
QPointF m_lastMousePos;
bool m_mousePressed;
};
QT_CHARTS_END_NAMESPACE
#endif