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

Side by Side Diff: printing/native_metafile_linux.h

Issue 6544028: Create a Factory for NativeMetafile. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Fixed styling issues (naming, 80cols) Created 9 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 | Annotate | Revision Log
OLDNEW
(Empty)
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
3 // found in the LICENSE file.
4
5 #ifndef NATIVE_METAFILE_LINUX_H_
vandebo (ex-Chrome) 2011/02/22 22:18:16 PRINTING_...
dpapad 2011/02/23 00:44:39 Done.
6 #define NATIVE_METAFILE_LINUX_H_
7
8 #include <string>
9
10 #include "base/basictypes.h"
11
12 typedef struct _cairo_surface cairo_surface_t;
13 typedef struct _cairo cairo_t;
14
15 namespace base {
16 struct FileDescriptor;
17 }
18
19 class FilePath;
20
21 namespace printing {
22
23 // This class uses Cairo graphics library to generate PostScript/PDF stream
24 // and stores rendering results in a string buffer.
25 class NativeMetafile {
26 public:
27 enum FileFormat {
vandebo (ex-Chrome) 2011/02/22 22:18:16 We don't use PS (iirc, because the cairo backend h
28 PDF,
29 PS,
30 };
31
32 virtual ~NativeMetafile() {};
33
34 // Initializes to a fresh new metafile. Returns true on success.
35 // Note: Only call in the renderer to allocate rendering resources.
36 virtual bool Init() = 0;
37
38 // Initializes a copy of metafile from PDF/PS stream data.
39 // Returns true on success.
40 // |src_buffer| should point to the shared memory which stores PDF/PS
41 // contents generated in the renderer.
42 // Note: Only call in the browser to initialize |data_|.
43 virtual bool Init(const void* src_buffer, uint32 src_buffer_size) = 0;
44
45 // Sets raw PS/PDF data for the document. This is used when a cairo drawing
46 // surface has already been created. This method will cause all subsequent
47 // drawing on the surface to be discarded (in Close()). If Init() has not yet
48 // been called this method simply calls the second version of Init.
49 virtual bool SetRawData(const void* src_buffer, uint32 src_buffer_size) = 0;
50
51 virtual FileFormat GetFileFormat() const = 0;
52
53 // Prepares a new cairo surface/context for rendering a new page.
54 // The unit is in point (=1/72 in).
55 // Returns NULL when failed.
56 virtual cairo_t* StartPage(double width_in_points,
57 double height_in_points,
58 double margin_top_in_points,
59 double margin_right_in_points,
60 double margin_bottom_in_points,
61 double margin_left_in_points) = 0;
62
63 // Destroys the surface and the context used in rendering current page.
64 // The results of current page will be appended into buffer |data_|.
65 // Returns true on success.
66 virtual bool FinishPage() = 0;
67
68 // Closes resulting PDF/PS file. No further rendering is allowed.
69 virtual void Close() = 0;
70
71 // Returns size of PDF/PS contents stored in buffer |data_|.
72 // This function should ONLY be called after PDF/PS file is closed.
73 virtual uint32 GetDataSize() const = 0;
74
75 // Copies PDF/PS contents stored in buffer |data_| into |dst_buffer|.
76 // This function should ONLY be called after PDF/PS file is closed.
77 // Returns true only when success.
78 virtual bool GetData(void* dst_buffer, uint32 dst_buffer_size) const = 0;
79
80 // Saves PDF/PS contents stored in buffer |data_| into the file
81 // associated with |fd|.
82 // This function should ONLY be called after PDF/PS file is closed.
83 virtual bool SaveTo(const base::FileDescriptor& fd) const = 0;
84
85 };
86
87 } // namespace printing
88
89 #endif /* NATIVE_METAFILE_LINUX_H_ */
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698