From 47d455dd55be855e4cc691c32f687f723d9247ee Mon Sep 17 00:00:00 2001 From: toma Date: Wed, 25 Nov 2009 17:56:58 +0000 Subject: Copy the KDE 3.5 branch to branches/trinity for new KDE 3.5 features. BUG:215923 git-svn-id: svn://anonsvn.kde.org/home/kde/branches/trinity/kdegraphics@1054174 283d02a7-25f6-0310-bc7c-ecb5cbfe19da --- kview/kviewviewer/kviewkonqextension.cpp | 105 +++++++++++++++++++++++++++++++ 1 file changed, 105 insertions(+) create mode 100644 kview/kviewviewer/kviewkonqextension.cpp (limited to 'kview/kviewviewer/kviewkonqextension.cpp') diff --git a/kview/kviewviewer/kviewkonqextension.cpp b/kview/kviewviewer/kviewkonqextension.cpp new file mode 100644 index 00000000..40876b7c --- /dev/null +++ b/kview/kviewviewer/kviewkonqextension.cpp @@ -0,0 +1,105 @@ +/* This file is part of the KDE project + Copyright (C) 1999 Simon Hausmann + 2001 Matthias Kretz + + This program is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 2 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program; if not, write to the Free Software + Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + +*/ + +#include "kviewkonqextension.h" +#include "kviewviewer.h" +#include "kimageviewer/canvas.h" +#include "imagesettings.h" + +#include +#include +#include + +#include +#include +#include +#include + +KViewKonqExtension::KViewKonqExtension( KImageViewer::Canvas * canvas, + KViewViewer *parent, const char *name ) + : KParts::BrowserExtension( parent, name ), + m_pViewer( parent ), + m_pCanvas( canvas ) +{ + KGlobal::locale()->insertCatalogue("kview"); +} + +void KViewKonqExtension::setXYOffset( int x, int y ) +{ + m_pCanvas->setXYOffset( x, y ); +} + +int KViewKonqExtension::xOffset() +{ + return m_pCanvas->xOffset(); +} + +int KViewKonqExtension::yOffset() +{ + return m_pCanvas->yOffset(); +} + +void KViewKonqExtension::print() +{ + if( ! m_pCanvas->image() ) + { + kdError( 4610 ) << "No image to print" << endl; + return; + } + + KPrinter printer;//( true, QPrinter::ScreenResolution ); + printer.addDialogPage( new ImageSettings ); + printer.setDocName( "KView: " + m_pViewer->url().fileName( false ) ); + + if ( !printer.setup( ((KViewViewer *)parent())->widget(), i18n("Print %1").arg(m_pViewer->url().fileName( false )) ) ) + return; + + QPainter painter; + painter.begin( &printer ); + + QPaintDeviceMetrics metrics( painter.device() ); + kdDebug( 4610 ) << "metrics: " << metrics.width() << "x" << metrics.height() << endl; + QPoint pos( 0, 0 ); + + QImage imagetoprint; + if( printer.option( "app-kviewviewer-fitimage" ) == "1" ) + imagetoprint = m_pCanvas->image()->smoothScale( metrics.width(), metrics.height(), QImage::ScaleMin ); + else + imagetoprint = *m_pCanvas->image(); + + if( printer.option( "app-kviewviewer-center" ) == "1" ) + { + pos.setX( ( metrics.width() - imagetoprint.width() ) / 2 ); + pos.setY( ( metrics.height() - imagetoprint.height() ) / 2 ); + } + + painter.drawImage( pos, imagetoprint ); + painter.end(); +} + +void KViewKonqExtension::del() +{ + m_pViewer->slotDel(); +} + +// vim:sw=4:ts=4 + +#include "kviewkonqextension.moc" + -- cgit v1.2.1