Revert "Revert "Add type cast definitions for CPDF_Dictionary.""
[pdfium.git] / core / src / fpdfapi / fpdf_page / fpdf_page_image.cpp
1 // Copyright 2014 PDFium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 // Original code copyright 2014 Foxit Software Inc. http://www.foxitsoftware.com
6
7 #include "../../../include/fpdfapi/fpdf_page.h"
8 #include "../../../include/fpdfapi/fpdf_pageobj.h"
9 #include "pageint.h"
10 CPDF_ImageObject::CPDF_ImageObject() {
11   m_pImage = NULL;
12   m_Type = PDFPAGE_IMAGE;
13 }
14 CPDF_ImageObject::~CPDF_ImageObject() {
15   if (!m_pImage) {
16     return;
17   }
18   if (m_pImage->IsInline() ||
19       (m_pImage->GetStream() && m_pImage->GetStream()->GetObjNum() == 0)) {
20     delete m_pImage;
21   } else {
22     m_pImage->GetDocument()->GetPageData()->ReleaseImage(m_pImage->GetStream());
23   }
24 }
25 void CPDF_ImageObject::CopyData(const CPDF_PageObject* pSrc) {
26   const CPDF_ImageObject* pSrcObj = (const CPDF_ImageObject*)pSrc;
27   if (m_pImage) {
28     m_pImage->Release();
29   }
30   m_pImage = pSrcObj->m_pImage->Clone();
31   m_Matrix = pSrcObj->m_Matrix;
32 }
33 void CPDF_ImageObject::Transform(const CFX_AffineMatrix& matrix) {
34   m_Matrix.Concat(matrix);
35   CalcBoundingBox();
36 }
37 void CPDF_ImageObject::CalcBoundingBox() {
38   m_Left = m_Bottom = 0;
39   m_Right = m_Top = 1.0f;
40   m_Matrix.TransformRect(m_Left, m_Right, m_Top, m_Bottom);
41 }
42 void CPDF_Image::Release() {
43   if (m_bInline || (m_pStream && m_pStream->GetObjNum() == 0)) {
44     delete this;
45   }
46 }
47 CPDF_Image* CPDF_Image::Clone() {
48   if (m_pStream->GetObjNum()) {
49     return m_pDocument->GetPageData()->GetImage(m_pStream);
50   }
51   CPDF_Image* pImage = new CPDF_Image(m_pDocument);
52   pImage->LoadImageF((CPDF_Stream*)((CPDF_Object*)m_pStream)->Clone(),
53                      m_bInline);
54   if (m_bInline) {
55     pImage->SetInlineDict(ToDictionary(m_pInlineDict->Clone(TRUE)));
56   }
57   return pImage;
58 }
59 CPDF_Image::CPDF_Image(CPDF_Document* pDoc) {
60   m_pDocument = pDoc;
61   m_pStream = NULL;
62   m_pOC = NULL;
63   m_bInline = FALSE;
64   m_pInlineDict = NULL;
65   m_pDIBSource = NULL;
66   m_pMask = NULL;
67   m_MatteColor = 0;
68 }
69 CPDF_Image::~CPDF_Image() {
70   if (m_bInline) {
71     if (m_pStream) {
72       m_pStream->Release();
73     }
74     if (m_pInlineDict) {
75       m_pInlineDict->Release();
76     }
77   }
78 }
79 FX_BOOL CPDF_Image::LoadImageF(CPDF_Stream* pStream, FX_BOOL bInline) {
80   m_pStream = pStream;
81   if (m_bInline && m_pInlineDict) {
82     m_pInlineDict->Release();
83     m_pInlineDict = NULL;
84   }
85   m_bInline = bInline;
86   CPDF_Dictionary* pDict = pStream->GetDict();
87   if (m_bInline) {
88     m_pInlineDict = ToDictionary(pDict->Clone());
89   }
90   m_pOC = pDict->GetDict(FX_BSTRC("OC"));
91   m_bIsMask = !pDict->KeyExist(FX_BSTRC("ColorSpace")) ||
92               pDict->GetInteger(FX_BSTRC("ImageMask"));
93   m_bInterpolate = pDict->GetInteger(FX_BSTRC("Interpolate"));
94   m_Height = pDict->GetInteger(FX_BSTRC("Height"));
95   m_Width = pDict->GetInteger(FX_BSTRC("Width"));
96   return TRUE;
97 }