/************************************************************************* * * $RCSfile: svdglev.cxx,v $ * * $Revision: 1.1.1.1 $ * * last change: $Author: hr $ $Date: 2000-09-18 17:01:24 $ * * The Contents of this file are made available subject to the terms of * either of the following licenses * * - GNU Lesser General Public License Version 2.1 * - Sun Industry Standards Source License Version 1.1 * * Sun Microsystems Inc., October, 2000 * * GNU Lesser General Public License Version 2.1 * ============================================= * Copyright 2000 by Sun Microsystems, Inc. * 901 San Antonio Road, Palo Alto, CA 94303, USA * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License version 2.1, as published by the Free Software Foundation. * * This library 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 for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * MA 02111-1307 USA * * * Sun Industry Standards Source License Version 1.1 * ================================================= * The contents of this file are subject to the Sun Industry Standards * Source License Version 1.1 (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.openoffice.org/license.html. * * Software provided under this License is provided on an "AS IS" basis, * WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, * WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS, * MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING. * See the License for the specific provisions governing your rights and * obligations concerning the Software. * * The Initial Developer of the Original Code is: Sun Microsystems, Inc. * * Copyright: 2000 by Sun Microsystems, Inc. * * All Rights Reserved. * * Contributor(s): _______________________________________ * * ************************************************************************/ #include "svdglev.hxx" #include #include "svdundo.hxx" #include "svdstr.hrc" // Namen aus der Resource #include "svdglob.hxx" // StringCache #include "svdpagv.hxx" #include "svdglue.hxx" #include "svdtrans.hxx" #include "svdobj.hxx" //////////////////////////////////////////////////////////////////////////////////////////////////// void SdrGlueEditView::ImpClearVars() { } SdrGlueEditView::SdrGlueEditView(SdrModel* pModel1, OutputDevice* pOut): SdrPolyEditView(pModel1,pOut) { ImpClearVars(); } SdrGlueEditView::SdrGlueEditView(SdrModel* pModel1, ExtOutputDevice* pXOut): SdrPolyEditView(pModel1,pXOut) { ImpClearVars(); } SdrGlueEditView::~SdrGlueEditView() { } //////////////////////////////////////////////////////////////////////////////////////////////////// void SdrGlueEditView::ImpDoMarkedGluePoints(PGlueDoFunc pDoFunc, BOOL bConst, const void* p1, const void* p2, const void* p3, const void* p4, const void* p5) { ULONG nMarkAnz=aMark.GetMarkCount(); for (ULONG nm=0; nmGetObj(); const SdrUShortCont* pPts=pM->GetMarkedGluePoints(); ULONG nPtAnz=pPts==NULL ? 0 : pPts->GetCount(); if (nPtAnz!=0) { SdrGluePointList* pGPL=NULL; if (bConst) { const SdrGluePointList* pConstGPL=pObj->GetGluePointList(); pGPL=(SdrGluePointList*)pConstGPL; } else { pGPL=pObj->ForceGluePointList(); } if (pGPL!=NULL) { if (!bConst) AddUndo(new SdrUndoGeoObj(*pObj)); for (ULONG nPtNum=0; nPtNumGetObject(nPtNum); USHORT nGlueIdx=pGPL->FindGluePoint(nPtId); if (nGlueIdx!=SDRGLUEPOINT_NOTFOUND) { SdrGluePoint& rGP=(*pGPL)[nGlueIdx]; (*pDoFunc)(rGP,pObj,p1,p2,p3,p4,p5); } } if (!bConst) pObj->SendRepaintBroadcast(); } } } if (!bConst && nMarkAnz!=0) pMod->SetChanged(); } //////////////////////////////////////////////////////////////////////////////////////////////////// static void ImpGetEscDir(SdrGluePoint& rGP, const SdrObject* pObj, const void* pbFirst, const void* pnThisEsc, const void* pnRet, const void*, const void*) { USHORT& nRet=*(USHORT*)pnRet; BOOL& bFirst=*(BOOL*)pbFirst; if (nRet!=FUZZY) { USHORT nEsc=rGP.GetEscDir(); BOOL bOn=(nEsc & *(USHORT*)pnThisEsc)!=0; if (bFirst) { nRet=bOn; bFirst=FALSE; } else if (nRet!=bOn) nRet=FUZZY; } } TRISTATE SdrGlueEditView::IsMarkedGluePointsEscDir(USHORT nThisEsc) const { ForceUndirtyMrkPnt(); BOOL bFirst=TRUE; USHORT nRet=FALSE; ((SdrGlueEditView*)this)->ImpDoMarkedGluePoints(ImpGetEscDir,TRUE,&bFirst,&nThisEsc,&nRet); return (TRISTATE)nRet; } static void ImpSetEscDir(SdrGluePoint& rGP, const SdrObject* pObj, const void* pnThisEsc, const void* pbOn, const void*, const void*, const void*) { USHORT nEsc=rGP.GetEscDir(); if (*(BOOL*)pbOn) nEsc|=*(USHORT*)pnThisEsc; else nEsc&=~*(USHORT*)pnThisEsc; rGP.SetEscDir(nEsc); } void SdrGlueEditView::SetMarkedGluePointsEscDir(USHORT nThisEsc, BOOL bOn) { ForceUndirtyMrkPnt(); BegUndo(ImpGetResStr(STR_EditSetGlueEscDir),aMark.GetGluePointMarkDescription()); ImpDoMarkedGluePoints(ImpSetEscDir,FALSE,&nThisEsc,&bOn); EndUndo(); } //////////////////////////////////////////////////////////////////////////////////////////////////// static void ImpGetPercent(SdrGluePoint& rGP, const SdrObject* pObj, const void* pbFirst, const void* pnRet, const void*, const void*, const void*) { USHORT& nRet=*(USHORT*)pnRet; BOOL& bFirst=*(BOOL*)pbFirst; if (nRet!=FUZZY) { BOOL bOn=rGP.IsPercent(); if (bFirst) { nRet=bOn; bFirst=FALSE; } else if (nRet!=bOn) nRet=FUZZY; } } TRISTATE SdrGlueEditView::IsMarkedGluePointsPercent() const { ForceUndirtyMrkPnt(); BOOL bFirst=TRUE; USHORT nRet=TRUE; ((SdrGlueEditView*)this)->ImpDoMarkedGluePoints(ImpGetPercent,TRUE,&bFirst,&nRet); return (TRISTATE)nRet; } static void ImpSetPercent(SdrGluePoint& rGP, const SdrObject* pObj, const void* pbOn, const void*, const void*, const void*, const void*) { Point aPos(rGP.GetAbsolutePos(*pObj)); rGP.SetPercent(*(BOOL*)pbOn); rGP.SetAbsolutePos(aPos,*pObj); } void SdrGlueEditView::SetMarkedGluePointsPercent(BOOL bOn) { ForceUndirtyMrkPnt(); BegUndo(ImpGetResStr(STR_EditSetGluePercent),aMark.GetGluePointMarkDescription()); ImpDoMarkedGluePoints(ImpSetPercent,FALSE,&bOn); EndUndo(); } //////////////////////////////////////////////////////////////////////////////////////////////////// static void ImpGetAlign(SdrGluePoint& rGP, const SdrObject* pObj, const void* pbFirst, const void* pbDontCare, const void* pbVert, const void* pnRet, const void*) { USHORT& nRet=*(USHORT*)pnRet; BOOL& bFirst=*(BOOL*)pbFirst; BOOL& bDontCare=*(BOOL*)pbDontCare; BOOL bVert=*(BOOL*)pbVert; if (!bDontCare) { USHORT nAlg=0; if (bVert) { nAlg=rGP.GetVertAlign(); } else { nAlg=rGP.GetHorzAlign(); } if (bFirst) { nRet=nAlg; bFirst=FALSE; } else if (nRet!=nAlg) { if (bVert) { nRet=SDRVERTALIGN_DONTCARE; } else { nRet=SDRHORZALIGN_DONTCARE; } bDontCare=TRUE; } } } USHORT SdrGlueEditView::GetMarkedGluePointsAlign(BOOL bVert) const { ForceUndirtyMrkPnt(); BOOL bFirst=TRUE; BOOL bDontCare=FALSE; USHORT nRet=0; ((SdrGlueEditView*)this)->ImpDoMarkedGluePoints(ImpGetAlign,TRUE,&bFirst,&bDontCare,&bVert,&nRet); return nRet; } static void ImpSetAlign(SdrGluePoint& rGP, const SdrObject* pObj, const void* pbVert, const void* pnAlign, const void*, const void*, const void*) { Point aPos(rGP.GetAbsolutePos(*pObj)); if (*(BOOL*)pbVert) { // bVert? rGP.SetVertAlign(*(USHORT*)pnAlign); } else { rGP.SetHorzAlign(*(USHORT*)pnAlign); } rGP.SetAbsolutePos(aPos,*pObj); } void SdrGlueEditView::SetMarkedGluePointsAlign(BOOL bVert, USHORT nAlign) { ForceUndirtyMrkPnt(); BegUndo(ImpGetResStr(STR_EditSetGlueAlign),aMark.GetGluePointMarkDescription()); ImpDoMarkedGluePoints(ImpSetAlign,FALSE,&bVert,&nAlign); EndUndo(); } //////////////////////////////////////////////////////////////////////////////////////////////////// BOOL SdrGlueEditView::IsDeleteMarkedGluePointsPossible() const { return HasMarkedGluePoints(); } void SdrGlueEditView::DeleteMarkedGluePoints() { BrkAction(); ForceUndirtyMrkPnt(); BegUndo(ImpGetResStr(STR_EditDelete),aMark.GetGluePointMarkDescription(),SDRREPFUNC_OBJ_DELETE); ULONG nMarkAnz=aMark.GetMarkCount(); for (ULONG nm=0; nmGetObj(); const SdrUShortCont* pPts=pM->GetMarkedGluePoints(); ULONG nPtAnz=pPts==NULL ? 0 : pPts->GetCount(); if (nPtAnz!=0) { SdrGluePointList* pGPL=pObj->ForceGluePointList(); if (pGPL!=NULL) { AddUndo(new SdrUndoGeoObj(*pObj)); for (ULONG nPtNum=0; nPtNumGetObject(nPtNum); USHORT nGlueIdx=pGPL->FindGluePoint(nPtId); if (nGlueIdx!=SDRGLUEPOINT_NOTFOUND) { pGPL->Delete(nGlueIdx); } } pObj->SendRepaintBroadcast(); } } } EndUndo(); UnmarkAllGluePoints(); if (nMarkAnz!=0) pMod->SetChanged(); } //////////////////////////////////////////////////////////////////////////////////////////////////// void SdrGlueEditView::ImpCopyMarkedGluePoints() { BegUndo(); ULONG nMarkAnz=aMark.GetMarkCount(); for (ULONG nm=0; nmGetObj(); SdrUShortCont* pPts=pM->GetMarkedGluePoints(); SdrGluePointList* pGPL=pObj->ForceGluePointList(); ULONG nPtAnz=pPts==NULL ? 0 : pPts->GetCount(); if (nPtAnz!=0 && pGPL!=NULL) { AddUndo(new SdrUndoGeoObj(*pObj)); for (ULONG nPtNum=0; nPtNumGetObject(nPtNum); USHORT nGlueIdx=pGPL->FindGluePoint(nPtId); if (nGlueIdx!=SDRGLUEPOINT_NOTFOUND) { SdrGluePoint aNewGP((*pGPL)[nGlueIdx]); // GluePoint klonen USHORT nNewIdx=pGPL->Insert(aNewGP); // und einfuegen USHORT nNewId=(*pGPL)[nNewIdx].GetId(); // Id des neuen GluePoints ermitteln pPts->Replace(nNewId,nPtNum); // und diesen markieren (anstelle des alten) } } } } EndUndo(); if (nMarkAnz!=0) pMod->SetChanged(); } //////////////////////////////////////////////////////////////////////////////////////////////////// void SdrGlueEditView::ImpTransformMarkedGluePoints(PGlueTrFunc pTrFunc, const void* p1, const void* p2, const void* p3, const void* p4, const void* p5) { ULONG nMarkAnz=aMark.GetMarkCount(); for (ULONG nm=0; nmGetObj(); const SdrUShortCont* pPts=pM->GetMarkedGluePoints(); Point aPvOfs(pM->GetPageView()->GetOffset()); ULONG nPtAnz=pPts==NULL ? 0 : pPts->GetCount(); if (nPtAnz!=0) { SdrGluePointList* pGPL=pObj->ForceGluePointList(); if (pGPL!=NULL) { AddUndo(new SdrUndoGeoObj(*pObj)); for (ULONG nPtNum=0; nPtNumGetObject(nPtNum); USHORT nGlueIdx=pGPL->FindGluePoint(nPtId); if (nGlueIdx!=SDRGLUEPOINT_NOTFOUND) { SdrGluePoint& rGP=(*pGPL)[nGlueIdx]; Point aPos(rGP.GetAbsolutePos(*pObj)); aPos+=aPvOfs; (*pTrFunc)(aPos,p1,p2,p3,p4,p5); aPos-=aPvOfs; rGP.SetAbsolutePos(aPos,*pObj); } } pObj->SendRepaintBroadcast(); } } } if (nMarkAnz!=0) pMod->SetChanged(); } //////////////////////////////////////////////////////////////////////////////////////////////////// static void ImpMove(Point& rPt, const void* p1, const void* p2, const void* p3, const void* p4, const void* p5) { rPt.X()+=((const Size*)p1)->Width(); rPt.Y()+=((const Size*)p1)->Height(); } void SdrGlueEditView::MoveMarkedGluePoints(const Size& rSiz, BOOL bCopy) { ForceUndirtyMrkPnt(); XubString aStr(ImpGetResStr(STR_EditMove)); if (bCopy) aStr+=ImpGetResStr(STR_EditWithCopy); BegUndo(aStr,aMark.GetGluePointMarkDescription(),SDRREPFUNC_OBJ_MOVE); if (bCopy) ImpCopyMarkedGluePoints(); ImpTransformMarkedGluePoints(ImpMove,&rSiz); EndUndo(); AdjustMarkHdl(); } //////////////////////////////////////////////////////////////////////////////////////////////////// static void ImpResize(Point& rPt, const void* p1, const void* p2, const void* p3, const void* p4, const void* p5) { ResizePoint(rPt,*(const Point*)p1,*(const Fraction*)p2,*(const Fraction*)p3); } void SdrGlueEditView::ResizeMarkedGluePoints(const Point& rRef, const Fraction& xFact, const Fraction& yFact, BOOL bCopy) { ForceUndirtyMrkPnt(); XubString aStr(ImpGetResStr(STR_EditResize)); if (bCopy) aStr+=ImpGetResStr(STR_EditWithCopy); BegUndo(aStr,aMark.GetGluePointMarkDescription(),SDRREPFUNC_OBJ_RESIZE); if (bCopy) ImpCopyMarkedGluePoints(); ImpTransformMarkedGluePoints(ImpResize,&rRef,&xFact,&yFact); EndUndo(); AdjustMarkHdl(); } //////////////////////////////////////////////////////////////////////////////////////////////////// static void ImpRotate(Point& rPt, const void* p1, const void* p2, const void* p3, const void* p4, const void* p5) { RotatePoint(rPt,*(const Point*)p1,*(const double*)p3,*(const double*)p4); } void SdrGlueEditView::RotateMarkedGluePoints(const Point& rRef, long nWink, BOOL bCopy) { ForceUndirtyMrkPnt(); XubString aStr(ImpGetResStr(STR_EditRotate)); if (bCopy) aStr+=ImpGetResStr(STR_EditWithCopy); BegUndo(aStr,aMark.GetGluePointMarkDescription(),SDRREPFUNC_OBJ_ROTATE); if (bCopy) ImpCopyMarkedGluePoints(); double nSin=sin(nWink*nPi180); double nCos=cos(nWink*nPi180); ImpTransformMarkedGluePoints(ImpRotate,&rRef,&nWink,&nSin,&nCos); EndUndo(); AdjustMarkHdl(); }