Cover page support for KPDF

This resolves issue #26.

Signed-off-by: Mavridis Philippe <mavridisf@gmail.com>
pull/27/head
Mavridis Philippe 4 years ago
parent 4bb8e05c48
commit 3afb31110a
No known key found for this signature in database
GPG Key ID: F8D2D7E2F989A494

@ -76,6 +76,9 @@
<entry key="ViewContinuous" type="Bool" > <entry key="ViewContinuous" type="Bool" >
<default>true</default> <default>true</default>
</entry> </entry>
<entry key="ViewCoverPage" type="Bool" >
<default>false</default>
</entry>
<entry key="ViewColumns" type="UInt" > <entry key="ViewColumns" type="UInt" >
<default>1</default> <default>1</default>
<min>1</min> <min>1</min>

@ -24,6 +24,7 @@
<Separator/> <Separator/>
<Action name="view_continuous"/> <Action name="view_continuous"/>
<Action name="view_twopages"/> <Action name="view_twopages"/>
<Action name="view_coverpage"/>
</Menu> </Menu>
<Menu name="go"><text>&amp;Go</text> <Menu name="go"><text>&amp;Go</text>
<Action name="previous_page"/> <Action name="previous_page"/>

@ -114,6 +114,7 @@ public:
TDEToggleAction * aZoomFitText; TDEToggleAction * aZoomFitText;
TDEToggleAction * aViewTwoPages; TDEToggleAction * aViewTwoPages;
TDEToggleAction * aViewContinuous; TDEToggleAction * aViewContinuous;
TDEToggleAction * aViewCoverPage;
TDEAction * aPrevAction; TDEAction * aPrevAction;
}; };
@ -282,6 +283,11 @@ void PageView::setupActions( TDEActionCollection * ac )
connect( d->aViewContinuous, TQT_SIGNAL( toggled( bool ) ), TQT_SLOT( slotContinuousToggled( bool ) ) ); connect( d->aViewContinuous, TQT_SIGNAL( toggled( bool ) ), TQT_SLOT( slotContinuousToggled( bool ) ) );
d->aViewContinuous->setChecked( KpdfSettings::viewContinuous() ); d->aViewContinuous->setChecked( KpdfSettings::viewContinuous() );
d->aViewCoverPage = new TDEToggleAction( i18n("Co&ver Page"), "contents2", 0, ac, "view_coverpage" );
connect( d->aViewCoverPage, TQT_SIGNAL( toggled( bool ) ), TQT_SLOT( slotCoverPageToggled( bool ) ) );
d->aViewCoverPage->setChecked( KpdfSettings::viewCoverPage() );
d->aViewCoverPage->setEnabled( KpdfSettings::viewColumns() > 1 );
// Mouse-Mode actions // Mouse-Mode actions
d->aMouseNormal = new TDERadioAction( i18n("&Browse Tool"), "input-mouse", 0, TQT_TQOBJECT(this), TQT_SLOT( slotSetMouseNormal() ), ac, "mouse_drag" ); d->aMouseNormal = new TDERadioAction( i18n("&Browse Tool"), "input-mouse", 0, TQT_TQOBJECT(this), TQT_SLOT( slotSetMouseNormal() ), ac, "mouse_drag" );
d->aMouseNormal->setExclusiveGroup( "MouseType" ); d->aMouseNormal->setExclusiveGroup( "MouseType" );
@ -1718,11 +1724,19 @@ void PageView::slotRelayoutPages()
insertY = 4; // 2 + 4*d->zoomFactor ? insertY = 4; // 2 + 4*d->zoomFactor ?
cIdx = 0; cIdx = 0;
rIdx = 0; rIdx = 0;
if( KpdfSettings::viewColumns() == 2 && KpdfSettings::viewCoverPage() )
++cIdx;
for ( iIt = d->items.begin(); iIt != iEnd; ++iIt ) for ( iIt = d->items.begin(); iIt != iEnd; ++iIt )
{ {
PageViewItem * item = *iIt; PageViewItem * item = *iIt;
int cWidth = colWidth[ cIdx ], int cWidth = colWidth[ cIdx ],
rHeight = rowHeight[ rIdx ]; rHeight = rowHeight[ rIdx ];
if( KpdfSettings::viewColumns() == 2 && KpdfSettings::viewCoverPage() && item->pageNumber() == 0 ) // align widget right inside viewport
insertX+=cWidth;
// center widget inside 'cells' // center widget inside 'cells'
item->moveTo( insertX + (cWidth - item->width()) / 2, item->moveTo( insertX + (cWidth - item->width()) / 2,
insertY + (rHeight - item->height()) / 2 ); insertY + (rHeight - item->height()) / 2 );
@ -1776,14 +1790,24 @@ void PageView::slotRelayoutPages()
// 2) hide all widgets except the displayable ones and dispose those // 2) hide all widgets except the displayable ones and dispose those
int insertX = 0; int insertX = 0;
cIdx = 0; cIdx = 0;
if( KpdfSettings::viewColumns() == 2 && KpdfSettings::viewCoverPage() && (int)d->document->currentPage() == 0 )
++cIdx;
for ( iIt = d->items.begin(); iIt != iEnd; ++iIt ) for ( iIt = d->items.begin(); iIt != iEnd; ++iIt )
{ {
PageViewItem * item = *iIt; PageViewItem * item = *iIt;
if ( item == currentItem || (cIdx > 0 && cIdx < nCols) ) if ( item == currentItem || (cIdx > 0 && cIdx < nCols) )
{ {
// center widget inside 'cells' if( KpdfSettings::viewCoverPage() && (int)d->document->currentPage() == 0 ) {
item->moveTo( insertX + (colWidth[ cIdx ] - item->width()) / 2, // center widget inside viewport
(fullHeight - item->height()) / 2 ); item->moveTo( insertX + (viewportWidth - item->width()) / 2,
(viewportHeight - item->height()) / 2 );
} else {
// center widget inside 'cells'
item->moveTo( insertX + (colWidth[ cIdx ] - item->width()) / 2,
(fullHeight - item->height()) / 2 );
}
// advance col index // advance col index
insertX += colWidth[ cIdx ]; insertX += colWidth[ cIdx ];
cIdx++; cIdx++;
@ -2110,6 +2134,8 @@ void PageView::slotTwoPagesToggled( bool on )
if ( d->document->pages() > 0 ) if ( d->document->pages() > 0 )
slotRelayoutPages(); slotRelayoutPages();
} }
d->aViewCoverPage->setEnabled( on );
} }
void PageView::slotContinuousToggled( bool on ) void PageView::slotContinuousToggled( bool on )
@ -2123,6 +2149,17 @@ void PageView::slotContinuousToggled( bool on )
} }
} }
void PageView::slotCoverPageToggled( bool on )
{
if ( KpdfSettings::viewCoverPage() != on )
{
KpdfSettings::setViewCoverPage( on );
KpdfSettings::writeConfig();
if ( d->document->pages() > 0 )
slotRelayoutPages();
}
}
void PageView::slotSetMouseNormal() void PageView::slotSetMouseNormal()
{ {
d->mouseMode = MouseNormal; d->mouseMode = MouseNormal;

@ -140,6 +140,7 @@ class PageView : public TQScrollView, public DocumentObserver
void slotRotateLeft(); void slotRotateLeft();
void slotTwoPagesToggled( bool ); void slotTwoPagesToggled( bool );
void slotContinuousToggled( bool ); void slotContinuousToggled( bool );
void slotCoverPageToggled( bool );
void slotSetMouseNormal(); void slotSetMouseNormal();
void slotSetMouseZoom(); void slotSetMouseZoom();
void slotSetMouseSelect(); void slotSetMouseSelect();

Loading…
Cancel
Save