diff options
Diffstat (limited to 'fpdfsdk/pdfwindow/PWL_Utils.cpp')
-rw-r--r-- | fpdfsdk/pdfwindow/PWL_Utils.cpp | 1867 |
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; -} |