diff options
Diffstat (limited to 'sd/source/ui/view/frmview.cxx')
-rw-r--r-- | sd/source/ui/view/frmview.cxx | 1076 |
1 files changed, 0 insertions, 1076 deletions
diff --git a/sd/source/ui/view/frmview.cxx b/sd/source/ui/view/frmview.cxx deleted file mode 100644 index 173e499e9..000000000 --- a/sd/source/ui/view/frmview.cxx +++ /dev/null @@ -1,1076 +0,0 @@ -/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ -/************************************************************************* - * - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * Copyright 2000, 2010 Oracle and/or its affiliates. - * - * OpenOffice.org - a multi-platform office productivity suite - * - * 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_sd.hxx" - -#include "FrameView.hxx" - -#include <svx/svxids.hrc> -#include <com/sun/star/awt/Rectangle.hpp> -#include <com/sun/star/drawing/framework/ResourceId.hpp> -#include <rtl/ustrbuf.hxx> -#include "unokywds.hxx" - -#include <vector> -#include "ViewShell.hxx" -#include "drawdoc.hxx" -#include "DrawDocShell.hxx" -#include "optsitem.hxx" -#include "ViewShellBase.hxx" -#include "DrawViewShell.hxx" -#include "OutlineViewShell.hxx" -#include "app.hxx" -#include "sdresid.hxx" -#include "pres.hxx" -#include "glob.hrc" -#include "sdiocmpt.hxx" -#include "framework/FrameworkHelper.hxx" -#include <comphelper/processfactory.hxx> -#include <sfx2/viewfrm.hxx> - -using namespace ::com::sun::star; -using namespace ::com::sun::star::uno; -using namespace ::com::sun::star::beans; -using namespace ::std; -using ::rtl::OUString; - -namespace sd { - -/************************************************************************* -|* -|* Ctor -|* -\************************************************************************/ - -FrameView::FrameView(SdDrawDocument* pDrawDoc, FrameView* pFrameView /* = NULK */) - : SdrView(pDrawDoc, (OutputDevice*) NULL), - mnRefCount(0), - mnPresViewShellId(SID_VIEWSHELL0), - mnSlotId(SID_OBJECT_SELECT), - mbIsNavigatorShowingAllShapes(false) -{ - EndListening(*pDrawDoc); - - EnableExtendedKeyInputDispatcher(sal_False); - EnableExtendedMouseEventDispatcher(sal_False); - EnableExtendedCommandEventDispatcher(sal_False); - - SetGridFront( sal_False ); - SetHlplFront( sal_False ); - SetOConSnap( sal_False ); - SetFrameDragSingles( sal_True ); - SetSlidesPerRow(4); - - if( NULL == pFrameView ) - { - DrawDocShell* pDocShell = pDrawDoc->GetDocSh(); - - if ( pDocShell ) - { - /********************************************************************** - * Das Dokument wurde geladen, ist eine FrameView vorhanden? - **********************************************************************/ - sal_uLong nSdViewShellCount = 0; - ViewShellBase* pBase = NULL; - SfxViewShell* pSfxViewSh = NULL; - SfxViewFrame* pSfxViewFrame = SfxViewFrame::GetFirst(pDocShell); - - while (pSfxViewFrame) - { - // Count the FrameViews and remember the type of the main - // view shell. - pSfxViewSh = pSfxViewFrame->GetViewShell(); - pBase = PTR_CAST(ViewShellBase, pSfxViewSh ); - - if (pBase != NULL) - { - nSdViewShellCount++; - - ::rtl::OUString sViewURL; - Reference<drawing::framework::XView> xView ( - framework::FrameworkHelper::Instance(*pBase)->GetView( - drawing::framework::ResourceId::create( - ::comphelper::getProcessComponentContext(), - framework::FrameworkHelper::msCenterPaneURL))); - if (xView.is()) - sViewURL = xView->getResourceId()->getResourceURL(); - - switch (framework::FrameworkHelper::GetViewId(sViewURL)) - { - default: -// case ViewShell::ST_IMPRESS: -// case ViewShell::ST_NOTES: -// case ViewShell::ST_HANDOUT: - mnPresViewShellId = SID_VIEWSHELL0; - break; - - case ViewShell::ST_SLIDE_SORTER: - mnPresViewShellId = SID_VIEWSHELL1; - break; - - case ViewShell::ST_OUTLINE: - mnPresViewShellId = SID_VIEWSHELL2; - break; - } - } - - pSfxViewFrame = SfxViewFrame::GetNext(*pSfxViewFrame, pDocShell); - } - - SdDrawDocument* pDoc = pDocShell->GetDoc(); - pFrameView = pDoc->GetFrameView(nSdViewShellCount); - } - } - - if (pFrameView) - { - /********************************************************************** - * FrameView mit der FrameView der DocShell initialisieren - **********************************************************************/ - SetRuler( pFrameView->HasRuler() ); - SetGridCoarse( pFrameView->GetGridCoarse() ); - SetGridFine( pFrameView->GetGridFine() ); - SetSnapGridWidth(pFrameView->GetSnapGridWidthX(), pFrameView->GetSnapGridWidthY()); - SetGridVisible( pFrameView->IsGridVisible() ); - SetGridFront( pFrameView->IsGridFront() ); - SetSnapAngle( pFrameView->GetSnapAngle() ); - SetGridSnap( pFrameView->IsGridSnap() ); - SetBordSnap( pFrameView->IsBordSnap() ); - SetHlplSnap( pFrameView->IsHlplSnap() ); - SetOFrmSnap( pFrameView->IsOFrmSnap() ); - SetOPntSnap( pFrameView->IsOPntSnap() ); - SetOConSnap( pFrameView->IsOConSnap() ); - SetHlplVisible( pFrameView->IsHlplVisible() ); - SetDragStripes( pFrameView->IsDragStripes() ); - SetPlusHandlesAlwaysVisible( pFrameView->IsPlusHandlesAlwaysVisible() ); - SetFrameDragSingles( pFrameView->IsFrameDragSingles() ); - SetSnapMagneticPixel( pFrameView->GetSnapMagneticPixel() ); - SetMarkedHitMovesAlways( pFrameView->IsMarkedHitMovesAlways() ); - SetMoveOnlyDragging( pFrameView->IsMoveOnlyDragging() ); - SetCrookNoContortion( pFrameView->IsCrookNoContortion() ); - SetSlantButShear( pFrameView->IsSlantButShear() ); - SetNoDragXorPolys( pFrameView->IsNoDragXorPolys() ); - SetAngleSnapEnabled( pFrameView->IsAngleSnapEnabled() ); - SetBigOrtho( pFrameView->IsBigOrtho() ); - SetOrtho( pFrameView->IsOrtho() ); - SetEliminatePolyPointLimitAngle( pFrameView->GetEliminatePolyPointLimitAngle() ); - SetEliminatePolyPoints( pFrameView->IsEliminatePolyPoints() ); - SetDesignMode( pFrameView->IsDesignMode() ); - - SetSolidMarkHdl( pFrameView->IsSolidMarkHdl() ); - SetSolidDragging( pFrameView->IsSolidDragging() ); - - maVisibleLayers = pFrameView->GetVisibleLayers(); - maPrintableLayers = pFrameView->GetPrintableLayers(); - maLockedLayers = pFrameView->GetLockedLayers(); - maStandardHelpLines = pFrameView->GetStandardHelpLines(); - maNotesHelpLines = pFrameView->GetNotesHelpLines(); - maHandoutHelpLines = pFrameView->GetHandoutHelpLines(); - SetActiveLayer( pFrameView->GetActiveLayer() ); - mbNoColors = pFrameView->IsNoColors(); - mbNoAttribs = pFrameView->IsNoAttribs() ; - maVisArea = pFrameView->GetVisArea(); - mePageKind = pFrameView->GetPageKind(); - mePageKindOnLoad = pFrameView->GetPageKindOnLoad(); - mnSelectedPage = pFrameView->GetSelectedPage(); - mnSelectedPageOnLoad = pFrameView->GetSelectedPageOnLoad(); - meStandardEditMode = pFrameView->GetViewShEditMode(PK_STANDARD); - meNotesEditMode = pFrameView->GetViewShEditMode(PK_NOTES); - meHandoutEditMode = pFrameView->GetViewShEditMode(PK_HANDOUT); - SetViewShEditModeOnLoad(pFrameView->GetViewShEditModeOnLoad()); - mbLayerMode = pFrameView->IsLayerMode(); - mbQuickEdit = pFrameView->IsQuickEdit(); - - // #i26631# - SetMasterPagePaintCaching( pFrameView->IsMasterPagePaintCaching() ); - - SetDragWithCopy( pFrameView->IsDragWithCopy() ); - mbBigHandles = pFrameView->IsBigHandles(); - mbDoubleClickTextEdit = pFrameView->IsDoubleClickTextEdit(); - mbClickChangeRotation = pFrameView->IsClickChangeRotation(); - mnSlidesPerRow = pFrameView->GetSlidesPerRow(); - mnDrawMode = pFrameView->GetDrawMode(); - mnTabCtrlPercent = pFrameView->GetTabCtrlPercent(); - mbIsNavigatorShowingAllShapes = pFrameView->IsNavigatorShowingAllShapes(); - SetPreviousViewShellType (pFrameView->GetPreviousViewShellType()); - SetViewShellTypeOnLoad (pFrameView->GetViewShellTypeOnLoad()); - } - else - { - /********************************************************************** - * FrameView mit den Applikationsdaten initialisieren - **********************************************************************/ - maVisibleLayers.SetAll(); - maPrintableLayers.SetAll(); - SetGridCoarse( Size( 1000, 1000 ) ); - SetSnapGridWidth(Fraction(1000, 1), Fraction(1000, 1)); - SetActiveLayer( String( SdResId(STR_LAYER_LAYOUT) ) ); - mbNoColors = sal_True; - mbNoAttribs = sal_False; - maVisArea = Rectangle( Point(), Size(0, 0) ); - mePageKind = PK_STANDARD; - mePageKindOnLoad = PK_STANDARD; - mnSelectedPage = 0; - mnSelectedPageOnLoad = 0; - meStandardEditMode = EM_PAGE; - meNotesEditMode = EM_PAGE; - meHandoutEditMode = EM_MASTERPAGE; - SetViewShEditModeOnLoad(EM_PAGE); - mbLayerMode = sal_False; - SetEliminatePolyPoints(sal_False); - mbBigHandles = sal_False; - mbDoubleClickTextEdit = sal_False; - mbClickChangeRotation = sal_False; - mnSlidesPerRow = 4; - - { - bool bUseContrast = Application::GetSettings().GetStyleSettings().GetHighContrastMode(); - mnDrawMode = bUseContrast ? OUTPUT_DRAWMODE_CONTRAST : OUTPUT_DRAWMODE_COLOR; - } - mnTabCtrlPercent = 0.0; - mbIsNavigatorShowingAllShapes = false; - SetPreviousViewShellType (ViewShell::ST_NONE); - SetViewShellTypeOnLoad (ViewShell::ST_IMPRESS); - - // get default for design mode - sal_Bool bInitDesignMode = pDrawDoc->GetOpenInDesignMode(); - if( pDrawDoc->OpenInDesignModeIsDefaulted() ) - { - bInitDesignMode = sal_True; - } - - SfxObjectShell* pObjShell = pDrawDoc->GetObjectShell(); - if( pObjShell && pObjShell->IsReadOnly() ) - bInitDesignMode = sal_False; - SetDesignMode( bInitDesignMode ); - - Update( SD_MOD()->GetSdOptions(pDrawDoc->GetDocumentType()) ); - } - -} - -/************************************************************************* -|* -|* Dtor -|* -\************************************************************************/ - -FrameView::~FrameView() -{ -} - - -/************************************************************************* -|* -|* Verbindung herstellen -|* -\************************************************************************/ - -void FrameView::Connect() -{ - mnRefCount++; -} - - -/************************************************************************* -|* -|* Verbindung loesen -|* -\************************************************************************/ - -void FrameView::Disconnect() -{ - if (mnRefCount > 0) - { - mnRefCount--; - } - - if (mnRefCount == 0) - { - delete this; - } -} - -/************************************************************************* -|* -|* Update mit Daten der SdOptions -|* -\************************************************************************/ - -void FrameView::Update(SdOptions* pOptions) -{ - if (pOptions) - { - mbRuler = pOptions->IsRulerVisible(); - SetGridVisible( pOptions->IsGridVisible() ); - SetSnapAngle( pOptions->GetAngle() ); - SetGridSnap( pOptions->IsUseGridSnap() ); - SetBordSnap( pOptions->IsSnapBorder() ); - SetHlplSnap( pOptions->IsSnapHelplines() ); - SetOFrmSnap( pOptions->IsSnapFrame() ); - SetOPntSnap( pOptions->IsSnapPoints() ); - SetHlplVisible( pOptions->IsHelplines() ); - SetDragStripes( pOptions->IsDragStripes() ); - SetPlusHandlesAlwaysVisible( pOptions->IsHandlesBezier() ); - SetSnapMagneticPixel( pOptions->GetSnapArea() ); - SetMarkedHitMovesAlways( pOptions->IsMarkedHitMovesAlways() ); - SetMoveOnlyDragging( pOptions->IsMoveOnlyDragging() ); - SetSlantButShear( pOptions->IsMoveOnlyDragging() ); - SetNoDragXorPolys ( !pOptions->IsMoveOutline() ); - SetCrookNoContortion( pOptions->IsCrookNoContortion() ); - SetAngleSnapEnabled( pOptions->IsRotate() ); - SetBigOrtho( pOptions->IsBigOrtho() ); - SetOrtho( pOptions->IsOrtho() ); - SetEliminatePolyPointLimitAngle( pOptions->GetEliminatePolyPointLimitAngle() ); - GetModel()->SetPickThroughTransparentTextFrames( pOptions->IsPickThrough() ); - - SetSolidMarkHdl( pOptions->IsSolidMarkHdl() ); - SetSolidDragging( pOptions->IsSolidDragging() ); - - SetGridCoarse( Size( pOptions->GetFldDrawX(), pOptions->GetFldDrawY() ) ); - SetGridFine( Size( pOptions->GetFldDivisionX(), pOptions->GetFldDivisionY() ) ); - Fraction aFractX(pOptions->GetFldDrawX(), pOptions->GetFldDrawX() / ( pOptions->GetFldDivisionX() ? pOptions->GetFldDivisionX() : 1 )); - Fraction aFractY(pOptions->GetFldDrawY(), pOptions->GetFldDrawY() / ( pOptions->GetFldDivisionY() ? pOptions->GetFldDivisionY() : 1 )); - SetSnapGridWidth(aFractX, aFractY); - SetQuickEdit(pOptions->IsQuickEdit()); - - // #i26631# - SetMasterPagePaintCaching( pOptions->IsMasterPagePaintCaching() ); - - SetDragWithCopy(pOptions->IsDragWithCopy()); - SetBigHandles( pOptions->IsBigHandles() ); - SetDoubleClickTextEdit( pOptions->IsDoubleClickTextEdit() ); - SetClickChangeRotation( pOptions->IsClickChangeRotation() ); - } -} - - -/************************************************************************* -|* -|* EditMode (Page oder MasterPage) des Arbeitsmodus setzen -|* -\************************************************************************/ - -void FrameView::SetViewShEditMode(EditMode eMode, PageKind eKind) -{ - if (eKind == PK_STANDARD) - { - meStandardEditMode = eMode; - } - else if (eKind == PK_NOTES) - { - meNotesEditMode = eMode; - } - else if (eKind == PK_HANDOUT) - { - meHandoutEditMode = eMode; - } -} - - -/************************************************************************* -|* -|* EditMode (Page oder MasterPage) des Arbeitsmodus zurueckgeben -|* -\************************************************************************/ - -EditMode FrameView::GetViewShEditMode(PageKind eKind) -{ - EditMode eMode = EM_PAGE; - - if (eKind == PK_STANDARD) - { - eMode = meStandardEditMode; - } - else if (eKind == PK_NOTES) - { - eMode = meNotesEditMode; - } - else if (eKind == PK_HANDOUT) - { - eMode = meHandoutEditMode; - } - - return (eMode); -} - - - - -void FrameView::SetViewShEditModeOnLoad (EditMode eMode) -{ - meEditModeOnLoad = eMode; -} - - - - -EditMode FrameView::GetViewShEditModeOnLoad (void) const -{ - return meEditModeOnLoad; -} - - - - -static OUString createHelpLinesString( const SdrHelpLineList& rHelpLines ) -{ - ::rtl::OUStringBuffer aLines; - - const sal_uInt16 nCount = rHelpLines.GetCount(); - for( sal_uInt16 nHlpLine = 0; nHlpLine < nCount; nHlpLine++ ) - { - const SdrHelpLine& rHelpLine = rHelpLines[nHlpLine]; - const Point& rPos = rHelpLine.GetPos(); - - switch( rHelpLine.GetKind() ) - { - case SDRHELPLINE_POINT: - aLines.append( (sal_Unicode)'P' ); - aLines.append( (sal_Int32)rPos.X() ); - aLines.append( (sal_Unicode)',' ); - aLines.append( (sal_Int32)rPos.Y() ); - break; - case SDRHELPLINE_VERTICAL: - aLines.append( (sal_Unicode)'V' ); - aLines.append( (sal_Int32)rPos.X() ); - break; - case SDRHELPLINE_HORIZONTAL: - aLines.append( (sal_Unicode)'H' ); - aLines.append( (sal_Int32)rPos.Y() ); - break; - default: - OSL_FAIL( "Unsupported helpline Kind!" ); - } - } - - return aLines.makeStringAndClear(); -} - -#define addValue( n, v ) push_back( std::pair< OUString, Any >( OUString( RTL_CONSTASCII_USTRINGPARAM( n ) ), v ) ) -void FrameView::WriteUserDataSequence ( ::com::sun::star::uno::Sequence < ::com::sun::star::beans::PropertyValue >& rValues, sal_Bool ) -{ - std::vector< std::pair< OUString, Any > > aUserData; - - aUserData.addValue( sUNO_View_GridIsVisible, makeAny( (sal_Bool)IsGridVisible() ) ); - aUserData.addValue( sUNO_View_GridIsFront, makeAny( (sal_Bool)IsGridFront() ) ); - aUserData.addValue( sUNO_View_IsSnapToGrid, makeAny( (sal_Bool)IsGridSnap() ) ); - aUserData.addValue( sUNO_View_IsSnapToPageMargins, makeAny( (sal_Bool)IsBordSnap() ) ); - aUserData.addValue( sUNO_View_IsSnapToSnapLines, makeAny( (sal_Bool)IsHlplSnap() ) ); - aUserData.addValue( sUNO_View_IsSnapToObjectFrame, makeAny( (sal_Bool)IsOFrmSnap() ) ); - aUserData.addValue( sUNO_View_IsSnapToObjectPoints, makeAny( (sal_Bool)IsOPntSnap() ) ); - - aUserData.addValue( sUNO_View_IsPlusHandlesAlwaysVisible, makeAny( (sal_Bool)IsPlusHandlesAlwaysVisible() ) ); - aUserData.addValue( sUNO_View_IsFrameDragSingles, makeAny( (sal_Bool)IsFrameDragSingles() ) ); - - aUserData.addValue( sUNO_View_EliminatePolyPointLimitAngle, makeAny( (sal_Int32)GetEliminatePolyPointLimitAngle() ) ); - aUserData.addValue( sUNO_View_IsEliminatePolyPoints, makeAny( (sal_Bool)IsEliminatePolyPoints() ) ); - - Any aAny; - GetVisibleLayers().QueryValue( aAny ); - aUserData.addValue( sUNO_View_VisibleLayers, aAny ); - - GetPrintableLayers().QueryValue( aAny ); - aUserData.addValue( sUNO_View_PrintableLayers, aAny ); - - GetLockedLayers().QueryValue( aAny ); - aUserData.addValue( sUNO_View_LockedLayers, aAny ); - - aUserData.addValue( sUNO_View_NoAttribs, makeAny( (sal_Bool)IsNoAttribs() ) ); - aUserData.addValue( sUNO_View_NoColors, makeAny( (sal_Bool)IsNoColors() ) ); - - if( GetStandardHelpLines().GetCount() ) - aUserData.addValue( sUNO_View_SnapLinesDrawing, makeAny( createHelpLinesString( GetStandardHelpLines() ) ) ); - - if( GetNotesHelpLines().GetCount() ) - aUserData.addValue( sUNO_View_SnapLinesNotes, makeAny( createHelpLinesString( GetNotesHelpLines() ) ) ); - - if( GetHandoutHelpLines().GetCount() ) - aUserData.addValue( sUNO_View_SnapLinesHandout, makeAny( createHelpLinesString( GetHandoutHelpLines() ) ) ); - - aUserData.addValue( sUNO_View_RulerIsVisible, makeAny( (sal_Bool)HasRuler() ) ); - aUserData.addValue( sUNO_View_PageKind, makeAny( (sal_Int16)GetPageKind() ) ); - aUserData.addValue( sUNO_View_SelectedPage, makeAny( (sal_Int16)GetSelectedPage() ) ); - aUserData.addValue( sUNO_View_IsLayerMode, makeAny( (sal_Bool)IsLayerMode() ) ); - - aUserData.addValue( sUNO_View_IsBigHandles, makeAny( (sal_Bool)IsBigHandles() ) ); - aUserData.addValue( sUNO_View_IsDoubleClickTextEdit, makeAny( (sal_Bool)IsDoubleClickTextEdit() ) ); - aUserData.addValue( sUNO_View_IsClickChangeRotation, makeAny( (sal_Bool)IsClickChangeRotation() ) ); - - aUserData.addValue( sUNO_View_SlidesPerRow, makeAny( (sal_Int16)GetSlidesPerRow() ) ); - aUserData.addValue( sUNO_View_EditModeStandard, makeAny( (sal_Int32)GetViewShEditMode( PK_STANDARD ) ) ); - aUserData.addValue( sUNO_View_EditModeNotes, makeAny( (sal_Int32)GetViewShEditMode( PK_NOTES ) ) ); - aUserData.addValue( sUNO_View_EditModeHandout, makeAny( (sal_Int32)GetViewShEditMode( PK_HANDOUT ) ) ); - - { - const Rectangle aVisArea = GetVisArea(); - - aUserData.addValue( sUNO_View_VisibleAreaTop, makeAny( (sal_Int32)aVisArea.Top() ) ); - aUserData.addValue( sUNO_View_VisibleAreaLeft, makeAny( (sal_Int32)aVisArea.Left() ) ); - aUserData.addValue( sUNO_View_VisibleAreaWidth, makeAny( (sal_Int32)aVisArea.GetWidth() ) ); - aUserData.addValue( sUNO_View_VisibleAreaHeight, makeAny( (sal_Int32)aVisArea.GetHeight() ) ); - } - - aUserData.addValue( sUNO_View_GridCoarseWidth, makeAny( (sal_Int32)GetGridCoarse().Width() ) ); - aUserData.addValue( sUNO_View_GridCoarseHeight, makeAny( (sal_Int32)GetGridCoarse().Height() ) ); - aUserData.addValue( sUNO_View_GridFineWidth, makeAny( (sal_Int32)GetGridFine().Width() ) ); - aUserData.addValue( sUNO_View_GridFineHeight, makeAny( (sal_Int32)GetGridFine().Height() ) ); - aUserData.addValue( sUNO_View_GridSnapWidthXNumerator, makeAny( (sal_Int32)GetSnapGridWidthX().GetNumerator() ) ); - aUserData.addValue( sUNO_View_GridSnapWidthXDenominator, makeAny( (sal_Int32)GetSnapGridWidthX().GetDenominator() ) ); - aUserData.addValue( sUNO_View_GridSnapWidthYNumerator, makeAny( (sal_Int32)GetSnapGridWidthY().GetNumerator() ) ); - aUserData.addValue( sUNO_View_GridSnapWidthYDenominator, makeAny( (sal_Int32)GetSnapGridWidthY().GetDenominator() ) ); - aUserData.addValue( sUNO_View_IsAngleSnapEnabled, makeAny( (sal_Bool)IsAngleSnapEnabled() ) ); - aUserData.addValue( sUNO_View_SnapAngle, makeAny( (sal_Int32)GetSnapAngle() ) ); - - const sal_Int32 nOldLength = rValues.getLength(); - rValues.realloc( nOldLength + aUserData.size() ); - - PropertyValue* pValue = &(rValues.getArray()[nOldLength]); - - std::vector< std::pair< OUString, Any > >::iterator aIter( aUserData.begin() ); - for( ; aIter != aUserData.end(); ++aIter, ++pValue ) - { - pValue->Name = (*aIter).first; - pValue->Value = (*aIter).second; - } -} -#undef addValue - -static void createHelpLinesFromString( const rtl::OUString& rLines, SdrHelpLineList& rHelpLines ) -{ - const sal_Unicode * pStr = rLines.getStr(); - SdrHelpLine aNewHelpLine; - rtl::OUStringBuffer sBuffer; - - while( *pStr ) - { - Point aPoint; - - switch( *pStr ) - { - case (sal_Unicode)'P': - aNewHelpLine.SetKind( SDRHELPLINE_POINT ); - break; - case (sal_Unicode)'V': - aNewHelpLine.SetKind( SDRHELPLINE_VERTICAL ); - break; - case (sal_Unicode)'H': - aNewHelpLine.SetKind( SDRHELPLINE_HORIZONTAL ); - break; - default: - OSL_FAIL( "syntax error in snap lines settings string" ); - return; - } - - pStr++; - - while( (*pStr >= sal_Unicode('0') && *pStr <= sal_Unicode('9')) || (*pStr == '+') || (*pStr == '-') ) - { - sBuffer.append( *pStr++ ); - } - - sal_Int32 nValue = sBuffer.makeStringAndClear().toInt32(); - - if( aNewHelpLine.GetKind() == SDRHELPLINE_HORIZONTAL ) - { - aPoint.Y() = nValue; - } - else - { - aPoint.X() = nValue; - - if( aNewHelpLine.GetKind() == SDRHELPLINE_POINT ) - { - if( *pStr++ != ',' ) - return; - - while( (*pStr >= sal_Unicode('0') && *pStr <= sal_Unicode('9')) || (*pStr == '+') || (*pStr == '-') ) - { - sBuffer.append( *pStr++ ); - } - - aPoint.Y() = sBuffer.makeStringAndClear().toInt32(); - - } - } - - aNewHelpLine.SetPos( aPoint ); - rHelpLines.Insert( aNewHelpLine ); - } -} - -void FrameView::ReadUserDataSequence ( const ::com::sun::star::uno::Sequence < ::com::sun::star::beans::PropertyValue >& rSequence, sal_Bool ) -{ - const sal_Int32 nLength = rSequence.getLength(); - if (nLength) - { - const bool bImpress = dynamic_cast< SdDrawDocument* >(GetModel())->GetDocumentType() == DOCUMENT_TYPE_IMPRESS; - - sal_Bool bBool = sal_False; - sal_Int32 nInt32 = 0; - sal_Int16 nInt16 = 0; - rtl::OUString aString; - - sal_Int32 aSnapGridWidthXNum = GetSnapGridWidthX().GetNumerator(); - sal_Int32 aSnapGridWidthXDom = GetSnapGridWidthX().GetDenominator(); - - sal_Int32 aSnapGridWidthYNum = GetSnapGridWidthY().GetNumerator(); - sal_Int32 aSnapGridWidthYDom = GetSnapGridWidthY().GetDenominator(); - - const com::sun::star::beans::PropertyValue *pValue = rSequence.getConstArray(); - for (sal_Int16 i = 0 ; i < nLength; i++, pValue++ ) - { - if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sUNO_View_ViewId ) ) ) - { - } - else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sUNO_View_SnapLinesDrawing ) ) ) - { - if( pValue->Value >>= aString ) - { - SdrHelpLineList aHelpLines; - createHelpLinesFromString( aString, aHelpLines ); - SetStandardHelpLines( aHelpLines ); - } - } - else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sUNO_View_SnapLinesNotes ) ) ) - { - if( pValue->Value >>= aString ) - { - SdrHelpLineList aHelpLines; - createHelpLinesFromString( aString, aHelpLines ); - SetNotesHelpLines( aHelpLines ); - } - } - else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sUNO_View_SnapLinesHandout ) ) ) - { - if( pValue->Value >>= aString ) - { - SdrHelpLineList aHelpLines; - createHelpLinesFromString( aString, aHelpLines ); - SetHandoutHelpLines( aHelpLines ); - } - } - else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sUNO_View_RulerIsVisible ) ) ) - { - if( pValue->Value >>= bBool ) - { - SetRuler( bBool ); - } - } - else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sUNO_View_PageKind ) ) ) - { - if( pValue->Value >>= nInt16 ) - { - SdDrawDocument* pDoc = dynamic_cast< SdDrawDocument* >( GetModel() ); - if( pDoc && pDoc->GetDocSh() && ( SFX_CREATE_MODE_EMBEDDED == pDoc->GetDocSh()->GetCreateMode() ) ) - SetPageKind( (PageKind)nInt16 ); - - SetPageKindOnLoad( (PageKind)nInt16 ); - } - } - else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sUNO_View_SelectedPage ) ) ) - { - if( pValue->Value >>= nInt16 ) - { - SdDrawDocument* pDoc = dynamic_cast< SdDrawDocument* >( GetModel() ); - if( pDoc && pDoc->GetDocSh() && ( SFX_CREATE_MODE_EMBEDDED == pDoc->GetDocSh()->GetCreateMode() ) ) - SetSelectedPage( (sal_uInt16)nInt16 ); - - SetSelectedPageOnLoad( (sal_uInt16)nInt16 ); - } - } - else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sUNO_View_IsLayerMode ) ) ) - { - if( pValue->Value >>= bBool ) - { - SetLayerMode( bBool ); - } - } - else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sUNO_View_IsBigHandles ) ) ) - { - if( pValue->Value >>= bBool ) - { - SetBigHandles( bBool ); - } - } - else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sUNO_View_IsDoubleClickTextEdit ) ) ) - { - if( pValue->Value >>= bBool ) - { - SetDoubleClickTextEdit( bBool ); - } - } - else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sUNO_View_IsClickChangeRotation ) ) ) - { - if( pValue->Value >>= bBool ) - { - SetClickChangeRotation( bBool ); - } - } - else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sUNO_View_SlidesPerRow ) ) ) - { - if( pValue->Value >>= nInt16 ) - { - SetSlidesPerRow( (sal_uInt16)nInt16 ); - } - } - else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sUNO_View_EditModeStandard ) ) ) - { - if( pValue->Value >>= nInt32 ) - { - SdDrawDocument* pDoc = dynamic_cast< SdDrawDocument* >( GetModel() ); - if( pDoc && pDoc->GetDocSh() && ( SFX_CREATE_MODE_EMBEDDED == pDoc->GetDocSh()->GetCreateMode() ) ) - SetViewShEditMode( (EditMode)nInt32, PK_STANDARD ); - } - } - else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sUNO_View_EditModeNotes ) ) ) - { - if( pValue->Value >>= nInt32 ) - { - SdDrawDocument* pDoc = dynamic_cast< SdDrawDocument* >( GetModel() ); - if( pDoc && pDoc->GetDocSh() && ( SFX_CREATE_MODE_EMBEDDED == pDoc->GetDocSh()->GetCreateMode() ) ) - SetViewShEditMode( (EditMode)nInt32, PK_NOTES ); - } - } - else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sUNO_View_EditModeHandout ) ) ) - { - if( pValue->Value >>= nInt32 ) - { - SdDrawDocument* pDoc = dynamic_cast< SdDrawDocument* >( GetModel() ); - if( pDoc && pDoc->GetDocSh() && ( SFX_CREATE_MODE_EMBEDDED == pDoc->GetDocSh()->GetCreateMode() ) ) - SetViewShEditMode( (EditMode)nInt32, PK_HANDOUT ); - } - } - else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sUNO_View_VisibleAreaTop ) ) ) - { - sal_Int32 nTop = 0; - if( pValue->Value >>= nTop ) - { - Rectangle aVisArea( GetVisArea() ); - aVisArea.nBottom += nTop - aVisArea.nTop; - aVisArea.nTop = nTop; - SetVisArea( aVisArea ); - } - } - else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sUNO_View_VisibleAreaLeft ) ) ) - { - sal_Int32 nLeft = 0; - if( pValue->Value >>= nLeft ) - { - Rectangle aVisArea( GetVisArea() ); - aVisArea.nRight += nLeft - aVisArea.nLeft; - aVisArea.nLeft = nLeft; - SetVisArea( aVisArea ); - } - } - else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sUNO_View_VisibleAreaWidth ) ) ) - { - sal_Int32 nWidth = 0; - if( pValue->Value >>= nWidth ) - { - Rectangle aVisArea( GetVisArea() ); - aVisArea.nRight = aVisArea.nLeft + nWidth - 1; - SetVisArea( aVisArea ); - } - } - else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sUNO_View_VisibleAreaHeight ) ) ) - { - sal_Int32 nHeight = 0; - if( pValue->Value >>= nHeight ) - { - Rectangle aVisArea( GetVisArea() ); - aVisArea.nBottom = nHeight + aVisArea.nTop - 1; - SetVisArea( aVisArea ); - } - } - - else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sUNO_View_GridIsVisible ) ) ) - { - if( pValue->Value >>= bBool ) - { - SetGridVisible( bBool ); - } - } - - else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sUNO_View_IsSnapToGrid ) ) ) - { - if( pValue->Value >>= bBool ) - { - SetGridSnap( bBool ); - } - } - else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sUNO_View_GridIsFront ) ) ) - { - if( pValue->Value >>= bBool ) - { - SetGridFront( bBool ); - } - } - else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sUNO_View_IsSnapToPageMargins ) ) ) - { - if( pValue->Value >>= bBool ) - { - SetBordSnap( bBool ); - } - } - else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sUNO_View_IsSnapToSnapLines ) ) ) - { - if( pValue->Value >>= bBool ) - { - SetHlplSnap( bBool ); - } - } - else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sUNO_View_IsSnapToObjectFrame ) ) ) - { - if( pValue->Value >>= bBool ) - { - SetOFrmSnap( bBool ); - } - } - else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sUNO_View_IsSnapToObjectPoints ) ) ) - { - if( pValue->Value >>= bBool ) - { - SetOPntSnap( bBool ); - } - } - else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sUNO_View_IsPlusHandlesAlwaysVisible ) ) ) - { - if( pValue->Value >>= bBool ) - { - SetPlusHandlesAlwaysVisible( bBool ); - } - } - else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sUNO_View_IsFrameDragSingles ) ) ) - { - if( pValue->Value >>= bBool ) - { - SetFrameDragSingles( bBool ); - } - } - else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sUNO_View_EliminatePolyPointLimitAngle ) ) ) - { - if( pValue->Value >>= nInt32 ) - { - SetEliminatePolyPointLimitAngle( nInt32 ); - } - } - else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sUNO_View_IsEliminatePolyPoints ) ) ) - { - if( pValue->Value >>= bBool ) - { - SetEliminatePolyPoints( bBool ); - } - } - else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sUNO_View_ActiveLayer ) ) ) - { - if( pValue->Value >>= aString ) - { - SetActiveLayer( aString ); - } - } - else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sUNO_View_NoAttribs ) ) ) - { - if( pValue->Value >>= bBool ) - { - SetNoAttribs( bBool ); - } - } - else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sUNO_View_NoColors ) ) ) - { - if( pValue->Value >>= bBool ) - { - SetNoColors( bBool ); - } - } - else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sUNO_View_GridCoarseWidth ) ) ) - { - if( pValue->Value >>= nInt32 ) - { - const Size aCoarse( nInt32, GetGridCoarse().Height() ); - SetGridCoarse( aCoarse ); - } - } - else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sUNO_View_GridCoarseHeight ) ) ) - { - if( pValue->Value >>= nInt32 ) - { - const Size aCoarse( GetGridCoarse().Width(), nInt32 ); - SetGridCoarse( aCoarse ); - } - } - else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sUNO_View_GridFineWidth ) ) ) - { - if( pValue->Value >>= nInt32 ) - { - const Size aCoarse( nInt32, GetGridFine().Height() ); - SetGridFine( aCoarse ); - } - } - else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sUNO_View_GridFineHeight ) ) ) - { - if( pValue->Value >>= nInt32 ) - { - const Size aCoarse( GetGridFine().Width(), nInt32 ); - SetGridFine( aCoarse ); - } - } - else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sUNO_View_IsAngleSnapEnabled ) ) ) - { - if( pValue->Value >>= bBool ) - { - SetAngleSnapEnabled( bBool ); - } - } - else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sUNO_View_SnapAngle ) ) ) - { - if( pValue->Value >>= nInt32 ) - { - SetSnapAngle( nInt32 ); - } - } - else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sUNO_View_GridSnapWidthXNumerator ) ) ) - { - pValue->Value >>= aSnapGridWidthXNum; - } - else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sUNO_View_GridSnapWidthXDenominator ) ) ) - { - pValue->Value >>= aSnapGridWidthXDom; - } - else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sUNO_View_GridSnapWidthYNumerator ) ) ) - { - pValue->Value >>= aSnapGridWidthYNum; - } - else if (pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sUNO_View_GridSnapWidthYDenominator ) ) ) - { - pValue->Value >>= aSnapGridWidthYDom; - } - else if (!bImpress && pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sUNO_View_VisibleLayers ) ) ) - { - SetOfByte aSetOfBytes; - aSetOfBytes.PutValue( pValue->Value ); - SetVisibleLayers( aSetOfBytes ); - } - else if (!bImpress && pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sUNO_View_PrintableLayers ) ) ) - { - SetOfByte aSetOfBytes; - aSetOfBytes.PutValue( pValue->Value ); - SetPrintableLayers( aSetOfBytes ); - } - else if (!bImpress && pValue->Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sUNO_View_LockedLayers ) ) ) - { - SetOfByte aSetOfBytes; - aSetOfBytes.PutValue( pValue->Value ); - SetLockedLayers( aSetOfBytes ); - } - } - - switch (GetPageKindOnLoad()) - { - case PK_STANDARD: SetViewShEditModeOnLoad(meStandardEditMode); break; - case PK_NOTES: SetViewShEditModeOnLoad(meNotesEditMode); break; - case PK_HANDOUT: SetViewShEditModeOnLoad(meHandoutEditMode); break; - default: SetViewShEditModeOnLoad(EM_PAGE); break; - } - - const Fraction aSnapGridWidthX( aSnapGridWidthXNum, aSnapGridWidthXDom ); - const Fraction aSnapGridWidthY( aSnapGridWidthYNum, aSnapGridWidthYDom ); - - SetSnapGridWidth( aSnapGridWidthX, aSnapGridWidthY ); - } -} - - - - -void FrameView::SetPreviousViewShellType (ViewShell::ShellType eType) -{ - mePreviousViewShellType = eType; -} - - - - -ViewShell::ShellType FrameView::GetPreviousViewShellType (void) const -{ - return mePreviousViewShellType; -} - - - - -void FrameView::SetViewShellTypeOnLoad (ViewShell::ShellType eType) -{ - meViewShellTypeOnLoad = eType; -} - - - - -ViewShell::ShellType FrameView::GetViewShellTypeOnLoad (void) const -{ - return meViewShellTypeOnLoad; -} - - - - -void FrameView::SetSelectedPage(sal_uInt16 nPage) -{ - mnSelectedPage = nPage; -} - - - - -sal_uInt16 FrameView::GetSelectedPage (void) const -{ - return mnSelectedPage; -} - - - - -void FrameView::SetIsNavigatorShowingAllShapes (const bool bIsNavigatorShowingAllShapes) -{ - mbIsNavigatorShowingAllShapes = bIsNavigatorShowingAllShapes; -} - - - - -bool FrameView::IsNavigatorShowingAllShapes (void) const -{ - return mbIsNavigatorShowingAllShapes; -} - - -} // end of namespace sd - -/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ |