From e3bd7e05d553aeb5233e78044147a231def7e7a2 Mon Sep 17 00:00:00 2001 From: Emil Sawicki Date: Wed, 5 Jan 2022 12:13:05 +0100 Subject: [PATCH 1/2] Refactor min and max values --- .../items/charts/lrhorizontalbarchart.cpp | 6 +++- limereport/items/charts/lrlineschart.cpp | 13 +++++--- .../items/charts/lrverticalbarchart.cpp | 17 ++++++---- limereport/items/lrchartitem.cpp | 33 +++++++++++-------- limereport/items/lrchartitem.h | 2 ++ 5 files changed, 46 insertions(+), 25 deletions(-) diff --git a/limereport/items/charts/lrhorizontalbarchart.cpp b/limereport/items/charts/lrhorizontalbarchart.cpp index e5e0e45..78c081c 100644 --- a/limereport/items/charts/lrhorizontalbarchart.cpp +++ b/limereport/items/charts/lrhorizontalbarchart.cpp @@ -4,11 +4,15 @@ namespace LimeReport{ void HorizontalBarChart::paintChart(QPainter *painter, QRectF chartRect) { + updateMinAndMaxValues(); + + const qreal valuesVMargin = this->valuesVMargin(painter); + QRectF calcRect = verticalLabelsRect(painter, chartRect.adjusted( hPadding(chartRect), vPadding(chartRect) * 2, -(chartRect.width() * 0.9), - -(vPadding(chartRect) * 2 + valuesVMargin(painter)) + -(vPadding(chartRect) * 2 + valuesVMargin) )); qreal barsShift = calcRect.width(); diff --git a/limereport/items/charts/lrlineschart.cpp b/limereport/items/charts/lrlineschart.cpp index 9ee2b81..0bff366 100644 --- a/limereport/items/charts/lrlineschart.cpp +++ b/limereport/items/charts/lrlineschart.cpp @@ -4,10 +4,15 @@ namespace LimeReport { void LinesChart::paintChart(QPainter *painter, QRectF chartRect) { + updateMinAndMaxValues(); + + const qreal valuesHMargin = this->valuesHMargin(painter); + const qreal valuesVMargin = this->valuesVMargin(painter); + QRectF calcRect = horizontalLabelsRect( painter, chartRect.adjusted( - hPadding(chartRect) * 2 + valuesHMargin(painter), + hPadding(chartRect) * 2 + valuesHMargin, chartRect.height() - (painter->fontMetrics().height() + vPadding(chartRect)*2), -(hPadding(chartRect) * 2), -vPadding(chartRect) @@ -18,7 +23,7 @@ void LinesChart::paintChart(QPainter *painter, QRectF chartRect) painter, chartRect.adjusted( hPadding(chartRect), - vPadding(chartRect) + valuesVMargin(painter), + vPadding(chartRect) + valuesVMargin, -hPadding(chartRect), -(vPadding(chartRect) + barsShift) ) @@ -26,8 +31,8 @@ void LinesChart::paintChart(QPainter *painter, QRectF chartRect) paintSerialLines( painter, chartRect.adjusted( - hPadding(chartRect) * 2 + valuesHMargin(painter), - vPadding(chartRect) + valuesVMargin(painter), + hPadding(chartRect) * 2 + valuesHMargin, + vPadding(chartRect) + valuesVMargin, -(hPadding(chartRect) * 2), -(vPadding(chartRect)+barsShift) ) diff --git a/limereport/items/charts/lrverticalbarchart.cpp b/limereport/items/charts/lrverticalbarchart.cpp index f69f8b3..83af650 100644 --- a/limereport/items/charts/lrverticalbarchart.cpp +++ b/limereport/items/charts/lrverticalbarchart.cpp @@ -4,10 +4,15 @@ namespace LimeReport{ void VerticalBarChart::paintChart(QPainter *painter, QRectF chartRect) { + updateMinAndMaxValues(); + + const qreal valuesHMargin = this->valuesHMargin(painter); + const qreal valuesVMargin = this->valuesVMargin(painter); + QRectF calcRect = horizontalLabelsRect( painter, chartRect.adjusted( - hPadding(chartRect) * 2 + valuesHMargin(painter), + hPadding(chartRect) * 2 + valuesHMargin, chartRect.height() - (painter->fontMetrics().height() + vPadding(chartRect) * 2), -(hPadding(chartRect) * 2), -vPadding(chartRect) @@ -18,7 +23,7 @@ void VerticalBarChart::paintChart(QPainter *painter, QRectF chartRect) painter, chartRect.adjusted( hPadding(chartRect), - vPadding(chartRect) + valuesVMargin(painter), + vPadding(chartRect) + valuesVMargin, -hPadding(chartRect), -(vPadding(chartRect) + barsShift) ) @@ -26,8 +31,8 @@ void VerticalBarChart::paintChart(QPainter *painter, QRectF chartRect) paintVerticalBars( painter, chartRect.adjusted( - hPadding(chartRect) * 2 + valuesHMargin(painter), - vPadding(chartRect) + valuesVMargin(painter), + hPadding(chartRect) * 2 + valuesHMargin, + vPadding(chartRect) + valuesVMargin, -hPadding(chartRect) * 2, -(vPadding(chartRect) + barsShift) ) @@ -35,8 +40,8 @@ void VerticalBarChart::paintChart(QPainter *painter, QRectF chartRect) paintSerialLines( painter, chartRect.adjusted( - hPadding(chartRect) * 2 + valuesHMargin(painter), - vPadding(chartRect) + valuesVMargin(painter), + hPadding(chartRect) * 2 + valuesHMargin, + vPadding(chartRect) + valuesVMargin, -hPadding(chartRect) * 2, -(vPadding(chartRect) + barsShift) ) diff --git a/limereport/items/lrchartitem.cpp b/limereport/items/lrchartitem.cpp index 086ed3e..8227fdb 100644 --- a/limereport/items/lrchartitem.cpp +++ b/limereport/items/lrchartitem.cpp @@ -516,26 +516,29 @@ AbstractSeriesChart::AbstractSeriesChart(ChartItem *chartItem) qreal AbstractSeriesChart::maxValue() { - if (m_chartItem->itemMode() == DesignMode) return 40; - qreal maxValue = 0; - foreach(SeriesItem* series, m_chartItem->series()){ - foreach(qreal value, series->data()->values()){ - if (value>maxValue) maxValue=value; - } - } - return maxValue; + return m_maxValue; } qreal AbstractSeriesChart::minValue() { - if (m_chartItem->itemMode() == DesignMode) return 0; - qreal minValue = 0; + return m_minValue; +} + +void AbstractSeriesChart::updateMinAndMaxValues() +{ + if (m_chartItem->itemMode() == DesignMode) { + m_maxValue = 40; + m_minValue = 0; + return; + } + m_minValue = 0; + m_maxValue = 0; foreach(SeriesItem* series, m_chartItem->series()){ foreach(qreal value, series->data()->values()){ - if (valuem_maxValue) m_maxValue=value; } } - return minValue; } qreal AbstractSeriesChart::hPadding(QRectF chartRect) @@ -679,11 +682,13 @@ void AbstractSeriesChart::paintVerticalGrid(QPainter *painter, QRectF gridRect) painter->setRenderHint(QPainter::Antialiasing,false); qreal vStep = gridRect.height() / 4; + const qreal valuesHMargin = this->valuesHMargin(painter); + for (int i=0;i<5;i++){ painter->drawText(QRectF(gridRect.bottomLeft()-QPointF(0,vStep*i+painter->fontMetrics().height()), - QSizeF(valuesHMargin(painter),painter->fontMetrics().height())), + QSizeF(valuesHMargin,painter->fontMetrics().height())), QString::number(minValue()+i*delta/4)); - painter->drawLine(gridRect.bottomLeft()-QPointF(-valuesHMargin(painter),vStep*i), + painter->drawLine(gridRect.bottomLeft()-QPointF(-valuesHMargin,vStep*i), gridRect.bottomRight()-QPointF(0,vStep*i)); } diff --git a/limereport/items/lrchartitem.h b/limereport/items/lrchartitem.h index cfc283e..2059a9d 100644 --- a/limereport/items/lrchartitem.h +++ b/limereport/items/lrchartitem.h @@ -85,6 +85,7 @@ public: protected: qreal maxValue(); qreal minValue(); + void updateMinAndMaxValues(); int valuesCount(); int seriesCount(); bool verticalLabels(QPainter* painter, QRectF labelsRect); @@ -103,6 +104,7 @@ protected: virtual QFont adaptValuesFont(qreal width, QFont font); private: + qreal m_minValue = 0, m_maxValue = 0; qreal m_designValues [9]; }; From c11e47b1cb1efd71b6f1846ec730bb7aa494043f Mon Sep 17 00:00:00 2001 From: fralx Date: Wed, 12 Jan 2022 16:52:01 +0300 Subject: [PATCH 2/2] Segment intersection value calculation has been fixed --- limereport/lritemscontainerdesignitf.cpp | 8 +++----- limereport/lrpageitemdesignintf.cpp | 1 - 2 files changed, 3 insertions(+), 6 deletions(-) diff --git a/limereport/lritemscontainerdesignitf.cpp b/limereport/lritemscontainerdesignitf.cpp index 441e069..365e7e3 100644 --- a/limereport/lritemscontainerdesignitf.cpp +++ b/limereport/lritemscontainerdesignitf.cpp @@ -6,15 +6,13 @@ namespace LimeReport { bool Segment::intersect(Segment value) { - return ((value.m_end>=m_begin)&&(value.m_end<=m_end)) || - ((value.m_begin>=m_begin)&&(value.m_end>=m_end)) || - ((value.m_begin>=m_begin)&&(value.m_end<=m_end)) || - ((value.m_beginm_end)) ; + return (value.m_begin <= m_end) && (value.m_end >= m_begin); } qreal Segment::intersectValue(Segment value) { - if ((value.m_end>=m_begin)&&(value.m_end<=m_end)){ + if (!intersect(value)) return 0; + if ((value.m_end >= m_begin) && (value.m_end <= m_end)){ return value.m_end-m_begin; } if ((value.m_begin>=m_begin)&&(value.m_end>=m_end)){ diff --git a/limereport/lrpageitemdesignintf.cpp b/limereport/lrpageitemdesignintf.cpp index 6d010a5..f191a16 100644 --- a/limereport/lrpageitemdesignintf.cpp +++ b/limereport/lrpageitemdesignintf.cpp @@ -804,7 +804,6 @@ void PageItemDesignIntf::initPageSize(const PageItemDesignIntf::PageSize &size) m_sizeChainging = true; if (m_pageSize != Custom){ QSizeF pageSize = getRectByPageSize(size); - qDebug() << pageSize; setWidth(pageSize.width()); setHeight(pageSize.height()); }