/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ /* * This file is part of the LibreOffice project. * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. * * This file incorporates work covered by the following license notice: * * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed * with this work for additional information regarding copyright * ownership. The ASF licenses this file to you under the Apache * License, Version 2.0 (the "License"); you may not use this file * except in compliance with the License. You may obtain a copy of * the License at http://www.apache.org/licenses/LICENSE-2.0 . */ #include "BezierObjectBar.hxx" #include #include #include #include #include #include #include #include #include #include #include #include "sdresid.hxx" #include "res_bmp.hrc" #include "glob.hrc" #include "strings.hrc" #include "DrawDocShell.hxx" #include "ViewShell.hxx" #include "Window.hxx" #include "drawview.hxx" #include "drawdoc.hxx" #include "fusel.hxx" #include "fuconbez.hxx" using namespace sd; #define BezierObjectBar #include "sdslots.hxx" namespace sd { /** * Declare default interface (Slotmap must not be empty) */ SFX_IMPL_INTERFACE(BezierObjectBar, ::SfxShell) void BezierObjectBar::InitInterface_Impl() { } BezierObjectBar::BezierObjectBar( ViewShell* pSdViewShell, ::sd::View* pSdView) : SfxShell(pSdViewShell->GetViewShell()), mpView(pSdView), mpViewSh(pSdViewShell) { DrawDocShell* pDocShell = mpViewSh->GetDocSh(); SetPool(&pDocShell->GetPool()); SetUndoManager(pDocShell->GetUndoManager()); SetRepeatTarget(mpView); SetHelpId( SD_IF_SDDRAWBEZIEROBJECTBAR ); } BezierObjectBar::~BezierObjectBar() { SetRepeatTarget(nullptr); } /** * Status of attribute items. */ void BezierObjectBar::GetAttrState(SfxItemSet& rSet) { SfxItemSet aAttrSet( mpView->GetDoc().GetPool() ); mpView->GetAttributes( aAttrSet ); rSet.Put(aAttrSet, false); // <- sal_False, so DontCare-Status gets acquired rtl::Reference xFunc( mpViewSh->GetCurrentFunction() ); if(xFunc.is()) { if( nullptr != dynamic_cast< const FuSelection *>( xFunc.get() )) { sal_uInt16 nEditMode = static_cast(xFunc.get())->GetEditMode(); rSet.Put(SfxBoolItem(nEditMode, true)); } else if( nullptr != dynamic_cast< const FuConstructBezierPolygon *>( xFunc.get() )) { sal_uInt16 nEditMode = static_cast(xFunc.get())->GetEditMode(); rSet.Put(SfxBoolItem(nEditMode, true)); } } if(!mpView->IsMoveAllowed() || !mpView->IsResizeAllowed()) { // #i77187# if object is move and/or size protected, do not allow point editing at all rSet.DisableItem(SID_BEZIER_MOVE); rSet.DisableItem(SID_BEZIER_INSERT); rSet.DisableItem(SID_BEZIER_DELETE); rSet.DisableItem(SID_BEZIER_CUTLINE); rSet.DisableItem(SID_BEZIER_CONVERT); rSet.DisableItem(SID_BEZIER_EDGE); rSet.DisableItem(SID_BEZIER_SMOOTH); rSet.DisableItem(SID_BEZIER_SYMMTR); rSet.DisableItem(SID_BEZIER_CLOSE); rSet.DisableItem(SID_BEZIER_ELIMINATE_POINTS); } else { IPolyPolygonEditorController* pIPPEC = nullptr; if( mpView->GetMarkedObjectList().GetMarkCount() ) pIPPEC = mpView; else pIPPEC = dynamic_cast< IPolyPolygonEditorController* >( mpView->getSmartTags().getSelected().get() ); if ( !pIPPEC || !pIPPEC->IsRipUpAtMarkedPointsPossible()) { rSet.DisableItem(SID_BEZIER_CUTLINE); } if (!pIPPEC || !pIPPEC->IsDeleteMarkedPointsPossible()) { rSet.DisableItem(SID_BEZIER_DELETE); } if (!pIPPEC || !pIPPEC->IsSetMarkedSegmentsKindPossible()) { rSet.DisableItem(SID_BEZIER_CONVERT); } else { SdrPathSegmentKind eSegm = pIPPEC->GetMarkedSegmentsKind(); switch (eSegm) { case SDRPATHSEGMENT_DONTCARE: rSet.InvalidateItem(SID_BEZIER_CONVERT); break; case SDRPATHSEGMENT_LINE : rSet.Put(SfxBoolItem(SID_BEZIER_CONVERT,false)); break; // Button down = curve case SDRPATHSEGMENT_CURVE : rSet.Put(SfxBoolItem(SID_BEZIER_CONVERT,true)); break; default: break; } } if (!pIPPEC || !pIPPEC->IsSetMarkedPointsSmoothPossible()) { rSet.DisableItem(SID_BEZIER_EDGE); rSet.DisableItem(SID_BEZIER_SMOOTH); rSet.DisableItem(SID_BEZIER_SYMMTR); } else { SdrPathSmoothKind eSmooth = pIPPEC->GetMarkedPointsSmooth(); switch (eSmooth) { case SDRPATHSMOOTH_DONTCARE : break; case SDRPATHSMOOTH_ANGULAR : rSet.Put(SfxBoolItem(SID_BEZIER_EDGE, true)); break; case SDRPATHSMOOTH_ASYMMETRIC: rSet.Put(SfxBoolItem(SID_BEZIER_SMOOTH,true)); break; case SDRPATHSMOOTH_SYMMETRIC : rSet.Put(SfxBoolItem(SID_BEZIER_SYMMTR,true)); break; } } if (!pIPPEC || !pIPPEC->IsOpenCloseMarkedObjectsPossible()) { rSet.DisableItem(SID_BEZIER_CLOSE); } else { SdrObjClosedKind eClose = pIPPEC->GetMarkedObjectsClosedState(); switch (eClose) { case SDROBJCLOSED_DONTCARE: rSet.InvalidateItem(SID_BEZIER_CLOSE); break; case SDROBJCLOSED_OPEN : rSet.Put(SfxBoolItem(SID_BEZIER_CLOSE,false)); break; case SDROBJCLOSED_CLOSED : rSet.Put(SfxBoolItem(SID_BEZIER_CLOSE,true)); break; default: break; } } if(pIPPEC == mpView) rSet.Put(SfxBoolItem(SID_BEZIER_ELIMINATE_POINTS, mpView->IsEliminatePolyPoints())); else rSet.DisableItem( SID_BEZIER_ELIMINATE_POINTS ); // only works for views } } /** * Process SfxRequests */ void BezierObjectBar::Execute(SfxRequest& rReq) { sal_uInt16 nSId = rReq.GetSlot(); switch (nSId) { case SID_BEZIER_CUTLINE: case SID_BEZIER_CONVERT: case SID_BEZIER_DELETE: case SID_BEZIER_EDGE: case SID_BEZIER_SMOOTH: case SID_BEZIER_SYMMTR: case SID_BEZIER_CLOSE: { const SdrMarkList& rMarkList = mpView->GetMarkedObjectList(); IPolyPolygonEditorController* pIPPEC = nullptr; if( rMarkList.GetMarkCount() ) pIPPEC = mpView; else pIPPEC = dynamic_cast< IPolyPolygonEditorController* >( mpView->getSmartTags().getSelected().get() ); if( pIPPEC && !mpView->IsAction()) { switch (nSId) { case SID_BEZIER_DELETE: pIPPEC->DeleteMarkedPoints(); break; case SID_BEZIER_CUTLINE: pIPPEC->RipUpAtMarkedPoints(); break; case SID_BEZIER_CONVERT: { pIPPEC->SetMarkedSegmentsKind(SDRPATHSEGMENT_TOGGLE); break; } case SID_BEZIER_EDGE: case SID_BEZIER_SMOOTH: case SID_BEZIER_SYMMTR: { SdrPathSmoothKind eKind; switch (nSId) { default: case SID_BEZIER_EDGE: eKind = SDRPATHSMOOTH_ANGULAR; break; case SID_BEZIER_SMOOTH: eKind = SDRPATHSMOOTH_ASYMMETRIC; break; case SID_BEZIER_SYMMTR: eKind = SDRPATHSMOOTH_SYMMETRIC; break; } pIPPEC->SetMarkedPointsSmooth(eKind); break; } case SID_BEZIER_CLOSE: { SdrPathObj* pPathObj = static_cast( rMarkList.GetMark(0)->GetMarkedSdrObj() ); const bool bUndo = mpView->IsUndoEnabled(); if( bUndo ) mpView->BegUndo(SD_RESSTR(STR_UNDO_BEZCLOSE)); mpView->UnmarkAllPoints(); if( bUndo ) mpView->AddUndo(mpView->GetModel()->GetSdrUndoFactory().CreateUndoGeoObject(*pPathObj)); pPathObj->ToggleClosed(); if( bUndo ) mpView->EndUndo(); break; } } } if( (pIPPEC == mpView) && !mpView->AreObjectsMarked() ) mpViewSh->GetViewFrame()->GetDispatcher()->Execute(SID_OBJECT_SELECT, SfxCallMode::ASYNCHRON); rReq.Ignore(); } break; case SID_BEZIER_ELIMINATE_POINTS: { mpView->SetEliminatePolyPoints(!mpView->IsEliminatePolyPoints()); Invalidate(SID_BEZIER_ELIMINATE_POINTS); rReq.Done(); } break; case SID_BEZIER_MOVE: case SID_BEZIER_INSERT: { rtl::Reference xFunc( mpViewSh->GetCurrentFunction() ); if(xFunc.is()) { if( nullptr != dynamic_cast< const FuSelection *>( xFunc.get() )) { static_cast(xFunc.get())->SetEditMode(rReq.GetSlot()); } else if( nullptr != dynamic_cast< const FuConstructBezierPolygon *>( xFunc.get() )) { static_cast(xFunc.get())->SetEditMode(rReq.GetSlot()); } } rReq.Ignore (); } break; default: break; } Invalidate(); } } // end of namespace sd /* vim:set shiftwidth=4 softtabstop=4 expandtab: */