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.
5 #ifndef PRINTING_PRINTING_CONTEXT_H_
6 #define PRINTING_PRINTING_CONTEXT_H_
10 #include "base/basictypes.h"
11 #include "base/callback.h"
12 #include "base/strings/string16.h"
13 #include "printing/print_settings.h"
14 #include "ui/gfx/native_widget_types.h"
17 class DictionaryValue
;
22 // An abstraction of a printer context, implemented by objects that describe the
23 // user selected printing context. This includes the OS-dependent UI to ask the
24 // user about the print settings. Concrete implementations directly talk to the
25 // printer and manage the document and page breaks.
26 class PRINTING_EXPORT PrintingContext
{
28 // Printing context delegate.
32 virtual ~Delegate() {};
34 // Returns parent view to use for modal dialogs.
35 virtual gfx::NativeView
GetParentView() = 0;
37 // Returns application locale.
38 virtual std::string
GetAppLocale() = 0;
41 // Tri-state result for user behavior-dependent functions.
48 virtual ~PrintingContext();
50 // Callback of AskUserForSettings, used to notify the PrintJobWorker when
51 // print settings are available.
52 typedef base::Callback
<void(Result
)> PrintSettingsCallback
;
54 // Asks the user what printer and format should be used to print. Updates the
55 // context with the select device settings. The result of the call is returned
56 // in the callback. This is necessary for Linux, which only has an
57 // asynchronous printing API.
58 virtual void AskUserForSettings(int max_pages
,
60 const PrintSettingsCallback
& callback
) = 0;
62 // Selects the user's default printer and format. Updates the context with the
63 // default device settings.
64 virtual Result
UseDefaultSettings() = 0;
66 // Updates the context with PDF printer settings.
67 Result
UsePdfSettings();
69 // Returns paper size to be used for PDF or Cloud Print in device units.
70 virtual gfx::Size
GetPdfPaperSizeDeviceUnits() = 0;
72 // Updates printer settings.
73 // |external_preview| is true if pdf is going to be opened in external
74 // preview. Used by MacOS only now to open Preview.app.
75 virtual Result
UpdatePrinterSettings(bool external_preview
,
76 bool show_system_dialog
) = 0;
78 // Updates Print Settings. |job_settings| contains all print job
79 // settings information. |ranges| has the new page range settings.
80 Result
UpdatePrintSettings(const base::DictionaryValue
& job_settings
);
82 // Initializes with predefined settings.
83 virtual Result
InitWithSettings(const PrintSettings
& settings
) = 0;
85 // Does platform specific setup of the printer before the printing. Signal the
86 // printer that a document is about to be spooled.
87 // Warning: This function enters a message loop. That may cause side effects
88 // like IPC message processing! Some printers have side-effects on this call
89 // like virtual printers that ask the user for the path of the saved document;
90 // for example a PDF printer.
91 virtual Result
NewDocument(const base::string16
& document_name
) = 0;
94 virtual Result
NewPage() = 0;
96 // Closes the printed page.
97 virtual Result
PageDone() = 0;
99 // Closes the printing job. After this call the object is ready to start a new
101 virtual Result
DocumentDone() = 0;
103 // Cancels printing. Can be used in a multi-threaded context. Takes effect
105 virtual void Cancel() = 0;
107 // Releases the native printing context.
108 virtual void ReleaseContext() = 0;
110 // Returns the native context used to print.
111 virtual gfx::NativeDrawingContext
context() const = 0;
113 // Creates an instance of this object. Implementers of this interface should
114 // implement this method to create an object of their implementation.
115 static scoped_ptr
<PrintingContext
> Create(Delegate
* delegate
);
117 void set_margin_type(MarginType type
);
119 const PrintSettings
& settings() const {
124 explicit PrintingContext(Delegate
* delegate
);
126 // Reinitializes the settings for object reuse.
127 void ResetSettings();
129 // Does bookkeeping when an error occurs.
130 PrintingContext::Result
OnError();
132 // Complete print context settings.
133 PrintSettings settings_
;
135 // Printing context delegate.
138 // The dialog box has been dismissed.
139 volatile bool dialog_box_dismissed_
;
141 // Is a print job being done.
142 volatile bool in_print_job_
;
144 // Did the user cancel the print job.
145 volatile bool abort_printing_
;
148 DISALLOW_COPY_AND_ASSIGN(PrintingContext
);
151 } // namespace printing
153 #endif // PRINTING_PRINTING_CONTEXT_H_