summaryrefslogtreecommitdiff
path: root/fpdfsdk/pdfwindow/PWL_Utils.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'fpdfsdk/pdfwindow/PWL_Utils.cpp')
-rw-r--r--fpdfsdk/pdfwindow/PWL_Utils.cpp1867
1 files changed, 12 insertions, 1855 deletions
diff --git a/fpdfsdk/pdfwindow/PWL_Utils.cpp b/fpdfsdk/pdfwindow/PWL_Utils.cpp
index 54e75db8fe..45668b6a25 100644
--- a/fpdfsdk/pdfwindow/PWL_Utils.cpp
+++ b/fpdfsdk/pdfwindow/PWL_Utils.cpp
@@ -17,66 +17,6 @@
#include "fpdfsdk/pdfwindow/PWL_Icon.h"
#include "fpdfsdk/pdfwindow/PWL_Wnd.h"
-CFX_ByteString CPWL_Utils::GetAppStreamFromArray(const CPWL_PathData* pPathData,
- int32_t nCount) {
- CFX_ByteTextBuf csAP;
-
- for (int32_t i = 0; i < nCount; i++) {
- switch (pPathData[i].type) {
- case PWLPT_MOVETO:
- csAP << pPathData[i].point.x << " " << pPathData[i].point.y << " m\n";
- break;
- case PWLPT_LINETO:
- csAP << pPathData[i].point.x << " " << pPathData[i].point.y << " l\n";
- break;
- case PWLPT_BEZIERTO:
- csAP << pPathData[i].point.x << " " << pPathData[i].point.y << " "
- << pPathData[i + 1].point.x << " " << pPathData[i + 1].point.y
- << " " << pPathData[i + 2].point.x << " "
- << pPathData[i + 2].point.y << " c\n";
-
- i += 2;
- break;
- default:
- break;
- }
- }
-
- return csAP.MakeString();
-}
-
-void CPWL_Utils::GetPathDataFromArray(CFX_PathData& path,
- const CPWL_PathData* pPathData,
- int32_t nCount) {
- for (int32_t i = 0; i < nCount; i++) {
- switch (pPathData[i].type) {
- case PWLPT_MOVETO:
- path.AppendPoint(pPathData[i].point, FXPT_TYPE::MoveTo, false);
- break;
- case PWLPT_LINETO:
- path.AppendPoint(pPathData[i].point, FXPT_TYPE::LineTo, false);
- break;
- case PWLPT_BEZIERTO:
- path.AppendPoint(pPathData[i].point, FXPT_TYPE::BezierTo, false);
- break;
- default:
- break;
- }
- }
-}
-
-CFX_FloatRect CPWL_Utils::MaxRect(const CFX_FloatRect& rect1,
- const CFX_FloatRect& rect2) {
- CFX_FloatRect rcRet;
-
- rcRet.left = std::min(rect1.left, rect2.left);
- rcRet.bottom = std::min(rect1.bottom, rect2.bottom);
- rcRet.right = std::max(rect1.right, rect2.right);
- rcRet.top = std::max(rect1.top, rect2.top);
-
- return rcRet;
-}
-
CFX_FloatRect CPWL_Utils::OffsetRect(const CFX_FloatRect& rect,
FX_FLOAT x,
FX_FLOAT y) {
@@ -84,28 +24,6 @@ CFX_FloatRect CPWL_Utils::OffsetRect(const CFX_FloatRect& rect,
rect.top + y);
}
-bool CPWL_Utils::ContainsRect(const CFX_FloatRect& rcParent,
- const CFX_FloatRect& rcChild) {
- return rcChild.left >= rcParent.left && rcChild.bottom >= rcParent.bottom &&
- rcChild.right <= rcParent.right && rcChild.top <= rcParent.top;
-}
-
-bool CPWL_Utils::IntersectRect(const CFX_FloatRect& rect1,
- const CFX_FloatRect& rect2) {
- FX_FLOAT left = rect1.left > rect2.left ? rect1.left : rect2.left;
- FX_FLOAT right = rect1.right < rect2.right ? rect1.right : rect2.right;
- FX_FLOAT bottom = rect1.bottom > rect2.bottom ? rect1.bottom : rect2.bottom;
- FX_FLOAT top = rect1.top < rect2.top ? rect1.top : rect2.top;
-
- return left < right && bottom < top;
-}
-
-CFX_PointF CPWL_Utils::OffsetPoint(const CFX_PointF& point,
- FX_FLOAT x,
- FX_FLOAT y) {
- return CFX_PointF(point.x + x, point.y + y);
-}
-
CPVT_WordRange CPWL_Utils::OverlapWordRange(const CPVT_WordRange& wr1,
const CPVT_WordRange& wr2) {
CPVT_WordRange wrRet;
@@ -420,40 +338,6 @@ CFX_ByteString CPWL_Utils::GetEditSelAppStream(CFX_Edit* pEdit,
return CFX_Edit::GetSelectAppearanceStream(pEdit, ptOffset, pRange);
}
-CFX_ByteString CPWL_Utils::GetTextAppStream(const CFX_FloatRect& rcBBox,
- IPVT_FontMap* pFontMap,
- const CFX_WideString& sText,
- int32_t nAlignmentH,
- int32_t nAlignmentV,
- FX_FLOAT fFontSize,
- bool bMultiLine,
- bool bAutoReturn,
- const CPWL_Color& crText) {
- CFX_ByteTextBuf sRet;
-
- std::unique_ptr<CFX_Edit> pEdit(new CFX_Edit);
- pEdit->SetFontMap(pFontMap);
- pEdit->SetPlateRect(rcBBox);
- pEdit->SetAlignmentH(nAlignmentH, true);
- pEdit->SetAlignmentV(nAlignmentV, true);
- pEdit->SetMultiLine(bMultiLine, true);
- pEdit->SetAutoReturn(bAutoReturn, true);
- if (IsFloatZero(fFontSize))
- pEdit->SetAutoFontSize(true, true);
- else
- pEdit->SetFontSize(fFontSize);
-
- pEdit->Initialize();
- pEdit->SetText(sText);
-
- CFX_ByteString sEdit =
- CPWL_Utils::GetEditAppStream(pEdit.get(), CFX_PointF(0.0f, 0.0f));
- if (sEdit.GetLength() > 0)
- sRet << "BT\n" << CPWL_Utils::GetColorAppStream(crText) << sEdit << "ET\n";
-
- return sRet.MakeString();
-}
-
CFX_ByteString CPWL_Utils::GetPushButtonAppStream(const CFX_FloatRect& rcBBox,
IPVT_FontMap* pFontMap,
CPDF_Stream* pIconStream,
@@ -915,57 +799,6 @@ CFX_ByteString CPWL_Utils::GetCircleBorderAppStream(
return sAppStream.MakeString();
}
-CPWL_Color CPWL_Utils::SubstractColor(const CPWL_Color& sColor,
- FX_FLOAT fColorSub) {
- CPWL_Color sRet;
- sRet.nColorType = sColor.nColorType;
-
- switch (sColor.nColorType) {
- case COLORTYPE_TRANSPARENT:
- sRet.nColorType = COLORTYPE_RGB;
- sRet.fColor1 = std::max(1 - fColorSub, 0.0f);
- sRet.fColor2 = std::max(1 - fColorSub, 0.0f);
- sRet.fColor3 = std::max(1 - fColorSub, 0.0f);
- break;
- case COLORTYPE_RGB:
- case COLORTYPE_GRAY:
- case COLORTYPE_CMYK:
- sRet.fColor1 = std::max(sColor.fColor1 - fColorSub, 0.0f);
- sRet.fColor2 = std::max(sColor.fColor2 - fColorSub, 0.0f);
- sRet.fColor3 = std::max(sColor.fColor3 - fColorSub, 0.0f);
- sRet.fColor4 = std::max(sColor.fColor4 - fColorSub, 0.0f);
- break;
- }
-
- return sRet;
-}
-
-CPWL_Color CPWL_Utils::DevideColor(const CPWL_Color& sColor,
- FX_FLOAT fColorDevide) {
- CPWL_Color sRet;
- sRet.nColorType = sColor.nColorType;
-
- switch (sColor.nColorType) {
- case COLORTYPE_TRANSPARENT:
- sRet.nColorType = COLORTYPE_RGB;
- sRet.fColor1 = 1 / fColorDevide;
- sRet.fColor2 = 1 / fColorDevide;
- sRet.fColor3 = 1 / fColorDevide;
- break;
- case COLORTYPE_RGB:
- case COLORTYPE_GRAY:
- case COLORTYPE_CMYK:
- sRet = sColor;
- sRet.fColor1 /= fColorDevide;
- sRet.fColor2 /= fColorDevide;
- sRet.fColor3 /= fColorDevide;
- sRet.fColor4 /= fColorDevide;
- break;
- }
-
- return sRet;
-}
-
CFX_ByteString CPWL_Utils::GetAppStream_Check(const CFX_FloatRect& rcBBox,
const CPWL_Color& crText) {
CFX_ByteTextBuf sAP;
@@ -1101,118 +934,6 @@ CFX_ByteString CPWL_Utils::GetDropButtonAppStream(const CFX_FloatRect& rcBBox) {
return sAppStream.MakeString();
}
-void CPWL_Utils::ConvertCMYK2GRAY(FX_FLOAT dC,
- FX_FLOAT dM,
- FX_FLOAT dY,
- FX_FLOAT dK,
- FX_FLOAT& dGray) {
- if (dC < 0 || dC > 1 || dM < 0 || dM > 1 || dY < 0 || dY > 1 || dK < 0 ||
- dK > 1)
- return;
- dGray = 1.0f - std::min(1.0f, 0.3f * dC + 0.59f * dM + 0.11f * dY + dK);
-}
-
-void CPWL_Utils::ConvertGRAY2CMYK(FX_FLOAT dGray,
- FX_FLOAT& dC,
- FX_FLOAT& dM,
- FX_FLOAT& dY,
- FX_FLOAT& dK) {
- if (dGray < 0 || dGray > 1)
- return;
- dC = 0.0f;
- dM = 0.0f;
- dY = 0.0f;
- dK = 1.0f - dGray;
-}
-
-void CPWL_Utils::ConvertGRAY2RGB(FX_FLOAT dGray,
- FX_FLOAT& dR,
- FX_FLOAT& dG,
- FX_FLOAT& dB) {
- if (dGray < 0 || dGray > 1)
- return;
- dR = dGray;
- dG = dGray;
- dB = dGray;
-}
-
-void CPWL_Utils::ConvertRGB2GRAY(FX_FLOAT dR,
- FX_FLOAT dG,
- FX_FLOAT dB,
- FX_FLOAT& dGray) {
- if (dR < 0 || dR > 1 || dG < 0 || dG > 0 || dB < 0 || dB > 1)
- return;
- dGray = 0.3f * dR + 0.59f * dG + 0.11f * dB;
-}
-
-void CPWL_Utils::ConvertCMYK2RGB(FX_FLOAT dC,
- FX_FLOAT dM,
- FX_FLOAT dY,
- FX_FLOAT dK,
- FX_FLOAT& dR,
- FX_FLOAT& dG,
- FX_FLOAT& dB) {
- if (dC < 0 || dC > 1 || dM < 0 || dM > 1 || dY < 0 || dY > 1 || dK < 0 ||
- dK > 1)
- return;
- dR = 1.0f - std::min(1.0f, dC + dK);
- dG = 1.0f - std::min(1.0f, dM + dK);
- dB = 1.0f - std::min(1.0f, dY + dK);
-}
-
-void CPWL_Utils::ConvertRGB2CMYK(FX_FLOAT dR,
- FX_FLOAT dG,
- FX_FLOAT dB,
- FX_FLOAT& dC,
- FX_FLOAT& dM,
- FX_FLOAT& dY,
- FX_FLOAT& dK) {
- if (dR < 0 || dR > 1 || dG < 0 || dG > 1 || dB < 0 || dB > 1)
- return;
-
- dC = 1.0f - dR;
- dM = 1.0f - dG;
- dY = 1.0f - dB;
- dK = std::min(dC, std::min(dM, dY));
-}
-
-void CPWL_Utils::PWLColorToARGB(const CPWL_Color& color,
- int32_t& alpha,
- FX_FLOAT& red,
- FX_FLOAT& green,
- FX_FLOAT& blue) {
- switch (color.nColorType) {
- case COLORTYPE_TRANSPARENT: {
- alpha = 0;
- } break;
- case COLORTYPE_GRAY: {
- ConvertGRAY2RGB(color.fColor1, red, green, blue);
- } break;
- case COLORTYPE_RGB: {
- red = color.fColor1;
- green = color.fColor2;
- blue = color.fColor3;
- } break;
- case COLORTYPE_CMYK: {
- ConvertCMYK2RGB(color.fColor1, color.fColor2, color.fColor3,
- color.fColor4, red, green, blue);
- } break;
- }
-}
-
-FX_COLORREF CPWL_Utils::PWLColorToFXColor(const CPWL_Color& color,
- int32_t nTransparancy) {
- int32_t nAlpha = nTransparancy;
- FX_FLOAT dRed = 0;
- FX_FLOAT dGreen = 0;
- FX_FLOAT dBlue = 0;
-
- PWLColorToARGB(color, nAlpha, dRed, dGreen, dBlue);
-
- return ArgbEncode(nAlpha, (int32_t)(dRed * 255), (int32_t)(dGreen * 255),
- (int32_t)(dBlue * 255));
-}
-
void CPWL_Utils::DrawFillRect(CFX_RenderDevice* pDevice,
CFX_Matrix* pUser2Device,
const CFX_FloatRect& rect,
@@ -1271,9 +992,9 @@ void CPWL_Utils::DrawFillRect(CFX_RenderDevice* pDevice,
CFX_Matrix* pUser2Device,
const CFX_FloatRect& rect,
const CPWL_Color& color,
- int32_t nTransparancy) {
+ int32_t nTransparency) {
CPWL_Utils::DrawFillRect(pDevice, pUser2Device, rect,
- PWLColorToFXColor(color, nTransparancy));
+ color.ToFXColor(nTransparency));
}
void CPWL_Utils::DrawShadow(CFX_RenderDevice* pDevice,
@@ -1281,7 +1002,7 @@ void CPWL_Utils::DrawShadow(CFX_RenderDevice* pDevice,
bool bVertical,
bool bHorizontal,
CFX_FloatRect rect,
- int32_t nTransparancy,
+ int32_t nTransparency,
int32_t nStartGray,
int32_t nEndGray) {
FX_FLOAT fStepGray = 1.0f;
@@ -1294,7 +1015,7 @@ void CPWL_Utils::DrawShadow(CFX_RenderDevice* pDevice,
CPWL_Utils::DrawStrokeLine(
pDevice, pUser2Device, CFX_PointF(rect.left, fy),
CFX_PointF(rect.right, fy),
- ArgbEncode(nTransparancy, nGray, nGray, nGray), 1.5f);
+ ArgbEncode(nTransparency, nGray, nGray, nGray), 1.5f);
}
}
@@ -1306,7 +1027,7 @@ void CPWL_Utils::DrawShadow(CFX_RenderDevice* pDevice,
CPWL_Utils::DrawStrokeLine(
pDevice, pUser2Device, CFX_PointF(fx, rect.bottom),
CFX_PointF(fx, rect.top),
- ArgbEncode(nTransparancy, nGray, nGray, nGray), 1.5f);
+ ArgbEncode(nTransparency, nGray, nGray, nGray), 1.5f);
}
}
}
@@ -1319,7 +1040,7 @@ void CPWL_Utils::DrawBorder(CFX_RenderDevice* pDevice,
const CPWL_Color& crLeftTop,
const CPWL_Color& crRightBottom,
BorderStyle nStyle,
- int32_t nTransparancy) {
+ int32_t nTransparency) {
FX_FLOAT fLeft = rect.left;
FX_FLOAT fRight = rect.right;
FX_FLOAT fTop = rect.top;
@@ -1336,8 +1057,7 @@ void CPWL_Utils::DrawBorder(CFX_RenderDevice* pDevice,
path.AppendRect(fLeft + fWidth, fBottom + fWidth, fRight - fWidth,
fTop - fWidth);
pDevice->DrawPath(&path, pUser2Device, nullptr,
- PWLColorToFXColor(color, nTransparancy), 0,
- FXFILL_ALTERNATE);
+ color.ToFXColor(nTransparency), 0, FXFILL_ALTERNATE);
break;
}
case BorderStyle::DASH: {
@@ -1366,8 +1086,7 @@ void CPWL_Utils::DrawBorder(CFX_RenderDevice* pDevice,
gsd.m_LineWidth = fWidth;
pDevice->DrawPath(&path, pUser2Device, &gsd, 0,
- PWLColorToFXColor(color, nTransparancy),
- FXFILL_WINDING);
+ color.ToFXColor(nTransparency), FXFILL_WINDING);
break;
}
case BorderStyle::BEVELED:
@@ -1396,7 +1115,7 @@ void CPWL_Utils::DrawBorder(CFX_RenderDevice* pDevice,
FXPT_TYPE::LineTo, false);
pDevice->DrawPath(&pathLT, pUser2Device, &gsd,
- PWLColorToFXColor(crLeftTop, nTransparancy), 0,
+ crLeftTop.ToFXColor(nTransparency), 0,
FXFILL_ALTERNATE);
CFX_PathData pathRB;
@@ -1420,7 +1139,7 @@ void CPWL_Utils::DrawBorder(CFX_RenderDevice* pDevice,
FXPT_TYPE::LineTo, false);
pDevice->DrawPath(&pathRB, pUser2Device, &gsd,
- PWLColorToFXColor(crRightBottom, nTransparancy), 0,
+ crRightBottom.ToFXColor(nTransparency), 0,
FXFILL_ALTERNATE);
CFX_PathData path;
@@ -1430,8 +1149,7 @@ void CPWL_Utils::DrawBorder(CFX_RenderDevice* pDevice,
fRight - fHalfWidth, fTop - fHalfWidth);
pDevice->DrawPath(&path, pUser2Device, &gsd,
- PWLColorToFXColor(color, nTransparancy), 0,
- FXFILL_ALTERNATE);
+ color.ToFXColor(nTransparency), 0, FXFILL_ALTERNATE);
break;
}
case BorderStyle::UNDERLINE: {
@@ -1445,1571 +1163,10 @@ void CPWL_Utils::DrawBorder(CFX_RenderDevice* pDevice,
gsd.m_LineWidth = fWidth;
pDevice->DrawPath(&path, pUser2Device, &gsd, 0,
- PWLColorToFXColor(color, nTransparancy),
- FXFILL_ALTERNATE);
+ color.ToFXColor(nTransparency), FXFILL_ALTERNATE);
break;
}
}
}
}
-bool CPWL_Utils::IsBlackOrWhite(const CPWL_Color& color) {
- switch (color.nColorType) {
- case COLORTYPE_TRANSPARENT:
- return false;
- case COLORTYPE_GRAY:
- return color.fColor1 < 0.5f;
- case COLORTYPE_RGB:
- return color.fColor1 + color.fColor2 + color.fColor3 < 1.5f;
- case COLORTYPE_CMYK:
- return color.fColor1 + color.fColor2 + color.fColor3 + color.fColor4 >
- 2.0f;
- }
-
- return true;
-}
-
-CPWL_Color CPWL_Utils::GetReverseColor(const CPWL_Color& color) {
- CPWL_Color crRet = color;
-
- switch (color.nColorType) {
- case COLORTYPE_GRAY:
- crRet.fColor1 = 1.0f - crRet.fColor1;
- break;
- case COLORTYPE_RGB:
- crRet.fColor1 = 1.0f - crRet.fColor1;
- crRet.fColor2 = 1.0f - crRet.fColor2;
- crRet.fColor3 = 1.0f - crRet.fColor3;
- break;
- case COLORTYPE_CMYK:
- crRet.fColor1 = 1.0f - crRet.fColor1;
- crRet.fColor2 = 1.0f - crRet.fColor2;
- crRet.fColor3 = 1.0f - crRet.fColor3;
- crRet.fColor4 = 1.0f - crRet.fColor4;
- break;
- }
-
- return crRet;
-}
-
-CFX_ByteString CPWL_Utils::GetIconAppStream(int32_t nType,
- const CFX_FloatRect& rect,
- const CPWL_Color& crFill,
- const CPWL_Color& crStroke) {
- CFX_ByteString sAppStream = CPWL_Utils::GetColorAppStream(crStroke, false);
- sAppStream += CPWL_Utils::GetColorAppStream(crFill, true);
-
- CFX_ByteString sPath;
- CFX_PathData path;
-
- switch (nType) {
- case PWL_ICONTYPE_CHECKMARK:
- GetGraphics_Checkmark(sPath, path, rect, PWLPT_STREAM);
- break;
- case PWL_ICONTYPE_CIRCLE:
- GetGraphics_Circle(sPath, path, rect, PWLPT_STREAM);
- break;
- case PWL_ICONTYPE_COMMENT:
- GetGraphics_Comment(sPath, path, rect, PWLPT_STREAM);
- break;
- case PWL_ICONTYPE_CROSS:
- GetGraphics_Cross(sPath, path, rect, PWLPT_STREAM);
- break;
- case PWL_ICONTYPE_HELP:
- GetGraphics_Help(sPath, path, rect, PWLPT_STREAM);
- break;
- case PWL_ICONTYPE_INSERTTEXT:
- GetGraphics_InsertText(sPath, path, rect, PWLPT_STREAM);
- break;
- case PWL_ICONTYPE_KEY:
- GetGraphics_Key(sPath, path, rect, PWLPT_STREAM);
- break;
- case PWL_ICONTYPE_NEWPARAGRAPH:
- GetGraphics_NewParagraph(sPath, path, rect, PWLPT_STREAM);
- break;
- case PWL_ICONTYPE_TEXTNOTE:
- GetGraphics_TextNote(sPath, path, rect, PWLPT_STREAM);
- break;
- case PWL_ICONTYPE_PARAGRAPH:
- GetGraphics_Paragraph(sPath, path, rect, PWLPT_STREAM);
- break;
- case PWL_ICONTYPE_RIGHTARROW:
- GetGraphics_RightArrow(sPath, path, rect, PWLPT_STREAM);
- break;
- case PWL_ICONTYPE_RIGHTPOINTER:
- GetGraphics_RightPointer(sPath, path, rect, PWLPT_STREAM);
- break;
- case PWL_ICONTYPE_STAR:
- GetGraphics_Star(sPath, path, rect, PWLPT_STREAM);
- break;
- case PWL_ICONTYPE_UPARROW:
- GetGraphics_UpArrow(sPath, path, rect, PWLPT_STREAM);
- break;
- case PWL_ICONTYPE_UPLEFTARROW:
- GetGraphics_UpLeftArrow(sPath, path, rect, PWLPT_STREAM);
- break;
- case PWL_ICONTYPE_GRAPH:
- GetGraphics_Graph(sPath, path, rect, PWLPT_STREAM);
- break;
- case PWL_ICONTYPE_PAPERCLIP:
- GetGraphics_Paperclip(sPath, path, rect, PWLPT_STREAM);
- break;
- case PWL_ICONTYPE_ATTACHMENT:
- GetGraphics_Attachment(sPath, path, rect, PWLPT_STREAM);
- break;
- case PWL_ICONTYPE_TAG:
- GetGraphics_Tag(sPath, path, rect, PWLPT_STREAM);
- break;
- case PWL_ICONTYPE_FOXIT:
- GetGraphics_Foxit(sPath, path, rect, PWLPT_STREAM);
- break;
- }
-
- sAppStream += sPath;
- if (crStroke.nColorType != COLORTYPE_TRANSPARENT)
- sAppStream += "B*\n";
- else
- sAppStream += "f*\n";
-
- return sAppStream;
-}
-
-void CPWL_Utils::DrawIconAppStream(CFX_RenderDevice* pDevice,
- CFX_Matrix* pUser2Device,
- int32_t nType,
- const CFX_FloatRect& rect,
- const CPWL_Color& crFill,
- const CPWL_Color& crStroke,
- const int32_t nTransparancy) {
- CFX_GraphStateData gsd;
- gsd.m_LineWidth = 1.0f;
-
- CFX_ByteString sPath;
- CFX_PathData path;
-
- switch (nType) {
- case PWL_ICONTYPE_CHECKMARK:
- GetGraphics_Checkmark(sPath, path, rect, PWLPT_PATHDATA);
- break;
- case PWL_ICONTYPE_CIRCLE:
- GetGraphics_Circle(sPath, path, rect, PWLPT_PATHDATA);
- break;
- case PWL_ICONTYPE_COMMENT:
- GetGraphics_Comment(sPath, path, rect, PWLPT_PATHDATA);
- break;
- case PWL_ICONTYPE_CROSS:
- GetGraphics_Cross(sPath, path, rect, PWLPT_PATHDATA);
- break;
- case PWL_ICONTYPE_HELP:
- GetGraphics_Help(sPath, path, rect, PWLPT_PATHDATA);
- break;
- case PWL_ICONTYPE_INSERTTEXT:
- GetGraphics_InsertText(sPath, path, rect, PWLPT_PATHDATA);
- break;
- case PWL_ICONTYPE_KEY:
- GetGraphics_Key(sPath, path, rect, PWLPT_PATHDATA);
- break;
- case PWL_ICONTYPE_NEWPARAGRAPH:
- GetGraphics_NewParagraph(sPath, path, rect, PWLPT_PATHDATA);
- break;
- case PWL_ICONTYPE_TEXTNOTE:
- GetGraphics_TextNote(sPath, path, rect, PWLPT_PATHDATA);
- break;
- case PWL_ICONTYPE_PARAGRAPH:
- GetGraphics_Paragraph(sPath, path, rect, PWLPT_PATHDATA);
- break;
- case PWL_ICONTYPE_RIGHTARROW:
- GetGraphics_RightArrow(sPath, path, rect, PWLPT_PATHDATA);
- break;
- case PWL_ICONTYPE_RIGHTPOINTER:
- GetGraphics_RightPointer(sPath, path, rect, PWLPT_PATHDATA);
- break;
- case PWL_ICONTYPE_STAR:
- GetGraphics_Star(sPath, path, rect, PWLPT_PATHDATA);
- break;
- case PWL_ICONTYPE_UPARROW:
- GetGraphics_UpArrow(sPath, path, rect, PWLPT_PATHDATA);
- break;
- case PWL_ICONTYPE_UPLEFTARROW:
- GetGraphics_UpLeftArrow(sPath, path, rect, PWLPT_PATHDATA);
- break;
- case PWL_ICONTYPE_GRAPH:
- GetGraphics_Graph(sPath, path, rect, PWLPT_PATHDATA);
- break;
- case PWL_ICONTYPE_PAPERCLIP:
- GetGraphics_Paperclip(sPath, path, rect, PWLPT_PATHDATA);
- break;
- case PWL_ICONTYPE_ATTACHMENT:
- GetGraphics_Attachment(sPath, path, rect, PWLPT_PATHDATA);
- break;
- case PWL_ICONTYPE_TAG:
- GetGraphics_Tag(sPath, path, rect, PWLPT_PATHDATA);
- break;
- case PWL_ICONTYPE_FOXIT:
- GetGraphics_Foxit(sPath, path, rect, PWLPT_PATHDATA);
- break;
- default:
- return;
- }
-
- pDevice->DrawPath(
- &path, pUser2Device, &gsd, PWLColorToFXColor(crFill, nTransparancy),
- PWLColorToFXColor(crStroke, nTransparancy), FXFILL_ALTERNATE);
-}
-
-void CPWL_Utils::GetGraphics_Checkmark(CFX_ByteString& sPathData,
- CFX_PathData& path,
- const CFX_FloatRect& crBBox,
- const PWL_PATH_TYPE type) {
- FX_FLOAT fWidth = crBBox.right - crBBox.left;
- FX_FLOAT fHeight = crBBox.top - crBBox.bottom;
-
- CPWL_PathData PathArray[] = {
- {{crBBox.left + fWidth / 15.0f, crBBox.bottom + fHeight * 2 / 5.0f},
- PWLPT_MOVETO},
- {{crBBox.left + fWidth / 15.0f +
- FX_BEZIER * (fWidth / 7.0f - fWidth / 15.0f),
- crBBox.bottom + fHeight * 2 / 5.0f +
- FX_BEZIER * (fHeight * 2 / 7.0f - fHeight * 2 / 5.0f)},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth / 4.5f +
- FX_BEZIER * (fWidth / 5.0f - fWidth / 4.5f),
- crBBox.bottom + fHeight / 16.0f +
- FX_BEZIER * (fHeight / 5.0f - fHeight / 16.0f)},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth / 4.5f, crBBox.bottom + fHeight / 16.0f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth / 4.5f +
- FX_BEZIER * (fWidth / 4.4f - fWidth / 4.5f),
- crBBox.bottom + fHeight / 16.0f - FX_BEZIER * fHeight / 16.0f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth / 3.0f +
- FX_BEZIER * (fWidth / 4.0f - fWidth / 3.0f),
- crBBox.bottom},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth / 3.0f, crBBox.bottom}, PWLPT_BEZIERTO},
- {{crBBox.left + fWidth / 3.0f +
- FX_BEZIER * fWidth * (1 / 7.0f + 2 / 15.0f),
- crBBox.bottom + FX_BEZIER * fHeight * 4 / 5.0f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth * 14 / 15.0f +
- FX_BEZIER * fWidth * (1 / 7.0f - 7 / 15.0f),
- crBBox.bottom + fHeight * 15 / 16.0f +
- FX_BEZIER * (fHeight * 4 / 5.0f - fHeight * 15 / 16.0f)},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth * 14 / 15.0f,
- crBBox.bottom + fHeight * 15 / 16.0f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth * 14 / 15.0f +
- FX_BEZIER * (fWidth * 7 / 15.0f - fWidth * 14 / 15.0f),
- crBBox.bottom + fHeight * 15 / 16.0f +
- FX_BEZIER * (fHeight * 8 / 7.0f - fHeight * 15 / 16.0f)},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth / 3.6f +
- FX_BEZIER * (fWidth / 3.4f - fWidth / 3.6f),
- crBBox.bottom + fHeight / 3.5f +
- FX_BEZIER * (fHeight / 3.5f - fHeight / 3.5f)},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth / 3.6f, crBBox.bottom + fHeight / 3.5f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth / 3.6f,
- crBBox.bottom + fHeight / 3.5f +
- FX_BEZIER * (fHeight / 4.0f - fHeight / 3.5f)},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth / 15.0f +
- FX_BEZIER * (fWidth / 3.5f - fWidth / 15.0f),
- crBBox.bottom + fHeight * 2 / 5.0f +
- FX_BEZIER * (fHeight * 3.5f / 5.0f - fHeight * 2 / 5.0f)},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth / 15.0f, crBBox.bottom + fHeight * 2 / 5.0f},
- PWLPT_BEZIERTO}};
-
- if (type == PWLPT_STREAM)
- sPathData = GetAppStreamFromArray(PathArray, FX_ArraySize(PathArray));
- else
- GetPathDataFromArray(path, PathArray, FX_ArraySize(PathArray));
-}
-
-void CPWL_Utils::GetGraphics_Circle(CFX_ByteString& sPathData,
- CFX_PathData& path,
- const CFX_FloatRect& crBBox,
- const PWL_PATH_TYPE type) {
- FX_FLOAT fWidth = crBBox.right - crBBox.left;
- FX_FLOAT fHeight = crBBox.top - crBBox.bottom;
-
- CPWL_PathData PathArray[] = {
- {{crBBox.left + fWidth / 15.0f, crBBox.bottom + fHeight / 2.0f},
- PWLPT_MOVETO},
- {{crBBox.left + fWidth / 15.0f,
- crBBox.bottom + fHeight / 2.0f +
- FX_BEZIER * (fHeight * 14 / 15.0f - fHeight / 2.0f)},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth / 2.0f -
- FX_BEZIER * (fWidth / 2.0f - fWidth / 15.0f),
- crBBox.top - fHeight / 15.0f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth / 2.0f, crBBox.top - fHeight / 15.0f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth / 2.0f +
- FX_BEZIER * (fWidth * 14 / 15.0f - fWidth / 2.0f),
- crBBox.top - fHeight / 15.0f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth / 15.0f,
- crBBox.bottom + fHeight / 2.0f +
- FX_BEZIER * (fHeight * 14 / 15.0f - fHeight / 2.0f)},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth / 15.0f, crBBox.bottom + fHeight / 2.0f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth / 15.0f,
- crBBox.bottom + fHeight / 2.0f -
- FX_BEZIER * (fHeight / 2.0f - fHeight / 15.0f)},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth / 2.0f +
- FX_BEZIER * (fWidth * 14 / 15.0f - fWidth / 2.0f),
- crBBox.bottom + fHeight / 15.0f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth / 2.0f, crBBox.bottom + fHeight / 15.0f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth / 2.0f -
- FX_BEZIER * (fWidth / 2.0f - fWidth / 15.0f),
- crBBox.bottom + fHeight / 15.0f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth / 15.0f,
- crBBox.bottom + fHeight / 2.0f -
- FX_BEZIER * (fHeight / 2.0f - fHeight / 15.0f)},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth / 15.0f, crBBox.bottom + fHeight / 2.0f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth * 3 / 15.0f, crBBox.bottom + fHeight / 2.0f},
- PWLPT_MOVETO},
- {{crBBox.left + fWidth * 3 / 15.0f,
- crBBox.bottom + fHeight / 2.0f +
- FX_BEZIER * (fHeight * 4 / 5.0f - fHeight / 2.0f)},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth / 2.0f -
- FX_BEZIER * (fWidth / 2.0f - fWidth * 3 / 15.0f),
- crBBox.top - fHeight * 3 / 15.0f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth / 2.0f, crBBox.top - fHeight * 3 / 15.0f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth / 2.0f +
- FX_BEZIER * (fWidth * 4 / 5.0f - fWidth / 2.0f),
- crBBox.top - fHeight * 3 / 15.0f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth * 3 / 15.0f,
- crBBox.bottom + fHeight / 2.0f +
- FX_BEZIER * (fHeight * 4 / 5.0f - fHeight / 2.0f)},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth * 3 / 15.0f, crBBox.bottom + fHeight / 2.0f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth * 3 / 15.0f,
- crBBox.bottom + fHeight / 2.0f -
- FX_BEZIER * (fHeight * 4 / 5.0f - fHeight / 2.0f)},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth / 2.0f +
- FX_BEZIER * (fWidth * 4 / 5.0f - fWidth / 2.0f),
- crBBox.bottom + fHeight * 3 / 15.0f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth / 2.0f, crBBox.bottom + fHeight * 3 / 15.0f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth / 2.0f -
- FX_BEZIER * (fWidth * 4 / 5.0f - fWidth / 2.0f),
- crBBox.bottom + fHeight * 3 / 15.0f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth * 3 / 15.0f,
- crBBox.bottom + fHeight / 2.0f -
- FX_BEZIER * (fHeight * 4 / 5.0f - fHeight / 2.0f)},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth * 3 / 15.0f, crBBox.bottom + fHeight / 2.0f},
- PWLPT_BEZIERTO}};
-
- if (type == PWLPT_STREAM)
- sPathData = GetAppStreamFromArray(PathArray, FX_ArraySize(PathArray));
- else
- GetPathDataFromArray(path, PathArray, FX_ArraySize(PathArray));
-}
-
-void CPWL_Utils::GetGraphics_Comment(CFX_ByteString& sPathData,
- CFX_PathData& path,
- const CFX_FloatRect& crBBox,
- const PWL_PATH_TYPE type) {
- FX_FLOAT fWidth = crBBox.right - crBBox.left;
- FX_FLOAT fHeight = crBBox.top - crBBox.bottom;
-
- CPWL_PathData PathArray[] = {
- {{crBBox.left + fWidth / 15.0f, crBBox.top - fHeight / 6.0f},
- PWLPT_MOVETO},
- {{crBBox.left + fWidth / 15.0f,
- crBBox.top - fHeight / 6.0f +
- FX_BEZIER * (fHeight / 6.0f - fHeight / 10.0f)},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth * 2 / 15.0f - FX_BEZIER * fWidth / 15.0f,
- crBBox.top - fHeight / 10.0f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth * 2 / 15.0f, crBBox.top - fHeight / 10.0f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth * 2 / 15.0f, crBBox.top - fHeight / 10.0f},
- PWLPT_LINETO},
- {{crBBox.right - fWidth * 2 / 15.0f + FX_BEZIER * fWidth / 15.0f,
- crBBox.top - fHeight / 10.0f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth / 15.0f,
- crBBox.top - fHeight / 6 +
- FX_BEZIER * (fHeight / 6.0f - fHeight / 10.0f)},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth / 15.0f, crBBox.top - fHeight / 6.0f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth / 15.0f, crBBox.bottom + fHeight / 3.0f},
- PWLPT_LINETO},
- {{crBBox.right - fWidth / 15.0f,
- crBBox.bottom + fHeight * 4 / 15.0f + FX_BEZIER * fHeight / 15.0f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth * 2 / 15.0f + FX_BEZIER * fWidth / 15.0f,
- crBBox.bottom + fHeight * 4 / 15.0f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth * 2 / 15.0f, crBBox.bottom + fHeight * 4 / 15.0f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth * 5 / 15.0f, crBBox.bottom + fHeight * 4 / 15.0f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 5 / 15.0f,
- crBBox.bottom + fHeight * 2 / 15 + FX_BEZIER * fHeight * 2 / 15.0f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth * 5 / 15.0f - FX_BEZIER * fWidth * 2 / 15.0f,
- crBBox.bottom + fHeight * 2 / 15.0f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth * 6 / 30.0f, crBBox.bottom + fHeight * 2 / 15.0f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth * 7 / 30.0f + FX_BEZIER * fWidth / 30.0f,
- crBBox.bottom + fHeight * 2 / 15.0f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth * 7 / 30.0f,
- crBBox.bottom + fHeight * 2 / 15.0f + FX_BEZIER * fHeight * 2 / 15.0f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth * 7 / 30.0f, crBBox.bottom + fHeight * 4 / 15.0f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth * 2 / 15.0f, crBBox.bottom + fHeight * 4 / 15.0f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 2 / 15.0f - FX_BEZIER * fWidth / 15.0f,
- crBBox.bottom + fHeight * 4 / 15.0f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth / 15.0f,
- crBBox.bottom + fHeight / 3.0f - FX_BEZIER * fHeight / 15.0f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth / 15.0f, crBBox.bottom + fHeight / 3.0f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth / 15.0f, crBBox.top - fHeight / 6.0f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 2 / 15.0f, crBBox.top - fHeight * 8 / 30.0f},
- PWLPT_MOVETO},
- {{crBBox.right - fWidth * 2 / 15.0f, crBBox.top - fHeight * 8 / 30.0f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 2 / 15, crBBox.top - fHeight * 25 / 60.0f},
- PWLPT_MOVETO},
- {{crBBox.right - fWidth * 2 / 15.0f, crBBox.top - fHeight * 25 / 60.0f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 2 / 15.0f, crBBox.top - fHeight * 17 / 30.0f},
- PWLPT_MOVETO},
- {{crBBox.right - fWidth * 4 / 15.0f, crBBox.top - fHeight * 17 / 30.0f},
- PWLPT_LINETO}};
-
- if (type == PWLPT_STREAM)
- sPathData = GetAppStreamFromArray(PathArray, FX_ArraySize(PathArray));
- else
- GetPathDataFromArray(path, PathArray, FX_ArraySize(PathArray));
-}
-
-void CPWL_Utils::GetGraphics_Cross(CFX_ByteString& sPathData,
- CFX_PathData& path,
- const CFX_FloatRect& crBBox,
- const PWL_PATH_TYPE type) {
- FX_FLOAT fWidth = crBBox.right - crBBox.left;
- FX_FLOAT fHeight = crBBox.top - crBBox.bottom;
- CFX_PointF center_point(crBBox.left + fWidth / 2,
- crBBox.bottom + fHeight / 2);
-
- CPWL_PathData PathArray[] = {
- {{center_point.x, center_point.y + fHeight / 10.0f}, PWLPT_MOVETO},
- {{center_point.x + fWidth * 0.3f,
- center_point.y + fHeight / 10.0f + fWidth * 0.3f},
- PWLPT_LINETO},
- {{center_point.x + fWidth / 10.0f + fWidth * 0.3f,
- center_point.y + fHeight * 0.3f},
- PWLPT_LINETO},
- {{center_point.x + fWidth / 10.0f, center_point.y}, PWLPT_LINETO},
- {{center_point.x + fWidth / 10.0f + fWidth * 0.3f,
- center_point.y - fHeight * 0.3f},
- PWLPT_LINETO},
- {{center_point.x + fWidth * 0.3f,
- center_point.y - fHeight / 10.0f - fHeight * 0.3f},
- PWLPT_LINETO},
- {{center_point.x, center_point.y - fHeight / 10.0f}, PWLPT_LINETO},
- {{center_point.x - fWidth * 0.3f,
- center_point.y - fHeight / 10 - fHeight * 0.3f},
- PWLPT_LINETO},
- {{center_point.x - fWidth / 10.0f - fWidth * 0.3f,
- center_point.y - fHeight * 0.3f},
- PWLPT_LINETO},
- {{center_point.x - fWidth / 10, center_point.y}, PWLPT_LINETO},
- {{center_point.x - fWidth / 10 - fWidth * 0.3f,
- center_point.y + fHeight * 0.3f},
- PWLPT_LINETO},
- {{center_point.x - fWidth * 0.3f,
- center_point.y + fHeight / 10.0f + fHeight * 0.3f},
- PWLPT_LINETO},
- {{center_point.x, center_point.y + fHeight / 10.0f}, PWLPT_LINETO}};
-
- if (type == PWLPT_STREAM)
- sPathData = GetAppStreamFromArray(PathArray, FX_ArraySize(PathArray));
- else
- GetPathDataFromArray(path, PathArray, FX_ArraySize(PathArray));
-}
-
-void CPWL_Utils::GetGraphics_Help(CFX_ByteString& sPathData,
- CFX_PathData& path,
- const CFX_FloatRect& crBBox,
- const PWL_PATH_TYPE type) {
- FX_FLOAT fWidth = crBBox.right - crBBox.left;
- FX_FLOAT fHeight = crBBox.top - crBBox.bottom;
-
- CPWL_PathData PathArray[] = {
- {{crBBox.left + fWidth / 60.0f, crBBox.bottom + fHeight / 2.0f},
- PWLPT_MOVETO},
- {{crBBox.left + fWidth / 60.0f,
- crBBox.bottom + fHeight / 2.0f +
- FX_BEZIER * (fHeight / 60.0f - fHeight / 2.0f)},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth / 2.0f -
- FX_BEZIER * (fWidth / 2.0f - fWidth / 60.0f),
- crBBox.bottom + fHeight / 60.0f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth / 2.0f, crBBox.bottom + fHeight / 60.0f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth / 2.0f + FX_BEZIER * fWidth * 29 / 60.0f,
- crBBox.bottom + fHeight / 60.0f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth / 60.0f,
- crBBox.bottom + fHeight / 2.0f +
- FX_BEZIER * (fHeight / 60.0f - fHeight / 2.0f)},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth / 60.0f, crBBox.bottom + fHeight / 2.0f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth / 60.0f,
- crBBox.bottom + fHeight / 2.0f + FX_BEZIER * fHeight * 29 / 60.0f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth / 2.0f + FX_BEZIER * fWidth * 29 / 60.0f,
- crBBox.top - fHeight / 60.0f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth / 2.0f, crBBox.top - fHeight / 60.0f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth / 2.0f - FX_BEZIER * fWidth * 29 / 60.0f,
- crBBox.top - fHeight / 60.0f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth / 60.0f,
- crBBox.bottom + fHeight / 2.0f + FX_BEZIER * fHeight * 29 / 60.0f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth / 60.0f, crBBox.bottom + fHeight / 2.0f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth * 0.27f, crBBox.top - fHeight * 0.36f},
- PWLPT_MOVETO},
- {{crBBox.left + fWidth * 0.27f,
- crBBox.top - fHeight * 0.36f + FX_BEZIER * fHeight * 0.23f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth * 0.5f - FX_BEZIER * fWidth * 0.23f,
- crBBox.bottom + fHeight * 0.87f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth * 0.5f, crBBox.bottom + fHeight * 0.87f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth * 0.5f + FX_BEZIER * fWidth * 0.23f,
- crBBox.bottom + fHeight * 0.87f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth * 0.27f,
- crBBox.top - fHeight * 0.36f + FX_BEZIER * fHeight * 0.23f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth * 0.27f, crBBox.top - fHeight * 0.36f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth * 0.27f - fWidth * 0.08f * 0.2f,
- crBBox.top - fHeight * 0.36f - fHeight * 0.15f * 0.7f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth * 0.35f + fWidth * 0.08f * 0.2f,
- crBBox.top - fHeight * 0.51f + fHeight * 0.15f * 0.2f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth * 0.35f, crBBox.top - fHeight * 0.51f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth * 0.35f - fWidth * 0.1f * 0.5f,
- crBBox.top - fHeight * 0.51f - fHeight * 0.15f * 0.3f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth * 0.45f - fWidth * 0.1f * 0.5f,
- crBBox.top - fHeight * 0.68f + fHeight * 0.15f * 0.5f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth * 0.45f, crBBox.top - fHeight * 0.68f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth * 0.45f, crBBox.bottom + fHeight * 0.30f},
- PWLPT_LINETO},
- {{crBBox.right - fWidth * 0.45f,
- crBBox.bottom + fHeight * 0.30f - fWidth * 0.1f * 0.7f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth * 0.55f,
- crBBox.bottom + fHeight * 0.30f - fWidth * 0.1f * 0.7f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth * 0.55f, crBBox.bottom + fHeight * 0.30f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth * 0.55f, crBBox.top - fHeight * 0.66f},
- PWLPT_LINETO},
- {{crBBox.right - fWidth * 0.55f - fWidth * 0.1f * 0.05f,
- crBBox.top - fHeight * 0.66f + fHeight * 0.18f * 0.5f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth * 0.45f - fWidth * 0.1f * 0.05f,
- crBBox.top - fHeight * 0.48f - fHeight * 0.18f * 0.3f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth * 0.45f, crBBox.top - fHeight * 0.48f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth * 0.45f + fWidth * 0.08f * 0.2f,
- crBBox.top - fHeight * 0.48f + fHeight * 0.18f * 0.2f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth * 0.37f - fWidth * 0.08f * 0.2f,
- crBBox.top - fHeight * 0.36f - fHeight * 0.18f * 0.7f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth * 0.37f, crBBox.top - fHeight * 0.36f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth * 0.37f,
- crBBox.top - fHeight * 0.36f + FX_BEZIER * fHeight * 0.13f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth * 0.5f + FX_BEZIER * fWidth * 0.13f,
- crBBox.bottom + fHeight * 0.77f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth * 0.5f, crBBox.bottom + fHeight * 0.77f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth * 0.5f - FX_BEZIER * fWidth * 0.13f,
- crBBox.bottom + fHeight * 0.77f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth * 0.37f,
- crBBox.top - fHeight * 0.36f + FX_BEZIER * fHeight * 0.13f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth * 0.37f, crBBox.top - fHeight * 0.36f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth * 0.37f,
- crBBox.top - fHeight * 0.36f - fWidth * 0.1f * 0.6f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth * 0.27f,
- crBBox.top - fHeight * 0.36f - fWidth * 0.1f * 0.6f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth * 0.27f, crBBox.top - fHeight * 0.36f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth * 0.56f, crBBox.bottom + fHeight * 0.13f},
- PWLPT_MOVETO},
- {{crBBox.right - fWidth * 0.56f,
- crBBox.bottom + fHeight * 0.13f + FX_BEZIER * fHeight * 0.055f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth * 0.505f - FX_BEZIER * fWidth * 0.095f,
- crBBox.bottom + fHeight * 0.185f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth * 0.505f, crBBox.bottom + fHeight * 0.185f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth * 0.505f + FX_BEZIER * fWidth * 0.065f,
- crBBox.bottom + fHeight * 0.185f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth * 0.44f,
- crBBox.bottom + fHeight * 0.13f + FX_BEZIER * fHeight * 0.055f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth * 0.44f, crBBox.bottom + fHeight * 0.13f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth * 0.44f,
- crBBox.bottom + fHeight * 0.13f - FX_BEZIER * fHeight * 0.055f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth * 0.505f + FX_BEZIER * fWidth * 0.065f,
- crBBox.bottom + fHeight * 0.075f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth * 0.505f, crBBox.bottom + fHeight * 0.075f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth * 0.505f - FX_BEZIER * fWidth * 0.065f,
- crBBox.bottom + fHeight * 0.075f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth * 0.56f,
- crBBox.bottom + fHeight * 0.13f - FX_BEZIER * fHeight * 0.055f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth * 0.56f, crBBox.bottom + fHeight * 0.13f},
- PWLPT_BEZIERTO}};
-
- if (type == PWLPT_STREAM)
- sPathData = GetAppStreamFromArray(PathArray, FX_ArraySize(PathArray));
- else
- GetPathDataFromArray(path, PathArray, FX_ArraySize(PathArray));
-}
-
-void CPWL_Utils::GetGraphics_InsertText(CFX_ByteString& sPathData,
- CFX_PathData& path,
- const CFX_FloatRect& crBBox,
- const PWL_PATH_TYPE type) {
- FX_FLOAT fWidth = crBBox.right - crBBox.left;
- FX_FLOAT fHeight = crBBox.top - crBBox.bottom;
-
- CPWL_PathData PathArray[] = {
- {{crBBox.left + fWidth / 10, crBBox.bottom + fHeight / 10}, PWLPT_MOVETO},
- {{crBBox.left + fWidth / 2, crBBox.top - fHeight * 2 / 15}, PWLPT_LINETO},
- {{crBBox.right - fWidth / 10, crBBox.bottom + fHeight / 10},
- PWLPT_LINETO},
- {{crBBox.left + fWidth / 10, crBBox.bottom + fHeight / 10},
- PWLPT_LINETO}};
-
- if (type == PWLPT_STREAM)
- sPathData = GetAppStreamFromArray(PathArray, FX_ArraySize(PathArray));
- else
- GetPathDataFromArray(path, PathArray, FX_ArraySize(PathArray));
-}
-
-void CPWL_Utils::GetGraphics_Key(CFX_ByteString& sPathData,
- CFX_PathData& path,
- const CFX_FloatRect& crBBox,
- const PWL_PATH_TYPE type) {
- FX_FLOAT fWidth = crBBox.right - crBBox.left;
- FX_FLOAT fHeight = crBBox.top - crBBox.bottom;
- FX_FLOAT k = -fHeight / fWidth;
- CFX_PointF tail;
- CFX_PointF CicleCenter;
- tail.x = crBBox.left + fWidth * 0.9f;
- tail.y = k * (tail.x - crBBox.right) + crBBox.bottom;
- CicleCenter.x = crBBox.left + fWidth * 0.15f;
- CicleCenter.y = k * (CicleCenter.x - crBBox.right) + crBBox.bottom;
-
- CPWL_PathData PathArray[] = {
- {{tail.x + fWidth / 30.0f, -fWidth / 30.0f / k + tail.y}, PWLPT_MOVETO},
- {{tail.x + fWidth / 30.0f - fWidth * 0.18f,
- -k * fWidth * 0.18f - fWidth / 30 / k + tail.y},
- PWLPT_LINETO},
- {{tail.x + fWidth / 30 - fWidth * 0.18f + fWidth * 0.07f,
- -fWidth * 0.07f / k - k * fWidth * 0.18f - fWidth / 30 / k + tail.y},
- PWLPT_LINETO},
- {{tail.x + fWidth / 30 - fWidth * 0.18f - fWidth / 20 + fWidth * 0.07f,
- -fWidth * 0.07f / k - k * fWidth / 20 - k * fWidth * 0.18f -
- fWidth / 30 / k + tail.y},
- PWLPT_LINETO},
- {{tail.x + fWidth / 30 - fWidth * 0.18f - fWidth / 20,
- -k * fWidth / 20 - k * fWidth * 0.18f - fWidth / 30 / k + tail.y},
- PWLPT_LINETO},
- {{tail.x + fWidth / 30 - fWidth * 0.18f - fWidth / 20 - fWidth / 15,
- -k * fWidth / 15 - k * fWidth / 20 - k * fWidth * 0.18f -
- fWidth / 30 / k + tail.y},
- PWLPT_LINETO},
- {{tail.x + fWidth / 30 - fWidth * 0.18f - fWidth / 20 - fWidth / 15 +
- fWidth * 0.07f,
- -fWidth * 0.07f / k - k * fWidth / 15 - k * fWidth / 20 -
- k * fWidth * 0.18f - fWidth / 30 / k + tail.y},
- PWLPT_LINETO},
- {{tail.x + fWidth / 30 - fWidth * 0.18f - fWidth / 20 - fWidth / 15 -
- fWidth / 20 + fWidth * 0.07f,
- -fWidth * 0.07f / k + -k * fWidth / 20 + -k * fWidth / 15 -
- k * fWidth / 20 - k * fWidth * 0.18f - fWidth / 30 / k + tail.y},
- PWLPT_LINETO},
- {{tail.x + fWidth / 30 - fWidth * 0.18f - fWidth / 20 - fWidth / 15 -
- fWidth / 20,
- -k * fWidth / 20 + -k * fWidth / 15 - k * fWidth / 20 -
- k * fWidth * 0.18f - fWidth / 30 / k + tail.y},
- PWLPT_LINETO},
- {{tail.x + fWidth / 30 - fWidth * 0.45f,
- -k * fWidth * 0.45f - fWidth / 30 / k + tail.y},
- PWLPT_LINETO},
- {{tail.x + fWidth / 30 - fWidth * 0.45f + fWidth * 0.2f,
- -fWidth * 0.4f / k - k * fWidth * 0.45f - fWidth / 30 / k + tail.y},
- PWLPT_BEZIERTO},
- {{CicleCenter.x + fWidth * 0.2f, -fWidth * 0.1f / k + CicleCenter.y},
- PWLPT_BEZIERTO},
- {{CicleCenter.x, CicleCenter.y}, PWLPT_BEZIERTO},
- {{CicleCenter.x - fWidth / 60.0f, -k * fWidth / 60 + CicleCenter.y},
- PWLPT_BEZIERTO},
- {{CicleCenter.x - fWidth / 60, -k * fWidth / 60 + CicleCenter.y},
- PWLPT_BEZIERTO},
- {{CicleCenter.x, CicleCenter.y}, PWLPT_BEZIERTO},
- {{CicleCenter.x - fWidth * 0.22f,
- fWidth * 0.35f / k + CicleCenter.y - fHeight * 0.05f},
- PWLPT_BEZIERTO},
- {{tail.x - fWidth / 30 - fWidth * 0.45f - fWidth * 0.18f,
- fWidth * 0.05f / k - k * fWidth * 0.45f + fWidth / 30 / k + tail.y -
- fHeight * 0.05f},
- PWLPT_BEZIERTO},
- {{tail.x - fWidth / 30.0f - fWidth * 0.45f,
- -k * fWidth * 0.45f + fWidth / 30.0f / k + tail.y},
- PWLPT_BEZIERTO},
- {{tail.x - fWidth / 30.0f, fWidth / 30.0f / k + tail.y}, PWLPT_LINETO},
- {{tail.x + fWidth / 30, -fWidth / 30 / k + tail.y}, PWLPT_LINETO},
- {{CicleCenter.x + fWidth * 0.08f, k * fWidth * 0.08f + CicleCenter.y},
- PWLPT_MOVETO},
- {{CicleCenter.x + fWidth * 0.08f + fWidth * 0.1f,
- -fWidth * 0.1f / k + k * fWidth * 0.08f + CicleCenter.y},
- PWLPT_BEZIERTO},
- {{CicleCenter.x + fWidth * 0.22f + fWidth * 0.1f,
- k * fWidth * 0.22f + CicleCenter.y - fWidth * 0.1f / k},
- PWLPT_BEZIERTO},
- {{CicleCenter.x + fWidth * 0.22f, k * fWidth * 0.22f + CicleCenter.y},
- PWLPT_BEZIERTO},
- {{CicleCenter.x + fWidth * 0.22f - fWidth * 0.1f,
- fWidth * 0.1f / k + k * fWidth * 0.22f + CicleCenter.y},
- PWLPT_BEZIERTO},
- {{CicleCenter.x + fWidth * 0.08f - fWidth * 0.1f,
- fWidth * 0.1f / k + k * fWidth * 0.08f + CicleCenter.y},
- PWLPT_BEZIERTO},
- {{CicleCenter.x + fWidth * 0.08f, k * fWidth * 0.08f + CicleCenter.y},
- PWLPT_BEZIERTO}};
-
- if (type == PWLPT_STREAM)
- sPathData = GetAppStreamFromArray(PathArray, FX_ArraySize(PathArray));
- else
- GetPathDataFromArray(path, PathArray, FX_ArraySize(PathArray));
-}
-
-void CPWL_Utils::GetGraphics_NewParagraph(CFX_ByteString& sPathData,
- CFX_PathData& path,
- const CFX_FloatRect& crBBox,
- const PWL_PATH_TYPE type) {
- FX_FLOAT fWidth = crBBox.right - crBBox.left;
- FX_FLOAT fHeight = crBBox.top - crBBox.bottom;
-
- CPWL_PathData PathArray[] = {
- {{crBBox.left + fWidth / 2.0f, crBBox.top - fHeight / 20.0f},
- PWLPT_MOVETO},
- {{crBBox.left + fWidth / 10.0f, crBBox.top - fHeight / 2.0f},
- PWLPT_LINETO},
- {{crBBox.right - fWidth / 10.0f, crBBox.top - fHeight / 2.0f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth / 2.0f, crBBox.top - fHeight / 20.0f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.12f, crBBox.top - fHeight * 17 / 30.0f},
- PWLPT_MOVETO},
- {{crBBox.left + fWidth * 0.12f, crBBox.bottom + fHeight / 10.0f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.22f, crBBox.bottom + fHeight / 10.0f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.22f,
- crBBox.top - fHeight * 17 / 30.0f - fWidth * 0.14f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.38f, crBBox.bottom + fHeight / 10.0f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.48f, crBBox.bottom + fHeight / 10.0f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.48f, crBBox.top - fHeight * 17 / 30.0f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.38f, crBBox.top - fHeight * 17 / 30.0f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.38f, crBBox.bottom + fWidth * 0.24f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.22f, crBBox.top - fHeight * 17 / 30.0f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.12f, crBBox.top - fHeight * 17 / 30.0f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.6f, crBBox.bottom + fHeight / 10.0f},
- PWLPT_MOVETO},
- {{crBBox.left + fWidth * 0.7f, crBBox.bottom + fHeight / 10.0f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.7f,
- crBBox.bottom + fHeight / 10.0f + fHeight / 7.0f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.97f,
- crBBox.bottom + fHeight / 10.0f + fHeight / 7.0f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth * 0.97f, crBBox.top - fHeight * 17 / 30.0f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth * 0.7f, crBBox.top - fHeight * 17 / 30.0f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth * 0.6f, crBBox.top - fHeight * 17 / 30.0f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.6f, crBBox.bottom + fHeight / 10.0f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.7f,
- crBBox.bottom + fHeight / 7 + fHeight * 0.18f},
- PWLPT_MOVETO},
- {{crBBox.left + fWidth * 0.85f,
- crBBox.bottom + fHeight / 7 + fHeight * 0.18f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth * 0.85f,
- crBBox.top - fHeight * 17 / 30.0f - fHeight * 0.08f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth * 0.7f,
- crBBox.top - fHeight * 17 / 30.0f - fHeight * 0.08f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth * 0.7f,
- crBBox.bottom + fHeight / 7 + fHeight * 0.18f},
- PWLPT_LINETO}};
-
- if (type == PWLPT_STREAM)
- sPathData = GetAppStreamFromArray(PathArray, FX_ArraySize(PathArray));
- else
- GetPathDataFromArray(path, PathArray, FX_ArraySize(PathArray));
-}
-
-void CPWL_Utils::GetGraphics_TextNote(CFX_ByteString& sPathData,
- CFX_PathData& path,
- const CFX_FloatRect& crBBox,
- const PWL_PATH_TYPE type) {
- FX_FLOAT fWidth = crBBox.right - crBBox.left;
- FX_FLOAT fHeight = crBBox.top - crBBox.bottom;
-
- CPWL_PathData PathArray[] = {
- {{crBBox.right - fWidth * 3 / 10.0f, crBBox.bottom + fHeight / 15.0f},
- PWLPT_MOVETO},
- {{crBBox.left + fWidth * 7 / 10.0f, crBBox.bottom + fHeight * 4 / 15.0f},
- PWLPT_LINETO},
- {{crBBox.right - fWidth / 10.0f, crBBox.bottom + fHeight * 4 / 15.0f},
- PWLPT_LINETO},
- {{crBBox.right - fWidth / 10.0f, crBBox.top - fHeight / 15.0f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth / 10.0f, crBBox.top - fHeight / 15.0f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth / 10.0f, crBBox.bottom + fHeight / 15.0f},
- PWLPT_LINETO},
- {{crBBox.right - fWidth * 3 / 10.0f, crBBox.bottom + fHeight / 15.0f},
- PWLPT_LINETO},
- {{crBBox.right - fWidth / 10.0f, crBBox.bottom + fHeight * 4 / 15.0f},
- PWLPT_LINETO},
- {{crBBox.right - fWidth * 3 / 10.0f, crBBox.bottom + fHeight / 15.0f},
- PWLPT_LINETO},
- {{crBBox.right - fWidth * 3 / 10.0f, crBBox.bottom + fHeight * 4 / 15.0f},
- PWLPT_LINETO},
- {{crBBox.right - fWidth / 10.0f, crBBox.bottom + fHeight * 4 / 15.0f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth / 5.0f, crBBox.top - fHeight * 4 / 15.0f},
- PWLPT_MOVETO},
- {{crBBox.right - fWidth / 5.0f, crBBox.top - fHeight * 4 / 15.0f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth / 5.0f, crBBox.top - fHeight * 7 / 15.0f},
- PWLPT_MOVETO},
- {{crBBox.right - fWidth / 5.0f, crBBox.top - fHeight * 7 / 15.0f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth / 5.0f, crBBox.top - fHeight * 10 / 15.0f},
- PWLPT_MOVETO},
- {{crBBox.right - fWidth * 3 / 10.0f, crBBox.top - fHeight * 10 / 15.0f},
- PWLPT_LINETO}};
-
- if (type == PWLPT_STREAM)
- sPathData = GetAppStreamFromArray(PathArray, FX_ArraySize(PathArray));
- else
- GetPathDataFromArray(path, PathArray, FX_ArraySize(PathArray));
-}
-
-void CPWL_Utils::GetGraphics_Paragraph(CFX_ByteString& sPathData,
- CFX_PathData& path,
- const CFX_FloatRect& crBBox,
- const PWL_PATH_TYPE type) {
- FX_FLOAT fWidth = crBBox.right - crBBox.left;
- FX_FLOAT fHeight = crBBox.top - crBBox.bottom;
-
- CPWL_PathData PathArray[] = {
- {{crBBox.left + fWidth / 2.0f, crBBox.top - fHeight / 15.0f},
- PWLPT_MOVETO},
- {{crBBox.left + fWidth * 0.7f, crBBox.top - fHeight / 15.0f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.7f, crBBox.bottom + fHeight / 15.0f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.634f, crBBox.bottom + fHeight / 15.0f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.634f, crBBox.top - fHeight * 2 / 15.0f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.566f, crBBox.top - fHeight * 2 / 15.0f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.566f, crBBox.bottom + fHeight / 15.0f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth / 2.0f, crBBox.bottom + fHeight / 15.0f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth / 2.0f,
- crBBox.top - fHeight / 15.0f - fHeight * 0.4f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.2f,
- crBBox.top - fHeight / 15.0f - fHeight * 0.4f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth * 0.2f, crBBox.top - fHeight / 15.0f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth / 2.0f, crBBox.top - fHeight / 15.0f},
- PWLPT_BEZIERTO}};
-
- if (type == PWLPT_STREAM)
- sPathData = GetAppStreamFromArray(PathArray, FX_ArraySize(PathArray));
- else
- GetPathDataFromArray(path, PathArray, FX_ArraySize(PathArray));
-}
-
-void CPWL_Utils::GetGraphics_RightArrow(CFX_ByteString& sPathData,
- CFX_PathData& path,
- const CFX_FloatRect& crBBox,
- const PWL_PATH_TYPE type) {
- FX_FLOAT fWidth = crBBox.right - crBBox.left;
- FX_FLOAT fHeight = crBBox.top - crBBox.bottom;
-
- CPWL_PathData PathArray[] = {
- {{crBBox.right - fWidth / 15.0f, crBBox.top - fHeight / 2.0f},
- PWLPT_MOVETO},
- {{crBBox.left + fWidth / 2.0f + fWidth / 8.0f,
- crBBox.bottom + fHeight / 5.0f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth / 2.0f, crBBox.bottom + fHeight / 5.0f},
- PWLPT_LINETO},
- {{crBBox.right - fWidth / 15.0f - fWidth * 0.15f,
- crBBox.top - fHeight / 2.0f - fWidth / 25.0f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.1f,
- crBBox.top - fHeight / 2.0f - fWidth / 25.0f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.1f,
- crBBox.top - fHeight / 2.0f + fWidth / 25.0f},
- PWLPT_LINETO},
- {{crBBox.right - fWidth / 15.0f - fWidth * 0.15f,
- crBBox.top - fHeight / 2.0f + fWidth / 25.0f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth / 2.0f, crBBox.top - fHeight / 5.0f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth / 2.0f + fWidth / 8.0f,
- crBBox.top - fHeight / 5.0f},
- PWLPT_LINETO},
- {{crBBox.right - fWidth / 15.0f, crBBox.top - fHeight / 2.0f},
- PWLPT_LINETO}};
-
- if (type == PWLPT_STREAM)
- sPathData = GetAppStreamFromArray(PathArray, FX_ArraySize(PathArray));
- else
- GetPathDataFromArray(path, PathArray, FX_ArraySize(PathArray));
-}
-
-void CPWL_Utils::GetGraphics_RightPointer(CFX_ByteString& sPathData,
- CFX_PathData& path,
- const CFX_FloatRect& crBBox,
- const PWL_PATH_TYPE type) {
- FX_FLOAT fWidth = crBBox.right - crBBox.left;
- FX_FLOAT fHeight = crBBox.top - crBBox.bottom;
-
- CPWL_PathData PathArray[] = {
- {{crBBox.right - fWidth / 30.0f, crBBox.top - fHeight / 2.0f},
- PWLPT_MOVETO},
- {{crBBox.left + fWidth / 30.0f, crBBox.bottom + fHeight / 6.0f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 4 / 15.0f, crBBox.top - fHeight / 2.0f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth / 30.0f, crBBox.top - fHeight / 6.0f},
- PWLPT_LINETO},
- {{crBBox.right - fWidth / 30.0f, crBBox.top - fHeight / 2.0f},
- PWLPT_LINETO}};
-
- if (type == PWLPT_STREAM)
- sPathData = GetAppStreamFromArray(PathArray, FX_ArraySize(PathArray));
- else
- GetPathDataFromArray(path, PathArray, FX_ArraySize(PathArray));
-}
-
-void CPWL_Utils::GetGraphics_Star(CFX_ByteString& sPathData,
- CFX_PathData& path,
- const CFX_FloatRect& crBBox,
- const PWL_PATH_TYPE type) {
- FX_FLOAT fLongRadius =
- (crBBox.top - crBBox.bottom) / (1 + (FX_FLOAT)cos(FX_PI / 5.0f));
- fLongRadius = fLongRadius * 0.7f;
- FX_FLOAT fShortRadius = fLongRadius * 0.55f;
- CFX_PointF ptCenter = CFX_PointF((crBBox.left + crBBox.right) / 2.0f,
- (crBBox.top + crBBox.bottom) / 2.0f);
-
- FX_FLOAT px1[5], py1[5];
- FX_FLOAT px2[5], py2[5];
-
- FX_FLOAT fAngel = FX_PI / 10.0f;
-
- for (int32_t i = 0; i < 5; i++) {
- px1[i] = ptCenter.x + fLongRadius * (FX_FLOAT)cos(fAngel);
- py1[i] = ptCenter.y + fLongRadius * (FX_FLOAT)sin(fAngel);
-
- fAngel += FX_PI * 2 / 5.0f;
- }
-
- fAngel = FX_PI / 5.0f + FX_PI / 10.0f;
-
- for (int32_t j = 0; j < 5; j++) {
- px2[j] = ptCenter.x + fShortRadius * (FX_FLOAT)cos(fAngel);
- py2[j] = ptCenter.y + fShortRadius * (FX_FLOAT)sin(fAngel);
-
- fAngel += FX_PI * 2 / 5.0f;
- }
-
- CPWL_PathData PathArray[11];
- PathArray[0] = {{px1[0], py1[0]}, PWLPT_MOVETO};
- PathArray[1] = {{px2[0], py2[0]}, PWLPT_LINETO};
-
- for (int32_t k = 0; k < 4; k++) {
- PathArray[(k + 1) * 2] = {{px1[k + 1], py1[k + 1]}, PWLPT_LINETO};
- PathArray[(k + 1) * 2 + 1] = {{px2[k + 1], py2[k + 1]}, PWLPT_LINETO};
- }
-
- PathArray[10] = {{px1[0], py1[0]}, PWLPT_LINETO};
-
- if (type == PWLPT_STREAM)
- sPathData = GetAppStreamFromArray(PathArray, FX_ArraySize(PathArray));
- else
- GetPathDataFromArray(path, PathArray, FX_ArraySize(PathArray));
-}
-
-void CPWL_Utils::GetGraphics_UpArrow(CFX_ByteString& sPathData,
- CFX_PathData& path,
- const CFX_FloatRect& crBBox,
- const PWL_PATH_TYPE type) {
- FX_FLOAT fWidth = crBBox.right - crBBox.left;
- FX_FLOAT fHeight = crBBox.top - crBBox.bottom;
-
- CPWL_PathData PathArray[] = {
- {{crBBox.left + fWidth / 2.0f, crBBox.top - fHeight / 15.0f},
- PWLPT_MOVETO},
- {{crBBox.right - fWidth / 10.0f, crBBox.top - fWidth * 3 / 5.0f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.6f, crBBox.top - fWidth * 3 / 5.0f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.6f, crBBox.bottom + fHeight / 15.0f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.4f, crBBox.bottom + fHeight / 15.0f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.4f, crBBox.top - fWidth * 3 / 5.0f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth / 10, crBBox.top - fWidth * 3 / 5.0f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth / 2.0f, crBBox.top - fHeight / 15.0f},
- PWLPT_LINETO}};
-
- if (type == PWLPT_STREAM)
- sPathData = GetAppStreamFromArray(PathArray, FX_ArraySize(PathArray));
- else
- GetPathDataFromArray(path, PathArray, FX_ArraySize(PathArray));
-}
-
-void CPWL_Utils::GetGraphics_UpLeftArrow(CFX_ByteString& sPathData,
- CFX_PathData& path,
- const CFX_FloatRect& crBBox,
- const PWL_PATH_TYPE type) {
- FX_FLOAT fWidth = crBBox.right - crBBox.left;
- FX_FLOAT fHeight = crBBox.top - crBBox.bottom;
- CFX_PointF leftup(crBBox.left, crBBox.top);
- CFX_PointF rightdown(crBBox.right, crBBox.bottom);
- FX_FLOAT k = -fHeight / fWidth;
- CFX_PointF tail;
- tail.x = crBBox.left + fWidth * 4 / 5.0f;
- tail.y = k * (tail.x - crBBox.right) + rightdown.y;
-
- CPWL_PathData PathArray[] = {
- {{crBBox.left + fWidth / 20.0f,
- k * (crBBox.left + fWidth / 20.0f - rightdown.x) + rightdown.y},
- PWLPT_MOVETO},
- {{fHeight * 17 / 60.0f / k + tail.x + fWidth / 10.0f + fWidth / 5.0f,
- -fWidth / 5.0f / k + tail.y - fWidth / 10.0f / k +
- fHeight * 17 / 60.0f},
- PWLPT_LINETO},
- {{fHeight * 17 / 60.0f / k + tail.x + fWidth / 10.0f,
- tail.y - fWidth / 10.0f / k + fHeight * 17 / 60.0f},
- PWLPT_LINETO},
- {{tail.x + fWidth / 10.0f, tail.y - fWidth / 10.0f / k}, PWLPT_LINETO},
- {{tail.x - fWidth / 10.0f, tail.y + fWidth / 10.0f / k}, PWLPT_LINETO},
- {{fHeight * 17 / 60.0f / k + tail.x - fWidth / 10.0f,
- tail.y + fWidth / 10.0f / k + fHeight * 17 / 60.0f},
- PWLPT_LINETO},
- {{fHeight * 17 / 60.0f / k + tail.x - fWidth / 10.0f - fWidth / 5.0f,
- fWidth / 5.0f / k + tail.y + fWidth / 10.0f / k + fHeight * 17 / 60.0f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth / 20.0f,
- k * (crBBox.left + fWidth / 20.0f - rightdown.x) + rightdown.y},
- PWLPT_LINETO}};
-
- if (type == PWLPT_STREAM)
- sPathData = GetAppStreamFromArray(PathArray, FX_ArraySize(PathArray));
- else
- GetPathDataFromArray(path, PathArray, FX_ArraySize(PathArray));
-}
-
-void CPWL_Utils::GetGraphics_Graph(CFX_ByteString& sPathData,
- CFX_PathData& path,
- const CFX_FloatRect& crBBox,
- const PWL_PATH_TYPE type) {
- FX_FLOAT fWidth = crBBox.right - crBBox.left;
- FX_FLOAT fHeight = crBBox.top - crBBox.bottom;
-
- CPWL_PathData PathArray[] = {
- {{crBBox.left + fWidth * 0.05f, crBBox.top - fWidth * 0.15f},
- PWLPT_MOVETO},
- {{crBBox.left + fWidth * 0.25f, crBBox.top - fHeight * 0.15f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.275f, crBBox.bottom + fHeight * 0.08f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.05f, crBBox.bottom + fHeight * 0.08f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.05f, crBBox.top - fWidth * 0.15f},
- PWLPT_LINETO},
-
- {{crBBox.left + fWidth * 0.275f, crBBox.top - fWidth * 0.45f},
- PWLPT_MOVETO},
- {{crBBox.left + fWidth * 0.475f, crBBox.top - fWidth * 0.45f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.475f, crBBox.bottom + fHeight * 0.08f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.275f, crBBox.bottom + fHeight * 0.08f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.275f, crBBox.top - fWidth * 0.45f},
- PWLPT_LINETO},
-
- {{crBBox.left + fWidth * 0.5f, crBBox.top - fHeight * 0.05f},
- PWLPT_MOVETO},
- {{crBBox.left + fWidth * 0.7f, crBBox.top - fHeight * 0.05f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.7f, crBBox.bottom + fHeight * 0.08f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.5f, crBBox.bottom + fHeight * 0.08f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.5f, crBBox.top - fHeight * 0.05f},
- PWLPT_LINETO},
-
- {{crBBox.left + fWidth * 0.725f, crBBox.top - fWidth * 0.35f},
- PWLPT_MOVETO},
- {{crBBox.left + fWidth * 0.925f, crBBox.top - fWidth * 0.35f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.925f, crBBox.bottom + fHeight * 0.08f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.725f, crBBox.bottom + fHeight * 0.08f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.725f, crBBox.top - fWidth * 0.35f},
- PWLPT_LINETO}};
-
- if (type == PWLPT_STREAM)
- sPathData = GetAppStreamFromArray(PathArray, FX_ArraySize(PathArray));
- else
- GetPathDataFromArray(path, PathArray, FX_ArraySize(PathArray));
-}
-
-void CPWL_Utils::GetGraphics_Paperclip(CFX_ByteString& sPathData,
- CFX_PathData& path,
- const CFX_FloatRect& crBBox,
- const PWL_PATH_TYPE type) {
- FX_FLOAT fWidth = crBBox.right - crBBox.left;
- FX_FLOAT fHeight = crBBox.top - crBBox.bottom;
-
- CPWL_PathData PathArray[] = {
- {{crBBox.left + fWidth / 60, crBBox.top - fHeight * 0.25f}, PWLPT_MOVETO},
- {{crBBox.left + fWidth / 60, crBBox.bottom + fHeight * 0.25f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth / 60,
- crBBox.bottom + fHeight * 0.25f - fWidth * 57 / 60.0f * 0.35f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth / 30,
- crBBox.bottom + fHeight * 0.25f - fWidth * 57 / 60.0f * 0.35f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth / 30, crBBox.bottom + fHeight * 0.25f},
- PWLPT_BEZIERTO},
-
- {{crBBox.right - fWidth / 30, crBBox.top - fHeight * 0.33f},
- PWLPT_LINETO},
- {{crBBox.right - fWidth / 30,
- crBBox.top - fHeight * 0.33f + fHeight / 15 * 0.5f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth / 30 - fWidth * 0.12f,
- crBBox.top - fHeight * 0.33f + fHeight / 15 * 0.5f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth / 30 - fWidth * 0.12f,
- crBBox.top - fHeight * 0.33f},
- PWLPT_BEZIERTO},
-
- {{crBBox.right - fWidth / 30 - fWidth * 0.12f,
- crBBox.bottom + fHeight * 0.2f},
- PWLPT_LINETO},
- {{crBBox.right - fWidth / 30 - fWidth * 0.12f,
- crBBox.bottom + fHeight * 0.2f -
- (fWidth * 57 / 60.0f - fWidth * 0.24f) * 0.25f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth / 60 + fWidth * 0.12f,
- crBBox.bottom + fHeight * 0.2f -
- (fWidth * 57 / 60.0f - fWidth * 0.24f) * 0.25f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth / 60 + fWidth * 0.12f,
- crBBox.bottom + fHeight * 0.2f},
- PWLPT_BEZIERTO},
-
- {{crBBox.left + fWidth / 60 + fWidth * 0.12f,
- crBBox.top - fHeight * 0.2f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth / 60 + fWidth * 0.12f,
- crBBox.top - fHeight * 0.2f +
- (fWidth * 11 / 12.0f - fWidth * 0.36f) * 0.25f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth / 15 - fWidth * 0.24f,
- crBBox.top - fHeight * 0.2f +
- (fWidth * 11 / 12.0f - fWidth * 0.36f) * 0.25f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth / 15 - fWidth * 0.24f,
- crBBox.top - fHeight * 0.2f},
- PWLPT_BEZIERTO},
-
- {{crBBox.right - fWidth / 15 - fWidth * 0.24f,
- crBBox.bottom + fHeight * 0.25f},
- PWLPT_LINETO},
- {{crBBox.right - fWidth / 15 - fWidth * 0.24f,
- crBBox.bottom + fHeight * 0.25f -
- (fWidth * 14 / 15.0f - fWidth * 0.53f) * 0.25f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth * 0.29f,
- crBBox.bottom + fHeight * 0.25f -
- (fWidth * 14 / 15.0f - fWidth * 0.53f) * 0.25f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth * 0.29f, crBBox.bottom + fHeight * 0.25f},
- PWLPT_BEZIERTO},
-
- {{crBBox.left + fWidth * 0.29f, crBBox.top - fHeight * 0.33f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.29f,
- crBBox.top - fHeight * 0.33f + fWidth * 0.12f * 0.35f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth * 0.17f,
- crBBox.top - fHeight * 0.33f + fWidth * 0.12f * 0.35f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth * 0.17f, crBBox.top - fHeight * 0.33f},
- PWLPT_BEZIERTO},
-
- {{crBBox.left + fWidth * 0.17f, crBBox.bottom + fHeight * 0.3f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.17f,
- crBBox.bottom + fHeight * 0.3f - fWidth * (14 / 15.0f - 0.29f) * 0.35f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth / 15 - fWidth * 0.12f,
- crBBox.bottom + fHeight * 0.3f - fWidth * (14 / 15.0f - 0.29f) * 0.35f},
- PWLPT_BEZIERTO},
- {{crBBox.right - fWidth / 15 - fWidth * 0.12f,
- crBBox.bottom + fHeight * 0.3f},
- PWLPT_BEZIERTO},
-
- {{crBBox.right - fWidth / 15 - fWidth * 0.12f,
- crBBox.top - fHeight * 0.25f},
- PWLPT_LINETO},
- {{crBBox.right - fWidth / 15 - fWidth * 0.12f,
- crBBox.top - fHeight * 0.25f + fWidth * 0.35f * (11 / 12.0f - 0.12f)},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth / 60,
- crBBox.top - fHeight * 0.25f + fWidth * 0.35f * (11 / 12.0f - 0.12f)},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth / 60, crBBox.top - fHeight * 0.25f},
- PWLPT_BEZIERTO}};
-
- if (type == PWLPT_STREAM)
- sPathData = GetAppStreamFromArray(PathArray, FX_ArraySize(PathArray));
- else
- GetPathDataFromArray(path, PathArray, FX_ArraySize(PathArray));
-}
-
-void CPWL_Utils::GetGraphics_Attachment(CFX_ByteString& sPathData,
- CFX_PathData& path,
- const CFX_FloatRect& crBBox,
- const PWL_PATH_TYPE type) {
- FX_FLOAT fWidth = crBBox.right - crBBox.left;
- FX_FLOAT fHeight = crBBox.top - crBBox.bottom;
-
- CPWL_PathData PathArray[] = {
- {{crBBox.left + fWidth * 0.25f, crBBox.top - fHeight * 0.1f},
- PWLPT_MOVETO},
- {{crBBox.left + fWidth * 0.4f, crBBox.top - fHeight * 0.23f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.4f, crBBox.top - fHeight * 0.5f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.4f,
- crBBox.top - fHeight * 0.5f + fWidth * 0.04f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth * 0.6f,
- crBBox.top - fHeight * 0.5f + fWidth * 0.04f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth * 0.6f, crBBox.top - fHeight * 0.5f},
- PWLPT_BEZIERTO},
-
- {{crBBox.left + fWidth * 0.6f, crBBox.top - fHeight * 0.23f},
- PWLPT_LINETO},
- {{crBBox.right - fWidth * 0.25f, crBBox.top - fHeight * 0.1f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.25f, crBBox.top - fHeight * 0.1f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.4f, crBBox.top - fHeight * 0.23f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.6f, crBBox.top - fHeight * 0.23f},
- PWLPT_LINETO},
-
- {{crBBox.left + fWidth * 0.4f, crBBox.top - fHeight * 0.5f},
- PWLPT_MOVETO},
- {{crBBox.left + fWidth * 0.4f - fWidth * 0.25f * 0.4f,
- crBBox.top - fHeight * 0.5f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth * 0.15f,
- crBBox.top - fHeight * 0.65f + fHeight * 0.15f * 0.4f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth * 0.15f, crBBox.top - fHeight * 0.65f},
- PWLPT_BEZIERTO},
-
- {{crBBox.right - fWidth * 0.15f, crBBox.top - fHeight * 0.65f},
- PWLPT_LINETO},
- {{crBBox.right - fWidth * 0.15f,
- crBBox.top - fHeight * 0.65f + fHeight * 0.15f * 0.4f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth * 0.6f + fWidth * 0.25f * 0.4f,
- crBBox.top - fHeight * 0.5f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth * 0.6f, crBBox.top - fHeight * 0.5f},
- PWLPT_BEZIERTO},
-
- {{crBBox.left + fWidth * 0.6f,
- crBBox.top - fHeight * 0.5f + fWidth * 0.04f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth * 0.4f,
- crBBox.top - fHeight * 0.5f + fWidth * 0.04f},
- PWLPT_BEZIERTO},
- {{crBBox.left + fWidth * 0.4f, crBBox.top - fHeight * 0.5f},
- PWLPT_BEZIERTO},
-
- {{crBBox.left + fWidth * 0.5f, crBBox.top - fHeight * 0.65f},
- PWLPT_MOVETO},
- {{crBBox.left + fWidth * 0.5f, crBBox.bottom + fHeight * 0.1f},
- PWLPT_LINETO}};
-
- if (type == PWLPT_STREAM)
- sPathData = GetAppStreamFromArray(PathArray, FX_ArraySize(PathArray));
- else
- GetPathDataFromArray(path, PathArray, FX_ArraySize(PathArray));
-}
-
-void CPWL_Utils::GetGraphics_Tag(CFX_ByteString& sPathData,
- CFX_PathData& path,
- const CFX_FloatRect& crBBox,
- const PWL_PATH_TYPE type) {
- FX_FLOAT fWidth = crBBox.right - crBBox.left;
- FX_FLOAT fHeight = crBBox.top - crBBox.bottom;
-
- CPWL_PathData PathArray[] = {
- {{crBBox.left + fWidth * 0.4f, crBBox.top - fHeight * 0.1f},
- PWLPT_MOVETO},
- {{crBBox.left + fWidth * 0.1f, crBBox.top - fHeight * 0.5f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.3f, crBBox.bottom + fHeight * 0.1f},
- PWLPT_LINETO},
- {{crBBox.right - fWidth * 0.1f, crBBox.bottom + fHeight * 0.1f},
- PWLPT_LINETO},
- {{crBBox.right - fWidth * 0.1f, crBBox.top - fHeight * 0.1f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.4f, crBBox.top - fHeight * 0.1f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.4f, crBBox.top - fHeight * 0.3f},
- PWLPT_MOVETO},
- {{crBBox.right - fWidth * 0.2f, crBBox.top - fHeight * 0.3f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.4f, crBBox.top - fHeight * 0.5f},
- PWLPT_MOVETO},
- {{crBBox.right - fWidth * 0.2f, crBBox.top - fHeight * 0.5f},
- PWLPT_LINETO},
- {{crBBox.left + fWidth * 0.4f, crBBox.top - fHeight * 0.7f},
- PWLPT_MOVETO},
- {{crBBox.right - fWidth * 0.2f, crBBox.top - fHeight * 0.7f},
- PWLPT_LINETO}};
-
- if (type == PWLPT_STREAM)
- sPathData = GetAppStreamFromArray(PathArray, FX_ArraySize(PathArray));
- else
- GetPathDataFromArray(path, PathArray, FX_ArraySize(PathArray));
-}
-
-void CPWL_Utils::GetGraphics_Foxit(CFX_ByteString& sPathData,
- CFX_PathData& path,
- const CFX_FloatRect& crBBox,
- const PWL_PATH_TYPE type) {
- FX_FLOAT fOutWidth = crBBox.right - crBBox.left;
- FX_FLOAT fOutHeight = crBBox.top - crBBox.bottom;
-
- CFX_FloatRect crInBox = crBBox;
- crInBox.left = crBBox.left + fOutWidth * 0.08f;
- crInBox.right = crBBox.right - fOutWidth * 0.08f;
- crInBox.top = crBBox.top - fOutHeight * 0.08f;
- crInBox.bottom = crBBox.bottom + fOutHeight * 0.08f;
-
- FX_FLOAT fWidth = crInBox.right - crInBox.left;
- FX_FLOAT fHeight = crInBox.top - crInBox.bottom;
-
- CPWL_PathData PathArray[] = {
- {{crInBox.left, crInBox.top}, PWLPT_MOVETO},
- {{crInBox.left + fWidth * 0.45f, crInBox.top}, PWLPT_LINETO},
- {{crInBox.left + fWidth * 0.45f,
- crInBox.top - FX_BEZIER * fHeight * 0.4f},
- PWLPT_BEZIERTO},
- {{crInBox.left + fWidth * 0.45f - FX_BEZIER * fWidth * 0.45f,
- crInBox.top - fHeight * 0.4f},
- PWLPT_BEZIERTO},
- {{crInBox.left, crInBox.top - fHeight * 0.4f}, PWLPT_BEZIERTO},
- {{crInBox.left, crInBox.top}, PWLPT_LINETO},
-
- {{crInBox.left + fWidth * 0.60f, crInBox.top}, PWLPT_MOVETO},
- {{crInBox.left + fWidth * 0.75f, crInBox.top}, PWLPT_LINETO},
- {{crInBox.left + fWidth * 0.75f,
- crInBox.top - FX_BEZIER * fHeight * 0.7f},
- PWLPT_BEZIERTO},
- {{crInBox.left + fWidth * 0.75f - FX_BEZIER * fWidth * 0.75f,
- crInBox.top - fHeight * 0.7f},
- PWLPT_BEZIERTO},
- {{crInBox.left, crInBox.top - fHeight * 0.7f}, PWLPT_BEZIERTO},
- {{crInBox.left, crInBox.top - fHeight * 0.55f}, PWLPT_LINETO},
- {{crInBox.left + FX_BEZIER * fWidth * 0.60f,
- crInBox.top - fHeight * 0.55f},
- PWLPT_BEZIERTO},
- {{crInBox.left + fWidth * 0.60f,
- crInBox.top - FX_BEZIER * fHeight * 0.55f},
- PWLPT_BEZIERTO},
- {{crInBox.left + fWidth * 0.60f, crInBox.top}, PWLPT_BEZIERTO},
-
- {{crInBox.left + fWidth * 0.90f, crInBox.top}, PWLPT_MOVETO},
- {{crInBox.left + fWidth * 0.90f,
- crInBox.top - FX_BEZIER * fHeight * 0.85f},
- PWLPT_BEZIERTO},
- {{crInBox.left + fWidth * 0.90f - FX_BEZIER * fWidth * 0.90f,
- crInBox.top - fHeight * 0.85f},
- PWLPT_BEZIERTO},
- {{crInBox.left, crInBox.top - fHeight * 0.85f}, PWLPT_BEZIERTO},
- {{crInBox.left, crInBox.bottom}, PWLPT_LINETO},
- {{crInBox.right, crInBox.bottom}, PWLPT_LINETO},
- {{crInBox.right, crInBox.top}, PWLPT_LINETO},
- {{crInBox.left + fWidth * 0.90f, crInBox.top}, PWLPT_LINETO},
- };
-
- if (type == PWLPT_STREAM)
- sPathData = GetAppStreamFromArray(PathArray, FX_ArraySize(PathArray));
- else
- GetPathDataFromArray(path, PathArray, FX_ArraySize(PathArray));
-}
-
-void CPWL_Color::ConvertColorType(int32_t nConvertColorType) {
- if (nColorType == nConvertColorType)
- return;
-
- switch (nColorType) {
- case COLORTYPE_TRANSPARENT:
- break;
- case COLORTYPE_GRAY:
- switch (nConvertColorType) {
- case COLORTYPE_RGB:
- CPWL_Utils::ConvertGRAY2RGB(fColor1, fColor1, fColor2, fColor3);
- break;
- case COLORTYPE_CMYK:
- CPWL_Utils::ConvertGRAY2CMYK(fColor1, fColor1, fColor2, fColor3,
- fColor4);
- break;
- }
- break;
- case COLORTYPE_RGB:
- switch (nConvertColorType) {
- case COLORTYPE_GRAY:
- CPWL_Utils::ConvertRGB2GRAY(fColor1, fColor2, fColor3, fColor1);
- break;
- case COLORTYPE_CMYK:
- CPWL_Utils::ConvertRGB2CMYK(fColor1, fColor2, fColor3, fColor1,
- fColor2, fColor3, fColor4);
- break;
- }
- break;
- case COLORTYPE_CMYK:
- switch (nConvertColorType) {
- case COLORTYPE_GRAY:
- CPWL_Utils::ConvertCMYK2GRAY(fColor1, fColor2, fColor3, fColor4,
- fColor1);
- break;
- case COLORTYPE_RGB:
- CPWL_Utils::ConvertCMYK2RGB(fColor1, fColor2, fColor3, fColor4,
- fColor1, fColor2, fColor3);
- break;
- }
- break;
- }
- nColorType = nConvertColorType;
-}