Files
core/DesktopEditor/graphics/ArrowHead.cpp

151 lines
2.7 KiB
C++

#include "ArrowHead.h"
namespace Aggplus
{
CArrowHead::CArrowHead()
{
m_lType = 0;
m_bIsMoveTo = false;
m_dX1 = 0;
m_dY1 = 0;
m_dX2 = 1;
m_dY2 = 1;
}
CArrowHead::~CArrowHead()
{
}
void CArrowHead::SetType(LONG lType)
{
m_lType = lType;
switch (m_lType)
{
case Aggplus::LineCapSquareAnchor:
case Aggplus::LineCapRoundAnchor:
case Aggplus::LineCapDiamondAnchor:
case Aggplus::LineCapArrowAnchor:
break;
default:
m_lType = 0;
break;
}
}
bool CArrowHead::IsNeed()
{
return (0 != m_lType);
}
void CArrowHead::PathCommandMoveTo(double fX, double fY)
{
if (!IsNeed())
return;
m_bIsMoveTo = true;
m_oPath.MoveTo(fX, fY);
m_oPath.LineTo(fX, fY);
}
void CArrowHead::PathCommandLineTo(double fX, double fY)
{
if (!IsNeed())
return;
m_oPath.LineTo(fX, fY);
}
void CArrowHead::PathCommandLinesTo(double* pPoints, LONG lCount)
{
if (!IsNeed())
return;
if (!m_bIsMoveTo && (lCount >= 2))
{
PathCommandMoveTo(pPoints[0], pPoints[1]);
}
m_oPath.AddLines(pPoints, lCount);
}
void CArrowHead::PathCommandCurveTo(double fX1, double fY1, double fX2, double fY2, double fX3, double fY3)
{
if (!IsNeed())
return;
m_oPath.CurveTo(fX1, fY1, fX2, fY2, fX3, fY3);
}
void CArrowHead::PathCommandCurvesTo(double* pPoints, LONG lCount)
{
if (!IsNeed())
return;
if (!m_bIsMoveTo && (lCount >= 2))
{
PathCommandMoveTo(pPoints[0], pPoints[1]);
}
m_oPath.AddBeziers(pPoints, lCount);
}
void CArrowHead::PathCommandArcTo(double fX, double fY, double fWidth, double fHeight, double fStartAngle, double fSweepAngle)
{
if (!IsNeed())
return;
m_oPath.AddArc2(fX, fY, fWidth, fHeight, -fStartAngle, -fSweepAngle);
}
void CArrowHead::PathCommandClose()
{
if (!IsNeed())
return;
m_oPath.Reset();
}
void CArrowHead::PathCommandEnd()
{
if (!IsNeed())
return;
m_oPath.Reset();
m_bIsMoveTo = false;
}
void CArrowHead::PathCommandStart()
{
if (!IsNeed())
return;
m_oPath.StartFigure();
}
bool CArrowHead::DrawPath(LONG lType)
{
if (!IsNeed())
return false;
if (lType & 0x01)
{
m_oPath.Transform(&m_oTransform);
LONG lCount = (LONG)m_oPath.GetPointCount();
if (2 > lCount)
return false;
double* pPoints = new double[2 * lCount];
m_oPath.GetPathPoints(pPoints, lCount);
m_dX1 = pPoints[2 * lCount - 4];
m_dY1 = pPoints[2 * lCount - 3];
m_dX2 = pPoints[2 * lCount - 2];
m_dY2 = pPoints[2 * lCount - 1];
RELEASEARRAYOBJECTS(pPoints);
return true;
}
return false;
}
}