2008/04/01 15:57:41 thb 1.44.36.3: #i85898# Stripping all external header guards 2008/04/01 12:54:37 thb 1.44.36.2: #i85898# Stripping all external header guards 2008/03/31 16:55:29 rt 1.44.36.1: #i87441# Change license header to LPGL v3.
		
			
				
	
	
		
			1623 lines
		
	
	
		
			57 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			1623 lines
		
	
	
		
			57 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*************************************************************************
 | |
|  *
 | |
|  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
 | |
|  *
 | |
|  * Copyright 2008 by Sun Microsystems, Inc.
 | |
|  *
 | |
|  * OpenOffice.org - a multi-platform office productivity suite
 | |
|  *
 | |
|  * $RCSfile: vprint.cxx,v $
 | |
|  * $Revision: 1.45 $
 | |
|  *
 | |
|  * This file is part of OpenOffice.org.
 | |
|  *
 | |
|  * 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.
 | |
|  *
 | |
|  * 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).
 | |
|  *
 | |
|  * 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.
 | |
|  *
 | |
|  ************************************************************************/
 | |
| 
 | |
| // MARKER(update_precomp.py): autogen include statement, do not remove
 | |
| #include "precompiled_sw.hxx"
 | |
| 
 | |
| 
 | |
| #include <hintids.hxx>
 | |
| #include <sfx2/printer.hxx>
 | |
| #include <sfx2/objsh.hxx>
 | |
| 
 | |
| #ifndef _INTN_HXX //autogen
 | |
| // #include <tools/intn.hxx>
 | |
| #endif
 | |
| #include <sfx2/progress.hxx>
 | |
| #include <sfx2/app.hxx>
 | |
| #include <sfx2/prnmon.hxx>
 | |
| #include <svx/paperinf.hxx>
 | |
| #include <svx/pbinitem.hxx>
 | |
| #include <svx/svdview.hxx>
 | |
| #include <unotools/localedatawrapper.hxx>
 | |
| #include <txtfld.hxx>
 | |
| #include <fmtfld.hxx>
 | |
| #include <fmtfsize.hxx>
 | |
| #include <frmatr.hxx>
 | |
| #include <rootfrm.hxx>
 | |
| #include <pagefrm.hxx>
 | |
| #include <cntfrm.hxx>
 | |
| #include <doc.hxx>
 | |
| #include <fesh.hxx>
 | |
| #include <pam.hxx>
 | |
| #include <viewimp.hxx>      // Imp->SetFirstVisPageInvalid()
 | |
| #include <layact.hxx>
 | |
| #include <ndtxt.hxx>
 | |
| #include <fldbas.hxx>
 | |
| #include <docufld.hxx>      // PostItFld /-Type
 | |
| #include <docfld.hxx>       // _SetGetExpFld
 | |
| #include <shellres.hxx>
 | |
| #include <viewopt.hxx>
 | |
| #include <swprtopt.hxx>     // SwPrtOptions
 | |
| #include <pagedesc.hxx>
 | |
| #include <poolfmt.hxx>      // fuer RES_POOLPAGE_JAKET
 | |
| #include <mdiexp.hxx>       // Ansteuern der Statusleiste
 | |
| #ifndef _STATSTR_HRC
 | |
| #include <statstr.hrc>      //      -- " --
 | |
| #endif
 | |
| #include <ptqueue.hxx>
 | |
| #include <tabfrm.hxx>
 | |
| #include <txtfrm.hxx>       // MinPrtLine
 | |
| #include <viscrs.hxx>       // SwShellCrsr
 | |
| #include <fmtpdsc.hxx>      // SwFmtPageDesc
 | |
| 
 | |
| #define JOBSET_ERR_DEFAULT          0
 | |
| #define JOBSET_ERR_ERROR            1
 | |
| #define JOBSET_ERR_ISSTARTET        2
 | |
| 
 | |
| //--------------------------------------------------------------------
 | |
| //Klasse zum Puffern von Paints
 | |
| class SwQueuedPaint
 | |
| {
 | |
| public:
 | |
|     SwQueuedPaint *pNext;
 | |
|     ViewShell      *pSh;
 | |
|     SwRect          aRect;
 | |
| 
 | |
|     SwQueuedPaint( ViewShell *pNew, const SwRect &rRect ) :
 | |
|         pNext( 0 ),
 | |
|         pSh( pNew ),
 | |
|         aRect( rRect )
 | |
|     {}
 | |
| };
 | |
| 
 | |
| SwQueuedPaint *SwPaintQueue::pQueue = 0;
 | |
| 
 | |
| //Klasse zum Speichern einiger Druckereinstellungen
 | |
| class SwPrtOptSave
 | |
| {
 | |
|     Printer *pPrt;
 | |
|     Size aSize;
 | |
|     Paper ePaper;
 | |
|     Orientation eOrientation;
 | |
|     USHORT nPaperBin;
 | |
| public:
 | |
|     SwPrtOptSave( Printer *pPrinter );
 | |
|     ~SwPrtOptSave();
 | |
| };
 | |
| 
 | |
| // saves some settings from the draw view
 | |
| class SwDrawViewSave
 | |
| {
 | |
|     String sLayerNm;
 | |
|     SdrView* pDV;
 | |
|     sal_Bool bPrintControls;
 | |
| public:
 | |
|     SwDrawViewSave( SdrView* pSdrView );
 | |
|     ~SwDrawViewSave();
 | |
| };
 | |
| 
 | |
| 
 | |
| void SwPaintQueue::Add( ViewShell *pNew, const SwRect &rNew )
 | |
| {
 | |
|     SwQueuedPaint *pPt;
 | |
|     if ( 0 != (pPt = pQueue) )
 | |
|     {
 | |
|         while ( pPt->pSh != pNew && pPt->pNext )
 | |
|             pPt = pPt->pNext;
 | |
|         if ( pPt->pSh == pNew )
 | |
|         {
 | |
|             pPt->aRect.Union( rNew );
 | |
|             return;
 | |
|         }
 | |
|     }
 | |
|     SwQueuedPaint *pNQ = new SwQueuedPaint( pNew, rNew );
 | |
|     if ( pPt )
 | |
|         pPt->pNext = pNQ;
 | |
|     else
 | |
|         pQueue = pNQ;
 | |
| }
 | |
| 
 | |
| 
 | |
| 
 | |
| void SwPaintQueue::Repaint()
 | |
| {
 | |
|     if ( !SwRootFrm::IsInPaint() && pQueue )
 | |
|     {
 | |
|         SwQueuedPaint *pPt = pQueue;
 | |
|         do
 | |
|         {   ViewShell *pSh = pPt->pSh;
 | |
|             SET_CURR_SHELL( pSh );
 | |
|             if ( pSh->IsPreView() )
 | |
|             {
 | |
|                 if ( pSh->GetWin() )
 | |
|                 {
 | |
|                     //Fuer PreView aussenherum, weil im PaintHdl (UI) die
 | |
|                     //Zeilen/Spalten bekannt sind.
 | |
|                     pSh->GetWin()->Invalidate();
 | |
|                     pSh->GetWin()->Update();
 | |
|                 }
 | |
|             }
 | |
|             else
 | |
|                 pSh->Paint( pPt->aRect.SVRect() );
 | |
|             pPt = pPt->pNext;
 | |
|         } while ( pPt );
 | |
| 
 | |
|         do
 | |
|         {   pPt = pQueue;
 | |
|             pQueue = pQueue->pNext;
 | |
|             delete pPt;
 | |
|         } while ( pQueue );
 | |
|     }
 | |
| }
 | |
| 
 | |
| 
 | |
| 
 | |
| void SwPaintQueue::Remove( ViewShell *pSh )
 | |
| {
 | |
|     SwQueuedPaint *pPt;
 | |
|     if ( 0 != (pPt = pQueue) )
 | |
|     {
 | |
|         SwQueuedPaint *pPrev = 0;
 | |
|         while ( pPt && pPt->pSh != pSh )
 | |
|         {
 | |
|             pPrev = pPt;
 | |
|             pPt = pPt->pNext;
 | |
|         }
 | |
|         if ( pPt )
 | |
|         {
 | |
|             if ( pPrev )
 | |
|                 pPrev->pNext = pPt->pNext;
 | |
|             else if ( pPt == pQueue )
 | |
|                 pQueue = 0;
 | |
|             delete pPt;
 | |
|         }
 | |
|     }
 | |
| }
 | |
| 
 | |
| 
 | |
| const XubString& SwPrtOptions::MakeNextJobName()
 | |
| {
 | |
|     static char __READONLY_DATA sDelim[] = " - ";
 | |
|     USHORT nDelim = sJobName.SearchAscii( sDelim );
 | |
|     if( STRING_NOTFOUND == nDelim )
 | |
|         sJobName.AppendAscii(sDelim);
 | |
|     else
 | |
|         sJobName.Erase( nDelim + 3/*Zeichen!*/ );
 | |
| 
 | |
|     return sJobName += XubString::CreateFromInt32( ++nJobNo );
 | |
| }
 | |
| 
 | |
| /******************************************************************************
 | |
|  *  Methode     :   void SetSwVisArea( ViewShell *pSh, Point aPrtOffset, ...
 | |
|  *  Beschreibung:
 | |
|  *  Erstellt    :   OK 04.11.94 16:27
 | |
|  *  Aenderung   :
 | |
|  ******************************************************************************/
 | |
| 
 | |
| void SetSwVisArea( ViewShell *pSh, const SwRect &rRect, BOOL bPDFExport )
 | |
| {
 | |
|     ASSERT( !pSh->GetWin(), "Drucken mit Window?" );
 | |
|     pSh->aVisArea = rRect;
 | |
|     pSh->Imp()->SetFirstVisPageInvalid();
 | |
|     Point aPt( rRect.Pos() );
 | |
| 
 | |
|     if (!bPDFExport)
 | |
|         aPt += pSh->aPrtOffst;
 | |
|     aPt.X() = -aPt.X(); aPt.Y() = -aPt.Y();
 | |
| 
 | |
|     OutputDevice *pOut = bPDFExport ?
 | |
|                          pSh->GetOut() :
 | |
|                          pSh->getIDocumentDeviceAccess()->getPrinter( false );
 | |
| 
 | |
|     MapMode aMapMode( pOut->GetMapMode() );
 | |
|     aMapMode.SetOrigin( aPt );
 | |
|     pOut->SetMapMode( aMapMode );
 | |
| }
 | |
| 
 | |
| /******************************************************************************
 | |
|  *  Methode     :   struct _PostItFld : public _SetGetExpFld
 | |
|  *  Beschreibung:   Update an das PostItFeld
 | |
|  *  Erstellt    :   OK 07.11.94 10:18
 | |
|  *  Aenderung   :
 | |
|  ******************************************************************************/
 | |
