summaryrefslogtreecommitdiff
path: root/sd/source/ui/view/drviews4.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'sd/source/ui/view/drviews4.cxx')
-rw-r--r--sd/source/ui/view/drviews4.cxx986
1 files changed, 0 insertions, 986 deletions
diff --git a/sd/source/ui/view/drviews4.cxx b/sd/source/ui/view/drviews4.cxx
deleted file mode 100644
index aa5ef82b3..000000000
--- a/sd/source/ui/view/drviews4.cxx
+++ /dev/null
@@ -1,986 +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 <com/sun/star/drawing/XDrawPagesSupplier.hpp>
-
-#include "DrawViewShell.hxx"
-#include <vcl/msgbox.hxx>
-#include <svl/urlbmk.hxx>
-#include <svx/svdpagv.hxx>
-#include <svx/svdundo.hxx>
-#include <svx/fmglob.hxx>
-#include <editeng/eeitem.hxx>
-#include <editeng/flditem.hxx>
-#include <svx/svxids.hrc>
-#include <svx/ruler.hxx>
-#include <svx/globl3d.hxx>
-#include <editeng/outliner.hxx>
-#include <sfx2/ipclient.hxx>
-#include <sfx2/request.hxx>
-#include <sfx2/dispatch.hxx>
-#include <svx/svdopath.hxx>
-#include <sfx2/viewfrm.hxx>
-#include <editeng/editview.hxx>
-#include <vcl/cursor.hxx>
-
-
-#include "app.hrc"
-#include "glob.hrc"
-#include "strings.hrc"
-#include "res_bmp.hrc"
-#include "DrawDocShell.hxx"
-#include "drawdoc.hxx"
-#include "Window.hxx"
-#include "fupoor.hxx"
-#include "fusnapln.hxx"
-#include "app.hxx"
-#include "Ruler.hxx"
-#include "sdresid.hxx"
-#include "GraphicViewShell.hxx"
-#include "sdpage.hxx"
-#include "slideshow.hxx"
-#include "anminfo.hxx"
-#include "sdpopup.hxx"
-#include "drawview.hxx"
-#include <svx/bmpmask.hxx>
-#include "LayerTabBar.hxx"
-
-#include <svx/svditer.hxx>
-
-namespace sd {
-
-#define PIPETTE_RANGE 0
-
-#ifdef _MSC_VER
-#pragma optimize ( "", off )
-#endif
-
-using namespace ::com::sun::star::uno;
-using namespace ::com::sun::star::drawing;
-
-/*************************************************************************
-|*
-|* aktuelle Seite loeschen
-|*
-\************************************************************************/
-
-void DrawViewShell::DeleteActualPage()
-{
- sal_uInt16 nPage = maTabControl.GetCurPageId() - 1;
-
- mpDrawView->SdrEndTextEdit();
-
- try
- {
- Reference<XDrawPagesSupplier> xDrawPagesSupplier( GetDoc()->getUnoModel(), UNO_QUERY_THROW );
- Reference<XDrawPages> xPages( xDrawPagesSupplier->getDrawPages(), UNO_QUERY_THROW );
- Reference< XDrawPage > xPage( xPages->getByIndex( nPage ), UNO_QUERY_THROW );
- xPages->remove( xPage );
- }
- catch( Exception& )
- {
- OSL_FAIL("SelectionManager::DeleteSelectedMasterPages(), exception caught!");
- }
-}
-
-/*************************************************************************
-|*
-|* aktuelle Ebene loeschen
-|*
-\************************************************************************/
-
-void DrawViewShell::DeleteActualLayer()
-{
- SdrLayerAdmin& rAdmin = GetDoc()->GetLayerAdmin();
- const String& rName = GetLayerTabControl()->GetPageText(GetLayerTabControl()->GetCurPageId());
- String aString(SdResId(STR_ASK_DELETE_LAYER));
-
- // Platzhalter ersetzen
- sal_uInt16 nPos = aString.Search(sal_Unicode('$'));
- aString.Erase(nPos, 1);
- aString.Insert(rName, nPos);
-
- if (QueryBox(GetActiveWindow(), WB_YES_NO, aString).Execute() == RET_YES)
- {
- const SdrLayer* pLayer = rAdmin.GetLayer(rName, sal_False);
- mpDrawView->DeleteLayer( pLayer->GetName() );
-
- // damit TabBar und Window neu gezeichnet werden;
- // sollte spaeter wie beim Aendern der Layerfolge durch einen
- // Hint von Joe angestossen werden
- // ( View::Notify() --> ViewShell::ResetActualLayer() )
-
- mbIsLayerModeActive = false; // damit ChangeEditMode() ueberhaupt was tut
- ChangeEditMode(GetEditMode(), true);
- }
-}
-
-
-/*************************************************************************
-|*
-|* Keyboard event
-|*
-\************************************************************************/
-
-sal_Bool DrawViewShell::KeyInput (const KeyEvent& rKEvt, ::sd::Window* pWin)
-{
- sal_Bool bRet = sal_False;
-
- if ( !IsInputLocked() || ( rKEvt.GetKeyCode().GetCode() == KEY_ESCAPE ) )
- {
- if(KEY_RETURN == rKEvt.GetKeyCode().GetCode()
- && rKEvt.GetKeyCode().IsMod1()
- && GetView()->IsTextEdit())
- {
- // this should be used for cursor travelling.
- SdPage* pActualPage = GetActualPage();
- const SdrMarkList& rMarkList = GetView()->GetMarkedObjectList();
- SdrTextObj* pCandidate = 0L;
-
- if(pActualPage && 1 == rMarkList.GetMarkCount())
- {
- SdrMark* pMark = rMarkList.GetMark(0);
-
- // remember which object was the text in edit mode
- SdrObject* pOldObj = pMark->GetMarkedSdrObj();
-
- // end text edit now
- GetView()->SdrEndTextEdit();
-
- // look for a new candidate, a successor of pOldObj
- SdrObjListIter aIter(*pActualPage, IM_DEEPNOGROUPS);
- sal_Bool bDidVisitOldObject(sal_False);
-
- while(aIter.IsMore() && !pCandidate)
- {
- SdrObject* pObj = aIter.Next();
-
- if(pObj && pObj->ISA(SdrTextObj))
- {
- sal_uInt32 nInv(pObj->GetObjInventor());
- sal_uInt16 nKnd(pObj->GetObjIdentifier());
-
- if(SdrInventor == nInv &&
- (OBJ_TITLETEXT == nKnd || OBJ_OUTLINETEXT == nKnd || OBJ_TEXT == nKnd)
- && bDidVisitOldObject)
- {
- pCandidate = (SdrTextObj*)pObj;
- }
-
- if(pObj == pOldObj)
- {
- bDidVisitOldObject = sal_True;
- }
- }
- }
- }
-
- if(pCandidate)
- {
- // set the new candidate to text edit mode
- GetView()->UnMarkAll();
- GetView()->MarkObj(pCandidate, GetView()->GetSdrPageView());
-
- GetViewFrame()->GetDispatcher()->Execute(
- SID_ATTR_CHAR, SFX_CALLMODE_ASYNCHRON);
- }
- else
- {
- // insert a new page with the same page layout
- GetViewFrame()->GetDispatcher()->Execute(
- SID_INSERTPAGE_QUICK, SFX_CALLMODE_ASYNCHRON);
- }
- }
- else
- {
- bRet = ViewShell::KeyInput(rKEvt, pWin);
- }
- }
-
- return bRet;
-}
-
-/*************************************************************************
-|*
-|* Vom Lineal ausgehenden Drag (Hilflinien, Ursprung) beginnen
-|*
-\************************************************************************/
-
-void DrawViewShell::StartRulerDrag (
- const Ruler& rRuler,
- const MouseEvent& rMEvt)
-{
- GetActiveWindow()->CaptureMouse();
-
- Point aWPos = GetActiveWindow()->PixelToLogic(GetActiveWindow()->GetPointerPosPixel());
-
- if ( rRuler.GetExtraRect().IsInside(rMEvt.GetPosPixel()) )
- {
- mpDrawView->BegSetPageOrg(aWPos);
- mbIsRulerDrag = sal_True;
- }
- else
- {
- // #i34536# if no guide-lines are visible yet, that show them
- if( ! mpDrawView->IsHlplVisible())
- mpDrawView->SetHlplVisible( sal_True );
-
- SdrHelpLineKind eKind;
-
- if ( rMEvt.IsMod1() )
- eKind = SDRHELPLINE_POINT;
- else if ( rRuler.IsHorizontal() )
- eKind = SDRHELPLINE_HORIZONTAL;
- else
- eKind = SDRHELPLINE_VERTICAL;
-
- mpDrawView->BegDragHelpLine(aWPos, eKind);
- mbIsRulerDrag = sal_True;
- }
-}
-
-/*************************************************************************
-|*
-|* MouseButtonDown event
-|*
-\************************************************************************/
-
-void DrawViewShell::MouseButtonDown(const MouseEvent& rMEvt,
- ::sd::Window* pWin)
-{
- // We have to check if a context menu is shown and we have an UI
- // active inplace client. In that case we have to ignore the mouse
- // button down event. Otherwise we would crash (context menu has been
- // opened by inplace client and we would deactivate the inplace client,
- // the contex menu is closed by VCL asynchronously which in the end
- // would work on deleted objects or the context menu has no parent anymore)
- SfxInPlaceClient* pIPClient = GetViewShell()->GetIPClient();
- sal_Bool bIsOleActive = ( pIPClient && pIPClient->IsObjectInPlaceActive() );
-
- if ( bIsOleActive && PopupMenu::IsInExecute() )
- return;
-
- if ( !IsInputLocked() )
- {
- ViewShell::MouseButtonDown(rMEvt, pWin);
-
- if ( mbPipette )
- ( (SvxBmpMask*) GetViewFrame()->GetChildWindow( SvxBmpMaskChildWindow::GetChildWindowId() )->GetWindow() )->PipetteClicked();
- }
-}
-
-/*************************************************************************
-|*
-|* MouseMove event
-|*
-\************************************************************************/
-
-
-void DrawViewShell::MouseMove(const MouseEvent& rMEvt, ::sd::Window* pWin)
-{
- if ( !IsInputLocked() )
- {
- if ( mpDrawView->IsAction() )
- {
- Rectangle aOutputArea(Point(0,0), GetActiveWindow()->GetOutputSizePixel());
-
- if ( !aOutputArea.IsInside(rMEvt.GetPosPixel()) )
- {
- sal_Bool bInsideOtherWindow = sal_False;
-
- if (mpContentWindow.get() != NULL)
- {
- aOutputArea = Rectangle(Point(0,0),
- mpContentWindow->GetOutputSizePixel());
-
- Point aPos = mpContentWindow->GetPointerPosPixel();
- if ( aOutputArea.IsInside(aPos) )
- bInsideOtherWindow = sal_True;
- }
-
- if (! GetActiveWindow()->HasFocus ())
- {
- GetActiveWindow()->ReleaseMouse ();
- mpDrawView->BrkAction ();
- return;
- }
- else if ( bInsideOtherWindow )
- {
- GetActiveWindow()->ReleaseMouse();
- pWin->CaptureMouse ();
- }
- }
- else if ( pWin != GetActiveWindow() )
- pWin->CaptureMouse();
- }
-
- // Since the next MouseMove may execute a IsSolidDraggingNow() in
- // SdrCreateView::MovCreateObj and there the ApplicationBackgroundColor
- // is needed it is necessary to set it here.
- if(mpDrawView!=NULL && GetDoc()!=NULL)
- {
- svtools::ColorConfig aColorConfig;
- Color aFillColor;
-
- if(DOCUMENT_TYPE_IMPRESS == GetDoc()->GetDocumentType())
- {
- aFillColor = Color( aColorConfig.GetColorValue( svtools::APPBACKGROUND ).nColor );
- }
- else
- {
- aFillColor = Color( aColorConfig.GetColorValue( svtools::DOCCOLOR ).nColor );
- }
-
- mpDrawView->SetApplicationBackgroundColor(aFillColor);
- }
-
- ViewShell::MouseMove(rMEvt, pWin);
-
- if( !mbMousePosFreezed )
- maMousePos = rMEvt.GetPosPixel();
-
- Rectangle aRect;
-
- if ( mbIsRulerDrag )
- {
- Point aLogPos = GetActiveWindow()->PixelToLogic(maMousePos);
- mpDrawView->MovAction(aLogPos);
- }
-
- if ( mpDrawView->IsAction() )
- {
- mpDrawView->TakeActionRect(aRect);
- aRect = GetActiveWindow()->LogicToPixel(aRect);
- }
- else
- {
- aRect = Rectangle(maMousePos, maMousePos);
- }
-
- ShowMousePosInfo(aRect, pWin);
-
- if ( mbPipette && GetViewFrame()->HasChildWindow( SvxBmpMaskChildWindow::GetChildWindowId() ) )
- {
- const long nStartX = maMousePos.X() - PIPETTE_RANGE;
- const long nEndX = maMousePos.X() + PIPETTE_RANGE;
- const long nStartY = maMousePos.Y() - PIPETTE_RANGE;
- const long nEndY = maMousePos.Y() + PIPETTE_RANGE;
- long nRed = 0;
- long nGreen = 0;
- long nBlue = 0;
- const double fDiv = ( ( PIPETTE_RANGE << 1 ) + 1 ) * ( ( PIPETTE_RANGE << 1 ) + 1 );
-
- for ( long nY = nStartY; nY <= nEndY; nY++ )
- {
- for( long nX = nStartX; nX <= nEndX; nX++ )
- {
- const Color aCol( pWin->GetPixel( pWin->PixelToLogic( Point( nX, nY ) ) ) );
-
- nRed += aCol.GetRed();
- nGreen += aCol.GetGreen();
- nBlue += aCol.GetBlue();
- }
- }
-
- ( (SvxBmpMask*) GetViewFrame()->GetChildWindow( SvxBmpMaskChildWindow::GetChildWindowId() )->GetWindow() )->
- SetColor( Color( (sal_uInt8) ( nRed / fDiv + .5 ),
- (sal_uInt8) ( nGreen / fDiv + .5 ),
- (sal_uInt8) ( nBlue / fDiv + .5 ) ) );
- }
- }
-}
-
-
-/*************************************************************************
-|*
-|* MouseButtonUp event
-|*
-\************************************************************************/
-
-void DrawViewShell::MouseButtonUp(const MouseEvent& rMEvt, ::sd::Window* pWin)
-{
- if ( !IsInputLocked() )
- {
- bool bIsSetPageOrg = mpDrawView->IsSetPageOrg();
-
- if (mbIsRulerDrag)
- {
- Rectangle aOutputArea(Point(0,0), GetActiveWindow()->GetOutputSizePixel());
-
- if (aOutputArea.IsInside(rMEvt.GetPosPixel()))
- {
- mpDrawView->EndAction();
-
- if (bIsSetPageOrg)
- GetViewFrame()->GetBindings().Invalidate(SID_RULER_NULL_OFFSET);
- }
- else if (rMEvt.IsLeft() && bIsSetPageOrg)
- {
- mpDrawView->BrkAction();
- SdPage* pPage = (SdPage*) mpDrawView->GetSdrPageView()->GetPage();
- Point aOrg(pPage->GetLftBorder(), pPage->GetUppBorder());
- mpDrawView->GetSdrPageView()->SetPageOrigin(aOrg);
- GetViewFrame()->GetBindings().Invalidate(SID_RULER_NULL_OFFSET);
- }
- else
- {
- mpDrawView->BrkAction();
- }
-
- GetActiveWindow()->ReleaseMouse();
- mbIsRulerDrag = sal_False;
- }
- else
- ViewShell::MouseButtonUp(rMEvt, pWin);
- }
-}
-
-/*************************************************************************
-|*
-|* Command event
-|*
-\************************************************************************/
-
-void DrawViewShell::Command(const CommandEvent& rCEvt, ::sd::Window* pWin)
-{
- // The command event is send to the window after a possible context
- // menu from an inplace client is closed. Now we have the chance to
- // deactivate the inplace client without any problem regarding parent
- // windows and code on the stack.
- SfxInPlaceClient* pIPClient = GetViewShell()->GetIPClient();
- sal_Bool bIsOleActive = ( pIPClient && pIPClient->IsObjectInPlaceActive() );
- if ( bIsOleActive && ( rCEvt.GetCommand() == COMMAND_CONTEXTMENU ))
- {
- // Deactivate OLE object
- mpDrawView->UnmarkAll();
- SelectionHasChanged();
- return;
- }
-
- if ( !IsInputLocked() )
- {
- if( GetView() &&GetView()->getSmartTags().Command(rCEvt) )
- return;
-
- const bool bNativeShow (SlideShow::IsRunning(GetViewShellBase()));
-
- if( rCEvt.GetCommand() == COMMAND_PASTESELECTION && !bNativeShow )
- {
- TransferableDataHelper aDataHelper( TransferableDataHelper::CreateFromSelection( GetActiveWindow() ) );
-
- if( aDataHelper.GetTransferable().is() )
- {
- Point aPos;
- sal_Int8 nDnDAction = DND_ACTION_COPY;
-
- if( GetActiveWindow() )
- aPos = GetActiveWindow()->PixelToLogic( rCEvt.GetMousePosPixel() );
-
- if( !mpDrawView->InsertData( aDataHelper, aPos, nDnDAction, sal_False ) )
- {
- INetBookmark aINetBookmark( aEmptyStr, aEmptyStr );
-
- if( ( aDataHelper.HasFormat( SOT_FORMATSTR_ID_NETSCAPE_BOOKMARK ) &&
- aDataHelper.GetINetBookmark( SOT_FORMATSTR_ID_NETSCAPE_BOOKMARK, aINetBookmark ) ) ||
- ( aDataHelper.HasFormat( SOT_FORMATSTR_ID_FILEGRPDESCRIPTOR ) &&
- aDataHelper.GetINetBookmark( SOT_FORMATSTR_ID_FILEGRPDESCRIPTOR, aINetBookmark ) ) ||
- ( aDataHelper.HasFormat( SOT_FORMATSTR_ID_UNIFORMRESOURCELOCATOR ) &&
- aDataHelper.GetINetBookmark( SOT_FORMATSTR_ID_UNIFORMRESOURCELOCATOR, aINetBookmark ) ) )
- {
- InsertURLField( aINetBookmark.GetURL(), aINetBookmark.GetDescription(), aEmptyStr, NULL );
- }
- }
- }
- }
- else if( rCEvt.GetCommand() == COMMAND_CONTEXTMENU && !bNativeShow &&
- pWin != NULL && !mpDrawView->IsAction() && !SD_MOD()->GetWaterCan() )
- {
- sal_uInt16 nSdResId = 0; // ResourceID fuer Popup-Menue
- sal_Bool bGraphicShell = this->ISA(GraphicViewShell);
-
- // Ist ein Fangobjekt unter dem Mauszeiger?
- SdrPageView* pPV;
- Point aMPos = pWin->PixelToLogic( maMousePos );
- sal_uInt16 nHitLog = (sal_uInt16) GetActiveWindow()->PixelToLogic(
- Size(FuPoor::HITPIX, 0 ) ).Width();
- sal_uInt16 nHelpLine;
- // fuer Klebepunkt
- SdrObject* pObj = NULL;
- sal_uInt16 nPickId = 0;
- // fuer Feldbefehl
- OutlinerView* pOLV = mpDrawView->GetTextEditOutlinerView();
- const SvxFieldItem* pFldItem = NULL;
- if( pOLV )
- pFldItem = pOLV->GetFieldAtSelection();
-
- // Hilfslinie
- if ( mpDrawView->PickHelpLine( aMPos, nHitLog, *GetActiveWindow(), nHelpLine, pPV) )
- {
- nSdResId = RID_DRAW_SNAPOBJECT_POPUP;
- ShowSnapLineContextMenu(*pPV, nHelpLine, rCEvt.GetMousePosPixel());
- return;
- }
- // Klebepunkt unter dem Mauszeiger markiert?
- else if( mpDrawView->PickGluePoint( aMPos, pObj, nPickId, pPV ) &&
- mpDrawView->IsGluePointMarked( pObj, nPickId ) )
- {
- nSdResId = RID_DRAW_GLUEPOINT_POPUP;
- }
- // Feldbefehl ?
- else if( pFldItem && (pFldItem->GetField()->ISA( SvxDateField ) ||
- pFldItem->GetField()->ISA( SvxExtTimeField ) ||
- pFldItem->GetField()->ISA( SvxExtFileField ) ||
- pFldItem->GetField()->ISA( SvxAuthorField ) ) )
- {
- LanguageType eLanguage( LANGUAGE_SYSTEM );
-
- // Format popup with outliner language, if possible
- if( pOLV->GetOutliner() )
- {
- ESelection aSelection( pOLV->GetSelection() );
- eLanguage = pOLV->GetOutliner()->GetLanguage( aSelection.nStartPara, aSelection.nStartPos );
- }
-
- SdFieldPopup aFieldPopup( pFldItem->GetField(), eLanguage );
-
- if ( rCEvt.IsMouseEvent() )
- aMPos = rCEvt.GetMousePosPixel();
- else
- aMPos = Point( 20, 20 );
- aFieldPopup.Execute( pWin, aMPos );
-
- SvxFieldData* pField = aFieldPopup.GetField();
- if( pField )
- {
- SvxFieldItem aFieldItem( *pField, EE_FEATURE_FIELD );
- // Feld selektieren, so dass es beim Insert geloescht wird
- ESelection aSel = pOLV->GetSelection();
- sal_Bool bSel = sal_True;
- if( aSel.nStartPos == aSel.nEndPos )
- {
- bSel = sal_False;
- aSel.nEndPos++;
- }
- pOLV->SetSelection( aSel );
-
- pOLV->InsertField( aFieldItem );
-
- // Selektion wird wieder in den Ursprungszustand gebracht
- if( !bSel )
- aSel.nEndPos--;
- pOLV->SetSelection( aSel );
-
- delete pField;
- }
- }
- else
- {
- // ist etwas selektiert?
- if (mpDrawView->AreObjectsMarked() &&
- mpDrawView->GetMarkedObjectList().GetMarkCount() == 1 )
- {
- pObj = mpDrawView->GetMarkedObjectList().GetMark(0)->GetMarkedSdrObj();
- if( HasCurrentFunction(SID_BEZIER_EDIT) && (dynamic_cast< SdrPathObj * >( pObj ) != 0 ) )
- {
- nSdResId = RID_BEZIER_POPUP;
- }
- else
- {
- if( mpDrawView->GetTextEditObject() )
- {
- OutlinerView* pOutlinerView = mpDrawView->GetTextEditOutlinerView();
- Point aPos(rCEvt.GetMousePosPixel());
-
- if ( pOutlinerView )
- {
- if( ( rCEvt.IsMouseEvent() && pOutlinerView->IsWrongSpelledWordAtPos(aPos) ) ||
- ( !rCEvt.IsMouseEvent() && pOutlinerView->IsCursorAtWrongSpelledWord() ) )
- {
- // Popup for Online-Spelling now handled by DrawDocShell
- Link aLink = LINK(GetDocSh(), DrawDocShell, OnlineSpellCallback);
-
- if( !rCEvt.IsMouseEvent() )
- {
- aPos = GetActiveWindow()->LogicToPixel( pOutlinerView->GetEditView().GetCursor()->GetPos() );
- }
- // While showing the spell context menu
- // we lock the input so that another
- // context menu can not be opened during
- // that time (crash #i43235#). In order
- // to not lock the UI completely we
- // first release the mouse.
- GetActiveWindow()->ReleaseMouse();
- LockInput();
- pOutlinerView->ExecuteSpellPopup(aPos, &aLink);
- UnlockInput();
- }
- else
- {
- if( (pObj->GetObjInventor() == SdrInventor) && (pObj->GetObjIdentifier() == OBJ_TABLE) )
- {
- nSdResId = RID_DRAW_TABLEOBJ_INSIDE_POPUP;
- }
- else
- {
- nSdResId = RID_DRAW_TEXTOBJ_INSIDE_POPUP;
- }
- }
- }
- }
- else
- {
- sal_uInt32 nInv = pObj->GetObjInventor();
- sal_uInt16 nId = pObj->GetObjIdentifier();
-
- if (nInv == SdrInventor)
- {
- switch ( nId )
- {
- case OBJ_OUTLINETEXT:
- nSdResId = bGraphicShell ? RID_GRAPHIC_OUTLINETEXTOBJ_POPUP :
- RID_DRAW_OUTLINETEXTOBJ_POPUP;
- break;
-
- case OBJ_CAPTION:
- case OBJ_TITLETEXT:
- case OBJ_TEXT:
- nSdResId = bGraphicShell ? RID_GRAPHIC_TEXTOBJ_POPUP :
- RID_DRAW_TEXTOBJ_POPUP;
- break;
-
- case OBJ_PATHLINE:
- case OBJ_PLIN:
- nSdResId = bGraphicShell ? RID_GRAPHIC_POLYLINEOBJ_POPUP :
- RID_DRAW_POLYLINEOBJ_POPUP;
- break;
-
- case OBJ_FREELINE:
- case OBJ_EDGE: // Connector
- nSdResId = bGraphicShell ? RID_GRAPHIC_EDGEOBJ_POPUP :
- RID_DRAW_EDGEOBJ_POPUP;
- break;
-
- case OBJ_LINE:
- nSdResId = bGraphicShell ? RID_GRAPHIC_LINEOBJ_POPUP :
- RID_DRAW_LINEOBJ_POPUP;
- break;
-
- case OBJ_MEASURE:
- nSdResId = bGraphicShell ? RID_GRAPHIC_MEASUREOBJ_POPUP :
- RID_DRAW_MEASUREOBJ_POPUP;
- break;
-
- case OBJ_RECT:
- case OBJ_CIRC:
- case OBJ_FREEFILL:
- case OBJ_PATHFILL:
- case OBJ_POLY:
- case OBJ_SECT:
- case OBJ_CARC:
- case OBJ_CCUT:
- nSdResId = bGraphicShell ? RID_GRAPHIC_GEOMOBJ_POPUP :
- RID_DRAW_GEOMOBJ_POPUP;
- break;
-
- case OBJ_CUSTOMSHAPE:
- nSdResId = bGraphicShell ? RID_GRAPHIC_CUSTOMSHAPE_POPUP :
- RID_DRAW_CUSTOMSHAPE_POPUP;
- break;
-
- case OBJ_GRUP:
- nSdResId = bGraphicShell ? RID_GRAPHIC_GROUPOBJ_POPUP :
- RID_DRAW_GROUPOBJ_POPUP;
- break;
-
- case OBJ_GRAF:
- nSdResId = bGraphicShell ? RID_GRAPHIC_GRAPHIC_POPUP :
- RID_DRAW_GRAPHIC_POPUP;
- break;
-
- case OBJ_OLE2:
- nSdResId = bGraphicShell ? RID_GRAPHIC_OLE2_POPUP :
- RID_DRAW_OLE2_POPUP;
- break;
- case OBJ_MEDIA:
- nSdResId = bGraphicShell ? RID_GRAPHIC_MEDIA_POPUP :
- RID_DRAW_MEDIA_POPUP;
- break;
- case OBJ_TABLE:
- nSdResId = bGraphicShell ? RID_GRAPHIC_TABLE_POPUP :
- RID_DRAW_TABLE_POPUP;
- break;
- }
- }
- else if( nInv == E3dInventor )
- {
- if( nId == E3D_POLYSCENE_ID || nId == E3D_SCENE_ID )
- {
- if( !mpDrawView->IsGroupEntered() )
- nSdResId = bGraphicShell ? RID_GRAPHIC_3DSCENE_POPUP :
- RID_DRAW_3DSCENE_POPUP;
- else
- nSdResId = bGraphicShell ? RID_GRAPHIC_3DSCENE2_POPUP :
- RID_DRAW_3DSCENE2_POPUP;
- }
- else
- nSdResId = bGraphicShell ? RID_GRAPHIC_3DOBJ_POPUP :
- RID_DRAW_3DOBJ_POPUP;
- }
- else if( nInv == FmFormInventor )
- {
- nSdResId = RID_FORM_CONTROL_POPUP;
- }
- }
- }
- }
-
- // Mehrfachselektion
- else if (mpDrawView->AreObjectsMarked() &&
- mpDrawView->GetMarkedObjectList().GetMarkCount() > 1 )
- {
- nSdResId = bGraphicShell ? RID_GRAPHIC_MULTISELECTION_POPUP :
- RID_DRAW_MULTISELECTION_POPUP;
- }
-
- // nichts selektiert
- else
- {
- nSdResId = bGraphicShell ? RID_GRAPHIC_NOSEL_POPUP :
- RID_DRAW_NOSEL_POPUP;
- }
- }
- // show Popup-Menu
- if (nSdResId)
- {
- GetActiveWindow()->ReleaseMouse();
-
- if(rCEvt.IsMouseEvent())
- GetViewFrame()->GetDispatcher()->ExecutePopup(SdResId(nSdResId));
- else
- {
- //don't open contextmenu at mouse position if not opened via mouse
-
- //middle of the window if nothing is marked
- Point aMenuPos(GetActiveWindow()->GetSizePixel().Width()/2
- ,GetActiveWindow()->GetSizePixel().Height()/2);
-
- //middle of the bounding rect if something is marked
- if( mpDrawView->AreObjectsMarked() && mpDrawView->GetMarkedObjectList().GetMarkCount() >= 1 )
- {
- Rectangle aMarkRect;
- mpDrawView->GetMarkedObjectList().TakeBoundRect(NULL,aMarkRect);
- aMenuPos = GetActiveWindow()->LogicToPixel( aMarkRect.Center() );
-
- //move the point into the visible window area
- if( aMenuPos.X() < 0 )
- aMenuPos.X() = 0;
- if( aMenuPos.Y() < 0 )
- aMenuPos.Y() = 0;
- if( aMenuPos.X() > GetActiveWindow()->GetSizePixel().Width() )
- aMenuPos.X() = GetActiveWindow()->GetSizePixel().Width();
- if( aMenuPos.Y() > GetActiveWindow()->GetSizePixel().Height() )
- aMenuPos.Y() = GetActiveWindow()->GetSizePixel().Height();
- }
-
- //open context menu at that point
- GetViewFrame()->GetDispatcher()->ExecutePopup(SdResId(nSdResId),GetActiveWindow(),&aMenuPos);
- }
- mbMousePosFreezed = sal_False;
- }
- }
- else
- {
- ViewShell::Command(rCEvt, pWin);
- }
- }
-}
-
-/*************************************************************************
-|*
-|* Linealmarkierungen anzeigen
-|*
-\************************************************************************/
-
-void DrawViewShell::ShowMousePosInfo(const Rectangle& rRect,
- ::sd::Window* pWin)
-{
- if (mbHasRulers && pWin )
- {
- RulerLine pHLines[2];
- RulerLine pVLines[2];
- long nHOffs = 0L;
- long nVOffs = 0L;
- sal_uInt16 nCnt;
-
- if (mpHorizontalRuler.get() != NULL)
- mpHorizontalRuler->SetLines();
-
- if (mpVerticalRuler.get() != NULL)
- mpVerticalRuler->SetLines();
-
- if (mpHorizontalRuler.get() != NULL)
- {
- nHOffs = mpHorizontalRuler->GetNullOffset() +
- mpHorizontalRuler->GetPageOffset();
- }
-
- if (mpVerticalRuler.get() != NULL)
- {
- nVOffs = mpVerticalRuler->GetNullOffset() +
- mpVerticalRuler->GetPageOffset();
- }
-
- nCnt = 1;
- pHLines[0].nPos = rRect.Left() - nHOffs;
- pVLines[0].nPos = rRect.Top() - nVOffs;
- pHLines[0].nStyle = 0;
- pVLines[0].nStyle = 0;
-
- if ( rRect.Right() != rRect.Left() || rRect.Bottom() != rRect.Top() )
- {
- pHLines[1].nPos = rRect.Right() - nHOffs;
- pVLines[1].nPos = rRect.Bottom() - nVOffs;
- pHLines[1].nStyle = 0;
- pVLines[1].nStyle = 0;
- nCnt++;
- }
-
- if (mpHorizontalRuler.get() != NULL)
- mpHorizontalRuler->SetLines(nCnt, pHLines);
- if (mpVerticalRuler.get() != NULL)
- mpVerticalRuler->SetLines(nCnt, pVLines);
- }
-
- // StatusBar Koordinatenanzeige
- OSL_ASSERT (GetViewShell()!=NULL);
- if ( !GetViewShell()->GetUIActiveClient() )
- {
- SfxItemSet aSet(GetPool(), SID_CONTEXT, SID_CONTEXT,
- SID_ATTR_POSITION, SID_ATTR_POSITION,
- SID_ATTR_SIZE, SID_ATTR_SIZE,
- 0L);
-
-// GetStatusBarState(aSet); nicht performant bei gedrueckter Modifiertaste!!
-
- aSet.Put( SfxStringItem( SID_CONTEXT, mpDrawView->GetStatusText() ) );
-
- SfxBindings& rBindings = GetViewFrame()->GetBindings();
- rBindings.SetState(aSet);
- rBindings.Invalidate(SID_CONTEXT);
- rBindings.Invalidate(SID_ATTR_POSITION);
- rBindings.Invalidate(SID_ATTR_SIZE);
- }
-}
-
-void DrawViewShell::LockInput()
-{
- mnLockCount++;
-}
-
-void DrawViewShell::UnlockInput()
-{
- DBG_ASSERT( mnLockCount, "Input for this shell is not locked!" );
- if ( mnLockCount )
- mnLockCount--;
-}
-
-
-
-
-void DrawViewShell::ShowSnapLineContextMenu (
- SdrPageView& rPageView,
- const sal_uInt16 nSnapLineIndex,
- const Point& rMouseLocation)
-{
- const SdrHelpLine& rHelpLine (rPageView.GetHelpLines()[nSnapLineIndex]);
- ::boost::scoped_ptr<PopupMenu> pMenu (new PopupMenu ());
-
- if (rHelpLine.GetKind() == SDRHELPLINE_POINT)
- {
- pMenu->InsertItem(
- SID_SET_SNAPITEM,
- String(SdResId(STR_POPUP_EDIT_SNAPPOINT)));
- pMenu->InsertSeparator();
- pMenu->InsertItem(
- SID_DELETE_SNAPITEM,
- String(SdResId(STR_POPUP_DELETE_SNAPPOINT)));
- }
- else
- {
- pMenu->InsertItem(
- SID_SET_SNAPITEM,
- String(SdResId(STR_POPUP_EDIT_SNAPLINE)));
- pMenu->InsertSeparator();
- pMenu->InsertItem(
- SID_DELETE_SNAPITEM,
- String(SdResId(STR_POPUP_DELETE_SNAPLINE)));
- }
-
- pMenu->RemoveDisabledEntries(sal_False, sal_False);
-
- const sal_uInt16 nResult = pMenu->Execute(
- GetActiveWindow(),
- Rectangle(rMouseLocation, Size(10,10)),
- POPUPMENU_EXECUTE_DOWN);
- switch (nResult)
- {
- case SID_SET_SNAPITEM:
- {
- SfxUInt32Item aHelpLineItem (ID_VAL_INDEX, nSnapLineIndex);
- const SfxPoolItem* aArguments[] = {&aHelpLineItem, NULL};
- GetViewFrame()->GetDispatcher()->Execute(
- SID_SET_SNAPITEM,
- SFX_CALLMODE_SLOT,
- aArguments);
- }
- break;
-
- case SID_DELETE_SNAPITEM:
- {
- rPageView.DeleteHelpLine(nSnapLineIndex);
- }
- break;
-
- default:
- break;
- }
-}
-
-
-
-
-#ifdef _MSC_VER
-#pragma optimize ( "", on )
-#endif
-
-} // end of namespace sd
-
-/* vim:set shiftwidth=4 softtabstop=4 expandtab: */