mirror of
				https://bitbucket.org/chromiumembedded/cef
				synced 2025-06-05 21:39:12 +02:00 
			
		
		
		
	git-svn-id: https://chromiumembedded.googlecode.com/svn/trunk@145 5089003a-bbd8-11dd-ad1f-f1f9622dbc98
		
			
				
	
	
		
			152 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			152 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
// Copyright (c) 2006-2008 The Chromium Authors. All rights reserved.
 | 
						|
// Use of this source code is governed by a BSD-style license that can be
 | 
						|
// found in the LICENSE file.
 | 
						|
 | 
						|
#ifndef _PRINTING_WIN_PRINTING_CONTEXT_H
 | 
						|
#define _PRINTING_WIN_PRINTING_CONTEXT_H
 | 
						|
 | 
						|
#include "print_settings.h"
 | 
						|
 | 
						|
#include <ocidl.h>
 | 
						|
#include <commdlg.h>
 | 
						|
#include <string>
 | 
						|
 | 
						|
#include "base/basictypes.h"
 | 
						|
 | 
						|
namespace printing {
 | 
						|
 | 
						|
// Describe the user selected printing context for Windows. This includes the
 | 
						|
// OS-dependent UI to ask the user about the print settings. This class directly
 | 
						|
// talk to the printer and manages the document and pages breaks.
 | 
						|
class PrintingContext {
 | 
						|
 public:
 | 
						|
  // Tri-state result for user behavior-dependent functions.
 | 
						|
  enum Result {
 | 
						|
    OK,
 | 
						|
    CANCEL,
 | 
						|
    FAILED,
 | 
						|
  };
 | 
						|
 | 
						|
  PrintingContext();
 | 
						|
  ~PrintingContext();
 | 
						|
 | 
						|
  // Asks the user what printer and format should be used to print. Updates the
 | 
						|
  // context with the select device settings.
 | 
						|
  Result AskUserForSettings(HWND window, int max_pages, bool has_selection);
 | 
						|
 | 
						|
  // Selects the user's default printer and format. Updates the context with the
 | 
						|
  // default device settings.
 | 
						|
  Result UseDefaultSettings();
 | 
						|
 | 
						|
  // Initializes with printer default's settings.
 | 
						|
  Result Init();
 | 
						|
 | 
						|
  // Initializes with predefined settings.
 | 
						|
  Result InitWithSettings(const PrintSettings& settings);
 | 
						|
 | 
						|
  // Reinitializes the settings to uninitialized for object reuse.
 | 
						|
  void ResetSettings();
 | 
						|
 | 
						|
  // Does platform specific setup of the printer before the printing. Signal the
 | 
						|
  // printer that a document is about to be spooled.
 | 
						|
  // Warning: This function enters a message loop. That may cause side effects
 | 
						|
  // like IPC message processing! Some printers have side-effects on this call
 | 
						|
  // like virtual printers that ask the user for the path of the saved document;
 | 
						|
  // for example a PDF printer.
 | 
						|
  Result NewDocument(const CefString& document_name);
 | 
						|
 | 
						|
  // Starts a new page.
 | 
						|
  Result NewPage();
 | 
						|
 | 
						|
  // Closes the printed page.
 | 
						|
  Result PageDone();
 | 
						|
 | 
						|
  // Closes the printing job. After this call the object is ready to start a new
 | 
						|
  // document.
 | 
						|
  Result DocumentDone();
 | 
						|
 | 
						|
  // Cancels printing. Can be used in a multithreaded context. Takes effect
 | 
						|
  // immediately.
 | 
						|
  void Cancel();
 | 
						|
 | 
						|
  // Dismiss the Print... dialog box if shown.
 | 
						|
  void DismissDialog();
 | 
						|
 | 
						|
  HDC context() {
 | 
						|
    return hdc_;
 | 
						|
  }
 | 
						|
 | 
						|
  const PrintSettings& settings() const {
 | 
						|
    return settings_;
 | 
						|
  }
 | 
						|
 | 
						|
 private:
 | 
						|
  // Class that manages the PrintDlgEx() callbacks. This is meant to be a
 | 
						|
  // temporary object used during the Print... dialog display.
 | 
						|
  class CallbackHandler;
 | 
						|
 | 
						|
  // Does bookkeeping when an error occurs.
 | 
						|
  PrintingContext::Result OnError();
 | 
						|
 | 
						|
  // Used in response to the user canceling the printing.
 | 
						|
  static BOOL CALLBACK AbortProc(HDC hdc, int nCode);
 | 
						|
 | 
						|
  // Reads the settings from the selected device context. Updates settings_ and
 | 
						|
  // its margins.
 | 
						|
  bool InitializeSettings(const DEVMODE& dev_mode,
 | 
						|
                          const CefString& new_device_name,
 | 
						|
                          const PRINTPAGERANGE* ranges,
 | 
						|
                          int number_ranges,
 | 
						|
                          bool selection_only,
 | 
						|
                          bool to_file);
 | 
						|
 | 
						|
  // Retrieves the printer's default low-level settings. hdc_ is allocated with
 | 
						|
  // this call.
 | 
						|
  bool GetPrinterSettings(HANDLE printer,
 | 
						|
                          const CefString& device_name,
 | 
						|
                          bool adjust_dev_mode);
 | 
						|
 | 
						|
  // Allocates the HDC for a specific DEVMODE.
 | 
						|
  bool AllocateContext(const CefString& printer_name,
 | 
						|
                       const DEVMODE* dev_mode);
 | 
						|
  
 | 
						|
  // Updates printer dev_mode with settings_
 | 
						|
  void PrintingContext::AdjustDevMode(DEVMODE& dev_mode);
 | 
						|
 | 
						|
  // Initializes the hdc_ either with setting_ or with just printer defaults.
 | 
						|
  Result Init(const CefString& device_name, bool adjust_dev_mode);
 | 
						|
 | 
						|
  // Parses the result of a PRINTDLGEX result.
 | 
						|
  Result ParseDialogResultEx(const PRINTDLGEX& dialog_options);
 | 
						|
  Result ParseDialogResult(const PRINTDLG& dialog_options);
 | 
						|
 | 
						|
  // The selected printer context.
 | 
						|
  HDC hdc_;
 | 
						|
 | 
						|
  // Complete print context settings.
 | 
						|
  PrintSettings settings_;
 | 
						|
 | 
						|
#ifndef NDEBUG
 | 
						|
  // Current page number in the print job.
 | 
						|
  int page_number_;
 | 
						|
#endif
 | 
						|
 | 
						|
  // The dialog box for the time it is shown.
 | 
						|
  volatile HWND dialog_box_;
 | 
						|
 | 
						|
  // The dialog box has been dismissed.
 | 
						|
  volatile bool dialog_box_dismissed_;
 | 
						|
 | 
						|
  // Is a print job being done.
 | 
						|
  volatile bool in_print_job_;
 | 
						|
 | 
						|
  // Did the user cancel the print job.
 | 
						|
  volatile bool abort_printing_;
 | 
						|
 | 
						|
  DISALLOW_EVIL_CONSTRUCTORS(PrintingContext);
 | 
						|
};
 | 
						|
 | 
						|
}  // namespace printing
 | 
						|
 | 
						|
#endif  // _PRINTING_WIN_PRINTING_CONTEXT_H
 |