| struct _PostItFld : public _SetGetExpFld
 | |
| {
 | |
|     _PostItFld( const SwNodeIndex& rNdIdx, const SwTxtFld* pFld,
 | |
|                     const SwIndex* pIdx = 0 )
 | |
|         : _SetGetExpFld( rNdIdx, pFld, pIdx ) {}
 | |
| 
 | |
|     USHORT GetPageNo( MultiSelection &rMulti, BOOL bRgt, BOOL bLft,
 | |
|                         USHORT& rVirtPgNo, USHORT& rLineNo );
 | |
|     SwPostItField* GetPostIt() const
 | |
|         { return (SwPostItField*) GetFld()->GetFld().GetFld(); }
 | |
| };
 | |
| 
 | |
| 
 | |
| 
 | |
| USHORT _PostItFld::GetPageNo( MultiSelection &rMulti, BOOL bRgt, BOOL bLft,
 | |
|                                 USHORT& rVirtPgNo, USHORT& rLineNo )
 | |
| {
 | |
|     //Problem: Wenn ein PostItFld in einem Node steht, der von mehr als
 | |
|     //einer Layout-Instanz repraesentiert wird, steht die Frage im Raum,
 | |
|     //ob das PostIt nur ein- oder n-mal gedruck werden soll.
 | |
|     //Wahrscheinlich nur einmal, als Seitennummer soll hier keine Zufaellige
 | |
|     //sondern die des ersten Auftretens des PostIts innerhalb des selektierten
 | |
|     //Bereichs ermittelt werden.
 | |
|     rVirtPgNo = 0;
 | |
|     USHORT nPos = GetCntnt();
 | |
|     SwClientIter aIter( (SwModify &)GetFld()->GetTxtNode() );
 | |
|     for( SwTxtFrm* pFrm = (SwTxtFrm*)aIter.First( TYPE( SwFrm ));
 | |
|             pFrm;  pFrm = (SwTxtFrm*)aIter.Next() )
 | |
|     {
 | |
|         if( pFrm->GetOfst() > nPos ||
 | |
|             pFrm->HasFollow() && pFrm->GetFollow()->GetOfst() <= nPos )
 | |
|             continue;
 | |
|         USHORT nPgNo = pFrm->GetPhyPageNum();
 | |
|         BOOL bRight = pFrm->OnRightPage();
 | |
|         if( rMulti.IsSelected( nPgNo ) &&
 | |
|             ( (bRight && bRgt) || (!bRight && bLft) ) )
 | |
|         {
 | |
|             rLineNo = (USHORT)(pFrm->GetLineCount( nPos ) +
 | |
|                       pFrm->GetAllLines() - pFrm->GetThisLines());
 | |
|             rVirtPgNo = pFrm->GetVirtPageNum();
 | |
|             return nPgNo;
 | |
|         }
 | |
|     }
 | |
|     return 0;
 | |
| }
 | |
| 
 | |
| /******************************************************************************
 | |
|  *  Methode     :   void lcl_GetPostIts( IDocumentFieldsAccess* pIDFA, _SetGetExpFlds& ...
 | |
|  *  Beschreibung:
 | |
|  *  Erstellt    :   OK 07.11.94 10:20
 | |
|  *  Aenderung   :
 | |
|  ******************************************************************************/
 | |
| 
 | |
| 
 | |
| void lcl_GetPostIts( IDocumentFieldsAccess* pIDFA, _SetGetExpFlds& rSrtLst )
 | |
| {
 | |
|     SwFieldType* pFldType = pIDFA->GetSysFldType( RES_POSTITFLD );
 | |
|     ASSERT( pFldType, "kein PostItType ? ");
 | |
| 
 | |
|     if( pFldType->GetDepends() )
 | |
|     {
 | |
|         // Modify-Object gefunden, trage alle Felder ins Array ein
 | |
|         SwClientIter aIter( *pFldType );
 | |
|         SwClient* pLast;
 | |
|         const SwTxtFld* pTxtFld;
 | |
| 
 | |
|         for( pLast = aIter.First( TYPE(SwFmtFld)); pLast; pLast = aIter.Next() )
 | |
|             if( 0 != ( pTxtFld = ((SwFmtFld*)pLast)->GetTxtFld() ) &&
 | |
|                 pTxtFld->GetTxtNode().GetNodes().IsDocNodes() )
 | |
|             {
 | |
|                 SwNodeIndex aIdx( pTxtFld->GetTxtNode() );
 | |
|                 _PostItFld* pNew = new _PostItFld( aIdx, pTxtFld );
 | |
|                 rSrtLst.Insert( pNew );
 | |
|             }
 | |
|     }
 | |
| }
 | |
| 
 | |
| /******************************************************************************
 | |
|  *  Methode     :   void lcl_FormatPostIt( IDocumentContentOperations* pIDCO, SwPaM& aPam, ...
 | |
|  *  Beschreibung:
 | |
|  *  Erstellt    :   OK 07.11.94 10:20
 | |
|  *  Aenderung   :
 | |
|  ******************************************************************************/
 | |
| 
 | |
| 
 | |
| void lcl_FormatPostIt( IDocumentContentOperations* pIDCO, SwPaM& aPam, SwPostItField* pField,
 | |
|                            USHORT nPageNo, USHORT nLineNo )
 | |
| {
 | |
|     static char __READONLY_DATA sTmp[] = " : ";
 | |
| 
 | |
|     ASSERT( ViewShell::GetShellRes(), "missing ShellRes" );
 | |
| 
 | |
|     String aStr(    ViewShell::GetShellRes()->aPostItPage   );
 | |
|     aStr.AppendAscii(sTmp);
 | |
| 
 | |
|     aStr += XubString::CreateFromInt32( nPageNo );
 | |
|     aStr += ' ';
 | |
|     if( nLineNo )
 | |
|     {
 | |
|         aStr += ViewShell::GetShellRes()->aPostItLine;
 | |
|         aStr.AppendAscii(sTmp);
 | |
|         aStr += XubString::CreateFromInt32( nLineNo );
 | |
|         aStr += ' ';
 | |
|     }
 | |
|     aStr += ViewShell::GetShellRes()->aPostItAuthor;
 | |
|     aStr.AppendAscii(sTmp);
 | |
|     aStr += pField->GetPar1();
 | |
|     aStr += ' ';
 | |
|     aStr += GetAppLocaleData().getDate( pField->GetDate() );
 | |
|     pIDCO->Insert( aPam, aStr, true );
 | |
| 
 | |
|     pIDCO->SplitNode( *aPam.GetPoint(), false );
 | |
|     aStr = pField->GetPar2();
 | |
| #if defined( WIN ) || defined( WNT ) || defined( PM2 )
 | |
|     // Bei Windows und Co alle CR rausschmeissen
 | |
|     aStr.EraseAllChars( '\r' );
 | |
| #endif
 | |
|     pIDCO->Insert( aPam, aStr, true );
 | |
|     pIDCO->SplitNode( *aPam.GetPoint(), false );
 | |
|     pIDCO->SplitNode( *aPam.GetPoint(), false );
 | |
| }
 | |
| 
 | |
| /******************************************************************************
 | |
|  *  Methode     :   void lcl_PrintPostIts( ViewShell* pPrtShell )
 | |
|  *  Beschreibung:
 | |
|  *  Erstellt    :   OK 07.11.94 10:21
 | |
|  *  Aenderung   :   MA 10. May. 95
 | |
|  ******************************************************************************/
 | |
| 
 | |
| 
 | |
| void lcl_PrintPostIts( ViewShell* pPrtShell, const XubString& rJobName,
 | |
|                         BOOL& rStartJob, int& rJobStartError, BOOL bReverse)
 | |
| {
 | |
|     // Formatieren und Ausdrucken
 | |
|     pPrtShell->CalcLayout();
 | |
| 
 | |
|     SfxPrinter* pPrn = pPrtShell->getIDocumentDeviceAccess()->getPrinter( false );
 | |
| 
 | |
|     //Das Druckdokument ist ein default Dokument, mithin arbeitet es auf der
 | |
|     //StandardSeite.
 | |
|     SwFrm *pPage = pPrtShell->GetLayout()->Lower();
 | |
| 
 | |
|     SwPrtOptSave aPrtSave( pPrn );
 | |
| 
 | |
|     pPrn->SetOrientation( ORIENTATION_PORTRAIT );
 | |
|     pPrn->SetPaperBin( pPage->GetAttrSet()->GetPaperBin().GetValue() );
 | |
| 
 | |
|     if( !rStartJob &&  JOBSET_ERR_DEFAULT == rJobStartError &&
 | |
|         rJobName.Len() )
 | |
|     {
 | |
|         if( !pPrn->IsJobActive() )
 | |
|         {
 | |
|             rStartJob = pPrn->StartJob( rJobName );
 | |
|             if( !rStartJob )
 | |
|             {
 | |
|                 rJobStartError = JOBSET_ERR_ERROR;
 | |
|                 return;
 | |
|             }
 | |
|         }
 | |
|         pPrtShell->InitPrt( pPrn );
 | |
|         rJobStartError = JOBSET_ERR_ISSTARTET;
 | |
|     }
 | |
| 
 | |
|     // Wir koennen auch rueckwaerts:
 | |
|     if ( bReverse )
 | |
|         pPage = pPrtShell->GetLayout()->GetLastPage();
 | |
| 
 | |
|     while( pPage )
 | |
|     {
 | |
|         //Mag der Anwender noch?, Abbruch erst in Prt()
 | |
|         GetpApp()->Reschedule();
 | |
|         ::SetSwVisArea( pPrtShell, pPage->Frm() );
 | |
|         pPrn->StartPage();
 | |
|         pPage->GetUpper()->Paint( pPage->Frm() );
 | |
| //      SFX_APP()->SpoilDemoOutput( *pPrtShell->GetOut(), pPage->Frm().SVRect());
 | |
|         SwPaintQueue::Repaint();
 | |
|         pPrn->EndPage();
 | |
|         pPage = bReverse ? pPage->GetPrev() : pPage->GetNext();
 | |
|     }
 | |
| }
 | |
| 
 | |
| /******************************************************************************
 | |
|  *  Methode     :   void lcl_PrintPostItsEndDoc( ViewShell* pPrtShell, ...
 | |
|  *  Beschreibung:
 | |
|  *  Erstellt    :   OK 07.11.94 10:21
 | |
|  *  Aenderung   :   MA 10. May. 95
 | |
|  ******************************************************************************/
 | |
| 
 | |
| 
 | |
