| Index: xfa/fwl/core/cfwl_picturebox.cpp
|
| diff --git a/xfa/fwl/core/cfwl_picturebox.cpp b/xfa/fwl/core/cfwl_picturebox.cpp
|
| index af0cb86514d1a04554eb23300ddf517cc3ebd90a..cb4cff35d1843322f95ac3e22d587397a967b163 100644
|
| --- a/xfa/fwl/core/cfwl_picturebox.cpp
|
| +++ b/xfa/fwl/core/cfwl_picturebox.cpp
|
| @@ -10,16 +10,54 @@
|
|
|
| #include "third_party/base/ptr_util.h"
|
|
|
| -CFWL_PictureBox::CFWL_PictureBox(const CFWL_App* app) : CFWL_Widget(app) {}
|
| +CFWL_PictureBox::CFWL_PictureBox(const CFWL_App* app)
|
| + : CFWL_Widget(app, pdfium::MakeUnique<CFWL_WidgetProperties>(), nullptr) {
|
| + m_rtClient.Reset();
|
| + m_rtImage.Reset();
|
| + m_matrix.SetIdentity();
|
| +}
|
|
|
| CFWL_PictureBox::~CFWL_PictureBox() {}
|
|
|
| -void CFWL_PictureBox::Initialize() {
|
| - ASSERT(!m_pIface);
|
| +FWL_Type CFWL_PictureBox::GetClassID() const {
|
| + return FWL_Type::PictureBox;
|
| +}
|
| +
|
| +void CFWL_PictureBox::GetWidgetRect(CFX_RectF& rect, bool bAutoSize) {
|
| + if (!bAutoSize) {
|
| + rect = m_pProperties->m_rtWidget;
|
| + return;
|
| + }
|
|
|
| - m_pIface = pdfium::MakeUnique<IFWL_PictureBox>(
|
| - m_pApp, pdfium::MakeUnique<CFWL_WidgetProperties>());
|
| + rect.Set(0, 0, 0, 0);
|
|
|
| - CFWL_Widget::Initialize();
|
| + CFWL_Widget::GetWidgetRect(rect, true);
|
| }
|
|
|
| +void CFWL_PictureBox::Update() {
|
| + if (IsLocked())
|
| + return;
|
| + if (!m_pProperties->m_pThemeProvider)
|
| + m_pProperties->m_pThemeProvider = GetAvailableTheme();
|
| +
|
| + GetClientRect(m_rtClient);
|
| +}
|
| +
|
| +void CFWL_PictureBox::DrawWidget(CFX_Graphics* pGraphics,
|
| + const CFX_Matrix* pMatrix) {
|
| + if (!pGraphics)
|
| + return;
|
| + if (!m_pProperties->m_pThemeProvider)
|
| + return;
|
| +
|
| + IFWL_ThemeProvider* pTheme = GetAvailableTheme();
|
| + if (HasBorder())
|
| + DrawBorder(pGraphics, CFWL_Part::Border, pTheme, pMatrix);
|
| + if (HasEdge())
|
| + DrawEdge(pGraphics, CFWL_Part::Edge, pTheme, pMatrix);
|
| +}
|
| +
|
| +void CFWL_PictureBox::OnDrawWidget(CFX_Graphics* pGraphics,
|
| + const CFX_Matrix* pMatrix) {
|
| + DrawWidget(pGraphics, pMatrix);
|
| +}
|
|
|