##// END OF EJS Templates
Fixed a bug with last two control points calculation
Fixed a bug with last two control points calculation

File last commit:

r423:b60b8b7d9d8b
r429:cbe57d7d97d6
Show More
splinepresenter.cpp
74 lines | 2.3 KiB | text/x-c | CppLexer
#include "splinepresenter_p.h"
#include <QPainter>
QTCOMMERCIALCHART_BEGIN_NAMESPACE
SplinePresenter::SplinePresenter(QSplineSeries* series, QGraphicsObject *parent) :
LineChartItem(0, series, parent)//,m_boundingRect()
{
//
}
QPointF SplinePresenter::calculateGeometryControlPoint(int index) const
{
QSplineSeries* splineSeries = qobject_cast<QSplineSeries*>(m_series);
const qreal deltaX = m_size.width()/m_domain.spanX();
const qreal deltaY = m_size.height()/m_domain.spanY();
qreal x = (splineSeries->controlPoint(index).x() - m_domain.m_minX)* deltaX;
qreal y = (splineSeries->controlPoint(index).y() - m_domain.m_minY)*-deltaY + m_size.height();
return QPointF(x,y);
}
void SplinePresenter::applyGeometry(QVector<QPointF>& points)
{
if(points.size()==0) return;
QPainterPath splinePath;
const QPointF& point = points.at(0);
splinePath.moveTo(point);
QSplineSeries* splineSeries = qobject_cast<QSplineSeries*>(m_series);
for (int i = 0; i < splineSeries->count() - 1; i++)
{
const QPointF& point = points.at(i + 1);
splinePath.cubicTo(calculateGeometryControlPoint(2 * i), calculateGeometryControlPoint(2 * i + 1), point);
}
prepareGeometryChange();
m_path = splinePath;
m_rect = splinePath.boundingRect();
}
void SplinePresenter::paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget)
{
Q_UNUSED(widget);
Q_UNUSED(option);
painter->save();
painter->setPen(m_pen);
painter->setClipRect(m_clipRect);
painter->drawPath(m_path);
QSplineSeries* splineSeries = qobject_cast<QSplineSeries*>(m_series);
for (int i = 0; i < splineSeries->count() - 1; i++)
{
painter->setPen(Qt::red);
painter->drawEllipse(m_points[i], 4, 4);
painter->setPen(Qt::blue);
// painter->drawLine(m_series->at(i), m_series->controlPoint(2 * i));
// painter->drawLine(m_series->at(i + 1), m_series->controlPoint(2 * i + 1));
painter->drawEllipse(calculateGeometryControlPoint(2 * i), 4, 4);
painter->drawEllipse(calculateGeometryControlPoint(2 * i + 1), 4, 4);
}
painter->setPen(Qt::red);
painter->drawEllipse(m_points[m_points.count() - 1], 4, 4);
painter->restore();
}
#include "moc_splinepresenter_p.cpp"
QTCOMMERCIALCHART_END_NAMESPACE