| Index: xfa/fwl/theme/cfwl_widgettp.cpp
|
| diff --git a/xfa/fwl/theme/cfwl_widgettp.cpp b/xfa/fwl/theme/cfwl_widgettp.cpp
|
| index 3ef9b0ba2d5e7598ae0c51abcf350e37939fad4a..99602577306009e7c8380edbdf40063a913fa697 100644
|
| --- a/xfa/fwl/theme/cfwl_widgettp.cpp
|
| +++ b/xfa/fwl/theme/cfwl_widgettp.cpp
|
| @@ -17,6 +17,7 @@
|
| #include "xfa/fwl/core/cfwl_widgetmgr.h"
|
| #include "xfa/fwl/core/ifwl_themeprovider.h"
|
| #include "xfa/fwl/core/ifwl_widget.h"
|
| +#include "xfa/fwl/theme/cfwl_arrowdata.h"
|
| #include "xfa/fxgraphics/cfx_color.h"
|
| #include "xfa/fxgraphics/cfx_path.h"
|
| #include "xfa/fxgraphics/cfx_shading.h"
|
| @@ -61,7 +62,7 @@ uint32_t CFWL_WidgetTP::SetThemeID(IFWL_Widget* pWidget,
|
| FX_BOOL bChildren) {
|
| uint32_t dwOld = m_dwThemeID;
|
| m_dwThemeID = dwThemeID;
|
| - if (CFWL_ArrowData::IsInstance()) {
|
| + if (CFWL_ArrowData::HasInstance()) {
|
| CFWL_ArrowData::GetInstance()->SetColorData(FWL_GetThemeColor(dwThemeID));
|
| }
|
| if (bChildren) {
|
| @@ -69,19 +70,23 @@ uint32_t CFWL_WidgetTP::SetThemeID(IFWL_Widget* pWidget,
|
| }
|
| return dwOld;
|
| }
|
| +
|
| FWL_Error CFWL_WidgetTP::GetThemeMatrix(IFWL_Widget* pWidget,
|
| CFX_Matrix& matrix) {
|
| matrix.Set(_ctm.a, _ctm.b, _ctm.c, _ctm.d, _ctm.e, _ctm.f);
|
| return FWL_Error::Succeeded;
|
| }
|
| +
|
| FWL_Error CFWL_WidgetTP::SetThemeMatrix(IFWL_Widget* pWidget,
|
| const CFX_Matrix& matrix) {
|
| _ctm.Set(matrix.a, matrix.b, matrix.c, matrix.d, matrix.e, matrix.f);
|
| return FWL_Error::Succeeded;
|
| }
|
| +
|
| FX_BOOL CFWL_WidgetTP::DrawBackground(CFWL_ThemeBackground* pParams) {
|
| return TRUE;
|
| }
|
| +
|
| FX_BOOL CFWL_WidgetTP::DrawText(CFWL_ThemeText* pParams) {
|
| if (!m_pTextOut)
|
| InitTTO();
|
| @@ -99,6 +104,7 @@ FX_BOOL CFWL_WidgetTP::DrawText(CFWL_ThemeText* pParams) {
|
| m_pTextOut->DrawLogicText(pParams->m_wsText.c_str(), iLen, pParams->m_rtPart);
|
| return TRUE;
|
| }
|
| +
|
| void* CFWL_WidgetTP::GetCapacity(CFWL_ThemePart* pThemePart,
|
| CFWL_WidgetCapacity dwCapacity) {
|
| switch (dwCapacity) {
|
| @@ -154,18 +160,22 @@ void* CFWL_WidgetTP::GetCapacity(CFWL_ThemePart* pThemePart,
|
| }
|
| return &m_fValue;
|
| }
|
| +
|
| FX_BOOL CFWL_WidgetTP::IsCustomizedLayout(IFWL_Widget* pWidget) {
|
| return FWL_GetThemeLayout(m_dwThemeID);
|
| }
|
| +
|
| FWL_Error CFWL_WidgetTP::GetPartRect(CFWL_ThemePart* pThemePart,
|
| CFX_RectF& rect) {
|
| return FWL_Error::Succeeded;
|
| }
|
| +
|
| FX_BOOL CFWL_WidgetTP::IsInPart(CFWL_ThemePart* pThemePart,
|
| FX_FLOAT fx,
|
| FX_FLOAT fy) {
|
| return TRUE;
|
| }
|
| +
|
| FX_BOOL CFWL_WidgetTP::CalcTextRect(CFWL_ThemeText* pParams, CFX_RectF& rect) {
|
| if (!pParams)
|
| return FALSE;
|
| @@ -177,17 +187,21 @@ FX_BOOL CFWL_WidgetTP::CalcTextRect(CFWL_ThemeText* pParams, CFX_RectF& rect) {
|
| pParams->m_wsText.GetLength(), rect);
|
| return TRUE;
|
| }
|
| +
|
| FWL_Error CFWL_WidgetTP::Initialize() {
|
| m_dwThemeID = 0;
|
| _ctm.SetIdentity();
|
| return FWL_Error::Succeeded;
|
| }
|
| +
|
| FWL_Error CFWL_WidgetTP::Finalize() {
|
| if (!m_pTextOut)
|
| FinalizeTTO();
|
| return FWL_Error::Succeeded;
|
| }
|
| +
|
| CFWL_WidgetTP::~CFWL_WidgetTP() {}
|
| +
|
| FWL_Error CFWL_WidgetTP::SetFont(IFWL_Widget* pWidget,
|
| const FX_WCHAR* strFont,
|
| FX_FLOAT fFontSize,
|
| @@ -201,6 +215,7 @@ FWL_Error CFWL_WidgetTP::SetFont(IFWL_Widget* pWidget,
|
| m_pTextOut->SetTextColor(rgbFont);
|
| return FWL_Error::Succeeded;
|
| }
|
| +
|
| FWL_Error CFWL_WidgetTP::SetFont(IFWL_Widget* pWidget,
|
| CFGAS_GEFont* pFont,
|
| FX_FLOAT fFontSize,
|
| @@ -213,6 +228,7 @@ FWL_Error CFWL_WidgetTP::SetFont(IFWL_Widget* pWidget,
|
| m_pTextOut->SetTextColor(rgbFont);
|
| return FWL_Error::Succeeded;
|
| }
|
| +
|
| CFGAS_GEFont* CFWL_WidgetTP::GetFont(IFWL_Widget* pWidget) {
|
| return m_pFDEFont;
|
| }
|
| @@ -352,6 +368,7 @@ void CFWL_WidgetTP::Draw3DRect(CFX_Graphics* pGraphics,
|
| }
|
| pGraphics->RestoreGraphState();
|
| }
|
| +
|
| void CFWL_WidgetTP::Draw3DCircle(CFX_Graphics* pGraphics,
|
| FWLTHEME_EDGE eType,
|
| FX_FLOAT fWidth,
|
| @@ -394,6 +411,7 @@ void CFWL_WidgetTP::Draw3DCircle(CFX_Graphics* pGraphics,
|
| pGraphics->StrokePath(&path, pMatrix);
|
| pGraphics->RestoreGraphState();
|
| }
|
| +
|
| void CFWL_WidgetTP::DrawBorder(CFX_Graphics* pGraphics,
|
| const CFX_RectF* pRect,
|
| CFX_Matrix* pMatrix) {
|
| @@ -412,11 +430,13 @@ void CFWL_WidgetTP::DrawBorder(CFX_Graphics* pGraphics,
|
| pGraphics->FillPath(&path, FXFILL_ALTERNATE, pMatrix);
|
| pGraphics->RestoreGraphState();
|
| }
|
| +
|
| void CFWL_WidgetTP::FillBackground(CFX_Graphics* pGraphics,
|
| const CFX_RectF* pRect,
|
| CFX_Matrix* pMatrix) {
|
| FillSoildRect(pGraphics, FWLTHEME_COLOR_Background, pRect, pMatrix);
|
| }
|
| +
|
| void CFWL_WidgetTP::FillSoildRect(CFX_Graphics* pGraphics,
|
| FX_ARGB fillColor,
|
| const CFX_RectF* pRect,
|
| @@ -434,6 +454,7 @@ void CFWL_WidgetTP::FillSoildRect(CFX_Graphics* pGraphics,
|
| pGraphics->FillPath(&path, FXFILL_WINDING, pMatrix);
|
| pGraphics->RestoreGraphState();
|
| }
|
| +
|
| void CFWL_WidgetTP::DrawAxialShading(CFX_Graphics* pGraphics,
|
| FX_FLOAT fx1,
|
| FX_FLOAT fy1,
|
| @@ -456,6 +477,7 @@ void CFWL_WidgetTP::DrawAxialShading(CFX_Graphics* pGraphics,
|
| pGraphics->FillPath(path, fillMode, pMatrix);
|
| pGraphics->RestoreGraphState();
|
| }
|
| +
|
| void CFWL_WidgetTP::DrawAnnulusRect(CFX_Graphics* pGraphics,
|
| FX_ARGB fillColor,
|
| const CFX_RectF* pRect,
|
| @@ -477,6 +499,7 @@ void CFWL_WidgetTP::DrawAnnulusRect(CFX_Graphics* pGraphics,
|
| pGraphics->FillPath(&path, FXFILL_ALTERNATE, pMatrix);
|
| pGraphics->RestoreGraphState();
|
| }
|
| +
|
| void CFWL_WidgetTP::DrawAnnulusCircle(CFX_Graphics* pGraphics,
|
| FX_ARGB fillColor,
|
| const CFX_RectF* pRect,
|
| @@ -501,6 +524,7 @@ void CFWL_WidgetTP::DrawAnnulusCircle(CFX_Graphics* pGraphics,
|
| pGraphics->FillPath(&path, FXFILL_ALTERNATE, pMatrix);
|
| pGraphics->RestoreGraphState();
|
| }
|
| +
|
| void CFWL_WidgetTP::DrawFocus(CFX_Graphics* pGraphics,
|
| const CFX_RectF* pRect,
|
| CFX_Matrix* pMatrix) {
|
| @@ -574,6 +598,7 @@ void CFWL_WidgetTP::DrawArrow(CFX_Graphics* pGraphics,
|
| pGraphics->FillPath(&path, FXFILL_WINDING, pMatrix);
|
| pGraphics->RestoreGraphState();
|
| }
|
| +
|
| void CFWL_WidgetTP::DrawArrow(CFX_Graphics* pGraphics,
|
| const CFX_RectF* pRect,
|
| FWLTHEME_DIRECTION eDict,
|
| @@ -629,17 +654,18 @@ void CFWL_WidgetTP::DrawArrow(CFX_Graphics* pGraphics,
|
| pGraphics->SetFillColor(&cr);
|
| pGraphics->FillPath(&path, FXFILL_WINDING, pMatrix);
|
| }
|
| +
|
| void CFWL_WidgetTP::DrawBtn(CFX_Graphics* pGraphics,
|
| const CFX_RectF* pRect,
|
| FWLTHEME_STATE eState,
|
| CFX_Matrix* pMatrix) {
|
| CFX_Path path;
|
| path.Create();
|
| - if (!CFWL_ArrowData::IsInstance()) {
|
| + if (!CFWL_ArrowData::HasInstance()) {
|
| CFWL_ArrowData::GetInstance()->SetColorData(FWL_GetThemeColor(m_dwThemeID));
|
| }
|
| CFWL_ArrowData::CColorData* pColorData =
|
| - CFWL_ArrowData::GetInstance()->m_pColorData;
|
| + CFWL_ArrowData::GetInstance()->m_pColorData.get();
|
| FX_FLOAT fRight = pRect->right();
|
| FX_FLOAT fBottom = pRect->bottom();
|
| path.AddRectangle(pRect->left, pRect->top, pRect->width, pRect->height);
|
| @@ -652,22 +678,25 @@ void CFWL_WidgetTP::DrawBtn(CFX_Graphics* pGraphics,
|
| pGraphics->SetStrokeColor(&rcStroke);
|
| pGraphics->StrokePath(&path, pMatrix);
|
| }
|
| +
|
| void CFWL_WidgetTP::DrawArrowBtn(CFX_Graphics* pGraphics,
|
| const CFX_RectF* pRect,
|
| FWLTHEME_DIRECTION eDict,
|
| FWLTHEME_STATE eState,
|
| CFX_Matrix* pMatrix) {
|
| DrawBtn(pGraphics, pRect, eState, pMatrix);
|
| - if (!CFWL_ArrowData::IsInstance()) {
|
| + if (!CFWL_ArrowData::HasInstance()) {
|
| CFWL_ArrowData::GetInstance()->SetColorData(FWL_GetThemeColor(m_dwThemeID));
|
| }
|
| CFWL_ArrowData::CColorData* pColorData =
|
| - CFWL_ArrowData::GetInstance()->m_pColorData;
|
| + CFWL_ArrowData::GetInstance()->m_pColorData.get();
|
| DrawArrow(pGraphics, pRect, eDict, pColorData->clrSign[eState - 1], pMatrix);
|
| }
|
| +
|
| CFWL_ArrowData::CFWL_ArrowData() : m_pColorData(nullptr) {
|
| SetColorData(0);
|
| }
|
| +
|
| CFWL_FontData::CFWL_FontData()
|
| : m_dwStyles(0),
|
| m_dwCodePage(0),
|
| @@ -679,6 +708,7 @@ CFWL_FontData::CFWL_FontData()
|
| #endif
|
| {
|
| }
|
| +
|
| CFWL_FontData::~CFWL_FontData() {
|
| if (m_pFont) {
|
| m_pFont->Release();
|
| @@ -692,12 +722,14 @@ CFWL_FontData::~CFWL_FontData() {
|
| }
|
| #endif
|
| }
|
| +
|
| FX_BOOL CFWL_FontData::Equal(const CFX_WideStringC& wsFontFamily,
|
| uint32_t dwFontStyles,
|
| uint16_t wCodePage) {
|
| return m_wsFamily == wsFontFamily && m_dwStyles == dwFontStyles &&
|
| m_dwCodePage == wCodePage;
|
| }
|
| +
|
| FX_BOOL CFWL_FontData::LoadFont(const CFX_WideStringC& wsFontFamily,
|
| uint32_t dwFontStyles,
|
| uint16_t dwCodePage) {
|
| @@ -723,12 +755,16 @@ CFWL_FontManager* CFWL_FontManager::GetInstance() {
|
| s_FontManager = new CFWL_FontManager;
|
| return s_FontManager;
|
| }
|
| +
|
| void CFWL_FontManager::DestroyInstance() {
|
| delete s_FontManager;
|
| s_FontManager = nullptr;
|
| }
|
| +
|
| CFWL_FontManager::CFWL_FontManager() {}
|
| +
|
| CFWL_FontManager::~CFWL_FontManager() {}
|
| +
|
| CFGAS_GEFont* CFWL_FontManager::FindFont(const CFX_WideStringC& wsFontFamily,
|
| uint32_t dwFontStyles,
|
| uint16_t wCodePage) {
|
| @@ -742,78 +778,20 @@ CFGAS_GEFont* CFWL_FontManager::FindFont(const CFX_WideStringC& wsFontFamily,
|
| m_FontsArray.push_back(std::move(pFontData));
|
| return m_FontsArray.back()->GetFont();
|
| }
|
| +
|
| FX_BOOL FWLTHEME_Init() {
|
| return TRUE;
|
| }
|
| +
|
| void FWLTHEME_Release() {
|
| CFWL_ArrowData::DestroyInstance();
|
| CFWL_FontManager::DestroyInstance();
|
| }
|
| +
|
| uint32_t FWL_GetThemeLayout(uint32_t dwThemeID) {
|
| return 0xffff0000 & dwThemeID;
|
| }
|
| +
|
| uint32_t FWL_GetThemeColor(uint32_t dwThemeID) {
|
| return 0x0000ffff & dwThemeID;
|
| }
|
| -
|
| -CFWL_ArrowData* CFWL_ArrowData::m_pInstance = nullptr;
|
| -
|
| -CFWL_ArrowData* CFWL_ArrowData::GetInstance() {
|
| - if (!m_pInstance)
|
| - m_pInstance = new CFWL_ArrowData;
|
| - return m_pInstance;
|
| -}
|
| -
|
| -FX_BOOL CFWL_ArrowData::IsInstance() {
|
| - return !!m_pInstance;
|
| -}
|
| -
|
| -void CFWL_ArrowData::DestroyInstance() {
|
| - delete m_pInstance;
|
| - m_pInstance = nullptr;
|
| -}
|
| -
|
| -CFWL_ArrowData::~CFWL_ArrowData() {
|
| - delete m_pColorData;
|
| -}
|
| -
|
| -void CFWL_ArrowData::SetColorData(uint32_t dwID) {
|
| - if (!m_pColorData) {
|
| - m_pColorData = new CColorData;
|
| - }
|
| - if (dwID) {
|
| - m_pColorData->clrBorder[0] = ArgbEncode(255, 142, 153, 125);
|
| - m_pColorData->clrBorder[1] = ArgbEncode(255, 157, 171, 119);
|
| - m_pColorData->clrBorder[2] = ArgbEncode(255, 118, 131, 97);
|
| - m_pColorData->clrBorder[3] = ArgbEncode(255, 172, 168, 153);
|
| - m_pColorData->clrStart[0] = ArgbEncode(255, 203, 215, 186);
|
| - m_pColorData->clrStart[1] = ArgbEncode(255, 218, 232, 185);
|
| - m_pColorData->clrStart[2] = ArgbEncode(255, 203, 215, 186);
|
| - m_pColorData->clrStart[3] = ArgbEncode(255, 254, 254, 251);
|
| - m_pColorData->clrEnd[0] = ArgbEncode(255, 149, 167, 117);
|
| - m_pColorData->clrEnd[1] = ArgbEncode(255, 198, 211, 155);
|
| - m_pColorData->clrEnd[2] = ArgbEncode(255, 149, 167, 117);
|
| - m_pColorData->clrEnd[3] = ArgbEncode(255, 243, 241, 236);
|
| - m_pColorData->clrSign[0] = ArgbEncode(255, 255, 255, 255);
|
| - m_pColorData->clrSign[1] = ArgbEncode(255, 255, 255, 255);
|
| - m_pColorData->clrSign[2] = ArgbEncode(255, 255, 255, 255);
|
| - m_pColorData->clrSign[3] = ArgbEncode(255, 128, 128, 128);
|
| - } else {
|
| - m_pColorData->clrBorder[0] = ArgbEncode(255, 202, 216, 249);
|
| - m_pColorData->clrBorder[1] = ArgbEncode(255, 171, 190, 233);
|
| - m_pColorData->clrBorder[2] = ArgbEncode(255, 135, 147, 219);
|
| - m_pColorData->clrBorder[3] = ArgbEncode(255, 172, 168, 153);
|
| - m_pColorData->clrStart[0] = ArgbEncode(255, 225, 234, 254);
|
| - m_pColorData->clrStart[1] = ArgbEncode(255, 253, 255, 255);
|
| - m_pColorData->clrStart[2] = ArgbEncode(255, 110, 142, 241);
|
| - m_pColorData->clrStart[3] = ArgbEncode(255, 254, 254, 251);
|
| - m_pColorData->clrEnd[0] = ArgbEncode(255, 175, 204, 251);
|
| - m_pColorData->clrEnd[1] = ArgbEncode(255, 185, 218, 251);
|
| - m_pColorData->clrEnd[2] = ArgbEncode(255, 210, 222, 235);
|
| - m_pColorData->clrEnd[3] = ArgbEncode(255, 243, 241, 236);
|
| - m_pColorData->clrSign[0] = ArgbEncode(255, 77, 97, 133);
|
| - m_pColorData->clrSign[1] = ArgbEncode(255, 77, 97, 133);
|
| - m_pColorData->clrSign[2] = ArgbEncode(255, 77, 97, 133);
|
| - m_pColorData->clrSign[3] = ArgbEncode(255, 128, 128, 128);
|
| - }
|
| -}
|
|
|