index d15773ecb9fa31aab81f794d2591bb720a57091b..a56cbfd9d65dd6066d4126c9cd5df143ba52f9dc 100644 (file)
--- a/src/ui/dialog/print.cpp
+++ b/src/ui/dialog/print.cpp
*/
/* Authors:
* Kees Cook <kees@outflux.net>
+ * Abhishek Sharma
*
* Copyright (C) 2007 Kees Cook
* Released under GNU GPL. Read the file 'COPYING' for more information.
#endif
#ifdef WIN32
#include <io.h>
+#include <windows.h>
#endif
#include <gtkmm/stock.h>
-static void
-draw_page (GtkPrintOperation */*operation*/,
- GtkPrintContext *context,
- gint /*page_nr*/,
- gpointer user_data)
+static void draw_page(
+#ifdef WIN32
+ GtkPrintOperation *operation,
+#else
+ GtkPrintOperation *,
+#endif
+ GtkPrintContext *context,
+ gint /*page_nr*/,
+ gpointer user_data)
{
struct workaround_gtkmm *junk = (struct workaround_gtkmm*)user_data;
//printf("%s %d\n",__FUNCTION__, page_nr);
if (junk->_tab->as_bitmap()) {
// Render as exported PNG
- gdouble width = sp_document_width(junk->_doc);
- gdouble height = sp_document_height(junk->_doc);
+ gdouble width = (junk->_doc)->getWidth();
+ gdouble height = (junk->_doc)->getHeight();
gdouble dpi = junk->_tab->bitmap_dpi();
std::string tmp_png;
std::string tmp_base = "inkscape-print-png-XXXXXX";
cairo_surface_t *surface = cairo_get_target(cr);
cairo_matrix_t ctm;
cairo_get_matrix(cr, &ctm);
+#ifdef WIN32
+ //Gtk+ does not take the non printable area into account
+ //http://bugzilla.gnome.org/show_bug.cgi?id=381371
+ //
+ // This workaround translates the origin from the top left of the
+ // printable area to the top left of the page.
+ GtkPrintSettings *settings = gtk_print_operation_get_print_settings(operation);
+ const gchar *printerName = gtk_print_settings_get_printer(settings);
+ HDC hdc = CreateDC("WINSPOOL", printerName, NULL, NULL);
+ if (hdc) {
+ cairo_matrix_t mat;
+ int x_off = GetDeviceCaps (hdc, PHYSICALOFFSETX);
+ int y_off = GetDeviceCaps (hdc, PHYSICALOFFSETY);
+ cairo_matrix_init_translate(&mat, -x_off, -y_off);
+ cairo_matrix_multiply (&ctm, &ctm, &mat);
+ DeleteDC(hdc);
+ }
+#endif
bool ret = ctx->setSurfaceTarget (surface, true, &ctm);
if (ret) {
ret = renderer.setupDocument (ctx, junk->_doc, TRUE, NULL);
_printop = gtk_print_operation_new ();
// set up dialog title, based on document name
- gchar *jobname = _doc->name ? _doc->name : _("SVG Document");
+ gchar const *jobname = _doc->getName() ? _doc->getName() : _("SVG Document");
Glib::ustring title = _("Print");
title += " ";
title += jobname;
// set up paper size to match the document size
gtk_print_operation_set_unit (_printop, GTK_UNIT_POINTS);
GtkPageSetup *page_setup = gtk_page_setup_new();
- gdouble doc_width = sp_document_width(_doc) * PT_PER_PX;
- gdouble doc_height = sp_document_height(_doc) * PT_PER_PX;
- GtkPaperSize *paper_size = gtk_paper_size_new_custom("custom", "custom",
- doc_width, doc_height, GTK_UNIT_POINTS);
+ gdouble doc_width = _doc->getWidth() * PT_PER_PX;
+ gdouble doc_height = _doc->getHeight() * PT_PER_PX;
+ GtkPaperSize *paper_size;
+ if (doc_width > doc_height) {
+ gtk_page_setup_set_orientation (page_setup, GTK_PAGE_ORIENTATION_LANDSCAPE);
+ paper_size = gtk_paper_size_new_custom("custom", "custom",
+ doc_height, doc_width, GTK_UNIT_POINTS);
+ } else {
+ gtk_page_setup_set_orientation (page_setup, GTK_PAGE_ORIENTATION_PORTRAIT);
+ paper_size = gtk_paper_size_new_custom("custom", "custom",
+ doc_width, doc_height, GTK_UNIT_POINTS);
+ }
+
gtk_page_setup_set_paper_size (page_setup, paper_size);
-#ifndef WIN32
gtk_print_operation_set_default_page_setup (_printop, page_setup);
-#endif
gtk_print_operation_set_use_full_page (_printop, TRUE);
// set up signals
@@ -210,4 +241,4 @@ Gtk::PrintOperationResult Print::run(Gtk::PrintOperationAction, Gtk::Window &par
fill-column:99
End:
*/
-// vim: filetype=cpp:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:encoding=utf-8:textwidth=99 :
+// vim: filetype=cpp:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:fileencoding=utf-8:textwidth=99 :