| void lcl_PrintPostItsEndDoc( ViewShell* pPrtShell,
 | |
|             _SetGetExpFlds& rPostItFields, MultiSelection &rMulti,
 | |
|             const XubString& rJobName, BOOL& rStartJob, int& rJobStartError,
 | |
|             BOOL bRgt, BOOL bLft, BOOL bRev )
 | |
| {
 | |
|     USHORT nPostIts = rPostItFields.Count();
 | |
|     if( !nPostIts )
 | |
|         // Keine Arbeit
 | |
|         return;
 | |
| 
 | |
|     SET_CURR_SHELL( pPrtShell );
 | |
| 
 | |
|     SwDoc* pPrtDoc = pPrtShell->GetDoc();
 | |
| 
 | |
|     // Dokument leeren und ans Dokumentende gehen
 | |
|     SwPaM aPam( pPrtDoc->GetNodes().GetEndOfContent() );
 | |
|     aPam.Move( fnMoveBackward, fnGoDoc );
 | |
|     aPam.SetMark();
 | |
|     aPam.Move( fnMoveForward, fnGoDoc );
 | |
|     pPrtDoc->Delete( aPam );
 | |
| 
 | |
|     for( USHORT i = 0, nVirtPg, nLineNo; i < nPostIts; ++i )
 | |
|     {
 | |
|         _PostItFld& rPostIt = (_PostItFld&)*rPostItFields[ i ];
 | |
|         if( rPostIt.GetPageNo( rMulti, bRgt, bLft, nVirtPg, nLineNo ) )
 | |
|             lcl_FormatPostIt( pPrtShell->GetDoc(), aPam,
 | |
|                            rPostIt.GetPostIt(), nVirtPg, nLineNo );
 | |
|     }
 | |
| 
 | |
|     lcl_PrintPostIts( pPrtShell, rJobName, rStartJob, rJobStartError, bRev );
 | |
| }
 | |
| 
 | |
| /******************************************************************************
 | |
|  *  Methode     :   void lcl_PrintPostItsEndPage( ViewShell* pPrtShell, ...
 | |
|  *  Beschreibung:
 | |
|  *  Erstellt    :   OK 07.11.94 10:22
 | |
|  *  Aenderung   :
 | |
|  ******************************************************************************/
 | |
| 
 | |
| 
 | |
| void lcl_PrintPostItsEndPage( ViewShell* pPrtShell,
 | |
|             _SetGetExpFlds& rPostItFields, USHORT nPageNo, MultiSelection &rMulti,
 | |
|             const XubString& rJobName, BOOL& rStartJob, int& rJobStartError,
 | |
|             BOOL bRgt, BOOL bLft, BOOL bRev )
 | |
| {
 | |
|     USHORT nPostIts = rPostItFields.Count();
 | |
|     if( !nPostIts )
 | |
|         // Keine Arbeit
 | |
|         return;
 | |
| 
 | |
|     SET_CURR_SHELL( pPrtShell );
 | |
| 
 | |
|     USHORT i = 0, nVirtPg, nLineNo;
 | |
|     while( ( i < nPostIts ) &&
 | |
|            ( nPageNo != ((_PostItFld&)*rPostItFields[ i ]).
 | |
|                                 GetPageNo( rMulti,bRgt, bLft, nVirtPg, nLineNo )))
 | |
|         ++i;
 | |
|     if(i == nPostIts)
 | |
|         // Nix zu drucken
 | |
|         return;
 | |
| 
 | |
|     SwDoc* pPrtDoc = pPrtShell->GetDoc();
 | |
| 
 | |
|     // Dokument leeren und ans Dokumentende gehen
 | |
|     SwPaM aPam( pPrtDoc->GetNodes().GetEndOfContent() );
 | |
|     aPam.Move( fnMoveBackward, fnGoDoc );
 | |
|     aPam.SetMark();
 | |
|     aPam.Move( fnMoveForward, fnGoDoc );
 | |
|     pPrtDoc->Delete( aPam );
 | |
| 
 | |
|     while( i < nPostIts )
 | |
|     {
 | |
|         _PostItFld& rPostIt = (_PostItFld&)*rPostItFields[ i ];
 | |
|         if( nPageNo == rPostIt.GetPageNo( rMulti, bRgt, bLft, nVirtPg, nLineNo ) )
 | |
|             lcl_FormatPostIt( pPrtShell->GetDoc(), aPam,
 | |
|                                 rPostIt.GetPostIt(), nVirtPg, nLineNo );
 | |
|         ++i;
 | |
|     }
 | |
|     lcl_PrintPostIts( pPrtShell, rJobName, rStartJob, rJobStartError, bRev );
 | |
| }
 | |
| 
 | |
| /******************************************************************************
 | |
|  *  Methode     :   void ViewShell::InitPrt( SfxPrinter *pNew, OutputDevice *pPDFOut )
 | |
|  *  Beschreibung:
 | |
|  *  Erstellt    :   OK 07.11.94 10:22
 | |
|  *  Aenderung   :
 | |
|  ******************************************************************************/
 | |
| 
 | |
| void ViewShell::InitPrt( SfxPrinter *pPrt, OutputDevice *pPDFOut )
 | |
| {
 | |
|     //Fuer den Printer merken wir uns einen negativen Offset, der
 | |
|     //genau dem Offset de OutputSize entspricht. Das ist notwendig,
 | |
|     //weil unser Ursprung der linken ober Ecke der physikalischen
 | |
|     //Seite ist, die Ausgaben (SV) aber den Outputoffset als Urstprung
 | |
|     //betrachten.
 | |
|     OutputDevice *pTmpDev = pPDFOut ? pPDFOut : (OutputDevice *) pPrt;
 | |
|     if ( pTmpDev )
 | |
|     {
 | |
|         aPrtOffst = pPrt ? pPrt->GetPageOffset() : Point();
 | |
| 
 | |
|         aPrtOffst += pTmpDev->GetMapMode().GetOrigin();
 | |
|         MapMode aMapMode( pTmpDev->GetMapMode() );
 | |
|         aMapMode.SetMapUnit( MAP_TWIP );
 | |
|         pTmpDev->SetMapMode( aMapMode );
 | |
|         pTmpDev->SetLineColor();
 | |
|         pTmpDev->SetFillColor();
 | |
|     }
 | |
|     else
 | |
|         aPrtOffst.X() = aPrtOffst.Y() = 0;
 | |
| 
 | |
|     if ( !pWin )
 | |
|         pOut = pTmpDev;    //Oder was sonst?
 | |
| }
 | |
| 
 | |
| /******************************************************************************
 | |
|  *  Methode     :   void ViewShell::ChgAllPageOrientation
 | |
|  *  Erstellt    :   MA 08. Aug. 95
 | |
|  *  Aenderung   :
 | |
|  ******************************************************************************/
 | |
| 
 | |
| 
 | |
| void ViewShell::ChgAllPageOrientation( USHORT eOri )
 | |
| {
 | |
|     ASSERT( nStartAction, "missing an Action" );
 | |
|     SET_CURR_SHELL( this );
 | |
| 
 | |
|     USHORT nAll = GetDoc()->GetPageDescCnt();
 | |
|     BOOL bNewOri = Orientation(eOri) == ORIENTATION_PORTRAIT ? FALSE : TRUE;
 | |
| 
 | |
|     for( USHORT i = 0; i < nAll; ++ i )
 | |
|     {
 | |
|         const SwPageDesc& rOld =
 | |
|             const_cast<const SwDoc *>(GetDoc())->GetPageDesc( i );
 | |
| 
 | |
|         if( rOld.GetLandscape() != bNewOri )
 | |
|         {
 | |
|             SwPageDesc aNew( rOld );
 | |
|             const sal_Bool bDoesUndo( GetDoc()->DoesUndo() );
 | |
|             GetDoc()->DoUndo( sal_False );
 | |
|             GetDoc()->CopyPageDesc(rOld, aNew);
 | |
|             GetDoc()->DoUndo( bDoesUndo );
 | |
|             aNew.SetLandscape( bNewOri );
 | |
|             SwFrmFmt& rFmt = aNew.GetMaster();
 | |
|             SwFmtFrmSize aSz( rFmt.GetFrmSize() );
 | |
|             // Groesse anpassen.
 | |
|             // PORTRAIT  -> Hoeher als Breit
 | |
|             // LANDSCAPE -> Breiter als Hoch
 | |
|             // Hoehe ist die VarSize, Breite ist die FixSize (per Def.)
 | |
|             if( bNewOri ? aSz.GetHeight() > aSz.GetWidth()
 | |
|                         : aSz.GetHeight() < aSz.GetWidth() )
 | |
|             {
 | |
|                 SwTwips aTmp = aSz.GetHeight();
 | |
|                 aSz.SetHeight( aSz.GetWidth() );
 | |
|                 aSz.SetWidth( aTmp );
 | |
|                 rFmt.SetAttr( aSz );
 | |
|             }
 | |
|             GetDoc()->ChgPageDesc( i, aNew );
 | |
|         }
 | |
|     }
 | |
| }
 | |
| 
 | |
| /******************************************************************************
 | |
|  *  Methode     :   void ViewShell::ChgAllPageOrientation
 | |
|  *  Erstellt    :   MA 08. Aug. 95
 | |
|  *  Aenderung   :
 | |
|  ******************************************************************************/
 | |
| 
 | |
| 
 | |
| void ViewShell::ChgAllPageSize( Size &rSz )
 | |
| {
 | |
|     ASSERT( nStartAction, "missing an Action" );
 | |
|     SET_CURR_SHELL( this );
 | |
| 
 | |
|     SwDoc* pMyDoc = GetDoc();
 | |
|     USHORT nAll = pMyDoc->GetPageDescCnt();
 | |
| 
 | |
|     for( USHORT i = 0; i < nAll; ++i )
 | |
|     {
 | |
|         const SwPageDesc &rOld = const_cast<const SwDoc *>(pMyDoc)->GetPageDesc( i );
 | |
|         SwPageDesc aNew( rOld );
 | |
|         const sal_Bool bDoesUndo( GetDoc()->DoesUndo() );
 | |
|         GetDoc()->DoUndo( sal_False );
 | |
|         GetDoc()->CopyPageDesc( rOld, aNew );
 | |
|         GetDoc()->DoUndo( bDoesUndo );
 | |
|         SwFrmFmt& rPgFmt = aNew.GetMaster();
 | |
|         Size aSz( rSz );
 | |
|         const BOOL bOri = aNew.GetLandscape();
 | |
|         if( bOri  ? aSz.Height() > aSz.Width()
 | |
|                   : aSz.Height() < aSz.Width() )
 | |
|         {
 | |
|             SwTwips aTmp = aSz.Height();
 | |
|             aSz.Height() = aSz.Width();
 | |
|             aSz.Width()  = aTmp;
 | |
|         }
 | |
| 
 | |
|         SwFmtFrmSize aFrmSz( rPgFmt.GetFrmSize() );
 | |
|         aFrmSz.SetSize( aSz );
 | |
|         rPgFmt.SetAttr( aFrmSz );
 | |
|         pMyDoc->ChgPageDesc( i, aNew );
 | |
|     }
 | |
| }
 | |
