Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 The Chromium 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 #ifndef PRINTING_EMF_WIN_H_ | 5 #ifndef PRINTING_EMF_WIN_H_ |
| 6 #define PRINTING_EMF_WIN_H_ | 6 #define PRINTING_EMF_WIN_H_ |
| 7 | 7 |
| 8 #include <windows.h> | 8 #include <windows.h> |
| 9 #include <vector> | 9 #include <vector> |
| 10 | 10 |
| 11 #include "base/basictypes.h" | 11 #include "base/basictypes.h" |
| 12 #include "base/gtest_prod_util.h" | 12 #include "base/gtest_prod_util.h" |
| 13 #include "printing/native_metafile_win.h" | 13 #include "printing/native_metafile.h" |
| 14 | 14 |
| 15 class FilePath; | 15 class FilePath; |
| 16 | 16 |
| 17 namespace gfx { | 17 namespace gfx { |
| 18 class Rect; | 18 class Rect; |
| 19 } | 19 } |
| 20 | 20 |
| 21 namespace printing { | 21 namespace printing { |
| 22 | 22 |
| 23 // Simple wrapper class that manage an EMF data stream and its virtual HDC. | |
|
vandebo (ex-Chrome)
2011/03/14 20:24:25
You can leave this comment in.
vandebo (ex-Chrome)
2011/03/14 22:55:05
You didn't address this.
dpapad
2011/03/15 16:11:06
Done.
| |
| 24 class Emf : public NativeMetafile { | 23 class Emf : public NativeMetafile { |
| 25 public: | 24 public: |
| 26 class Record; | 25 class Record; |
| 27 class Enumerator; | 26 class Enumerator; |
| 28 struct EnumerationContext; | 27 struct EnumerationContext; |
| 29 | 28 |
| 30 virtual ~Emf(); | 29 virtual ~Emf(); |
| 31 | 30 |
| 32 // Initializes the Emf with the data in |src_buffer|. Returns true on success. | 31 //NativeMetafile methods. |
| 32 virtual bool Init() { return true; } | |
| 33 virtual bool Init(const void* src_buffer, uint32 src_buffer_size); | 33 virtual bool Init(const void* src_buffer, uint32 src_buffer_size); |
| 34 | 34 |
| 35 // Generates a virtual HDC that will record every GDI commands and compile it | 35 virtual bool StartPage(); |
| 36 // in a EMF data stream. | 36 virtual bool FinishPage(); |
| 37 // hdc is used to setup the default DPI and color settings. hdc is optional. | 37 virtual bool Close(); |
| 38 // rect specifies the dimensions (in .01-millimeter units) of the EMF. rect is | 38 |
| 39 // optional. | 39 // Saves the EMF data to a file as-is. It is recommended to use the .emf file |
|
vandebo (ex-Chrome)
2011/03/14 20:24:25
I think this comment goes with SaveTo ?
dpapad
2011/03/14 22:15:12
Done. It turns out that moving functions around us
| |
| 40 // extension but it is not enforced. This function synchronously writes to the | |
| 41 // file. For testing only. | |
| 42 virtual uint32 GetDataSize() const; | |
| 43 virtual bool GetData(void* buffer, uint32 size) const; | |
| 44 | |
| 45 virtual bool SaveTo(const FilePath& file_path) const; | |
| 46 | |
| 47 // Should be passed to Playback to keep the exact same size. | |
| 48 virtual gfx::Rect GetPageBounds(unsigned int page_number) const; | |
| 49 | |
| 50 virtual unsigned int GetPageCount() const { | |
| 51 return 1; | |
|
vandebo (ex-Chrome)
2011/03/14 20:24:25
Actually (as I understand EMF better), we could ha
dpapad
2011/03/14 22:15:12
Done.
| |
| 52 } | |
| 53 | |
| 54 virtual HDC context() const { | |
| 55 return hdc_; | |
| 56 } | |
| 57 | |
| 40 virtual bool CreateDc(HDC sibling, const RECT* rect); | 58 virtual bool CreateDc(HDC sibling, const RECT* rect); |
| 41 | |
| 42 // Similar to the above method but the metafile is backed by a file. | |
| 43 virtual bool CreateFileBackedDc(HDC sibling, | 59 virtual bool CreateFileBackedDc(HDC sibling, |
| 44 const RECT* rect, | 60 const RECT* rect, |
| 45 const FilePath& path); | 61 const FilePath& path); |
| 62 virtual bool CreateFromFile(const FilePath& file_path); | |
| 46 | 63 |
| 47 // Load an EMF file. | |
| 48 virtual bool CreateFromFile(const FilePath& metafile_path); | |
| 49 | |
| 50 // TODO(maruel): CreateFromFile(). If ever used. Maybe users would like to | |
| 51 // have the ability to save web pages to an EMF file? Afterward, it is easy to | |
| 52 // convert to PDF or PS. | |
| 53 | |
| 54 // Closes the HDC created by CreateDc() and generates the compiled EMF | |
| 55 // data. | |
| 56 virtual bool CloseDc(); | |
| 57 | |
| 58 // Closes the EMF data handle when it is not needed anymore. | |
| 59 virtual void CloseEmf(); | 64 virtual void CloseEmf(); |
| 60 | 65 |
| 61 // "Plays" the EMF buffer in a HDC. It is the same effect as calling the | |
| 62 // original GDI function that were called when recording the EMF. |rect| is in | |
| 63 // "logical units" and is optional. If |rect| is NULL, the natural EMF bounds | |
| 64 // are used. | |
| 65 // Note: Windows has been known to have stack buffer overflow in its GDI | |
| 66 // functions, whether used directly or indirectly through precompiled EMF | |
| 67 // data. We have to accept the risk here. Since it is used only for printing, | |
| 68 // it requires user intervention. | |
| 69 virtual bool Playback(HDC hdc, const RECT* rect) const; | 66 virtual bool Playback(HDC hdc, const RECT* rect) const; |
| 70 | |
| 71 // The slow version of Playback(). It enumerates all the records and play them | |
| 72 // back in the HDC. The trick is that it skip over the records known to have | |
| 73 // issue with some printers. See Emf::Record::SafePlayback implementation for | |
| 74 // details. | |
| 75 virtual bool SafePlayback(HDC hdc) const; | 67 virtual bool SafePlayback(HDC hdc) const; |
| 76 | 68 |
| 77 // Retrieves the bounds of the painted area by this EMF buffer. This value | |
| 78 // should be passed to Playback to keep the exact same size. | |
| 79 virtual gfx::Rect GetBounds() const; | |
| 80 | |
| 81 // Retrieves the EMF stream size. | |
| 82 virtual uint32 GetDataSize() const; | |
| 83 | |
| 84 // Retrieves the EMF stream. | |
| 85 virtual bool GetData(void* buffer, uint32 size) const; | |
| 86 | |
| 87 // Retrieves the EMF stream. It is an helper function. | |
| 88 virtual bool GetData(std::vector<uint8>* buffer) const; | 69 virtual bool GetData(std::vector<uint8>* buffer) const; |
| 89 | 70 |
| 90 virtual HENHMETAFILE emf() const { | 71 virtual HENHMETAFILE emf() const { |
| 91 return emf_; | 72 return emf_; |
| 92 } | 73 } |
| 93 | 74 |
| 94 virtual HDC hdc() const { | |
| 95 return hdc_; | |
| 96 } | |
| 97 | |
| 98 // Inserts a custom GDICOMMENT records indicating StartPage/EndPage calls | |
| 99 // (since StartPage and EndPage do not work in a metafile DC). Only valid | |
| 100 // when hdc_ is non-NULL. | |
| 101 virtual bool StartPage(); | |
| 102 virtual bool EndPage(); | |
| 103 | |
| 104 // Saves the EMF data to a file as-is. It is recommended to use the .emf file | |
| 105 // extension but it is not enforced. This function synchronously writes to the | |
| 106 // file. For testing only. | |
| 107 virtual bool SaveTo(const std::wstring& filename) const; | |
| 108 | |
| 109 protected: | 75 protected: |
| 110 Emf(); | 76 Emf(); |
| 111 | 77 |
| 112 private: | 78 private: |
| 113 friend class NativeMetafileFactory; | 79 friend class NativeMetafileFactory; |
| 114 FRIEND_TEST_ALL_PREFIXES(EmfTest, DC); | 80 FRIEND_TEST_ALL_PREFIXES(EmfTest, DC); |
| 115 FRIEND_TEST_ALL_PREFIXES(EmfTest, FileBackedDC); | 81 FRIEND_TEST_ALL_PREFIXES(EmfTest, FileBackedDC); |
| 116 FRIEND_TEST_ALL_PREFIXES(EmfPrintingTest, Enumerate); | 82 FRIEND_TEST_ALL_PREFIXES(EmfPrintingTest, Enumerate); |
| 117 FRIEND_TEST_ALL_PREFIXES(EmfPrintingTest, PageBreak); | 83 FRIEND_TEST_ALL_PREFIXES(EmfPrintingTest, PageBreak); |
| 118 | 84 |
| (...skipping 13 matching lines...) Expand all Loading... | |
| 132 DISALLOW_COPY_AND_ASSIGN(Emf); | 98 DISALLOW_COPY_AND_ASSIGN(Emf); |
| 133 }; | 99 }; |
| 134 | 100 |
| 135 struct Emf::EnumerationContext { | 101 struct Emf::EnumerationContext { |
| 136 HANDLETABLE* handle_table; | 102 HANDLETABLE* handle_table; |
| 137 int objects_count; | 103 int objects_count; |
| 138 HDC hdc; | 104 HDC hdc; |
| 139 }; | 105 }; |
| 140 | 106 |
| 141 // One EMF record. It keeps pointers to the EMF buffer held by Emf::emf_. | 107 // One EMF record. It keeps pointers to the EMF buffer held by Emf::emf_. |
| 142 // The entries become invalid once Emf::CloseEmf() is called. | 108 // The entries become invalid once Emf::Close() is called. |
|
vandebo (ex-Chrome)
2011/03/14 20:24:25
CloseEmf
dpapad
2011/03/14 22:15:12
Done.
| |
| 143 class Emf::Record { | 109 class Emf::Record { |
| 144 public: | 110 public: |
| 145 // Plays the record. | 111 // Plays the record. |
| 146 bool Play() const; | 112 bool Play() const; |
| 147 | 113 |
| 148 // Plays the record working around quirks with SetLayout, | 114 // Plays the record working around quirks with SetLayout, |
| 149 // SetWorldTransform and ModifyWorldTransform. See implementation for details. | 115 // SetWorldTransform and ModifyWorldTransform. See implementation for details. |
| 150 bool SafePlayback(const XFORM* base_matrix) const; | 116 bool SafePlayback(const XFORM* base_matrix) const; |
| 151 | 117 |
| 152 // Access the underlying EMF record. | 118 // Access the underlying EMF record. |
| (...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 185 private: | 151 private: |
| 186 // Processes one EMF record and saves it in the items_ array. | 152 // Processes one EMF record and saves it in the items_ array. |
| 187 static int CALLBACK EnhMetaFileProc(HDC hdc, | 153 static int CALLBACK EnhMetaFileProc(HDC hdc, |
| 188 HANDLETABLE* handle_table, | 154 HANDLETABLE* handle_table, |
| 189 const ENHMETARECORD* record, | 155 const ENHMETARECORD* record, |
| 190 int objects_count, | 156 int objects_count, |
| 191 LPARAM param); | 157 LPARAM param); |
| 192 | 158 |
| 193 // The collection of every EMF records in the currently loaded EMF buffer. | 159 // The collection of every EMF records in the currently loaded EMF buffer. |
| 194 // Initialized by Enumerate(). It keeps pointers to the EMF buffer held by | 160 // Initialized by Enumerate(). It keeps pointers to the EMF buffer held by |
| 195 // Emf::emf_. The entries become invalid once Emf::CloseEmf() is called. | 161 // Emf::emf_. The entries become invalid once Emf::Close() is called. |
|
vandebo (ex-Chrome)
2011/03/14 20:24:25
CloseEmf
dpapad
2011/03/14 22:15:12
Done.
| |
| 196 std::vector<Record> items_; | 162 std::vector<Record> items_; |
| 197 | 163 |
| 198 EnumerationContext context_; | 164 EnumerationContext context_; |
| 199 | 165 |
| 200 DISALLOW_COPY_AND_ASSIGN(Enumerator); | 166 DISALLOW_COPY_AND_ASSIGN(Enumerator); |
| 201 }; | 167 }; |
| 202 | 168 |
| 203 } // namespace printing | 169 } // namespace printing |
| 204 | 170 |
| 205 #endif // PRINTING_EMF_WIN_H_ | 171 #endif // PRINTING_EMF_WIN_H_ |
| OLD | NEW |