Merge branch 'RefactorPrint'

- Modifies printing model to be similar to glabels-3.x.
   - Allow simple projects to print by-the-page (#51)
   - Added collated vs uncollated document merges
- Added ability to separate merge groups by page
- Updated man pages
- Updated misc developer documentation
This commit is contained in:
Jim Evins
2020-01-01 14:19:11 -05:00
parent af607ca4af
commit aebcda43cb
23 changed files with 1184 additions and 380 deletions
+169 -29
View File
@@ -47,9 +47,9 @@ namespace glabels
PageRenderer::PageRenderer( const Model* model )
: mModel(nullptr), mMerge(nullptr), mVariables(nullptr), mNCopies(0), mStartLabel(0), mLastLabel(0),
: mModel(nullptr), mMerge(nullptr), mVariables(nullptr), mNCopies(0), mStartItem(0), mLastItem(0),
mPrintOutlines(false), mPrintCropMarks(false), mPrintReverse(false),
mIPage(0), mIsMerge(false), mNPages(0), mNLabelsPerPage(0)
mIPage(0), mIsMerge(false), mNPages(0), mNItemsPerPage(0)
{
if ( model )
{
@@ -79,7 +79,7 @@ namespace glabels
{
mMerge = mModel->merge();
mOrigins = mModel->frame()->getOrigins();
mNLabelsPerPage = mModel->frame()->nLabels();
mNItemsPerPage = mModel->frame()->nLabels();
mIsMerge = ( dynamic_cast<const merge::None*>(mMerge) == nullptr );
updateNPages();
@@ -96,15 +96,33 @@ namespace glabels
}
void PageRenderer::setStartLabel( int startLabel )
void PageRenderer::setStartItem( int startItem )
{
mStartLabel = startLabel;
mStartItem = startItem;
updateNPages();
emit changed();
}
void PageRenderer::setIsCollated( bool isCollated )
{
mIsCollated = isCollated;
updateNPages();
emit changed();
}
void PageRenderer::setAreGroupsContiguous( bool areGroupsContiguous )
{
mAreGroupsContiguous = areGroupsContiguous;
updateNPages();
emit changed();
}
void PageRenderer::setPrintOutlines( bool printOutlinesFlag )
{
mPrintOutlines = printOutlinesFlag;
@@ -139,7 +157,7 @@ namespace glabels
int PageRenderer::nItems() const
{
return mLastLabel - mStartLabel;
return mNItems;
}
@@ -166,25 +184,49 @@ namespace glabels
{
if ( mModel )
{
if ( mIsMerge )
if ( !mIsMerge )
{
mLastLabel = mStartLabel + mNCopies*mMerge->nSelectedRecords();
// Simple project
mLastItem = mStartItem + mNCopies - 1;
mNItems = mNCopies;
mNGroups = 1;
mNItemsPerGroup = mNItems;
}
else
{
mLastLabel = mStartLabel + mNCopies;
}
mNPages = mLastLabel / mNLabelsPerPage;
if ( mLastLabel % mNLabelsPerPage )
{
mNPages++;
// Merge project
if ( mIsCollated )
{
// Collated Merge project
mNItemsPerGroup = mMerge->nSelectedRecords();
mNGroups = mNCopies;
}
else
{
// Un-Collated Merge project
mNItemsPerGroup = mNCopies;
mNGroups = mMerge->nSelectedRecords();
}
if ( mAreGroupsContiguous )
{
// Merge groups are contiguous
mLastItem = mStartItem + mNGroups*mNItemsPerGroup - 1;
}
else
{
// Merge groups start on new page
mNPagesPerGroup = (mStartItem + mNItemsPerGroup - 1)/mNItemsPerPage + 1;
mLastItem = (mNGroups-1)*mNPagesPerGroup*mNItemsPerPage + mStartItem + mNItemsPerGroup - 1;
}
mNItems = mNGroups*mNItemsPerGroup;
}
}
else
{
mNPages = 0;
}
mNPages = mLastItem/mNItemsPerPage + 1;
}
@@ -233,13 +275,20 @@ namespace glabels
{
if ( mModel )
{
if ( mIsMerge )
if ( !mIsMerge )
{
printMergePage( painter, iPage );
printSimplePage( painter, iPage );
}
else
{
printSimplePage( painter, iPage );
if ( mIsCollated )
{
printCollatedMergePage( painter, iPage );
}
else
{
printUnCollatedMergePage( painter, iPage );
}
}
}
}
@@ -250,7 +299,7 @@ namespace glabels
printCropMarks( painter );
int iCopy = 0;
int iLabel = mStartLabel;
int iItem = mStartItem;
int iCurrentPage = 0;
mVariables->resetVariables();
@@ -258,7 +307,7 @@ namespace glabels
{
if ( iCurrentPage == iPage )
{
int i = iLabel % mNLabelsPerPage;
int i = iItem % mNItemsPerPage;
painter->save();
@@ -276,13 +325,15 @@ namespace glabels
painter->restore(); // From before translation
}
// Next copy
iCopy++;
iLabel++;
iCurrentPage = iLabel / mNLabelsPerPage;
iItem++;
iCurrentPage = iItem / mNItemsPerPage;
// User variable book keeping
mVariables->incrementVariablesOnItem();
mVariables->incrementVariablesOnCopy();
if ( (iLabel % mNLabelsPerPage) == 0 /* starting a new page */ )
if ( (iItem % mNItemsPerPage) == 0 /* starting a new page */ )
{
mVariables->incrementVariablesOnPage();
}
@@ -290,12 +341,12 @@ namespace glabels
}
void PageRenderer::printMergePage( QPainter* painter, int iPage ) const
void PageRenderer::printCollatedMergePage( QPainter* painter, int iPage ) const
{
printCropMarks( painter );
int iCopy = 0;
int iLabel = mStartLabel;
int iItem = mStartItem;
int iCurrentPage = 0;
const QList<merge::Record*> records = mMerge->selectedRecords();
@@ -313,7 +364,7 @@ namespace glabels
{
if ( iCurrentPage == iPage )
{
int i = iLabel % mNLabelsPerPage;
int i = iItem % mNItemsPerPage;
painter->save();
@@ -331,20 +382,109 @@ namespace glabels
painter->restore(); // From before translation
}
// Next record
iRecord = (iRecord + 1) % nRecords;
if ( iRecord == 0 )
{
iCopy++;
if ( mAreGroupsContiguous )
{
iItem++;
}
else
{
iItem = iCopy*mNPagesPerGroup*mNItemsPerPage + mStartItem;
}
}
iLabel++;
iCurrentPage = iLabel / mNLabelsPerPage;
else
{
iItem++;
}
iCurrentPage = iItem / mNItemsPerPage;
// User variable book keeping
mVariables->incrementVariablesOnItem();
if ( iRecord == 0 )
{
mVariables->incrementVariablesOnCopy();
}
if ( (iLabel % mNLabelsPerPage) == 0 /* starting a new page */ )
if ( (iItem % mNItemsPerPage) == 0 /* starting a new page */ )
{
mVariables->incrementVariablesOnPage();
}
}
}
void PageRenderer::printUnCollatedMergePage( QPainter* painter, int iPage ) const
{
printCropMarks( painter );
int iCopy = 0;
int iItem = mStartItem;
int iCurrentPage = 0;
const QList<merge::Record*> records = mMerge->selectedRecords();
int iRecord = 0;
int nRecords = records.size();
if ( nRecords == 0 )
{
return;
}
mVariables->resetVariables();
while ( (iRecord < nRecords) && (iCurrentPage <= iPage) )
{
if ( iCurrentPage == iPage )
{
int i = iItem % mNItemsPerPage;
painter->save();
painter->translate( mOrigins[i].x().pt(), mOrigins[i].y().pt() );
painter->save();
clipLabel( painter );
printLabel( painter, records[iRecord], mVariables );
painter->restore(); // From before clip
printOutline( painter );
painter->restore(); // From before translation
}
// Next copy
iCopy = (iCopy + 1) % mNCopies;
if ( iCopy == 0 )
{
iRecord++;
if ( mAreGroupsContiguous )
{
iItem++;
}
else
{
iItem = iRecord*mNPagesPerGroup*mNItemsPerPage + mStartItem;
}
}
else
{
iItem++;
}
iCurrentPage = iItem / mNItemsPerPage;
// User variable book keeping
mVariables->incrementVariablesOnItem();
mVariables->incrementVariablesOnCopy();
if ( iCopy == 0 )
{
mVariables->resetOnCopyVariables();
}
if ( (iItem % mNItemsPerPage) == 0 /* starting a new page */ )
{
mVariables->incrementVariablesOnPage();
}