blob: 8859379084145956e7e411aa749d64432e475800 [file] [log] [blame]
[email protected]7868ecab2011-03-05 00:12:531// Copyright (c) 2011 The Chromium Authors. All rights reserved.
license.botbf09a502008-08-24 00:55:552// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
initial.commit09911bf2008-07-26 23:55:294
[email protected]8ff1d422009-07-07 21:31:395#ifndef PRINTING_PRINTING_CONTEXT_H_
6#define PRINTING_PRINTING_CONTEXT_H_
initial.commit09911bf2008-07-26 23:55:297
dchengc3df9ba2016-04-07 23:09:328#include <memory>
initial.commit09911bf2008-07-26 23:55:299#include <string>
10
[email protected]abe48112011-11-19 01:58:3811#include "base/callback.h"
avi126e93c2015-12-21 21:48:1612#include "base/macros.h"
[email protected]896d161f2013-06-11 22:52:2413#include "base/strings/string16.h"
Thiago Farina45e319532017-03-23 02:44:4914#include "printing/native_drawing_context.h"
[email protected]8ff1d422009-07-07 21:31:3915#include "printing/print_settings.h"
[email protected]08397d52011-02-05 01:53:3816#include "ui/gfx/native_widget_types.h"
initial.commit09911bf2008-07-26 23:55:2917
[email protected]f3a1c642011-07-12 19:15:0318namespace base {
[email protected]89f5aa8c2011-03-21 20:58:4419class DictionaryValue;
[email protected]f3a1c642011-07-12 19:15:0320}
[email protected]89f5aa8c2011-03-21 20:58:4421
initial.commit09911bf2008-07-26 23:55:2922namespace printing {
23
[email protected]51e8d9352010-10-06 22:21:1724// An abstraction of a printer context, implemented by objects that describe the
25// user selected printing context. This includes the OS-dependent UI to ask the
26// user about the print settings. Concrete implementations directly talk to the
27// printer and manage the document and page breaks.
[email protected]69f5b1e62011-09-01 06:34:0428class PRINTING_EXPORT PrintingContext {
initial.commit09911bf2008-07-26 23:55:2929 public:
Vitaly Bukabd7c9812014-08-26 08:57:5430 // Printing context delegate.
31 class Delegate {
32 public:
thestige85e6b62016-08-25 00:00:0633 Delegate() {}
34 virtual ~Delegate() {}
Vitaly Bukabd7c9812014-08-26 08:57:5435
36 // Returns parent view to use for modal dialogs.
37 virtual gfx::NativeView GetParentView() = 0;
38
39 // Returns application locale.
40 virtual std::string GetAppLocale() = 0;
41 };
42
initial.commit09911bf2008-07-26 23:55:2943 // Tri-state result for user behavior-dependent functions.
44 enum Result {
45 OK,
46 CANCEL,
47 FAILED,
48 };
49
[email protected]51e8d9352010-10-06 22:21:1750 virtual ~PrintingContext();
initial.commit09911bf2008-07-26 23:55:2951
[email protected]b7191422010-09-21 19:18:0552 // Callback of AskUserForSettings, used to notify the PrintJobWorker when
53 // print settings are available.
Vladislav Kuzkokov48ceab22018-02-14 16:29:2854 using PrintSettingsCallback = base::OnceCallback<void(Result)>;
[email protected]b7191422010-09-21 19:18:0555
initial.commit09911bf2008-07-26 23:55:2956 // Asks the user what printer and format should be used to print. Updates the
[email protected]b7191422010-09-21 19:18:0557 // context with the select device settings. The result of the call is returned
58 // in the callback. This is necessary for Linux, which only has an
59 // asynchronous printing API.
dgn4c172eea2014-12-15 21:11:2360 // On Android, when |is_scripted| is true, calling it initiates a full
61 // printing flow from the framework's PrintManager.
62 // (see https://codereview.chromium.org/740983002/)
Vitaly Bukabd7c9812014-08-26 08:57:5463 virtual void AskUserForSettings(int max_pages,
[email protected]51e8d9352010-10-06 22:21:1764 bool has_selection,
dgn4c172eea2014-12-15 21:11:2365 bool is_scripted,
Vladislav Kuzkokov48ceab22018-02-14 16:29:2866 PrintSettingsCallback callback) = 0;
[email protected]d8254622010-08-13 19:15:4667
initial.commit09911bf2008-07-26 23:55:2968 // Selects the user's default printer and format. Updates the context with the
69 // default device settings.
[email protected]51e8d9352010-10-06 22:21:1770 virtual Result UseDefaultSettings() = 0;
[email protected]38bba4f2010-03-12 05:29:0771
[email protected]2dafb8b2014-05-29 16:32:4872 // Updates the context with PDF printer settings.
73 Result UsePdfSettings();
74
[email protected]4c9054b2013-11-04 18:34:2975 // Returns paper size to be used for PDF or Cloud Print in device units.
76 virtual gfx::Size GetPdfPaperSizeDeviceUnits() = 0;
77
[email protected]e5324b52013-10-29 03:16:3778 // Updates printer settings.
[email protected]e5324b52013-10-29 03:16:3779 // |external_preview| is true if pdf is going to be opened in external
80 // preview. Used by MacOS only now to open Preview.app.
vitalybuka92ab8ce2014-08-26 23:41:4581 virtual Result UpdatePrinterSettings(bool external_preview,
vitalybuka95fa3c92015-05-05 03:03:3282 bool show_system_dialog,
83 int page_count) = 0;
[email protected]55b23a02011-08-17 23:09:3684
85 // Updates Print Settings. |job_settings| contains all print job
86 // settings information. |ranges| has the new page range settings.
[email protected]c95198b2014-06-12 16:56:5587 Result UpdatePrintSettings(const base::DictionaryValue& job_settings);
[email protected]7868ecab2011-03-05 00:12:5388
Vladislav Kuzkokove2199102018-02-20 16:25:1389#if defined(OS_CHROMEOS)
90 // Updates Print Settings.
91 Result UpdatePrintSettingsFromPOD(
92 std::unique_ptr<PrintSettings> job_settings);
93#endif
94
initial.commit09911bf2008-07-26 23:55:2995 // Does platform specific setup of the printer before the printing. Signal the
96 // printer that a document is about to be spooled.
97 // Warning: This function enters a message loop. That may cause side effects
98 // like IPC message processing! Some printers have side-effects on this call
99 // like virtual printers that ask the user for the path of the saved document;
100 // for example a PDF printer.
[email protected]b5fa4ee2013-10-01 07:19:07101 virtual Result NewDocument(const base::string16& document_name) = 0;
initial.commit09911bf2008-07-26 23:55:29102
103 // Starts a new page.
[email protected]51e8d9352010-10-06 22:21:17104 virtual Result NewPage() = 0;
initial.commit09911bf2008-07-26 23:55:29105
106 // Closes the printed page.
[email protected]51e8d9352010-10-06 22:21:17107 virtual Result PageDone() = 0;
initial.commit09911bf2008-07-26 23:55:29108
109 // Closes the printing job. After this call the object is ready to start a new
110 // document.
[email protected]51e8d9352010-10-06 22:21:17111 virtual Result DocumentDone() = 0;
initial.commit09911bf2008-07-26 23:55:29112
[email protected]8ff1d422009-07-07 21:31:39113 // Cancels printing. Can be used in a multi-threaded context. Takes effect
initial.commit09911bf2008-07-26 23:55:29114 // immediately.
[email protected]51e8d9352010-10-06 22:21:17115 virtual void Cancel() = 0;
initial.commit09911bf2008-07-26 23:55:29116
[email protected]51e8d9352010-10-06 22:21:17117 // Releases the native printing context.
118 virtual void ReleaseContext() = 0;
119
120 // Returns the native context used to print.
Nico Weber8e559562017-10-03 01:25:26121 virtual printing::NativeDrawingContext context() const = 0;
[email protected]51e8d9352010-10-06 22:21:17122
123 // Creates an instance of this object. Implementers of this interface should
Vitaly Bukabd7c9812014-08-26 08:57:54124 // implement this method to create an object of their implementation.
dchengc3df9ba2016-04-07 23:09:32125 static std::unique_ptr<PrintingContext> Create(Delegate* delegate);
[email protected]51e8d9352010-10-06 22:21:17126
[email protected]1c23b4e82011-10-15 22:30:48127 void set_margin_type(MarginType type);
thestige85e6b62016-08-25 00:00:06128 void set_is_modifiable(bool is_modifiable);
initial.commit09911bf2008-07-26 23:55:29129
130 const PrintSettings& settings() const {
131 return settings_;
132 }
133
skau3fadb492017-02-15 19:23:37134 int job_id() const { return job_id_; }
135
[email protected]51e8d9352010-10-06 22:21:17136 protected:
Vitaly Bukabd7c9812014-08-26 08:57:54137 explicit PrintingContext(Delegate* delegate);
[email protected]51e8d9352010-10-06 22:21:17138
139 // Reinitializes the settings for object reuse.
140 void ResetSettings();
initial.commit09911bf2008-07-26 23:55:29141
[email protected]c8ad40c2009-06-08 17:05:21142 // Does bookkeeping when an error occurs.
143 PrintingContext::Result OnError();
initial.commit09911bf2008-07-26 23:55:29144
initial.commit09911bf2008-07-26 23:55:29145 // Complete print context settings.
146 PrintSettings settings_;
147
Vitaly Bukabd7c9812014-08-26 08:57:54148 // Printing context delegate.
Lei Zhang9aeaf60d2017-11-22 18:29:44149 Delegate* const delegate_;
Vitaly Bukabd7c9812014-08-26 08:57:54150
initial.commit09911bf2008-07-26 23:55:29151 // Is a print job being done.
152 volatile bool in_print_job_;
153
154 // Did the user cancel the print job.
155 volatile bool abort_printing_;
156
skau3fadb492017-02-15 19:23:37157 // The job id for the current job. The value is 0 if no jobs are active.
158 int job_id_;
159
[email protected]b5fa4ee2013-10-01 07:19:07160 private:
[email protected]5930cb62009-12-08 02:04:22161 DISALLOW_COPY_AND_ASSIGN(PrintingContext);
initial.commit09911bf2008-07-26 23:55:29162};
163
164} // namespace printing
165
[email protected]8ff1d422009-07-07 21:31:39166#endif // PRINTING_PRINTING_CONTEXT_H_