Files
libreoffice/svx/source/svdraw/svdglev.cxx
Jens-Heiner Rechtien fd069bee7e initial import
2000-09-18 16:07:07 +00:00

424 lines
15 KiB
C++

/*************************************************************************
*
* $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 <math.h>
#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; nm<nMarkAnz; nm++) {
SdrMark* pM=aMark.GetMark(nm);
SdrObject* pObj=pM->GetObj();
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; nPtNum<nPtAnz; nPtNum++) {
USHORT nPtId=pPts->GetObject(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; nm<nMarkAnz; nm++) {
SdrMark* pM=aMark.GetMark(nm);
SdrObject* pObj=pM->GetObj();
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; nPtNum<nPtAnz; nPtNum++) {
USHORT nPtId=pPts->GetObject(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; nm<nMarkAnz; nm++) {
SdrMark* pM=aMark.GetMark(nm);
SdrObject* pObj=pM->GetObj();
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; nPtNum<nPtAnz; nPtNum++) {
USHORT nPtId=pPts->GetObject(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; nm<nMarkAnz; nm++) {
SdrMark* pM=aMark.GetMark(nm);
SdrObject* pObj=pM->GetObj();
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; nPtNum<nPtAnz; nPtNum++) {
USHORT nPtId=pPts->GetObject(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();
}