From 6eb30918e5aa0ada7ed877fc84cef9295e72d9f3 Mon Sep 17 00:00:00 2001 From: Arin Alexander Date: Thu, 9 Jan 2020 21:26:25 +0300 Subject: [PATCH] ChartItem: from now chart labels will rotate only if not enough space to draw them horizontally --- limereport/items/lrchartitem.cpp | 36 ++++++++++++++++++++++---------- 1 file changed, 25 insertions(+), 11 deletions(-) diff --git a/limereport/items/lrchartitem.cpp b/limereport/items/lrchartitem.cpp index df86704..abeb2e4 100644 --- a/limereport/items/lrchartitem.cpp +++ b/limereport/items/lrchartitem.cpp @@ -800,22 +800,36 @@ void VerticalBarChart::paintSerialLines(QPainter* painter, QRectF barsRect) painter->restore(); } - - void VerticalBarChart::paintLabels(QPainter *painter, QRectF labelsRect) { painter->save(); qreal hStep = (labelsRect.width() / valuesCount()); - - if (!m_chartItem->labels().isEmpty()){ - painter->rotate(270); - painter->translate(-(labelsRect.top()+labelsRect.height()),labelsRect.left()); - foreach (QString label, m_chartItem->labels()) { - painter->drawText(QRectF(QPoint(0,0), - QSize(labelsRect.height()-4,hStep)),Qt::AlignVCenter|Qt::AlignRight,label); - painter->translate(0,hStep); + bool rotateLabels = false; + QFontMetrics fm = painter->fontMetrics(); + foreach(QString label, m_chartItem->labels()){ + if (fm.width(label) > hStep){ + rotateLabels = true; + break; + } + } + if (!m_chartItem->labels().isEmpty()){ + if (rotateLabels){ + painter->rotate(270); + painter->translate( -(labelsRect.top()+labelsRect.height()), labelsRect.left() ); + foreach (QString label, m_chartItem->labels()) { + painter->drawText(QRectF(QPoint(0,0), + QSize(labelsRect.height()-4, hStep)), Qt::AlignVCenter | Qt::AlignRight, label); + painter->translate(0,hStep); + } + painter->rotate(-270); + } else { + painter->translate( labelsRect.left(), labelsRect.top() ); + foreach (QString label, m_chartItem->labels()) { + painter->drawText(QRectF(QPoint(0, 4), + QSize(hStep, labelsRect.height()-4)), Qt::AlignHCenter | Qt::AlignTop, label); + painter->translate(hStep, 0); + } } - painter->rotate(-270); } painter->restore(); }