Files
libreoffice/sw/source/core/view/viewpg.cxx

252 lines
7.8 KiB
C++
Raw Normal View History

/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2000-09-18 23:08:29 +00:00
/*************************************************************************
*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
2000-09-18 23:08:29 +00:00
*
* Copyright 2000, 2010 Oracle and/or its affiliates.
2000-09-18 23:08:29 +00:00
*
* OpenOffice.org - a multi-platform office productivity suite
2000-09-18 23:08:29 +00:00
*
* This file is part of OpenOffice.org.
2000-09-18 23:08:29 +00:00
*
* OpenOffice.org is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License version 3
* only, as published by the Free Software Foundation.
2000-09-18 23:08:29 +00:00
*
* OpenOffice.org is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License version 3 for more details
* (a copy is included in the LICENSE file that accompanied this code).
2000-09-18 23:08:29 +00:00
*
* You should have received a copy of the GNU Lesser General Public License
* version 3 along with OpenOffice.org. If not, see
* <http://www.openoffice.org/license.html>
* for a copy of the LGPLv3 License.
2000-09-18 23:08:29 +00:00
*
************************************************************************/
2009-08-19 07:32:06 +00:00
#include <com/sun/star/uno/Sequence.hxx>
2000-09-18 23:08:29 +00:00
#include <hintids.hxx>
2000-09-18 23:08:29 +00:00
#include <vcl/window.hxx>
2009-08-19 07:32:06 +00:00
#include <vcl/oldprintadaptor.hxx>
2000-09-18 23:08:29 +00:00
#include <sfx2/printer.hxx>
#include <sfx2/progress.hxx>
#include <pvprtdat.hxx>
#include <viewsh.hxx>
#include <pagefrm.hxx>
#include <rootfrm.hxx>
#include <viewimp.hxx>
#include <viewopt.hxx>
#include <printdata.hxx>
#include <fldbas.hxx>
#include <ptqueue.hxx>
#include <swregion.hxx>
#include <hints.hxx>
#include <fntcache.hxx>
2000-09-18 23:08:29 +00:00
#include <statstr.hrc> // Text fuer SfxProgress
#include <comcore.hrc>
2000-09-18 23:08:29 +00:00
#include <IDocumentFieldsAccess.hxx>
#include <IDocumentDeviceAccess.hxx>
2009-08-19 07:32:06 +00:00
using namespace ::com::sun::star;
SwPageFrm const*
lcl_getPage(SwRootFrm const& rLayout, sal_Int32 const nPage); // vprint.cxx
// OD 12.12.2002 #103492#
SwPagePreviewLayout* ViewShell::PagePreviewLayout()
2000-09-18 23:08:29 +00:00
{
return Imp()->PagePreviewLayout();
2000-09-18 23:08:29 +00:00
}
2002-05-29 14:06:25 +00:00
void ViewShell::ShowPreViewSelection( sal_uInt16 nSelPage )
{
Imp()->InvalidateAccessiblePreViewSelection( nSelPage );
}
/** adjust view options for page preview
OD 09.01.2003 #i6467#
*/
void ViewShell::AdjustOptionsForPagePreview(SwPrintData const& rPrintOptions)
{
if ( !IsPreView() )
{
OSL_FAIL( "view shell doesn't belongs to a page preview - no adjustment of its view options");
return;
}
PrepareForPrint( rPrintOptions );
return;
2000-09-18 23:08:29 +00:00
}
// print brochure
// OD 05.05.2003 #i14016# - consider empty pages on calculation of the scaling
// for a page to be printed.
void ViewShell::PrintProspect(
OutputDevice *pOutDev,
2009-08-31 08:59:41 +00:00
const SwPrintData &rPrintData,
2009-08-14 13:56:56 +00:00
sal_Int32 nRenderer // the index in the vector of prospect pages to be printed
)
2000-09-18 23:08:29 +00:00
{
2009-08-31 08:59:41 +00:00
const sal_Int32 nMaxRenderer = rPrintData.GetRenderData().GetPagePairsForProspectPrinting().size() - 1;
OSL_ENSURE( 0 <= nRenderer && nRenderer <= nMaxRenderer, "nRenderer out of bounds");
2009-08-07 14:42:45 +00:00
Printer *pPrinter = dynamic_cast< Printer * >(pOutDev);
if (!pPrinter || nMaxRenderer < 0 || nRenderer < 0 || nRenderer > nMaxRenderer)
2000-09-18 23:08:29 +00:00
return;
2009-08-31 08:59:41 +00:00
// save settings of OutputDevice (should be done always since the
2009-08-07 14:42:45 +00:00
// output device is now provided by a call from outside the Writer)
pPrinter->Push();
std::pair< sal_Int32, sal_Int32 > rPagesToPrint =
rPrintData.GetRenderData().GetPagePairsForProspectPrinting()[ nRenderer ];
// const USHORT nPageMax = static_cast< USHORT >(rPagesToPrint.first > rPagesToPrint.second ?
// rPagesToPrint.first : rPagesToPrint.second);
OSL_ENSURE( rPagesToPrint.first == -1 || rPrintData.GetRenderData().GetValidPagesSet().count( rPagesToPrint.first ) == 1, "first Page not valid" );
OSL_ENSURE( rPagesToPrint.second == -1 || rPrintData.GetRenderData().GetValidPagesSet().count( rPagesToPrint.second ) == 1, "second Page not valid" );
2000-09-18 23:08:29 +00:00
// eine neue Shell fuer den Printer erzeugen
2009-08-07 14:42:45 +00:00
ViewShell aShell( *this, 0, pPrinter );
2000-09-18 23:08:29 +00:00
SET_CURR_SHELL( &aShell );
2009-08-14 13:56:56 +00:00
aShell.PrepareForPrint( rPrintData );
2000-09-18 23:08:29 +00:00
2011-11-28 10:21:57 +07:00
//!! applying view options and formatting the document should now only be done in getRendererCount!
2000-09-18 23:08:29 +00:00
2009-08-31 08:59:41 +00:00
MapMode aMapMode( MAP_TWIP );
2009-09-04 14:41:56 +00:00
Size aPrtSize( pPrinter->PixelToLogic( pPrinter->GetPaperSizePixel(), aMapMode ) );
2000-09-18 23:08:29 +00:00
2009-08-31 08:59:41 +00:00
SwTwips nMaxRowSz, nMaxColSz;
2000-09-18 23:08:29 +00:00
2009-08-31 08:59:41 +00:00
const SwPageFrm *pStPage = 0;
const SwPageFrm *pNxtPage = 0;
if (rPagesToPrint.first > 0)
2000-09-18 23:08:29 +00:00
{
pStPage = lcl_getPage(*aShell.GetLayout(), rPagesToPrint.first);
2000-09-18 23:08:29 +00:00
}
2009-08-31 08:59:41 +00:00
if (rPagesToPrint.second > 0)
2000-09-18 23:08:29 +00:00
{
pNxtPage = lcl_getPage(*aShell.GetLayout(), rPagesToPrint.second);
2000-09-18 23:08:29 +00:00
}
// OD 05.05.2003 #i14016# - consider empty pages on calculation
// of page size, used for calculation of scaling.
2009-08-31 08:59:41 +00:00
Size aSttPageSize;
if ( pStPage )
2000-09-18 23:08:29 +00:00
{
2009-08-31 08:59:41 +00:00
if ( pStPage->IsEmptyPage() )
2000-09-18 23:08:29 +00:00
{
2009-08-31 08:59:41 +00:00
if ( pStPage->GetPhyPageNum() % 2 == 0 )
aSttPageSize = pStPage->GetPrev()->Frm().SSize();
else
aSttPageSize = pStPage->GetNext()->Frm().SSize();
}
else
{
aSttPageSize = pStPage->Frm().SSize();
2000-09-18 23:08:29 +00:00
}
}
2009-08-31 08:59:41 +00:00
Size aNxtPageSize;
if ( pNxtPage )
2000-09-18 23:08:29 +00:00
{
2009-08-31 08:59:41 +00:00
if ( pNxtPage->IsEmptyPage() )
2000-09-18 23:08:29 +00:00
{
2009-08-31 08:59:41 +00:00
if ( pNxtPage->GetPhyPageNum() % 2 == 0 )
aNxtPageSize = pNxtPage->GetPrev()->Frm().SSize();
else
aNxtPageSize = pNxtPage->GetNext()->Frm().SSize();
2000-09-18 23:08:29 +00:00
}
2009-08-31 08:59:41 +00:00
else
2000-09-18 23:08:29 +00:00
{
2009-08-31 08:59:41 +00:00
aNxtPageSize = pNxtPage->Frm().SSize();
2000-09-18 23:08:29 +00:00
}
2009-08-31 08:59:41 +00:00
}
2000-09-18 23:08:29 +00:00
2009-08-31 08:59:41 +00:00
if( !pStPage )
{
nMaxColSz = 2 * aNxtPageSize.Width();
nMaxRowSz = aNxtPageSize.Height();
}
else if( !pNxtPage )
{
nMaxColSz = 2 * aSttPageSize.Width();
nMaxRowSz = aSttPageSize.Height();
}
else
{
nMaxColSz = aNxtPageSize.Width() + aSttPageSize.Width();
nMaxRowSz = Max( aNxtPageSize.Height(), aSttPageSize.Height() );
}
2000-09-18 23:08:29 +00:00
// den MapMode einstellen
2009-08-31 08:59:41 +00:00
aMapMode.SetOrigin( Point() );
{
Fraction aScX( aPrtSize.Width(), nMaxColSz );
Fraction aScY( aPrtSize.Height(), nMaxRowSz );
if( aScX < aScY )
aScY = aScX;
2000-09-18 23:08:29 +00:00
{
// fuer Drawing, damit diese ihre Objecte vernuenftig Painten
// koennen, auf "glatte" Prozentwerte setzen
2009-08-31 08:59:41 +00:00
aScY *= Fraction( 1000, 1 );
long nTmp = (long)aScY;
if( 1 < nTmp )
--nTmp;
2000-09-18 23:08:29 +00:00
else
2009-08-31 08:59:41 +00:00
nTmp = 1;
aScY = Fraction( nTmp, 1000 );
}
2000-09-18 23:08:29 +00:00
2009-08-31 08:59:41 +00:00
aMapMode.SetScaleY( aScY );
aMapMode.SetScaleX( aScY );
}
2000-09-18 23:08:29 +00:00
2009-09-04 14:41:56 +00:00
Size aTmpPrtSize( pPrinter->PixelToLogic( pPrinter->GetPaperSizePixel(), aMapMode ) );
2000-09-18 23:08:29 +00:00
2009-08-31 08:59:41 +00:00
// calculate start point for equal border on all sides
Point aSttPt( (aTmpPrtSize.Width() - nMaxColSz) / 2,
(aTmpPrtSize.Height() - nMaxRowSz) / 2 );
for( int nC = 0; nC < 2; ++nC )
{
if( pStPage )
{
aShell.Imp()->SetFirstVisPageInvalid();
aShell.aVisArea = pStPage->Frm();
2000-09-18 23:08:29 +00:00
2009-08-31 08:59:41 +00:00
Point aPos( aSttPt );
aPos -= aShell.aVisArea.Pos();
2009-09-04 14:41:56 +00:00
// aPos -= aPrtOff;
2009-08-31 08:59:41 +00:00
aMapMode.SetOrigin( aPos );
pPrinter->SetMapMode( aMapMode );
pStPage->GetUpper()->Paint( pStPage->Frm() );
2000-09-18 23:08:29 +00:00
}
2009-08-31 08:59:41 +00:00
pStPage = pNxtPage;
aSttPt.X() += aTmpPrtSize.Width() / 2;
}
2000-09-18 23:08:29 +00:00
2009-08-31 08:59:41 +00:00
SwPaintQueue::Repaint();
2011-11-28 10:21:57 +07:00
//!! applying/modifying view options and formatting the document should now only be done in getRendererCount!
2000-09-18 23:08:29 +00:00
pFntCache->Flush();
2009-08-07 14:42:45 +00:00
// restore settings of OutputDevice (should be done always now since the
// output device is now provided by a call from outside the Writer)
pPrinter->Pop();
2000-09-18 23:08:29 +00:00
}
2009-08-07 14:42:45 +00:00
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */