/* -*- 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 * * for a copy of the LGPLv3 License. * ************************************************************************/ #include #include "DrawViewShell.hxx" #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #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 #include "LayerTabBar.hxx" #include 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( GetDoc()->getUnoModel(), UNO_QUERY_THROW ); Reference 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 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: */