Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(96)

Side by Side Diff: core/src/fpdfapi/fpdf_page/fpdf_page_image.cpp

Issue 1634373003: Refactor CPDF_Object and its subclasses. (Closed) Base URL: https://pdfium.googlesource.com/pdfium.git@master
Patch Set: rebase Created 4 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2014 PDFium Authors. All rights reserved. 1 // Copyright 2014 PDFium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 // Original code copyright 2014 Foxit Software Inc. http://www.foxitsoftware.com 5 // Original code copyright 2014 Foxit Software Inc. http://www.foxitsoftware.com
6 6
7 #include "pageint.h" 7 #include "pageint.h"
8 8
9 #include "core/include/fpdfapi/fpdf_page.h" 9 #include "core/include/fpdfapi/fpdf_page.h"
10 #include "core/include/fpdfapi/fpdf_pageobj.h" 10 #include "core/include/fpdfapi/fpdf_pageobj.h"
(...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after
42 void CPDF_Image::Release() { 42 void CPDF_Image::Release() {
43 if (m_bInline || (m_pStream && m_pStream->GetObjNum() == 0)) { 43 if (m_bInline || (m_pStream && m_pStream->GetObjNum() == 0)) {
44 delete this; 44 delete this;
45 } 45 }
46 } 46 }
47 CPDF_Image* CPDF_Image::Clone() { 47 CPDF_Image* CPDF_Image::Clone() {
48 if (m_pStream->GetObjNum()) 48 if (m_pStream->GetObjNum())
49 return m_pDocument->GetPageData()->GetImage(m_pStream); 49 return m_pDocument->GetPageData()->GetImage(m_pStream);
50 50
51 CPDF_Image* pImage = new CPDF_Image(m_pDocument); 51 CPDF_Image* pImage = new CPDF_Image(m_pDocument);
52 pImage->LoadImageF(ToStream(m_pStream->CPDF_Object::Clone()), m_bInline); 52 pImage->LoadImageF(ToStream(m_pStream->Clone()), m_bInline);
53 if (m_bInline) 53 if (m_bInline)
54 pImage->SetInlineDict(ToDictionary(m_pInlineDict->Clone(TRUE))); 54 pImage->SetInlineDict(ToDictionary(m_pInlineDict->Clone(TRUE)));
55 55
56 return pImage; 56 return pImage;
57 } 57 }
58 CPDF_Image::CPDF_Image(CPDF_Document* pDoc) { 58 CPDF_Image::CPDF_Image(CPDF_Document* pDoc) {
59 m_pDocument = pDoc; 59 m_pDocument = pDoc;
60 m_pStream = NULL; 60 m_pStream = NULL;
61 m_pOC = NULL; 61 m_pOC = NULL;
62 m_bInline = FALSE; 62 m_bInline = FALSE;
(...skipping 24 matching lines...) Expand all
87 m_pInlineDict = ToDictionary(pDict->Clone()); 87 m_pInlineDict = ToDictionary(pDict->Clone());
88 } 88 }
89 m_pOC = pDict->GetDictBy("OC"); 89 m_pOC = pDict->GetDictBy("OC");
90 m_bIsMask = 90 m_bIsMask =
91 !pDict->KeyExist("ColorSpace") || pDict->GetIntegerBy("ImageMask"); 91 !pDict->KeyExist("ColorSpace") || pDict->GetIntegerBy("ImageMask");
92 m_bInterpolate = pDict->GetIntegerBy("Interpolate"); 92 m_bInterpolate = pDict->GetIntegerBy("Interpolate");
93 m_Height = pDict->GetIntegerBy("Height"); 93 m_Height = pDict->GetIntegerBy("Height");
94 m_Width = pDict->GetIntegerBy("Width"); 94 m_Width = pDict->GetIntegerBy("Width");
95 return TRUE; 95 return TRUE;
96 } 96 }
OLDNEW
« no previous file with comments | « core/include/fpdfapi/fpdf_objects.h ('k') | core/src/fpdfapi/fpdf_parser/fpdf_parser_objects.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698