| 
 | |
| /******************************************************************************
 | |
|  *  Methode     :   void ViewShell::CalcPagesForPrint( short nMax, BOOL ...
 | |
|  *  Beschreibung:
 | |
|  *  Erstellt    :   OK 04.11.94 15:33
 | |
|  *  Aenderung   :   MA 07. Jun. 95
 | |
|  ******************************************************************************/
 | |
| 
 | |
| 
 | |
| 
 | |
| void lcl_SetState( SfxProgress& rProgress, ULONG nPage, ULONG nMax,
 | |
|     const XubString *pStr, ULONG nAct, ULONG nCnt, ULONG nOffs, ULONG nPageNo )
 | |
| {
 | |
|     XubString aTmp = XubString::CreateFromInt64( nPageNo );
 | |
|     if( pStr )
 | |
|     {
 | |
|         aTmp += ' ';
 | |
|         aTmp += *pStr;
 | |
|         if( nCnt )
 | |
|         {
 | |
|             nMax *= 2;
 | |
|             rProgress.SetStateText( (nAct-1)*nMax+nPage+nOffs,
 | |
|                                         aTmp, nCnt*nMax );
 | |
|         }
 | |
|         else
 | |
|             rProgress.SetStateText( nPage, aTmp, nMax );
 | |
|     }
 | |
|     else
 | |
|     {
 | |
|         aTmp += ' '; aTmp += '('; aTmp += XubString::CreateFromInt64( nPage );
 | |
|         aTmp += '/'; aTmp += XubString::CreateFromInt64( nMax ); aTmp += ')';
 | |
|         rProgress.SetStateText( nPage, aTmp, nMax );
 | |
|     }
 | |
| }
 | |
| 
 | |
| 
 | |
| 
 | |
| void ViewShell::CalcPagesForPrint( USHORT nMax, SfxProgress* pProgress,
 | |
|     const XubString* pStr, ULONG nMergeAct, ULONG nMergeCnt )
 | |
| {
 | |
|     SET_CURR_SHELL( this );
 | |
| 
 | |
|     //Seitenweise durchformatieren, by the way kann die Statusleiste
 | |
|     //angetriggert werden, damit der Anwender sieht worauf er wartet.
 | |
|     //Damit der Vorgang moeglichst transparent gestaltet werden kann
 | |
|     //Versuchen wir mal eine Schaetzung.
 | |
|     SfxPrinter* pPrt = getIDocumentDeviceAccess()->getPrinter( false );
 | |
|     BOOL bPrtJob = pPrt ? pPrt->IsJobActive() : FALSE;
 | |
|     SwRootFrm* pLayout = GetLayout();
 | |
|     ULONG nStatMax = pLayout->GetPageNum();
 | |
| 
 | |
|     const SwFrm *pPage = pLayout->Lower();
 | |
|     SwLayAction aAction( pLayout, Imp() );
 | |
| 
 | |
|     if( pProgress )
 | |
|     {
 | |
|         // HACK, damit die Anzeige sich nicht verschluckt.
 | |
|         const XubString aTmp( SW_RES( STR_STATSTR_FORMAT ) );
 | |
|         pProgress->SetText( aTmp );
 | |
|         lcl_SetState( *pProgress, 1, nStatMax, pStr, nMergeAct, nMergeCnt, 0, 1 );
 | |
|         pProgress->Reschedule(); //Mag der Anwender noch oder hat er genug?
 | |
|         aAction.SetProgress(pProgress);
 | |
|     }
 | |
| 
 | |
|     pLayout->StartAllAction();
 | |
|     for ( USHORT i = 1; pPage && i <= nMax; pPage = pPage->GetNext(), ++i )
 | |
|     {
 | |
|         if ( ( bPrtJob && !pPrt->IsJobActive() ) || Imp()->IsStopPrt() )
 | |
|             break;
 | |
| 
 | |
|         if( pProgress )
 | |
|         {
 | |
|             //HACK, damit die Anzeige sich nicht verschluckt.
 | |
|             if ( i > nStatMax ) nStatMax = i;
 | |
|             lcl_SetState( *pProgress, i, nStatMax, pStr, nMergeAct, nMergeCnt, 0, i );
 | |
|             pProgress->Reschedule(); //Mag der Anwender noch oder hat er genug?
 | |
|         }
 | |
| 
 | |
|         if ( ( bPrtJob && !pPrt->IsJobActive() ) || Imp()->IsStopPrt() )
 | |
|             break;
 | |
| 
 | |
|         pPage->Calc();
 | |
|         SwRect aOldVis( VisArea() );
 | |
|         aVisArea = pPage->Frm();
 | |
|         Imp()->SetFirstVisPageInvalid();
 | |
|         aAction.Reset();
 | |
|         aAction.SetPaint( FALSE );
 | |
|         aAction.SetWaitAllowed( FALSE );
 | |
|         aAction.SetReschedule( TRUE );
 | |
| 
 | |
|         aAction.Action();
 | |
| 
 | |
|         aVisArea = aOldVis;             //Zuruecksetzen wg. der Paints!
 | |
|         Imp()->SetFirstVisPageInvalid();
 | |
|         SwPaintQueue::Repaint();
 | |
| 
 | |
|         if ( pProgress )
 | |
|             pProgress->Reschedule(); //Mag der Anwender noch oder hat er genug?
 | |
|     }
 | |
| 
 | |
|     if (pProgress)
 | |
|         aAction.SetProgress( NULL );
 | |
| 
 | |
|     pLayout->EndAllAction();
 | |
| }
 | |
| 
 | |
| /******************************************************************************/
 | |
| 
 | |
| SwDoc * ViewShell::CreatePrtDoc( SfxPrinter* pPrt, SfxObjectShellRef &rDocShellRef)
 | |
| {
 | |
|     ASSERT( this->IsA( TYPE(SwFEShell) ),"ViewShell::Prt for FEShell only");
 | |
|     SwFEShell* pFESh = (SwFEShell*)this;
 | |
|     // Wir bauen uns ein neues Dokument
 | |
|     SwDoc *pPrtDoc = new SwDoc;
 | |
|     pPrtDoc->acquire();
 | |
|     pPrtDoc->SetRefForDocShell( (SfxObjectShellRef*)&(long&)rDocShellRef );
 | |
|     pPrtDoc->LockExpFlds();
 | |
| 
 | |
|     // Der Drucker wird uebernommen
 | |
|     if (pPrt)
 | |
|         pPrtDoc->setPrinter( pPrt, true, true );
 | |
| 
 | |
|     const SfxPoolItem* pCpyItem;
 | |
|     const SfxItemPool& rPool = GetAttrPool();
 | |
|     for( USHORT nWh = POOLATTR_BEGIN; nWh < POOLATTR_END; ++nWh )
 | |
|         if( 0 != ( pCpyItem = rPool.GetPoolDefaultItem( nWh ) ) )
 | |
|             pPrtDoc->GetAttrPool().SetPoolDefaultItem( *pCpyItem );
 | |
| 
 | |
|     // JP 29.07.99 - Bug 67951 - set all Styles from the SourceDoc into
 | |
|     //                              the PrintDoc - will be replaced!
 | |
|     pPrtDoc->ReplaceStyles( *GetDoc() );
 | |
| 
 | |
|     SwShellCrsr *pActCrsr = pFESh->_GetCrsr();
 | |
|     SwShellCrsr *pFirstCrsr = (SwShellCrsr*)*((SwCursor*)pActCrsr->GetNext());
 | |
|     if( !pActCrsr->HasMark() ) // bei Multiselektion kann der aktuelle Cursor leer sein
 | |
|         pActCrsr = (SwShellCrsr*)*((SwCursor*)pActCrsr->GetPrev());
 | |
| 
 | |
|     // Die Y-Position der ersten Selektion
 | |
|     const Point aSelPoint = pFESh->IsTableMode() ?
 | |
|                             pFESh->GetTableCrsr()->GetSttPos() :
 | |
|                             pFirstCrsr->GetSttPos();
 | |
| 
 | |
|     const SwPageFrm* pPage = GetLayout()->GetPageAtPos( aSelPoint );
 | |
| 
 | |
|     // und ihren Seitendescribtor
 | |
|     const SwPageDesc* pPageDesc = pPrtDoc->FindPageDescByName(
 | |
|                                         pPage->GetPageDesc()->GetName() );
 | |
| 
 | |
|     if( !pFESh->IsTableMode() && pActCrsr->HasMark() )
 | |
|     {   // Am letzten Absatz die Absatzattribute richten:
 | |
|         SwNodeIndex aNodeIdx( *pPrtDoc->GetNodes().GetEndOfContent().StartOfSectionNode() );
 | |
|         SwTxtNode* pTxtNd = pPrtDoc->GetNodes().GoNext( &aNodeIdx )->GetTxtNode();
 | |
|         SwCntntNode *pLastNd =
 | |
|             pActCrsr->GetCntntNode( (*pActCrsr->GetMark()) <= (*pActCrsr->GetPoint()) );
 | |
|         // Hier werden die Absatzattribute des ersten Absatzes uebertragen
 | |
|         if( pLastNd && pLastNd->IsTxtNode() )
 | |
|             ((SwTxtNode*)pLastNd)->CopyCollFmt( *pTxtNd );
 | |
|     }
 | |
| 
 | |
|     // es wurde in der CORE eine neu angelegt (OLE-Objekte kopiert!)
 | |
| //      if( aDocShellRef.Is() )
 | |
| //          SwDataExchange::InitOle( aDocShellRef, pPrtDoc );
 | |
|     // und fuellen es mit dem selektierten Bereich
 | |
|     pFESh->Copy( pPrtDoc );
 | |
| 
 | |
|     //Jetzt noch am ersten Absatz die Seitenvorlage setzen
 | |
|     {
 | |
|         SwNodeIndex aNodeIdx( *pPrtDoc->GetNodes().GetEndOfContent().StartOfSectionNode() );
 | |
|         SwCntntNode* pCNd = pPrtDoc->GetNodes().GoNext( &aNodeIdx ); // gehe zum 1. ContentNode
 | |
|         if( pFESh->IsTableMode() )
 | |
|         {
 | |
|             SwTableNode* pTNd = pCNd->FindTableNode();
 | |
|             if( pTNd )
 | |
|                 pTNd->GetTable().GetFrmFmt()->SetAttr( SwFmtPageDesc( pPageDesc ) );
 | |
|         }
 | |
|         else
 | |
|         {
 | |
|             pCNd->SetAttr( SwFmtPageDesc( pPageDesc ) );
 | |
|             if( pFirstCrsr->HasMark() )
 | |
|             {
 | |
|                 SwTxtNode *pTxtNd = pCNd->GetTxtNode();
 | |
|                 if( pTxtNd )
 | |
|                 {
 | |
|                     SwCntntNode *pFirstNd =
 | |
|                         pFirstCrsr->GetCntntNode( (*pFirstCrsr->GetMark()) > (*pFirstCrsr->GetPoint()) );
 | |
|                     // Hier werden die Absatzattribute des ersten Absatzes uebertragen
 | |
|                     if( pFirstNd && pFirstNd->IsTxtNode() )
 | |
|                         ((SwTxtNode*)pFirstNd)->CopyCollFmt( *pTxtNd );
 | |
|                 }
 | |
|             }
 | |
|         }
 | |
|     }
 | |
|     return pPrtDoc;
 | |
| }
 | |
