mirror of
https://github.com/fralx/LimeReport.git
synced 2025-01-12 09:31:04 +03:00
Finish endless_optimization
This commit is contained in:
parent
8dedda7c9c
commit
d6fe74e29e
@ -1,5 +1,6 @@
|
|||||||
#include "lritemscontainerdesignitf.h"
|
#include "lritemscontainerdesignitf.h"
|
||||||
#include "lritemdesignintf.h"
|
#include "lritemdesignintf.h"
|
||||||
|
#include "lrbanddesignintf.h"
|
||||||
|
|
||||||
namespace LimeReport {
|
namespace LimeReport {
|
||||||
|
|
||||||
@ -37,10 +38,14 @@ bool itemSortContainerLessThen(const PItemSortContainer c1, const PItemSortConta
|
|||||||
else return c1->m_rect.y()<c2->m_rect.y();
|
else return c1->m_rect.y()<c2->m_rect.y();
|
||||||
}
|
}
|
||||||
|
|
||||||
void ItemsContainerDesignInft::snapshotItemsLayout()
|
void ItemsContainerDesignInft::snapshotItemsLayout(SnapshotType type)
|
||||||
{
|
{
|
||||||
m_containerItems.clear();
|
m_containerItems.clear();
|
||||||
foreach(BaseDesignIntf *childItem, childBaseItems()){
|
foreach(BaseDesignIntf *childItem, childBaseItems()){
|
||||||
|
if (type == IgnoreBands){
|
||||||
|
if (!dynamic_cast<BandDesignIntf*>(childItem))
|
||||||
|
m_containerItems.append(PItemSortContainer(new ItemSortContainer(childItem)));
|
||||||
|
} else
|
||||||
m_containerItems.append(PItemSortContainer(new ItemSortContainer(childItem)));
|
m_containerItems.append(PItemSortContainer(new ItemSortContainer(childItem)));
|
||||||
}
|
}
|
||||||
qSort(m_containerItems.begin(),m_containerItems.end(),itemSortContainerLessThen);
|
qSort(m_containerItems.begin(),m_containerItems.end(),itemSortContainerLessThen);
|
||||||
|
@ -42,8 +42,9 @@ class ItemsContainerDesignInft : public BookmarkContainerDesignIntf{
|
|||||||
public:
|
public:
|
||||||
ItemsContainerDesignInft(const QString& xmlTypeName, QObject* owner = 0, QGraphicsItem* parent=0):
|
ItemsContainerDesignInft(const QString& xmlTypeName, QObject* owner = 0, QGraphicsItem* parent=0):
|
||||||
BookmarkContainerDesignIntf(xmlTypeName, owner, parent){}
|
BookmarkContainerDesignIntf(xmlTypeName, owner, parent){}
|
||||||
|
enum SnapshotType{Full, IgnoreBands};
|
||||||
protected:
|
protected:
|
||||||
void snapshotItemsLayout();
|
void snapshotItemsLayout(SnapshotType type = Full);
|
||||||
void arrangeSubItems(RenderPass pass, DataSourceManager *dataManager, ArrangeType type = AsNeeded);
|
void arrangeSubItems(RenderPass pass, DataSourceManager *dataManager, ArrangeType type = AsNeeded);
|
||||||
qreal findMaxBottom() const;
|
qreal findMaxBottom() const;
|
||||||
qreal findMaxHeight() const;
|
qreal findMaxHeight() const;
|
||||||
|
@ -131,6 +131,7 @@ BaseDesignIntf *PageItemDesignIntf::createSameTypeItem(QObject *owner, QGraphics
|
|||||||
void PageItemDesignIntf::geometryChangedEvent(QRectF newRect, QRectF)
|
void PageItemDesignIntf::geometryChangedEvent(QRectF newRect, QRectF)
|
||||||
{
|
{
|
||||||
Q_UNUSED(newRect)
|
Q_UNUSED(newRect)
|
||||||
|
if (itemMode() == DesignMode || !endlessHeight())
|
||||||
updateMarginRect();
|
updateMarginRect();
|
||||||
PageSize oldSize = m_pageSize;
|
PageSize oldSize = m_pageSize;
|
||||||
if (!m_sizeChainging && !isLoading())
|
if (!m_sizeChainging && !isLoading())
|
||||||
@ -490,9 +491,11 @@ void PageItemDesignIntf::setResetPageNumber(bool resetPageNumber)
|
|||||||
|
|
||||||
void PageItemDesignIntf::updateSubItemsSize(RenderPass pass, DataSourceManager *dataManager)
|
void PageItemDesignIntf::updateSubItemsSize(RenderPass pass, DataSourceManager *dataManager)
|
||||||
{
|
{
|
||||||
snapshotItemsLayout();
|
if (!endlessHeight()){
|
||||||
|
snapshotItemsLayout(IgnoreBands);
|
||||||
arrangeSubItems(pass, dataManager);
|
arrangeSubItems(pass, dataManager);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
bool PageItemDesignIntf::oldPrintMode() const
|
bool PageItemDesignIntf::oldPrintMode() const
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user