diff options
author | thestig@chromium.org <thestig@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2011-04-19 20:57:03 +0000 |
---|---|---|
committer | thestig@chromium.org <thestig@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2011-04-19 20:57:03 +0000 |
commit | 2ed86fdf0eb70c6799027792e726ccdf3908e2d7 (patch) | |
tree | 7aa8fda1e506a875bce1cde12ac3141ab21acb2b /printing/printing_context_cairo.cc | |
parent | 1730395f996faaa2097b7afa2b23c1def9f94e18 (diff) | |
download | chromium_src-2ed86fdf0eb70c6799027792e726ccdf3908e2d7.zip chromium_src-2ed86fdf0eb70c6799027792e726ccdf3908e2d7.tar.gz chromium_src-2ed86fdf0eb70c6799027792e726ccdf3908e2d7.tar.bz2 |
Print Preview: Implement dialog-less printing on Linux.
BUG=76124
TEST=Printed boarding pass using this code + print preview.
Review URL: http://codereview.chromium.org/6835008
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@82153 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'printing/printing_context_cairo.cc')
-rw-r--r-- | printing/printing_context_cairo.cc | 38 |
1 files changed, 13 insertions, 25 deletions
diff --git a/printing/printing_context_cairo.cc b/printing/printing_context_cairo.cc index 6b24063..81d8696 100644 --- a/printing/printing_context_cairo.cc +++ b/printing/printing_context_cairo.cc @@ -8,11 +8,11 @@ #include "base/values.h" #include "printing/metafile.h" #include "printing/print_job_constants.h" -#include "printing/print_settings_initializer_gtk.h" #include "printing/units.h" #if defined(OS_CHROMEOS) #include <unicode/ulocdata.h> +#include "printing/print_settings_initializer_gtk.h" #else #include <gtk/gtk.h> #include <gtk/gtkprintunixdialog.h> @@ -78,8 +78,6 @@ void PrintingContextCairo::AskUserForSettings( #if defined(OS_CHROMEOS) callback->Run(OK); #else - print_dialog_ = create_dialog_func_(this); - print_dialog_->AddRefToDialog(); print_dialog_->ShowDialog(callback); #endif // defined(OS_CHROMEOS) } @@ -128,20 +126,12 @@ PrintingContext::Result PrintingContextCairo::UseDefaultSettings() { settings_.SetPrinterPrintableArea(physical_size_device_units, printable_area_device_units, dpi); -#else // defined(OS_CHROMEOS) - GtkWidget* dialog = gtk_print_unix_dialog_new(NULL, NULL); - GtkPrintSettings* settings = - gtk_print_unix_dialog_get_settings(GTK_PRINT_UNIX_DIALOG(dialog)); - GtkPageSetup* page_setup = - gtk_print_unix_dialog_get_page_setup(GTK_PRINT_UNIX_DIALOG(dialog)); - - PageRanges ranges_vector; // Nothing to initialize for default settings. - PrintSettingsInitializerGtk::InitPrintSettings( - settings, page_setup, ranges_vector, false, &settings_); - - g_object_unref(settings); - // |page_setup| is owned by dialog, so it does not need to be unref'ed. - gtk_widget_destroy(dialog); +#else + if (!print_dialog_) { + print_dialog_ = create_dialog_func_(this); + print_dialog_->AddRefToDialog(); + } + print_dialog_->UseDefaultSettings(); #endif // defined(OS_CHROMEOS) return OK; @@ -149,19 +139,17 @@ PrintingContext::Result PrintingContextCairo::UseDefaultSettings() { PrintingContext::Result PrintingContextCairo::UpdatePrintSettings( const DictionaryValue& job_settings, const PageRanges& ranges) { +#if defined(OS_CHROMEOS) + NOTIMPLEMENTED(); + return OK; +#else DCHECK(!in_print_job_); - bool landscape; - if (!job_settings.GetBoolean(kSettingLandscape, &landscape)) + if (!print_dialog_->UpdateSettings(job_settings, ranges)) return OnError(); - settings_.SetOrientation(landscape); - settings_.ranges = ranges; - - // TODO(kmadhusu): Update other print settings such as number of copies, - // collate, duplex printing, etc., - return OK; +#endif } PrintingContext::Result PrintingContextCairo::InitWithSettings( |