[email protected] | 71f40a7 | 2012-05-16 07:26:59 | [diff] [blame] | 1 | // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
license.bot | bf09a50 | 2008-08-24 00:55:55 | [diff] [blame] | 2 | // Use of this source code is governed by a BSD-style license that can be |
3 | // found in the LICENSE file. | ||||
initial.commit | 09911bf | 2008-07-26 23:55:29 | [diff] [blame] | 4 | |
[email protected] | 8ff1d42 | 2009-07-07 21:31:39 | [diff] [blame] | 5 | #ifndef PRINTING_PRINT_SETTINGS_H_ |
6 | #define PRINTING_PRINT_SETTINGS_H_ | ||||
initial.commit | 09911bf | 2008-07-26 23:55:29 | [diff] [blame] | 7 | |
[email protected] | dcd1e886 | 2011-08-09 06:06:58 | [diff] [blame] | 8 | #include <string> |
9 | |||||
[email protected] | 896d161f | 2013-06-11 22:52:24 | [diff] [blame] | 10 | #include "base/strings/string16.h" |
[email protected] | 8ff1d42 | 2009-07-07 21:31:39 | [diff] [blame] | 11 | #include "printing/page_range.h" |
12 | #include "printing/page_setup.h" | ||||
[email protected] | 1c23b4e8 | 2011-10-15 22:30:48 | [diff] [blame] | 13 | #include "printing/print_job_constants.h" |
[email protected] | 63313ae | 2011-10-13 00:40:39 | [diff] [blame] | 14 | #include "printing/printing_export.h" |
tfarina | 3b0452d | 2014-12-31 15:20:09 | [diff] [blame] | 15 | #include "ui/gfx/geometry/rect.h" |
initial.commit | 09911bf | 2008-07-26 23:55:29 | [diff] [blame] | 16 | |
initial.commit | 09911bf | 2008-07-26 23:55:29 | [diff] [blame] | 17 | namespace printing { |
18 | |||||
[email protected] | 675a1ae | 2013-10-14 20:24:37 | [diff] [blame] | 19 | // Returns true if |color_mode| is color and not B&W. |
20 | PRINTING_EXPORT bool IsColorModelSelected(int color_mode); | ||||
[email protected] | 63313ae | 2011-10-13 00:40:39 | [diff] [blame] | 21 | |
[email protected] | fa879e51 | 2011-11-08 20:39:01 | [diff] [blame] | 22 | #if defined(USE_CUPS) |
23 | // Get the color model setting name and value for the |color_mode|. | ||||
24 | PRINTING_EXPORT void GetColorModelForMode(int color_mode, | ||||
25 | std::string* color_setting_name, | ||||
26 | std::string* color_value); | ||||
[email protected] | 63313ae | 2011-10-13 00:40:39 | [diff] [blame] | 27 | #endif |
28 | |||||
halcanary | 73b63fd | 2015-11-06 00:02:14 | [diff] [blame] | 29 | // Inform the printing system that it may embed this user-agent string |
30 | // in its output's metadata. | ||||
31 | PRINTING_EXPORT void SetAgent(const std::string& user_agent); | ||||
32 | PRINTING_EXPORT const std::string& GetAgent(); | ||||
33 | |||||
initial.commit | 09911bf | 2008-07-26 23:55:29 | [diff] [blame] | 34 | // OS-independent print settings. |
[email protected] | 69f5b1e6 | 2011-09-01 06:34:04 | [diff] [blame] | 35 | class PRINTING_EXPORT PrintSettings { |
initial.commit | 09911bf | 2008-07-26 23:55:29 | [diff] [blame] | 36 | public: |
[email protected] | 72ddef9 | 2014-06-12 08:08:06 | [diff] [blame] | 37 | // Media properties requested by the user. Default instance represents |
38 | // default media selection. | ||||
39 | struct RequestedMedia { | ||||
40 | // Size of the media, in microns. | ||||
41 | gfx::Size size_microns; | ||||
42 | // Platform specific id to map it back to the particular media. | ||||
43 | std::string vendor_id; | ||||
44 | |||||
45 | bool IsDefault() const { | ||||
46 | return size_microns.IsEmpty() && vendor_id.empty(); | ||||
47 | } | ||||
48 | }; | ||||
49 | |||||
initial.commit | 09911bf | 2008-07-26 23:55:29 | [diff] [blame] | 50 | PrintSettings(); |
vmpstr | 04b8358f | 2016-02-26 01:38:29 | [diff] [blame] | 51 | PrintSettings(const PrintSettings& other); |
[email protected] | 20f0487a | 2010-09-30 20:06:30 | [diff] [blame] | 52 | ~PrintSettings(); |
initial.commit | 09911bf | 2008-07-26 23:55:29 | [diff] [blame] | 53 | |
54 | // Reinitialize the settings to the default values. | ||||
55 | void Clear(); | ||||
56 | |||||
[email protected] | b076a08 | 2011-10-20 01:26:32 | [diff] [blame] | 57 | void SetCustomMargins(const PageMargins& requested_margins_in_points); |
[email protected] | c95198b | 2014-06-12 16:56:55 | [diff] [blame] | 58 | const PageMargins& requested_custom_margins_in_points() const { |
59 | return requested_custom_margins_in_points_; | ||||
60 | } | ||||
[email protected] | e5324b5 | 2013-10-29 03:16:37 | [diff] [blame] | 61 | void set_margin_type(MarginType margin_type) { margin_type_ = margin_type; } |
62 | MarginType margin_type() const { return margin_type_; } | ||||
[email protected] | 1c23b4e8 | 2011-10-15 22:30:48 | [diff] [blame] | 63 | |
[email protected] | e5324b5 | 2013-10-29 03:16:37 | [diff] [blame] | 64 | // Updates the orientation and flip the page if needed. |
65 | void SetOrientation(bool landscape); | ||||
66 | bool landscape() const { return landscape_; } | ||||
initial.commit | 09911bf | 2008-07-26 23:55:29 | [diff] [blame] | 67 | |
[email protected] | 72ddef9 | 2014-06-12 08:08:06 | [diff] [blame] | 68 | // Updates user requested media. |
69 | void set_requested_media(const RequestedMedia& media) { | ||||
70 | requested_media_ = media; | ||||
71 | } | ||||
72 | // Media properties requested by the user. Translated into device media by the | ||||
73 | // platform specific layers. | ||||
74 | const RequestedMedia& requested_media() const { | ||||
75 | return requested_media_; | ||||
76 | } | ||||
77 | |||||
[email protected] | e5324b5 | 2013-10-29 03:16:37 | [diff] [blame] | 78 | // Set printer printable area in in device units. |
79 | // Some platforms already provide flipped area. Set |landscape_needs_flip| | ||||
80 | // to false on those platforms to avoid double flipping. | ||||
81 | void SetPrinterPrintableArea(const gfx::Size& physical_size_device_units, | ||||
82 | const gfx::Rect& printable_area_device_units, | ||||
[email protected] | e5324b5 | 2013-10-29 03:16:37 | [diff] [blame] | 83 | bool landscape_needs_flip); |
84 | const PageSetup& page_setup_device_units() const { | ||||
85 | return page_setup_device_units_; | ||||
86 | } | ||||
87 | |||||
[email protected] | b5fa4ee | 2013-10-01 07:19:07 | [diff] [blame] | 88 | void set_device_name(const base::string16& device_name) { |
initial.commit | 09911bf | 2008-07-26 23:55:29 | [diff] [blame] | 89 | device_name_ = device_name; |
90 | } | ||||
[email protected] | b5fa4ee | 2013-10-01 07:19:07 | [diff] [blame] | 91 | const base::string16& device_name() const { return device_name_; } |
[email protected] | e5324b5 | 2013-10-29 03:16:37 | [diff] [blame] | 92 | |
[email protected] | 4993f34 | 2010-10-26 17:57:52 | [diff] [blame] | 93 | void set_dpi(int dpi) { dpi_ = dpi; } |
initial.commit | 09911bf | 2008-07-26 23:55:29 | [diff] [blame] | 94 | int dpi() const { return dpi_; } |
[email protected] | e5324b5 | 2013-10-29 03:16:37 | [diff] [blame] | 95 | |
rbpotter | 769ffdf | 2016-10-26 00:53:57 | [diff] [blame] | 96 | void set_scale_factor(double scale_factor) { scale_factor_ = scale_factor; } |
97 | double scale_factor() const { return scale_factor_; } | ||||
98 | |||||
[email protected] | b2b0fce | 2011-01-12 16:34:40 | [diff] [blame] | 99 | void set_supports_alpha_blend(bool supports_alpha_blend) { |
100 | supports_alpha_blend_ = supports_alpha_blend; | ||||
101 | } | ||||
102 | bool supports_alpha_blend() const { return supports_alpha_blend_; } | ||||
[email protected] | e5324b5 | 2013-10-29 03:16:37 | [diff] [blame] | 103 | |
[email protected] | 6ab86ac | 2010-05-29 07:18:29 | [diff] [blame] | 104 | int device_units_per_inch() const { |
105 | #if defined(OS_MACOSX) | ||||
106 | return 72; | ||||
107 | #else // defined(OS_MACOSX) | ||||
108 | return dpi(); | ||||
109 | #endif // defined(OS_MACOSX) | ||||
110 | } | ||||
initial.commit | 09911bf | 2008-07-26 23:55:29 | [diff] [blame] | 111 | |
thestig | e85e6b6 | 2016-08-25 00:00:06 | [diff] [blame] | 112 | void set_ranges(const PageRanges& ranges) { ranges_ = ranges; } |
113 | const PageRanges& ranges() const { return ranges_; } | ||||
initial.commit | 09911bf | 2008-07-26 23:55:29 | [diff] [blame] | 114 | |
[email protected] | e5324b5 | 2013-10-29 03:16:37 | [diff] [blame] | 115 | void set_selection_only(bool selection_only) { |
116 | selection_only_ = selection_only; | ||||
117 | } | ||||
118 | bool selection_only() const { return selection_only_; } | ||||
initial.commit | 09911bf | 2008-07-26 23:55:29 | [diff] [blame] | 119 | |
[email protected] | e5324b5 | 2013-10-29 03:16:37 | [diff] [blame] | 120 | void set_should_print_backgrounds(bool should_print_backgrounds) { |
121 | should_print_backgrounds_ = should_print_backgrounds; | ||||
122 | } | ||||
123 | bool should_print_backgrounds() const { return should_print_backgrounds_; } | ||||
initial.commit | 09911bf | 2008-07-26 23:55:29 | [diff] [blame] | 124 | |
[email protected] | e5324b5 | 2013-10-29 03:16:37 | [diff] [blame] | 125 | void set_display_header_footer(bool display_header_footer) { |
126 | display_header_footer_ = display_header_footer; | ||||
127 | } | ||||
128 | bool display_header_footer() const { return display_header_footer_; } | ||||
initial.commit | 09911bf | 2008-07-26 23:55:29 | [diff] [blame] | 129 | |
[email protected] | e5324b5 | 2013-10-29 03:16:37 | [diff] [blame] | 130 | void set_title(const base::string16& title) { title_ = title; } |
131 | const base::string16& title() const { return title_; } | ||||
[email protected] | c8ad40c | 2009-06-08 17:05:21 | [diff] [blame] | 132 | |
[email protected] | e5324b5 | 2013-10-29 03:16:37 | [diff] [blame] | 133 | void set_url(const base::string16& url) { url_ = url; } |
134 | const base::string16& url() const { return url_; } | ||||
135 | |||||
136 | void set_collate(bool collate) { collate_ = collate; } | ||||
137 | bool collate() const { return collate_; } | ||||
138 | |||||
139 | void set_color(ColorModel color) { color_ = color; } | ||||
140 | ColorModel color() const { return color_; } | ||||
141 | |||||
142 | void set_copies(int copies) { copies_ = copies; } | ||||
143 | int copies() const { return copies_; } | ||||
144 | |||||
145 | void set_duplex_mode(DuplexMode duplex_mode) { duplex_mode_ = duplex_mode; } | ||||
146 | DuplexMode duplex_mode() const { return duplex_mode_; } | ||||
147 | |||||
148 | int desired_dpi() const { return desired_dpi_; } | ||||
149 | |||||
thestig | e85e6b6 | 2016-08-25 00:00:06 | [diff] [blame] | 150 | #if defined(OS_WIN) |
151 | void set_print_text_with_gdi(bool use_gdi) { print_text_with_gdi_ = use_gdi; } | ||||
152 | bool print_text_with_gdi() const { return print_text_with_gdi_; } | ||||
thestig | 1f8436b | 2016-10-06 01:09:25 | [diff] [blame] | 153 | |
154 | void set_printer_is_xps(bool is_xps) { printer_is_xps_ = is_xps; } | ||||
155 | bool printer_is_xps() const { return printer_is_xps_; } | ||||
thestig | e85e6b6 | 2016-08-25 00:00:06 | [diff] [blame] | 156 | #endif |
157 | |||||
[email protected] | d30e8e64 | 2008-08-06 12:05:24 | [diff] [blame] | 158 | // Cookie generator. It is used to initialize PrintedDocument with its |
159 | // associated PrintSettings, to be sure that each generated PrintedPage is | ||||
160 | // correctly associated with its corresponding PrintedDocument. | ||||
initial.commit | 09911bf | 2008-07-26 23:55:29 | [diff] [blame] | 161 | static int NewCookie(); |
162 | |||||
[email protected] | e5324b5 | 2013-10-29 03:16:37 | [diff] [blame] | 163 | private: |
164 | // Multi-page printing. Each PageRange describes a from-to page combination. | ||||
165 | // This permits printing selected pages only. | ||||
166 | PageRanges ranges_; | ||||
167 | |||||
[email protected] | e5324b5 | 2013-10-29 03:16:37 | [diff] [blame] | 168 | // Desired visible dots per inch rendering for output. Printing should be |
169 | // scaled to ScreenDpi/dpix*desired_dpi. | ||||
170 | int desired_dpi_; | ||||
171 | |||||
172 | // Indicates if the user only wants to print the current selection. | ||||
173 | bool selection_only_; | ||||
174 | |||||
175 | // Indicates what kind of margins should be applied to the printable area. | ||||
176 | MarginType margin_type_; | ||||
[email protected] | c48bee2 | 2011-03-29 02:36:26 | [diff] [blame] | 177 | |
[email protected] | 55b23a0 | 2011-08-17 23:09:36 | [diff] [blame] | 178 | // Strings to be printed as headers and footers if requested by the user. |
[email protected] | e5324b5 | 2013-10-29 03:16:37 | [diff] [blame] | 179 | base::string16 title_; |
180 | base::string16 url_; | ||||
[email protected] | 55b23a0 | 2011-08-17 23:09:36 | [diff] [blame] | 181 | |
182 | // True if the user wants headers and footers to be displayed. | ||||
[email protected] | e5324b5 | 2013-10-29 03:16:37 | [diff] [blame] | 183 | bool display_header_footer_; |
[email protected] | 55b23a0 | 2011-08-17 23:09:36 | [diff] [blame] | 184 | |
[email protected] | 19d1c2d | 2013-01-14 00:59:46 | [diff] [blame] | 185 | // True if the user wants to print CSS backgrounds. |
[email protected] | e5324b5 | 2013-10-29 03:16:37 | [diff] [blame] | 186 | bool should_print_backgrounds_; |
[email protected] | 19d1c2d | 2013-01-14 00:59:46 | [diff] [blame] | 187 | |
[email protected] | e5324b5 | 2013-10-29 03:16:37 | [diff] [blame] | 188 | // True if the user wants to print with collate. |
189 | bool collate_; | ||||
190 | |||||
191 | // True if the user wants to print with collate. | ||||
192 | ColorModel color_; | ||||
193 | |||||
194 | // Number of copies user wants to print. | ||||
195 | int copies_; | ||||
196 | |||||
197 | // Duplex type user wants to use. | ||||
198 | DuplexMode duplex_mode_; | ||||
initial.commit | 09911bf | 2008-07-26 23:55:29 | [diff] [blame] | 199 | |
initial.commit | 09911bf | 2008-07-26 23:55:29 | [diff] [blame] | 200 | // Printer device name as opened by the OS. |
[email protected] | b5fa4ee | 2013-10-01 07:19:07 | [diff] [blame] | 201 | base::string16 device_name_; |
initial.commit | 09911bf | 2008-07-26 23:55:29 | [diff] [blame] | 202 | |
[email protected] | 72ddef9 | 2014-06-12 08:08:06 | [diff] [blame] | 203 | // Media requested by the user. |
204 | RequestedMedia requested_media_; | ||||
205 | |||||
[email protected] | 6ab86ac | 2010-05-29 07:18:29 | [diff] [blame] | 206 | // Page setup in device units. |
207 | PageSetup page_setup_device_units_; | ||||
initial.commit | 09911bf | 2008-07-26 23:55:29 | [diff] [blame] | 208 | |
209 | // Printer's device effective dots per inch in both axis. | ||||
210 | int dpi_; | ||||
211 | |||||
rbpotter | 769ffdf | 2016-10-26 00:53:57 | [diff] [blame] | 212 | // Scale factor |
213 | double scale_factor_; | ||||
214 | |||||
initial.commit | 09911bf | 2008-07-26 23:55:29 | [diff] [blame] | 215 | // Is the orientation landscape or portrait. |
216 | bool landscape_; | ||||
[email protected] | b2b0fce | 2011-01-12 16:34:40 | [diff] [blame] | 217 | |
218 | // True if this printer supports AlphaBlend. | ||||
219 | bool supports_alpha_blend_; | ||||
[email protected] | 1c23b4e8 | 2011-10-15 22:30:48 | [diff] [blame] | 220 | |
thestig | e85e6b6 | 2016-08-25 00:00:06 | [diff] [blame] | 221 | #if defined(OS_WIN) |
222 | // True to print text with GDI. | ||||
223 | bool print_text_with_gdi_; | ||||
thestig | 1f8436b | 2016-10-06 01:09:25 | [diff] [blame] | 224 | |
225 | // True if the printer is an XPS printer. | ||||
226 | bool printer_is_xps_; | ||||
thestig | e85e6b6 | 2016-08-25 00:00:06 | [diff] [blame] | 227 | #endif |
228 | |||||
[email protected] | b076a08 | 2011-10-20 01:26:32 | [diff] [blame] | 229 | // If margin type is custom, this is what was requested. |
230 | PageMargins requested_custom_margins_in_points_; | ||||
initial.commit | 09911bf | 2008-07-26 23:55:29 | [diff] [blame] | 231 | }; |
232 | |||||
233 | } // namespace printing | ||||
234 | |||||
[email protected] | 8ff1d42 | 2009-07-07 21:31:39 | [diff] [blame] | 235 | #endif // PRINTING_PRINT_SETTINGS_H_ |