diff options
Diffstat (limited to 'sd/source/ui/view/drviewsa.cxx')
-rw-r--r-- | sd/source/ui/view/drviewsa.cxx | 183 |
1 files changed, 57 insertions, 126 deletions
diff --git a/sd/source/ui/view/drviewsa.cxx b/sd/source/ui/view/drviewsa.cxx index 418a54295be0..5075c771d092 100644 --- a/sd/source/ui/view/drviewsa.cxx +++ b/sd/source/ui/view/drviewsa.cxx @@ -2,9 +2,9 @@ * * $RCSfile: drviewsa.cxx,v $ * - * $Revision: 1.24 $ + * $Revision: 1.25 $ * - * last change: $Author: rt $ $Date: 2004-07-12 15:19:19 $ + * last change: $Author: rt $ $Date: 2004-07-13 14:56:38 $ * * The Contents of this file are made available subject to the terms of * either of the following licenses @@ -59,6 +59,8 @@ * ************************************************************************/ +#include "DrawViewShell.hxx" + #define ITEMID_SIZE 0 #ifndef _CPPUHELPER_IMPLBASE1_HXX_ @@ -150,9 +152,6 @@ #ifndef SD_FU_SELECTION_HXX #include "fusel.hxx" #endif -#ifndef SD_DRAW_VIEW_SHELL_HXX -#include "DrawViewShell.hxx" -#endif #ifndef SD_BEZIER_OBJECT_BAR_HXX #include "BezierObjectBar.hxx" #endif @@ -174,16 +173,20 @@ #ifndef SD_DRAW_VIEW_HXX #include "drawview.hxx" #endif +#include "SdUnoDrawView.hxx" +#ifndef SD_VIEW_SHELL_BASE_HXX +#include "ViewShellBase.hxx" +#endif #ifndef SD_OBJECT_BAR_MANAGER_HXX #include "ObjectBarManager.hxx" #endif #include "SdUnoDrawView.hxx" -#include "FormShellManager.hxx" using namespace ::rtl; using namespace ::com::sun::star; using namespace ::com::sun::star::uno; + namespace sd { BOOL DrawViewShell::bPipette = FALSE; @@ -239,19 +242,12 @@ void SAL_CALL ScannerEventListener::disposing( const ::com::sun::star::lang::Eve DrawViewShell::DrawViewShell ( SfxViewFrame* pFrame, ViewShellBase& rViewShellBase, + ::Window* pParentWindow, PageKind ePageKind, FrameView* pFrameViewArgument) - : ViewShell (pFrame, rViewShellBase), - aTabControl(this, &pFrame->GetWindow()), - aLayerTab(this, &pFrame->GetWindow()), - aPageBtn(&pFrame->GetWindow(), - WB_3DLOOK | WB_RECTSTYLE | WB_SMALLSTYLE | WB_NOPOINTERFOCUS), - aMasterPageBtn(&pFrame->GetWindow(), - WB_3DLOOK | WB_RECTSTYLE | WB_SMALLSTYLE | WB_NOPOINTERFOCUS ), - aLayerBtn(&pFrame->GetWindow(), - WB_3DLOOK | WB_RECTSTYLE | WB_SMALLSTYLE | WB_NOPOINTERFOCUS ), + : ViewShell (pFrame, pParentWindow, rViewShellBase), + aTabControl(this, pParentWindow), pActualPage(NULL), - bLayerMode(FALSE), pXPolygon (0), nPolygonIndex (0), bLineError (FALSE), @@ -264,8 +260,8 @@ DrawViewShell::DrawViewShell ( bInEffectAssignment(FALSE), pSlotArray( NULL ), pClipEvtLstnr(NULL), - bPastePossible(FALSE), - mpFormShellManager(NULL) + mbIsLayerModeActive(false), + bPastePossible(FALSE) { if (pFrameViewArgument != NULL) pFrameView = pFrameViewArgument; @@ -282,18 +278,11 @@ DrawViewShell::DrawViewShell ( DrawViewShell::DrawViewShell ( SfxViewFrame* pFrame, + ::Window* pParentWindow, const DrawViewShell& rShell) - : ViewShell(pFrame, rShell), - aTabControl(this, &pFrame->GetWindow()), - aLayerTab(this, &pFrame->GetWindow()), - aPageBtn(&pFrame->GetWindow(), - WB_3DLOOK | WB_RECTSTYLE | WB_SMALLSTYLE | WB_NOPOINTERFOCUS ), - aMasterPageBtn(&pFrame->GetWindow(), - WB_3DLOOK | WB_RECTSTYLE | WB_SMALLSTYLE | WB_NOPOINTERFOCUS ), - aLayerBtn(&pFrame->GetWindow(), - WB_3DLOOK | WB_RECTSTYLE | WB_SMALLSTYLE | WB_NOPOINTERFOCUS ), + : ViewShell(pFrame, pParentWindow, rShell), + aTabControl(this, pParentWindow), pActualPage(NULL), - bLayerMode(FALSE), pXPolygon (0), nPolygonIndex (0), bLineError (FALSE), @@ -306,8 +295,8 @@ DrawViewShell::DrawViewShell ( bInEffectAssignment(FALSE), pSlotArray( NULL ), pClipEvtLstnr(NULL), - bPastePossible(FALSE), - mpFormShellManager(NULL) + mbIsLayerModeActive(false), + bPastePossible(FALSE) { pFrameView = new FrameView(GetDoc()); Construct (GetDocSh(), PK_STANDARD); @@ -324,8 +313,6 @@ DrawViewShell::~DrawViewShell() SfxViewShell* pViewShell = GetViewShell(); OSL_ASSERT (pViewShell!=NULL); - mpFormShellManager.reset(); - if( mxScannerListener.is() ) static_cast< ScannerEventListener* >( mxScannerListener.get() )->ParentDestroyed(); @@ -391,8 +378,8 @@ DrawViewShell::~DrawViewShell() // sterbende Funktion eventuell die ObjectBars zu wechseln. Die // entsprechende Shell ist aber schon vom SFX vom Dispatcher-Stack // genommen worden. - bObjectBarSwitchEnabled = FALSE; */ + GetObjectBarManager().DisableObjectBarSwitching(); if ( pClipEvtLstnr ) { @@ -402,7 +389,6 @@ DrawViewShell::~DrawViewShell() } delete pDrView; - pViewShell->SetWindow(NULL); pFrameView->Disconnect(); delete pXPolygon; @@ -457,8 +443,8 @@ void DrawViewShell::Construct(DrawDocShell* pDocSh, PageKind eInitialPageKind) GetDoc()->CreateFirstPages(); - pDrView = new DrawView(pDocSh, pWindow, this); - pView = pDrView; // Pointer der Basisklasse ViewShell + pDrView = new DrawView(pDocSh, GetActiveWindow(), this); + mpView = pDrView; // Pointer der Basisklasse ViewShell pDrView->SetSwapAsynchron(TRUE); // Asynchrones Laden von Graphiken ePageKind = eInitialPageKind; //af pFrameView->GetPageKind(); @@ -481,49 +467,9 @@ void DrawViewShell::Construct(DrawDocShell* pDocSh, PageKind eInitialPageKind) // Create the object bars and register them at the sub shell // manager. - ObjectBarManager& rObjectBarManager (GetObjectBarManager()); - // The id for the main object bars is the same. - if (eDocType == DOCUMENT_TYPE_DRAW) - rObjectBarManager.RegisterObjectBar ( - RID_DRAW_OBJ_TOOLBOX, - ::std::auto_ptr<SfxShell>(new DrawObjectBar(this, pDrView))); - else - rObjectBarManager.RegisterObjectBar ( - RID_DRAW_OBJ_TOOLBOX, - ::std::auto_ptr<SfxShell>(new ImpressObjectBar(this,pDrView))); - - rObjectBarManager.RegisterObjectBar ( - RID_BEZIER_TOOLBOX, - ::std::auto_ptr<SfxShell>(new BezierObjectBar(this, pDrView))); - - rObjectBarManager.RegisterObjectBar ( - RID_GLUEPOINTS_TOOLBOX, - ::std::auto_ptr<SfxShell>(new GluePointsObjectBar(this, pDrView))); - - rObjectBarManager.RegisterObjectBar ( - RID_DRAW_TEXT_TOOLBOX, - ::std::auto_ptr<SfxShell>(new TextObjectBar( - this, GetDoc()->GetPool(), pDrView))); - - ::std::auto_ptr<SfxShell> pFormShell(new FmFormShell(pViewShell, pDrView)); - rObjectBarManager.RegisterObjectBar (RID_FORMLAYER_TOOLBOX, pFormShell); - - rObjectBarManager.RegisterObjectBar ( - RID_DRAW_GRAF_TOOLBOX, - ::std::auto_ptr<SfxShell>(new GraphicObjectBar(this, pDrView))); - - rObjectBarManager.RegisterObjectBar ( - RID_SVX_EXTRUSION_BAR, - ::std::auto_ptr<SfxShell>(new svx::ExtrusionBar( pViewShell ))); - - rObjectBarManager.RegisterObjectBar ( - RID_SVX_FONTWORK_BAR, - ::std::auto_ptr<SfxShell>(new svx::FontworkBar( pViewShell ))); - + GetObjectBarManager().EnableObjectBarSwitching(); // Activate the relevant object bars. - rObjectBarManager.PushObjectBar (RID_FORMLAYER_TOOLBOX); - rObjectBarManager.PushObjectBar (RID_SVX_EXTRUSION_BAR); - rObjectBarManager.PushObjectBar (RID_DRAW_OBJ_TOOLBOX); + GetObjectBarManager().SwitchObjectBar (RID_DRAW_OBJ_TOOLBOX); Size aPageSize = GetDoc()->GetSdPage(0, ePageKind)->GetSize(); Point aPageOrg = Point(aPageSize.Width(), aPageSize.Height() / 2); @@ -544,31 +490,6 @@ void DrawViewShell::Construct(DrawDocShell* pDocSh, PageKind eInitialPageKind) // Split-Handler fuer TabControls aTabControl.SetSplitHdl( LINK( this, DrawViewShell, TabSplitHdl ) ); - aLayerTab.SetSplitHdl( LINK( this, DrawViewShell, TabSplitHdl ) ); - - aPageBtn.SetModeImage( Image( Bitmap( SdResId( BMP_TAB_PAGEMODE ) ), IMAGE_STDBTN_COLOR ) ); - aPageBtn.SetModeImage( Image( Bitmap( SdResId( BMP_TAB_PAGEMODE_H ) ), IMAGE_STDBTN_COLOR_HC ), BMP_COLOR_HIGHCONTRAST ); - aPageBtn.SetClickHdl(LINK(this, DrawViewShell, TabModeBtnHdl)); - aPageBtn.SetQuickHelpText( String( SdResId( STR_PAGEMODE ) ) ); - aPageBtn.SetHelpId( HID_SD_BTN_PAGE ); - aPageBtn.SetAccessibleName (String(SdResId(STR_PAGEMODE))); - aPageBtn.Show(); - - aMasterPageBtn.SetModeImage( Image( Bitmap( SdResId( BMP_TAB_MASTERPAGE ) ), IMAGE_STDBTN_COLOR ) ); - aMasterPageBtn.SetModeImage( Image( Bitmap( SdResId( BMP_TAB_MASTERPAGE_H ) ), IMAGE_STDBTN_COLOR_HC ), BMP_COLOR_HIGHCONTRAST ); - aMasterPageBtn.SetClickHdl(LINK(this, DrawViewShell, TabModeBtnHdl)); - aMasterPageBtn.SetQuickHelpText( String( SdResId( STR_MASTERPAGEMODE ) ) ); - aMasterPageBtn.SetHelpId( HID_SD_BTN_MASTERPAGE ); - aMasterPageBtn.SetAccessibleName (String(SdResId(STR_MASTERPAGEMODE))); - aMasterPageBtn.Show(); - - aLayerBtn.SetModeImage( Image( Bitmap( SdResId( BMP_TAB_LAYERMODE ) ), IMAGE_STDBTN_COLOR ) ); - aLayerBtn.SetModeImage( Image( Bitmap( SdResId( BMP_TAB_LAYERMODE_H ) ), IMAGE_STDBTN_COLOR_HC ), BMP_COLOR_HIGHCONTRAST ); - aLayerBtn.SetClickHdl(LINK(this, DrawViewShell, TabModeBtnHdl)); - aLayerBtn.SetQuickHelpText( String( SdResId( STR_LAYERMODE ) ) ); - aLayerBtn.SetHelpId( HID_SD_BTN_LAYER ); - aLayerBtn.SetAccessibleName (String(SdResId(STR_LAYERMODE))); - aLayerBtn.Show(); // Damit der richtige EditMode von der FrameView komplett eingestellt // werden kann, wird hier ein aktuell anderer gewaehlt (kleiner Trick) @@ -587,40 +508,34 @@ void DrawViewShell::Construct(DrawDocShell* pDocSh, PageKind eInitialPageKind) if( eDocType == DOCUMENT_TYPE_DRAW ) { SetHelpId( SD_IF_SDGRAPHICVIEWSHELL ); - pWindow->SetHelpId( SD_IF_SDGRAPHICVIEWSHELL ); - pWindow->SetUniqueId( SD_IF_SDGRAPHICVIEWSHELL ); + GetActiveWindow()->SetHelpId( SD_IF_SDGRAPHICVIEWSHELL ); + GetActiveWindow()->SetUniqueId( SD_IF_SDGRAPHICVIEWSHELL ); } else { if (ePageKind == PK_NOTES) { - aNotesBtn.Check(TRUE); - aLayerBtn.Disable(); SetHelpId( SID_NOTESMODE ); - pWindow->SetHelpId( SID_NOTESMODE ); - pWindow->SetUniqueId( SID_NOTESMODE ); + GetActiveWindow()->SetHelpId( SID_NOTESMODE ); + GetActiveWindow()->SetUniqueId( SID_NOTESMODE ); // AutoLayouts muessen erzeugt sein GetDoc()->StopWorkStartupDelay(); } else if (ePageKind == PK_HANDOUT) { - aHandoutBtn.Check(TRUE); - aPageBtn.Disable(); - aLayerBtn.Disable(); SetHelpId( SID_HANDOUTMODE ); - pWindow->SetHelpId( SID_HANDOUTMODE ); - pWindow->SetUniqueId( SID_HANDOUTMODE ); + GetActiveWindow()->SetHelpId( SID_HANDOUTMODE ); + GetActiveWindow()->SetUniqueId( SID_HANDOUTMODE ); // AutoLayouts muessen erzeugt sein GetDoc()->StopWorkStartupDelay(); } else { - aDrawBtn.Check(TRUE); SetHelpId( SD_IF_SDDRAWVIEWSHELL ); - pWindow->SetHelpId( SD_IF_SDDRAWVIEWSHELL ); - pWindow->SetUniqueId( SD_IF_SDDRAWVIEWSHELL ); + GetActiveWindow()->SetHelpId( SD_IF_SDDRAWVIEWSHELL ); + GetActiveWindow()->SetUniqueId( SD_IF_SDDRAWVIEWSHELL ); } } @@ -640,7 +555,7 @@ void DrawViewShell::Construct(DrawDocShell* pDocSh, PageKind eInitialPageKind) bIsRulerDrag = FALSE; - String aName( RTL_CONSTASCII_USTRINGPARAM( "DrawView" )); + String aName( RTL_CONSTASCII_USTRINGPARAM("DrawViewShell")); SetName (aName); if (pFrameView->GetPresentationViewShellId() != SID_VIEWSHELL0) @@ -681,9 +596,6 @@ void DrawViewShell::Construct(DrawDocShell* pDocSh, PageKind eInitialPageKind) } } - mpController = new SdUnoDrawView (GetViewShellBase(), *this, *pView); - mxController = static_cast<XWeak*>(mpController); - DestroyPolygons (); pXPolygon = new XPolygon; CreateBorder(); @@ -694,13 +606,32 @@ void DrawViewShell::Construct(DrawDocShell* pDocSh, PageKind eInitialPageKind) void DrawViewShell::Init (void) { ViewShell::Init (); + StartListening (*GetDocSh()); - mpFormShellManager = ::std::auto_ptr<FormShellManager>( - new FormShellManager (GetViewShellBase())); } + +DrawController* DrawViewShell::GetController (void) +{ + if ( ! mpController.is() && IsMainViewShell()) + { + // Create uno controller for the main view shell. For the ones + // displayed in the non-center panes we may later introduce + // sub-controllers. + DrawController* pController = new SdUnoDrawView ( + GetViewShellBase(), + *this, + *GetView()); + mpController = ::comphelper::ImplementationReference< + DrawController, + ::com::sun::star::uno::XInterface, + ::com::sun::star::uno::XWeak> (pController); + } + return mpController.get(); +} + /************************************************************************* |* |* pruefe ob linienzuege gezeichnet werden muessen @@ -952,7 +883,7 @@ void DrawViewShell::GetStatusBarState(SfxItemSet& rSet) else { SvxZoomItem* pZoomItem; - UINT16 nZoom = (UINT16) pWindow->GetZoom(); + UINT16 nZoom = (UINT16) GetActiveWindow()->GetZoom(); if( bZoomOnPage ) pZoomItem = new SvxZoomItem( SVX_ZOOM_WHOLEPAGE, nZoom ); @@ -975,7 +906,7 @@ void DrawViewShell::GetStatusBarState(SfxItemSet& rSet) } } - Point aPos = pWindow->PixelToLogic(aMousePos); + Point aPos = GetActiveWindow()->PixelToLogic(aMousePos); pDrView->GetPageViewPvNum(0)->LogicToPagePos(aPos); Fraction aUIScale(GetDoc()->GetUIScale()); aPos.X() = Fraction(aPos.X()) / aUIScale; @@ -1040,7 +971,7 @@ void DrawViewShell::GetStatusBarState(SfxItemSet& rSet) // If in layer mode additionally show the layer that contains all // selected shapes of the page. If the shapes are distributed on // more than one layer, no layer name is shown. - if( bLayerMode ) + if (IsLayerModeActive()) { SdrLayerAdmin& rLayerAdmin = GetDoc()->GetLayerAdmin(); SdrLayerID nLayer, nOldLayer; |