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:
+169
-29
@@ -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();
|
||||
}
|
||||
|
||||
+19
-8
@@ -64,7 +64,9 @@ namespace glabels
|
||||
void setModel( const Model* model );
|
||||
const Model* model() const;
|
||||
void setNCopies( int nCopies );
|
||||
void setStartLabel( int startLabel );
|
||||
void setStartItem( int startItem );
|
||||
void setIsCollated( bool isCollated );
|
||||
void setAreGroupsContiguous( bool areGroupscontiguous );
|
||||
void setPrintOutlines( bool printOutlinesFlag );
|
||||
void setPrintCropMarks( bool printCropMarksFlag );
|
||||
void setPrintReverse( bool printReverseFlag );
|
||||
@@ -97,7 +99,8 @@ namespace glabels
|
||||
private:
|
||||
void updateNPages();
|
||||
void printSimplePage( QPainter* painter, int iPage ) const;
|
||||
void printMergePage( QPainter* painter, int iPage ) const;
|
||||
void printCollatedMergePage( QPainter* painter, int iPage ) const;
|
||||
void printUnCollatedMergePage( QPainter* painter, int iPage ) const;
|
||||
void printCropMarks( QPainter* painter ) const;
|
||||
void printOutline( QPainter* painter ) const;
|
||||
void clipLabel( QPainter* painter ) const;
|
||||
@@ -113,16 +116,24 @@ namespace glabels
|
||||
Variables* mVariables;
|
||||
|
||||
int mNCopies;
|
||||
int mStartLabel;
|
||||
int mLastLabel;
|
||||
bool mPrintOutlines;
|
||||
bool mPrintCropMarks;
|
||||
bool mPrintReverse;
|
||||
int mStartItem;
|
||||
int mLastItem;
|
||||
int mNGroups;
|
||||
int mNItemsPerGroup;
|
||||
int mNPagesPerGroup;
|
||||
int mIPage;
|
||||
|
||||
bool mIsMerge;
|
||||
|
||||
int mNItems;
|
||||
int mNPages;
|
||||
int mNLabelsPerPage;
|
||||
int mNItemsPerPage;
|
||||
|
||||
bool mIsCollated;
|
||||
bool mAreGroupsContiguous;
|
||||
bool mPrintOutlines;
|
||||
bool mPrintCropMarks;
|
||||
bool mPrintReverse;
|
||||
|
||||
QVector<Point> mOrigins;
|
||||
};
|
||||
|
||||
@@ -118,6 +118,21 @@ namespace glabels
|
||||
}
|
||||
|
||||
|
||||
///
|
||||
/// Reset "on copy" variables to their initial values
|
||||
///
|
||||
void Variables::resetOnCopyVariables()
|
||||
{
|
||||
for ( auto& v : *this )
|
||||
{
|
||||
if ( v.increment() == Variable::Increment::PER_COPY )
|
||||
{
|
||||
v.resetValue();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
///
|
||||
/// Increment variables on item
|
||||
///
|
||||
|
||||
@@ -66,6 +66,7 @@ namespace glabels
|
||||
void setVariables( const QMap<QString,QString>& definitions );
|
||||
|
||||
void resetVariables();
|
||||
void resetOnCopyVariables();
|
||||
void incrementVariablesOnItem();
|
||||
void incrementVariablesOnCopy();
|
||||
void incrementVariablesOnPage();
|
||||
|
||||
Reference in New Issue
Block a user