/**************************************************************************** ** ** 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$ ** ****************************************************************************/ #include "chartbarcategoryaxisx_p.h" #include "chartpresenter_p.h" #include "qbarcategoryaxis_p.h" #include "chartlayout_p.h" #include #include #include QTCOMMERCIALCHART_BEGIN_NAMESPACE ChartBarCategoryAxisX::ChartBarCategoryAxisX(QBarCategoryAxis *axis, QGraphicsItem* item) : HorizontalAxis(axis, item, true), m_categoriesAxis(axis) { QObject::connect(m_categoriesAxis,SIGNAL(categoriesChanged()),this, SLOT(handleCategoriesChanged())); handleCategoriesChanged(); } ChartBarCategoryAxisX::~ChartBarCategoryAxisX() { } QVector ChartBarCategoryAxisX::calculateLayout() const { QVector points; const QRectF& gridRect = gridGeometry(); qreal range = max() - min(); const qreal delta = gridRect.width()/range; if(delta<2) return points; qreal offset =-min()-0.5; offset = int(offset * delta)%int(delta); int count = qFloor(range); if(count < 1 ) return points; points.resize(count+2); for (int i = 0; i < count+2; ++i) { points[i] = offset + i * delta + gridRect.left(); } return points; } QStringList ChartBarCategoryAxisX::createCategoryLabels(const QVector& layout) const { QStringList result ; const QRectF &gridRect = gridGeometry(); qreal d = (max() - min()) / gridRect.width(); for (int i = 0; i < layout.count() - 1; ++i) { qreal x = qFloor((((layout[i] + layout[i + 1]) / 2 - gridRect.left()) * d + min() + 0.5)); if ((x < m_categoriesAxis->categories().count()) && (x >= 0)) { result << m_categoriesAxis->categories().at(x); } else { // No label for x coordinate result << ""; } } result << ""; return result; } void ChartBarCategoryAxisX::updateGeometry() { const QVector& layout = ChartAxis::layout(); if (layout.isEmpty()) return; setLabels(createCategoryLabels(layout)); HorizontalAxis::updateGeometry(); } void ChartBarCategoryAxisX::handleCategoriesChanged() { if(presenter()) presenter()->layout()->invalidate(); } QSizeF ChartBarCategoryAxisX::sizeHint(Qt::SizeHint which, const QSizeF &constraint) const { Q_UNUSED(constraint) QFontMetrics fn(font()); QSizeF sh; QSizeF base = HorizontalAxis::sizeHint(which, constraint); QStringList ticksList = m_categoriesAxis->categories(); qreal width=0; qreal height=0; switch (which) { case Qt::MinimumSize: width = fn.boundingRect("...").width(); height = fn.height()+labelPadding(); width=qMax(width,base.width()); height += base.height(); sh = QSizeF(width,height); break; case Qt::PreferredSize:{ for (int i = 0; i < ticksList.size(); ++i) { QRectF rect = fn.boundingRect(ticksList.at(i)); width += rect.width(); } height = fn.height()+labelPadding(); width = qMax(width,base.width()); height += base.height(); sh = QSizeF(width,height); break; } default: break; } return sh; } #include "moc_chartbarcategoryaxisx_p.cpp" QTCOMMERCIALCHART_END_NAMESPACE