| SwDoc * ViewShell::FillPrtDoc( SwDoc *pPrtDoc, const SfxPrinter* pPrt)
 | |
| {
 | |
|     ASSERT( this->IsA( TYPE(SwFEShell) ),"ViewShell::Prt for FEShell only");
 | |
|     SwFEShell* pFESh = (SwFEShell*)this;
 | |
|     // Wir bauen uns ein neues Dokument
 | |
| //    SwDoc *pPrtDoc = new SwDoc;
 | |
| //    pPrtDoc->acquire();
 | |
| //    pPrtDoc->SetRefForDocShell( (SvEmbeddedObjectRef*)&(long&)rDocShellRef );
 | |
|     pPrtDoc->LockExpFlds();
 | |
| 
 | |
|     // Der Drucker wird uebernommen
 | |
|     //! Make a copy of it since it gets destroyed with the temporary document
 | |
|     //! used for PDF export
 | |
|     if (pPrt)
 | |
|         pPrtDoc->setPrinter( new SfxPrinter(*pPrt), true, true );
 | |
| 
 | |
|     const SfxPoolItem* pCpyItem;
 | |
|     const SfxItemPool& rPool = GetAttrPool();
 | |
|     for( USHORT nWh = POOLATTR_BEGIN; nWh < POOLATTR_END; ++nWh )
 | |
|         if( 0 != ( pCpyItem = rPool.GetPoolDefaultItem( nWh ) ) )
 | |
|             pPrtDoc->GetAttrPool().SetPoolDefaultItem( *pCpyItem );
 | |
| 
 | |
|     // JP 29.07.99 - Bug 67951 - set all Styles from the SourceDoc into
 | |
|     //                              the PrintDoc - will be replaced!
 | |
|     pPrtDoc->ReplaceStyles( *GetDoc() );
 | |
| 
 | |
|     SwShellCrsr *pActCrsr = pFESh->_GetCrsr();
 | |
|     SwShellCrsr *pFirstCrsr = (SwShellCrsr*)*((SwCursor*)pActCrsr->GetNext());
 | |
|     if( !pActCrsr->HasMark() ) // bei Multiselektion kann der aktuelle Cursor leer sein
 | |
|         pActCrsr = (SwShellCrsr*)*((SwCursor*)pActCrsr->GetPrev());
 | |
| 
 | |
|     // Die Y-Position der ersten Selektion
 | |
|     // Die Y-Position der ersten Selektion
 | |
|     const Point aSelPoint = pFESh->IsTableMode() ?
 | |
|                             pFESh->GetTableCrsr()->GetSttPos() :
 | |
|                             pFirstCrsr->GetSttPos();
 | |
| 
 | |
|     const SwPageFrm* pPage = GetLayout()->GetPageAtPos( aSelPoint );
 | |
| 
 | |
|     // und ihren Seitendescribtor
 | |
|     const SwPageDesc* pPageDesc = pPrtDoc->FindPageDescByName(
 | |
|                                 pPage->GetPageDesc()->GetName() );
 | |
| 
 | |
|     if( !pFESh->IsTableMode() && pActCrsr->HasMark() )
 | |
|     {   // Am letzten Absatz die Absatzattribute richten:
 | |
|         SwNodeIndex aNodeIdx( *pPrtDoc->GetNodes().GetEndOfContent().StartOfSectionNode() );
 | |
|         SwTxtNode* pTxtNd = pPrtDoc->GetNodes().GoNext( &aNodeIdx )->GetTxtNode();
 | |
|         SwCntntNode *pLastNd =
 | |
|             pActCrsr->GetCntntNode( (*pActCrsr->GetMark()) <= (*pActCrsr->GetPoint()) );
 | |
|         // Hier werden die Absatzattribute des ersten Absatzes uebertragen
 | |
|         if( pLastNd && pLastNd->IsTxtNode() )
 | |
|             ((SwTxtNode*)pLastNd)->CopyCollFmt( *pTxtNd );
 | |
|     }
 | |
| 
 | |
|     // es wurde in der CORE eine neu angelegt (OLE-Objekte kopiert!)
 | |
| //      if( aDocShellRef.Is() )
 | |
| //          SwDataExchange::InitOle( aDocShellRef, pPrtDoc );
 | |
|     // und fuellen es mit dem selektierten Bereich
 | |
|     pFESh->Copy( pPrtDoc );
 | |
| 
 | |
|     //Jetzt noch am ersten Absatz die Seitenvorlage setzen
 | |
|     {
 | |
|         SwNodeIndex aNodeIdx( *pPrtDoc->GetNodes().GetEndOfContent().StartOfSectionNode() );
 | |
|         SwCntntNode* pCNd = pPrtDoc->GetNodes().GoNext( &aNodeIdx ); // gehe zum 1. ContentNode
 | |
|         if( pFESh->IsTableMode() )
 | |
|         {
 | |
|             SwTableNode* pTNd = pCNd->FindTableNode();
 | |
|             if( pTNd )
 | |
|                 pTNd->GetTable().GetFrmFmt()->SetAttr( SwFmtPageDesc( pPageDesc ) );
 | |
|         }
 | |
|         else
 | |
|         {
 | |
|             pCNd->SetAttr( SwFmtPageDesc( pPageDesc ) );
 | |
|             if( pFirstCrsr->HasMark() )
 | |
|             {
 | |
|                 SwTxtNode *pTxtNd = pCNd->GetTxtNode();
 | |
|                 if( pTxtNd )
 | |
|                 {
 | |
|                     SwCntntNode *pFirstNd =
 | |
|                         pFirstCrsr->GetCntntNode( (*pFirstCrsr->GetMark()) > (*pFirstCrsr->GetPoint()) );
 | |
|                     // Hier werden die Absatzattribute des ersten Absatzes uebertragen
 | |
|                     if( pFirstNd && pFirstNd->IsTxtNode() )
 | |
|                         ((SwTxtNode*)pFirstNd)->CopyCollFmt( *pTxtNd );
 | |
|                 }
 | |
|             }
 | |
|         }
 | |
|     }
 | |
|     return pPrtDoc;
 | |
| }
 | |
| 
 | |
| /******************************************************************************
 | |
|  *  Methode     :   void ViewShell::Prt( const SwPrtOptions& rOptions,
 | |
|  *                                       SfxProgress* pProgress,
 | |
|  *                                       OutputDevice* pPDFOut )
 | |
|  *  Beschreibung:
 | |
|  *  Erstellt    :   OK 04.11.94 15:33
 | |
|  *  Aenderung   :   MA 10. May. 95
 | |
|  ******************************************************************************/
 | |
| 
 | |
| 
 | |
| BOOL ViewShell::Prt( SwPrtOptions& rOptions, SfxProgress* pProgress,
 | |
|                      OutputDevice* pPDFOut )
 | |
| {
 | |
| //!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
 | |
| //Immer die Druckroutine in viewpg.cxx (fuer Seitenvorschau) mitpflegen!!
 | |
| //!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
 | |
|     ASSERT( pPDFOut || pProgress, "Printing without progress bar!" )
 | |
| 
 | |
|     BOOL bStartJob = FALSE;
 | |
| 
 | |
|     //! Note: Since for PDF export of (multi-)selection a temporary
 | |
|     //! document is created that contains only the selects parts,
 | |
|     //! and thus that document is to printed in whole the,
 | |
|     //! rOptions.bPrintSelection parameter will be false.
 | |
|     BOOL bSelection = rOptions.bPrintSelection;
 | |
| 
 | |
|     MultiSelection aMulti( rOptions.aMulti );
 | |
| 
 | |
|     if ( !aMulti.GetSelectCount() )
 | |
|         return bStartJob;
 | |
| 
 | |
|     Range aPages( aMulti.FirstSelected(), aMulti.LastSelected() );
 | |
|     if ( aPages.Max() > USHRT_MAX )
 | |
|         aPages.Max() = USHRT_MAX;
 | |
| 
 | |
|     ASSERT( aPages.Min() > 0,
 | |
|             "Seite 0 Drucken?" );
 | |
|     ASSERT( aPages.Min() <= aPages.Max(),
 | |
|             "MinSeite groesser MaxSeite." );
 | |
| 
 | |
|     SfxPrinter* pPrt = 0;   //!! will be 0 for PDF export !!
 | |
|     if (pPDFOut)
 | |
|         pPDFOut->Push();
 | |
|     else
 | |
|     {
 | |
|         // wenn kein Drucker vorhanden ist, wird nicht gedruckt
 | |
|         pPrt = getIDocumentDeviceAccess()->getPrinter( false );
 | |
|         if( !pPrt || !pPrt->GetName().Len() )
 | |
|         {
 | |
|             ASSERT( FALSE, "Drucken ohne Drucker?" );
 | |
|             return bStartJob;
 | |
|         }
 | |
| 
 | |
|         if( !rOptions.GetJobName().Len() && !pPrt->IsJobActive() )
 | |
|             return bStartJob;
 | |
|     }
 | |
| 
 | |
|     // Einstellungen am Drucker merken
 | |
|     SwPrtOptSave aPrtSave( pPrt );
 | |
| 
 | |
|     OutputDevice *pPrtOrPDFOut = pPDFOut ? pPDFOut : (OutputDevice *) pPrt;
 | |
| 
 | |
|     // eine neue Shell fuer den Printer erzeugen
 | |
|     ViewShell *pShell;
 | |
|     SwDoc *pPrtDoc;
 | |
| 
 | |
|     //!! muss warum auch immer hier in diesem scope existieren !!
 | |
|     //!! (h?ngt mit OLE Objekten im Dokument zusammen.)
 | |
|     SfxObjectShellRef aDocShellRef;
 | |
| 
 | |
|     // PDF export for (multi-)selection has already generated a temporary document
 | |
|     // with the selected text. (see XRenderable implementation in unotxdoc.cxx)
 | |
|     // Thus we like to go in the 'else' part here in that case.
 | |
|     // Is is implemented this way because PDF export calls this Prt function
 | |
|     // once per page and we do not like to always have the temporary document
 | |
|     // to be created that often here in the 'then' part.
 | |
|     if ( bSelection )
 | |
|     {
 | |
|         pPrtDoc = CreatePrtDoc( pPrt, aDocShellRef );
 | |
| 
 | |
|         // eine ViewShell darauf
 | |
|         OutputDevice *pTmpDev = pPDFOut ? pPDFOut : 0;
 | |
|         pShell = new ViewShell( *pPrtDoc, 0, pOpt, pTmpDev );
 | |
|         pPrtDoc->SetRefForDocShell( 0 );
 | |
|     }
 | |
|     else
 | |
|     {
 | |
|         pPrtDoc = GetDoc();
 | |
|         OutputDevice *pTmpDev = pPDFOut ? pPDFOut : 0;
 | |
|         pShell = new ViewShell( *this, 0, pTmpDev );
 | |
|     }
 | |
| 
 | |
|     {   //Zusaetzlicher Scope, damit die CurrShell vor dem zerstoeren der
 | |
|         //Shell zurueckgesetzt wird.
 | |
| 
 | |
|     SET_CURR_SHELL( pShell );
 | |
| 
 | |
|     if ( pProgress )
 | |
|     {
 | |
|         Link aLnk = LINK(pShell->Imp(), SwViewImp, SetStopPrt);
 | |
|         ((SfxPrintProgress *)pProgress)->SetCancelHdl(aLnk);
 | |
|     }
 | |
| 
 | |
|     //JP 01.02.99: das ReadOnly Flag wird NIE mitkopiert; Bug 61335
 | |
|     if( pOpt->IsReadonly() )
 | |
|         pShell->pOpt->SetReadonly( TRUE );
 | |
| 
 | |
|     // save options at draw view:
 | |
|     SwDrawViewSave aDrawViewSave( pShell->GetDrawView() );
 | |
| 
 | |
|     pShell->PrepareForPrint( rOptions );
 | |
| 
 | |
|     XubString* pStr = 0;
 | |
|     ULONG nMergeAct = rOptions.nMergeAct, nMergeCnt = rOptions.nMergeCnt;
 | |
|     if ( pProgress )
 | |
|     {
 | |
|         if( nMergeAct )
 | |
|         {
 | |
|             pStr = new SW_RESSTR(STR_STATSTR_LETTER);
 | |
|             *pStr += ' ';
 | |
|             *pStr += XubString::CreateFromInt64( nMergeAct );
 | |
|             if( nMergeCnt )
 | |
|             {
 | |
|                 *pStr += '/';
 | |
|                 *pStr += XubString::CreateFromInt64( nMergeCnt );
 | |
|             }
 | |
|         }
 | |
|         else
 | |
|         {
 | |
|             ++nMergeAct;
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     // Seiten fuers Drucken formatieren
 | |
|     pShell->CalcPagesForPrint( (USHORT)aPages.Max(), pProgress, pStr,
 | |
|                                 nMergeAct, nMergeCnt );
 | |
| 
 | |
|     // Some field types, can require a valid layout
 | |
|     // (expression fields in tables). For these we do an UpdateFlds
 | |
|     // here after calculation of the pages.
 | |
|     // --> FME 2004-06-21 #i9684# For performance reasons, we do not update
 | |
|     //                            the fields during pdf export.
 | |
|     // #i56195# prevent update of fields (for mail merge)
 | |
|     if ( !pPDFOut && rOptions.bUpdateFieldsInPrinting )
 | |
|     // <--
 | |
|         pShell->UpdateFlds(TRUE);
 | |
| 
 | |
|     if( !pShell->Imp()->IsStopPrt() &&
 | |
|         ( pPDFOut || rOptions.GetJobName().Len() || pPrt->IsJobActive()) )
 | |
|     {
 | |
|         BOOL bStop = FALSE;
 | |
|         int nJobStartError = JOBSET_ERR_DEFAULT;
 | |
| 
 | |
|         USHORT nCopyCnt = rOptions.bCollate ? rOptions.nCopyCount : 1;
 | |
| 
 | |
|         USHORT nPrintCount = 1;
 | |
|         XubString sJobName( rOptions.GetJobName() );
 | |
| 
 | |
|         for ( USHORT nCnt = 0; !bStop && nCnt < nCopyCnt; nCnt++ )
 | |
|         {
 | |
|             const SwPageFrm *pStPage  = (SwPageFrm*)pShell->GetLayout()->Lower();
 | |
|             const SwFrm     *pEndPage = pStPage;
 | |
| 
 | |
|             USHORT nFirstPageNo = 0;
 | |
|             USHORT nLastPageNo  = 0;
 | |
|             USHORT nPageNo      = 1;
 | |
| 
 | |
|             if (pPrt)
 | |
|             {
 | |
|                 if( rOptions.IsPrintSingleJobs() && sJobName.Len() &&
 | |
|                     ( bStartJob || rOptions.bJobStartet ) )
 | |
|                 {
 | |
|                     pPrt->EndJob();
 | |
|                     bStartJob = FALSE;
 | |
|                     rOptions.bJobStartet = TRUE;
 | |
| 
 | |
|                     // Reschedule statt Yield, da Yield keine Events abarbeitet
 | |
|                     // und es sonst eine Endlosschleife gibt.
 | |
|                     while( pPrt->IsPrinting() && pProgress )
 | |
|                             pProgress->Reschedule();
 | |
| 
 | |
|                     sJobName = rOptions.MakeNextJobName();
 | |
|                     nJobStartError = JOBSET_ERR_DEFAULT;
 | |
|                 }
 | |
|             }
 | |
| 
 | |
|             for( USHORT i = 1; i <= (USHORT)aPages.Max(); ++i )
 | |
|             {
 | |
|                 if( i < (USHORT)aPages.Min() )
 | |
|                 {
 | |
|                     if( !pStPage->GetNext() )
 | |
|                         break;
 | |
|                     pStPage = (SwPageFrm*)pStPage->GetNext();
 | |
|                     pEndPage= pStPage;
 | |
|                 }
 | |
|                 else if( i == (USHORT)aPages.Min() )
 | |
|                 {
 | |
|                     nFirstPageNo = i;
 | |
|                     nLastPageNo = nFirstPageNo;
 | |
|                     if( !pStPage->GetNext() || (i == (USHORT)aPages.Max()) )
 | |
|                         break;
 | |
|                     pEndPage = pStPage->GetNext();
 | |
|                 }
 | |
|                 else if( i > (USHORT)aPages.Min() )
 | |
|                 {
 | |
|                     nLastPageNo = i;
 | |
|                     if( !pEndPage->GetNext() || (i == (USHORT)aPages.Max()) )
 | |
|                         break;
 | |
|                     pEndPage = pEndPage->GetNext();
 | |
|                 }
 | |
|             }
 | |
| 
 | |
|             if( !nFirstPageNo )
 | |
|             {
 | |
|                 bStop = TRUE;
 | |
|                 break;
 | |
|             }
 | |
| 
 | |
| // HACK: Hier muss von der MultiSelection noch eine akzeptable Moeglichkeit
 | |
| // geschaffen werden, alle Seiten von Seite x an zu deselektieren.
 | |
| // Z.B. durch SetTotalRange ....
 | |
| 
 | |
| //          aMulti.Select( Range( nLastPageNo+1, SELECTION_MAX ), FALSE );
 | |
|             MultiSelection aTmpMulti( Range( 1, nLastPageNo ) );
 | |
|             long nTmpIdx = aMulti.FirstSelected();
 | |
|             static long nEndOfSelection = SFX_ENDOFSELECTION;
 | |
|             while ( nEndOfSelection != nTmpIdx && nTmpIdx <= long(nLastPageNo) )
 | |
|             {
 | |
|                 aTmpMulti.Select( nTmpIdx );
 | |
|                 nTmpIdx = aMulti.NextSelected();
 | |
|             }
 | |
|             aMulti = aTmpMulti;
 | |
| // Ende des HACKs
 | |
| 
 | |
|             const USHORT nSelCount = USHORT(aMulti.GetSelectCount()
 | |
|                             /* * nCopyCnt*/);
 | |
| 
 | |
|             if ( pProgress )
 | |
|             {
 | |
|                 pProgress->SetText( SW_RESSTR(STR_STATSTR_PRINT) );
 | |
|                 lcl_SetState( *pProgress, 1, nSelCount, pStr,
 | |
|                               nMergeAct, nMergeCnt, nSelCount, 1 );
 | |
|             }
 | |
| 
 | |
|             if ( rOptions.bPrintReverse )
 | |
|             {
 | |
|                 const SwFrm *pTmp = pStPage;
 | |
|                 pStPage  = (SwPageFrm*)pEndPage;
 | |
|                 pEndPage = pTmp;
 | |
|                 nPageNo  = nLastPageNo;
 | |
|             }
 | |
|             else
 | |
|                 nPageNo = nFirstPageNo;
 | |
| 
 | |
|             // PostitListe holen
 | |
|             _SetGetExpFlds aPostItFields;
 | |
|             SwDoc*     pPostItDoc   = 0;
 | |
|             ViewShell* pPostItShell = 0;
 | |
|             if( rOptions.nPrintPostIts != POSTITS_NONE )
 | |
|             {
 | |
|                 lcl_GetPostIts( pDoc, aPostItFields );
 | |
|                 pPostItDoc   = new SwDoc;
 | |
|                 if (pPrt)
 | |
|                     pPostItDoc->setPrinter( pPrt, true, true );
 | |
|                 pPostItShell = new ViewShell( *pPostItDoc, 0,
 | |
|                                                pShell->GetViewOptions() );
 | |
|                 // Wenn PostIts am Dokumentenende gedruckt werden sollen,
 | |
|                 // die Druckreihenfolge allerdings umgekehrt ist, dann hier
 | |
|                 if ( ( rOptions.nPrintPostIts == POSTITS_ENDDOC ) &&
 | |
|                         rOptions.bPrintReverse )
 | |
|                         lcl_PrintPostItsEndDoc( pPostItShell, aPostItFields,
 | |
|                         aMulti, sJobName, bStartJob, nJobStartError,
 | |
|                         rOptions.bPrintRightPage, rOptions.bPrintLeftPage, TRUE );
 | |
| 
 | |
|             }
 | |
| 
 | |
|             // aOldMapMode wird fuer das Drucken von Umschlaegen gebraucht.
 | |
|             MapMode aOldMapMode;
 | |
| 
 | |
|             const SwPageDesc *pLastPageDesc = NULL;
 | |
|             BOOL bSetOrient   = FALSE;
 | |
|             BOOL bSetPaperSz  = FALSE;
 | |
|             BOOL bSetPaperBin = FALSE;
 | |
|             BOOL bSetPrt      = FALSE;
 | |
|             if (pPrt)
 | |
|             {
 | |
|                 bSetOrient      = pPrt->HasSupport( SUPPORT_SET_ORIENTATION );
 | |
|                 bSetPaperSz     = pPrt->HasSupport( SUPPORT_SET_PAPERSIZE );
 | |
|                 bSetPaperBin    =  !rOptions.bPaperFromSetup &&
 | |
|                                     pPrt->HasSupport( SUPPORT_SET_PAPERBIN );
 | |
|                 bSetPrt = bSetOrient || bSetPaperSz || bSetPaperBin;
 | |
|             }
 | |
| 
 | |
|             if ( rOptions.nPrintPostIts != POSTITS_ONLY )
 | |
|             {
 | |
|                 // --> FME 2005-01-05 #110536# This valiable is used to track
 | |
|                 // the number of pages which actually have been printed.
 | |
|                 // If nPagesPrinted is odd, we have to send an additional
 | |
|                 // empty page to the printer if we are currently in collation
 | |
|                 // and duplex mode and there are still some more copies of the
 | |
|                 // document to print.
 | |
|                 USHORT nPagesPrinted = 0;
 | |
|                 // <--
 | |
| 
 | |
|                 while( pStPage && !bStop )
 | |
|                 {
 | |
|                     // Mag der Anwender noch ?
 | |
|                     if ( pProgress )
 | |
|                         pProgress->Reschedule();
 | |
| 
 | |
|                     if (pPrt)
 | |
|                     {
 | |
|                         if (    JOBSET_ERR_ERROR == nJobStartError ||
 | |
|                              ( !pPrt->IsJobActive() && ( !sJobName.Len() || bStartJob ) ) ||
 | |
|                                 pShell->Imp()->IsStopPrt() )
 | |
|                         {
 | |
|                             bStop = TRUE;
 | |
|                             break;
 | |
|                         }
 | |
|                     }
 | |
| 
 | |
|                     ::SetSwVisArea( pShell, pStPage->Frm(), 0 != pPDFOut );
 | |
| 
 | |
|                     //  wenn wir einen Umschlag drucken wird ein Offset beachtet
 | |
|                     if( pStPage->GetFmt()->GetPoolFmtId() == RES_POOLPAGE_JAKET )
 | |
|                     {
 | |
|                         aOldMapMode = pPrtOrPDFOut->GetMapMode();
 | |
|                         Point aNewOrigin = pPrtOrPDFOut->GetMapMode().GetOrigin();
 | |
|                         aNewOrigin += rOptions.aOffset;
 | |
|                         MapMode aTmp( pPrtOrPDFOut->GetMapMode() );
 | |
|                         aTmp.SetOrigin( aNewOrigin );
 | |
|                         pPrtOrPDFOut->SetMapMode( aTmp );
 | |
|                     }
 | |
| 
 | |
|                     const BOOL bRightPg = pStPage->OnRightPage();
 | |
|                     if( aMulti.IsSelected( nPageNo ) &&
 | |
|                         ( (bRightPg && rOptions.bPrintRightPage) ||
 | |
|                             (!bRightPg && rOptions.bPrintLeftPage) ) )
 | |
|                     {
 | |
|                         if ( bSetPrt )
 | |
|                         {
 | |
|                             // check for empty page
 | |
|                             const SwPageFrm& rFormatPage = pStPage->GetFormatPage();
 | |
| 
 | |
|                             if ( pLastPageDesc != rFormatPage.GetPageDesc() )
 | |
|                             {
 | |
|                                 pLastPageDesc = rFormatPage.GetPageDesc();
 | |
| 
 | |
|                                 const BOOL bLandScp = rFormatPage.GetPageDesc()->GetLandscape();
 | |
| 
 | |
|                                 if( bSetPaperBin )      // Schacht einstellen.
 | |
|                                     pPrt->SetPaperBin( rFormatPage.GetFmt()->
 | |
|                                                        GetPaperBin().GetValue() );
 | |
| 
 | |
|                                 if (bSetOrient )
 | |
|                                  {
 | |
|                                         // Orientation einstellen: Breiter als Hoch
 | |
|                                         //  -> Landscape, sonst -> Portrait.
 | |
|                                         if( bLandScp )
 | |
|                                             pPrt->SetOrientation(ORIENTATION_LANDSCAPE);
 | |
|                                         else
 | |
|                                             pPrt->SetOrientation(ORIENTATION_PORTRAIT);
 | |
|                                  }
 | |
| 
 | |
|                                  if (bSetPaperSz )
 | |
|                                  {
 | |
|                                     Size aSize = pStPage->Frm().SSize();
 | |
|                                     if ( bLandScp && bSetOrient )
 | |
|                                     {
 | |
|                                             // landscape is always interpreted as a rotation by 90 degrees !
 | |
|                                             // this leads to non WYSIWIG but at least it prints!
 | |
|                                             // #i21775#
 | |
|                                             long nWidth = aSize.Width();
 | |
|                                             aSize.Width() = aSize.Height();
 | |
|                                             aSize.Height() = nWidth;
 | |
|                                     }
 | |
|                                     Paper ePaper = SvxPaperInfo::GetSvPaper(aSize,MAP_TWIP,TRUE);
 | |
|                                     if ( PAPER_USER == ePaper )
 | |
|                                             pPrt->SetPaperSizeUser( aSize );
 | |
|                                     else
 | |
|                                             pPrt->SetPaper( ePaper );
 | |
|                                  }
 | |
|                             }
 | |
|                         }
 | |
| 
 | |
|                         // Wenn PostIts nach Seite gedruckt werden sollen,
 | |
|                         // jedoch Reverse eingestellt ist ...
 | |
|                         if( rOptions.bPrintReverse &&
 | |
|                             rOptions.nPrintPostIts == POSTITS_ENDPAGE )
 | |
|                                 lcl_PrintPostItsEndPage( pPostItShell, aPostItFields,
 | |
|                                     nPageNo, aMulti, sJobName, bStartJob, nJobStartError,
 | |
|                                     rOptions.bPrintRightPage, rOptions.bPrintLeftPage,
 | |
|                                     rOptions.bPrintReverse );
 | |
| 
 | |
|                         if ( pProgress )
 | |
|                             lcl_SetState( *pProgress, nPrintCount++, nSelCount,
 | |
|                                           pStr, nMergeAct, nMergeCnt,
 | |
|                                           nSelCount, nPageNo );
 | |
| 
 | |
|                         if( !bStartJob && JOBSET_ERR_DEFAULT == nJobStartError
 | |
|                             && sJobName.Len() )
 | |
|                         {
 | |
|                             if( pPrt && !pPrt->IsJobActive() )
 | |
|                             {
 | |
|                                 bStartJob = pPrt->StartJob( sJobName );
 | |
|                                 if( !bStartJob )
 | |
|                                 {
 | |
|                                     nJobStartError = JOBSET_ERR_ERROR;
 | |
|                                     continue;
 | |
|                                 }
 | |
|                             }
 | |
| 
 | |
|                             pShell->InitPrt( pPrt, pPDFOut );
 | |
| 
 | |
|                             ::SetSwVisArea( pShell, pStPage->Frm(), 0 != pPDFOut );
 | |
|                             nJobStartError = JOBSET_ERR_ISSTARTET;
 | |
|                         }
 | |
|                         // --> FME 2005-12-12 #b6354161# Feature - Print empty pages
 | |
|                         if ( rOptions.bPrintEmptyPages || pStPage->Frm().Height() )
 | |
|                         // <--
 | |
|                         {
 | |
|                             if (pPrt)
 | |
|                                 pPrt->StartPage();
 | |
| 
 | |
|                             pStPage->GetUpper()->Paint( pStPage->Frm() );
 | |
|                             ++nPagesPrinted;
 | |
| 
 | |
|                             if (pPrt)
 | |
|                                 pPrt->EndPage();
 | |
|                         }
 | |
|                         SwPaintQueue::Repaint();
 | |
| 
 | |
|                         // Wenn PostIts nach Seite gedruckt werden sollen ...
 | |
|                         if( (!rOptions.bPrintReverse) &&
 | |
|                             rOptions.nPrintPostIts == POSTITS_ENDPAGE )
 | |
|                                 lcl_PrintPostItsEndPage( pPostItShell, aPostItFields,
 | |
|                                     nPageNo, aMulti, sJobName, bStartJob, nJobStartError,
 | |
|                                     rOptions.bPrintRightPage, rOptions.bPrintLeftPage,
 | |
|                                     rOptions.bPrintReverse );
 | |
|                     }
 | |
| 
 | |
|                     // den eventl. fuer Umschlaege modifizierte OutDevOffset wieder
 | |
|                     // zuruecksetzen.
 | |
|                     if( pStPage->GetFmt()->GetPoolFmtId() == RES_POOLPAGE_JAKET )
 | |
|                         pPrtOrPDFOut->SetMapMode( aOldMapMode );
 | |
| 
 | |
|                     if ( pStPage == pEndPage )
 | |
|                     {
 | |
|                         // --> FME 2005-01-05 #110536# Print emtpy page if
 | |
|                         // we are have an odd page count in collation/duplex
 | |
|                         // mode and there are still some copies to print:
 | |
|                         if ( pPrt && ( 1 == ( nPagesPrinted % 2 ) ) &&
 | |
|                              DUPLEX_ON == pPrt->GetDuplexMode() &&
 | |
|                              nCnt + 1 < nCopyCnt )
 | |
|                         {
 | |
|                             pPrt->StartPage();
 | |
|                             pPrt->EndPage();
 | |
|                         }
 | |
|                         // <--
 | |
| 
 | |
|                         pStPage = 0;
 | |
|                     }
 | |
|                     else if ( rOptions.bPrintReverse )
 | |
|                     {
 | |
|                         --nPageNo;
 | |
|                         pStPage = (SwPageFrm*)pStPage->GetPrev();
 | |
|                     }
 | |
|                     else
 | |
|                     {   ++nPageNo;
 | |
|                         pStPage = (SwPageFrm*)pStPage->GetNext();
 | |
|                     }
 | |
|                 }
 | |
|                 if ( bStop )
 | |
|                     break;
 | |
|             }
 | |
| 
 | |
|             // Wenn PostIts am Dokumentenende gedruckt werden sollen, dann hier machen
 | |
|             if( ((rOptions.nPrintPostIts == POSTITS_ENDDOC) && !rOptions.bPrintReverse)
 | |
|                 || (rOptions.nPrintPostIts == POSTITS_ONLY) )
 | |
|                     lcl_PrintPostItsEndDoc( pPostItShell, aPostItFields, aMulti,
 | |
|                         sJobName, bStartJob, nJobStartError,
 | |
|                         rOptions.bPrintRightPage, rOptions.bPrintLeftPage,
 | |
|                         rOptions.bPrintReverse );
 | |
| 
 | |
|             if( pPostItShell )
 | |
|             {
 | |
|                 pPostItDoc->setPrinter( 0, false, false );  //damit am echten DOC der Drucker bleibt
 | |
|                 delete pPostItShell;        //Nimmt das PostItDoc mit ins Grab.
 | |
|             }
 | |
| 
 | |
|             if( bStartJob )
 | |
|                 rOptions.bJobStartet = TRUE;
 | |
|         }
 | |
| 
 | |
|     }
 | |
|     delete pStr;
 | |
| 
 | |
|     }  //Zus. Scope wg. CurShell!
 | |
| 
 | |
|     delete pShell;
 | |
| 
 | |
|     if (bSelection )
 | |
|     {
 | |
|          // damit das Dokument nicht den Drucker mit ins Grab nimmt
 | |
|         pPrtDoc->setPrinter( 0, false, false );
 | |
| 
 | |
|         if ( !pPrtDoc->release() )
 | |
|             delete pPrtDoc;
 | |
|     }
 | |
| 
 | |
|     // restore settings of OutputDevicef
 | |
|     if (pPDFOut)
 | |
|         pPDFOut->Pop();
 | |
| 
 | |
|     return bStartJob;
 | |
| }
 | |
| 
 | |
| /******************************************************************************
 | |
|  *  Methode     :   PrtOle2()
 | |
|  *  Beschreibung:
 | |
|  *  Erstellt    :   PK 07.12.94
 | |
|  *  Aenderung   :   MA 16. Feb. 95
 | |
|  ******************************************************************************/
 | |
| 
 | |
| 
 | |
| 
 | |
| void ViewShell::PrtOle2( SwDoc *pDoc, const SwViewOption *pOpt, SwPrtOptions& rOptions,
 | |
|                          OutputDevice* pOleOut, const Rectangle& rRect )
 | |
| {
 | |
|   //Wir brauchen eine Shell fuer das Drucken. Entweder hat das Doc schon
 | |
|     //eine, dann legen wir uns eine neue Sicht an, oder das Doc hat noch
 | |
|     //keine, dann erzeugen wir die erste Sicht.
 | |
|     ViewShell *pSh;
 | |
|     if( pDoc->GetRootFrm() && pDoc->GetRootFrm()->GetCurrShell() )
 | |
|         pSh = new ViewShell( *pDoc->GetRootFrm()->GetCurrShell(), 0, pOleOut );
 | |
|     else
 | |
|         pSh = new ViewShell( *pDoc, 0, pOpt, pOleOut );
 | |
| 
 | |
|     {
 | |
|         SET_CURR_SHELL( pSh );
 | |
|         pSh->PrepareForPrint( rOptions );
 | |
|         pSh->SetPrtFormatOption( TRUE );
 | |
| 
 | |
|         SwRect aSwRect( rRect );
 | |
|         pSh->aVisArea = aSwRect;
 | |
| 
 | |
|         if ( pSh->getIDocumentSettingAccess()->get(IDocumentSettingAccess::BROWSE_MODE) &&
 | |
|              pSh->GetNext() == pSh )
 | |
|         {
 | |
|             pSh->CheckBrowseView( FALSE );
 | |
|             pDoc->GetRootFrm()->Lower()->InvalidateSize();
 | |
|         }
 | |
| 
 | |
|         // --> FME 2005-02-10 #119474#
 | |
|         // CalcPagesForPrint() should not be necessary here. The pages in the
 | |
|         // visible area will be formatted in SwRootFrm::Paint().
 | |
|         // Removing this gives us a performance gain during saving the
 | |
|         // document because the thumbnail creation will not trigger a complete
 | |
|         // formatting of the document.
 | |
|         // Seiten fuers Drucken formatieren
 | |
|         // pSh->CalcPagesForPrint( SHRT_MAX );
 | |
|         // <--
 | |
| 
 | |
|         //#39275# jetzt will der Meyer doch ein Clipping
 | |
|         pOleOut->Push( PUSH_CLIPREGION );
 | |
|         pOleOut->IntersectClipRegion( aSwRect.SVRect() );
 | |
|         pSh->GetLayout()->Paint( aSwRect );
 | |
| //      SFX_APP()->SpoilDemoOutput( *pOleOut, rRect );
 | |
|         pOleOut->Pop();
 | |
| 
 | |
|         // erst muss das CurrShell Object zerstoert werden!!
 | |
|     }
 | |
|     delete pSh;
 | |
| }
 | |
| 
 | |
| /******************************************************************************
 | |
|  *  Methode     :   IsAnyFieldInDoc()
 | |
|  *  Beschreibung:   Stellt fest, ob im DocNodesArray Felder verankert sind
 | |
|  *  Erstellt    :   JP 27.07.95
 | |
|  *  Aenderung   :   JP 10.12.97
 | |
|  ******************************************************************************/
 | |
| 
 | |
| 
 | |
| 
 | |
| BOOL ViewShell::IsAnyFieldInDoc() const
 | |
| {
 | |
|     const SfxPoolItem* pItem;
 | |
|     USHORT nMaxItems = pDoc->GetAttrPool().GetItemCount( RES_TXTATR_FIELD );
 | |
|     for( USHORT n = 0; n < nMaxItems; ++n )
 | |
|         if( 0 != (pItem = pDoc->GetAttrPool().GetItem( RES_TXTATR_FIELD, n )))
 | |
|         {
 | |
|             const SwFmtFld* pFmtFld = (SwFmtFld*)pItem;
 | |
|             const SwTxtFld* pTxtFld = pFmtFld->GetTxtFld();
 | |
|             if( pTxtFld && pTxtFld->GetTxtNode().GetNodes().IsDocNodes() )
 | |
|                 return TRUE;
 | |
|         }
 | |
|     return FALSE;
 | |
| }
 | |
| 
 | |
| 
 | |
| 
 | |
| /******************************************************************************
 | |
|  *  Klasse      :   SwPrtOptSave
 | |
|  *  Erstellt    :   AMA 12.07.95
 | |
|  *  Aenderung   :   AMA 12.07.95
 | |
|  *  Holt sich im Ctor folgende Einstellungen des Druckers, die im Dtor dann
 | |
|  *  wieder im Drucker gesetzt werden (falls sie sich ueberhaupt geaendert haben)
 | |
|  *  - PaperBin - Orientation - PaperSize -
 | |
|  ******************************************************************************/
 | |
| 
 | |
| 
 | |
| 
 | |
| SwPrtOptSave::SwPrtOptSave( Printer *pPrinter )
 | |
|     : pPrt( pPrinter )
 | |
| {
 | |
|     if ( pPrt )
 | |
|     {
 | |
|         ePaper = pPrt->GetPaper();
 | |
|         if ( PAPER_USER == ePaper )
 | |
|             aSize = pPrt->GetPaperSize();
 | |
|         eOrientation = pPrt->GetOrientation();
 | |
|         nPaperBin = pPrt->GetPaperBin();
 | |
| 
 | |
|     }
 | |
| }
 | |
| 
 | |
| 
 | |
| 
 | |
| SwPrtOptSave::~SwPrtOptSave()
 | |
| {
 | |
|     if ( pPrt )
 | |
|     {
 | |
|         if ( PAPER_USER == ePaper )
 | |
|         {
 | |
|             if( pPrt->GetPaperSize() != aSize )
 | |
|                 pPrt->SetPaperSizeUser( aSize );
 | |
|         }
 | |
|         else if ( pPrt->GetPaper() != ePaper )
 | |
|             pPrt->SetPaper( ePaper );
 | |
|         if ( pPrt->GetOrientation() != eOrientation)
 | |
|             pPrt->SetOrientation( eOrientation );
 | |
|         if ( pPrt->GetPaperBin() != nPaperBin )
 | |
|             pPrt->SetPaperBin( nPaperBin );
 | |
|     }
 | |
| }
 | |
| 
 | |
| 
 | |
| /******************************************************************************
 | |
|  *  SwDrawViewSave
 | |
|  *
 | |
|  *  Saves some settings at the draw view
 | |
|  ******************************************************************************/
 | |
| 
 | |
| SwDrawViewSave::SwDrawViewSave( SdrView* pSdrView )
 | |
|     : pDV( pSdrView )
 | |
| {
 | |
|     if ( pDV )
 | |
|     {
 | |
|         sLayerNm.AssignAscii( RTL_CONSTASCII_STRINGPARAM("Controls" ) );
 | |
|         bPrintControls = pDV->IsLayerPrintable( sLayerNm );
 | |
|     }
 | |
| }
 | |
| 
 | |
| SwDrawViewSave::~SwDrawViewSave()
 | |
| {
 | |
|     if ( pDV )
 | |
|     {
 | |
|         pDV->SetLayerPrintable( sLayerNm, bPrintControls );
 | |
|     }
 | |
| }
 | |
| 
 | |
| 
 | |
| // OD 09.01.2003 #i6467# - method also called for page preview
 | |
| void ViewShell::PrepareForPrint(  const SwPrtOptions &rOptions )
 | |
| {
 | |
|     // Viewoptions fuer den Drucker setzen
 | |
|     pOpt->SetGraphic ( TRUE == rOptions.bPrintGraphic );
 | |
|     pOpt->SetTable   ( TRUE == rOptions.bPrintTable );
 | |
|     pOpt->SetDraw    ( TRUE == rOptions.bPrintDraw  );
 | |
|     pOpt->SetControl ( TRUE == rOptions.bPrintControl );
 | |
|     pOpt->SetPageBack( TRUE == rOptions.bPrintPageBackground );
 | |
|     pOpt->SetBlackFont( TRUE == rOptions.bPrintBlackFont );
 | |
| 
 | |
|     if ( HasDrawView() )
 | |
|     {
 | |
|         SdrView *pDrawView = GetDrawView();
 | |
|         String sLayerNm;
 | |
|         sLayerNm.AssignAscii(RTL_CONSTASCII_STRINGPARAM("Controls" ));
 | |
|         // OD 09.01.2003 #i6467# - consider, if view shell belongs to page preview
 | |
|         if ( !IsPreView() )
 | |
|         {
 | |
|             pDrawView->SetLayerPrintable( sLayerNm, rOptions.bPrintControl );
 | |
|         }
 | |
|         else
 | |
|         {
 | |
|             pDrawView->SetLayerVisible( sLayerNm, rOptions.bPrintControl );
 | |
|         }
 | |
|     }
 | |
| }
 |