summaryrefslogtreecommitdiffstats
path: root/kjsembed/bindings/painter_imp.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'kjsembed/bindings/painter_imp.cpp')
-rw-r--r--kjsembed/bindings/painter_imp.cpp521
1 files changed, 521 insertions, 0 deletions
diff --git a/kjsembed/bindings/painter_imp.cpp b/kjsembed/bindings/painter_imp.cpp
new file mode 100644
index 00000000..8fa77de0
--- /dev/null
+++ b/kjsembed/bindings/painter_imp.cpp
@@ -0,0 +1,521 @@
+// -*- c++ -*-
+
+/*
+ * Copyright (C) 2003, Richard J. Moore <rich@kde.org>
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Library General Public
+ * License as published by the Free Software Foundation; either
+ * version 2 of the License, or (at your option) any later version.
+ *
+ * This library 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
+ * Library General Public License for more details.
+ *
+ * You should have received a copy of the GNU Library General Public License
+ * along with this library; see the file COPYING.LIB. If not, write to
+ * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
+ * Boston, MA 02110-1301, USA.
+ */
+
+#include <qpainter.h>
+#include <qpixmap.h>
+#include <qimage.h>
+#include <kjsembed/jsopaqueproxy.h>
+#include <kjsembed/jsobjectproxy.h>
+#include <kjsembed/jsvalueproxy.h>
+#include <kjsembed/jsbinding.h>
+#include <qfont.h>
+#include <kjsembed/global.h>
+
+#include "painter_imp.h"
+
+namespace KJSEmbed {
+namespace Bindings {
+
+ KJS::Object PainterLoader::createBinding(KJSEmbedPart *jspart, KJS::ExecState *exec, const KJS::List &args) const
+ {
+ PainterRef * p = new PainterRef();
+ /*
+ QWidget *w = extractQWidget(exec, args, 0);
+ QPixmap pix = extractQPixmap(exec, args, 0);
+ if( w )
+ {
+ p->setDevice(w);
+ p->setCanDelete(false);
+ }
+ else if( !pix.isNull() )
+ p->setDevice( new QPixmap(pix) );
+ */
+ JSOpaqueProxy *prx = new JSOpaqueProxy( p, "Painter" );
+ prx->setOwner( JSProxy::JavaScript );
+ KJS::Object proxyObj( prx );
+ Painter::addBindings( exec, proxyObj );
+ return proxyObj;
+ }
+
+ void PainterLoader::addBindings( KJSEmbedPart *jspart, KJS::ExecState *exec, KJS::Object &proxy ) const
+ {
+ Painter::addBindings( exec, proxy );
+ }
+
+PainterRef::PainterRef()
+{
+ m_device = 0L;
+ m_painter = new QPainter;
+ m_canDelete = true;
+}
+PainterRef::~PainterRef()
+{
+ kdDebug() << "Painter ref going away..." << endl;
+ if( m_device && m_canDelete)
+ delete m_device;
+ delete m_painter;
+}
+
+QPainter *PainterRef::painter()
+{
+ return m_painter;
+}
+
+QPaintDevice *PainterRef::device()
+{
+ return m_device;
+}
+
+void PainterRef::setDevice(QPaintDevice *d)
+{
+ if( m_device && m_canDelete)
+ {
+ delete m_device;
+ m_device = 0L;
+ }
+ m_device = d;
+
+}
+
+void Painter::addBindings( KJS::ExecState *exec, KJS::Object &object ) {
+
+ if( !JSProxy::checkType(object, JSProxy::OpaqueProxy, "Painter") ) return;
+
+ JSProxy::MethodTable methods[] = {
+ { Methodbegin, "begin" },
+ { Methodend, "end" },
+ { Methodpixmap, "pixmap" },
+ { MethodsetPixmap, "setPixmap" },
+ { MethodsetPen, "setPen" },
+ { Methodpen, "pen" },
+ { MethodtextBox, "textBox" },
+ { MethodmoveTo, "moveTo" },
+ { MethodlineTo, "lineTo" },
+ { MethoddrawPoint, "drawPoint" },
+ { MethoddrawLine, "drawLine" },
+ { MethoddrawRect, "drawRect" },
+ { MethoddrawRoundRect, "drawRoundRect" },
+ { MethoddrawEllipse, "drawEllipse" },
+ { MethoddrawText, "drawText" },
+ { MethoddrawArc, "drawArc" },
+ { MethoddrawPie, "drawPie" },
+ { MethoddrawPixmap, "drawPixmap" },
+ { MethoddrawImage, "drawImage" },
+ { MethoddrawTiledPixmap, "drawTiledPixmap" },
+ { Methodscale, "scale" },
+ { Methodshear, "shear" },
+ { Methodrotate, "rotate" },
+ { Methodtranslate, "translate" },
+ { MethodsetFont, "setFont" },
+ { Methodfont, "font" },
+ { MethodsetBrush, "setBrush" },
+ { Methodbrush, "brush" },
+ { MethodbackgroundColor, "backgroundColor" },
+ { MethodsetBackgroundColor, "setBackgroundColor" },
+ { 0, 0 }
+ };
+
+ JSProxy::addMethods<Painter>(exec, methods, object );
+
+}
+
+KJS::Value Painter::call( KJS::ExecState *exec, KJS::Object &self, const KJS::List &args ) {
+ if( !JSProxy::checkType(self, JSProxy::OpaqueProxy, "Painter") ) return KJS::Boolean(false);
+
+ KJS::Value retValue = KJS::Boolean(false);
+ JSOpaqueProxy *op = JSProxy::toOpaqueProxy( self.imp() );
+
+ pr = op->toNative<PainterRef>();
+
+ switch ( mid ) {
+ case Methodbegin:
+ {
+ if ( args.size() == 1 ) {
+ JSObjectProxy *objp = JSProxy::toObjectProxy(args[0].imp() );
+ JSValueProxy *vp = JSProxy::toValueProxy(args[0].imp() );
+ JSOpaqueProxy *op = JSProxy::toOpaqueProxy(args[0].imp() );
+ if ( objp )
+ {
+ if( objp->widget() )
+ {
+ pr->setDevice( objp->widget() );
+ pr->setCanDelete(false);
+ retValue = KJS::Boolean( begin() );
+ }
+ else
+ {
+ QString msg = i18n( "Paintdevice was not a valid widget." );
+ throwError(exec,msg);
+ retValue = KJS::Boolean(false);
+ }
+ }
+ else if ( vp )
+ {
+ QPixmap *p = new QPixmap(vp->toVariant().toPixmap());
+ if( p->isNull() )
+ {
+ QString msg = i18n( "Cannto paint to a null pixmap." ).arg( op->typeName() );
+ throwError(exec,msg);
+ retValue = KJS::Boolean(false);
+ }
+ else
+ {
+ pr->setDevice( p );
+ pr->setCanDelete(true);
+ retValue = KJS::Boolean( begin() );
+ }
+ }
+ else if ( op && op->typeName() == "QPaintDevice" )
+ {
+ pr->setDevice( op->toNative<QPaintDevice>() );
+ pr->setCanDelete(false);
+ retValue = KJS::Boolean( begin() );
+ }
+ else
+ {
+ QString msg = i18n( "Paintdevice of type '%1' is not supported." ).arg( op->typeName() );
+ throwError(exec,msg);
+ retValue = KJS::Boolean(false);
+ }
+ }
+ else
+ {
+ QString msg = i18n( "Incorrect number of arguements '%1'." ).arg( args.size() );
+ throwError(exec,msg);
+ retValue = KJS::Boolean(false);
+ }
+ break;
+ }
+ case Methodend:
+ retValue = KJS::Boolean( end() );
+ break;
+ case Methodpixmap:
+ {
+ retValue = convertToValue(exec, pixmap());
+ break;
+ }
+ case MethodsetPixmap:
+ break;
+ case MethodsetPen:
+ {
+ QPen pn = extractQPen(exec, args, 0);
+ setPen(pn);
+ break;
+ }
+ case Methodpen:
+ {
+ retValue = convertToValue(exec, pen());
+ break;
+ }
+ case MethodtextBox:
+ {
+ retValue = convertToValue(exec, textBox(extractQString(exec, args, 0)));
+ break;
+ }
+ case MethodmoveTo:
+ {
+ moveTo(extractInt(exec, args, 0), extractInt(exec, args, 1));
+ break;
+ }
+ case MethodlineTo:
+ {
+ lineTo(extractInt(exec, args, 0), extractInt(exec, args, 1));
+ break;
+ }
+ case MethoddrawPoint:
+ {
+ drawPoint(extractInt(exec, args, 0), extractInt(exec, args, 1));
+ break;
+ }
+ case MethoddrawLine:
+ {
+ drawLine(extractInt(exec, args, 0), extractInt(exec, args, 1),extractInt(exec, args, 2), extractInt(exec, args, 3));
+ break;
+ }
+ case MethoddrawRect:
+ {
+ drawRect(extractInt(exec, args, 0), extractInt(exec, args, 1),extractInt(exec, args, 2), extractInt(exec, args, 3));
+ break;
+ }
+ case MethoddrawRoundRect:
+ {
+ drawRoundRect(extractInt(exec, args, 0), extractInt(exec, args, 1),extractInt(exec, args, 2), extractInt(exec, args, 3),extractInt(exec, args, 4), extractInt(exec, args, 5));
+ break;
+ }
+ case MethoddrawEllipse:
+ {
+ drawEllipse(extractInt(exec, args, 0), extractInt(exec, args, 1),extractInt(exec, args, 2), extractInt(exec, args, 3));
+ break;
+ }
+ case MethoddrawText:
+ {
+ drawText(extractInt(exec, args, 0), extractInt(exec, args, 1), extractQString(exec, args, 2));
+ break;
+ }
+ case MethoddrawArc:
+ {
+ drawArc(extractInt(exec, args, 0), extractInt(exec, args, 1),extractInt(exec, args, 2), extractInt(exec, args, 3),extractInt(exec, args, 4), extractInt(exec, args, 5));
+ break;
+ }
+ case MethoddrawPie:
+ {
+ drawPie(extractInt(exec, args, 0), extractInt(exec, args, 1),extractInt(exec, args, 2), extractInt(exec, args, 3),extractInt(exec, args, 4), extractInt(exec, args, 5));
+ break;
+ }
+ case MethoddrawPixmap:
+ {
+ drawPixmap(extractInt(exec, args, 0), extractInt(exec, args, 1), extractQPixmap(exec, args, 2), extractInt(exec, args, 3), extractInt(exec, args, 4), extractInt(exec, args, 5), extractInt(exec, args, 6));
+ break;
+ }
+ case MethoddrawImage:
+ {
+ drawImage( extractInt(exec, args, 0), extractInt(exec, args, 1), extractQImage(exec, args, 2), extractInt(exec, args, 3), extractInt(exec, args, 4), extractInt(exec, args, 5), extractInt(exec, args, 6), extractInt(exec, args, 7) );
+ break;
+ }
+ case MethoddrawTiledPixmap:
+ {
+ drawTiledPixmap(extractInt(exec, args, 0), extractInt(exec, args, 1), extractInt(exec, args, 2), extractInt(exec, args, 3), extractQPixmap(exec, args, 4), extractInt(exec, args, 5), extractInt(exec, args, 6));
+ break;
+ }
+ case Methodscale:
+ {
+ scale(extractDouble(exec, args, 0), extractDouble(exec, args, 1));
+ break;
+ }
+ case Methodshear:
+ {
+ shear(extractDouble(exec, args, 0), extractDouble(exec, args, 1));
+ break;
+ }
+ case Methodrotate:
+ {
+ rotate(extractDouble(exec, args, 0));
+ break;
+ }
+ case Methodtranslate:
+ {
+ translate(extractDouble(exec, args, 0), extractDouble(exec, args, 1));
+ break;
+ }
+ case MethodsetFont:
+ {
+ setFont(extractQFont(exec, args, 0));
+ break;
+ }
+ case Methodfont:
+ {
+ retValue = convertToValue(exec, font());
+ break;
+ }
+ case MethodsetBrush:
+ {
+ pr->painter()->setBrush(extractQBrush(exec, args, 0));
+ break;
+ }
+ case Methodbrush:
+ {
+ retValue = convertToValue(exec, brush());
+ break;
+ }
+ case MethodbackgroundColor:
+ {
+ retValue = convertToValue(exec, backgroundColor());
+ break;
+ }
+ case MethodsetBackgroundColor:
+ {
+ setBackgroundColor(extractQColor(exec, args, 0));
+ break;
+ }
+ default:
+ kdWarning() << "Painter has no method " << mid << endl;
+ break;
+ }
+
+ //op->setValue(pr, "Painter");
+ return retValue;
+}
+
+Painter::Painter( KJS::ExecState *exec, int id )
+ : JSProxyImp(exec), mid(id), pr(0)
+{
+}
+
+Painter::~Painter()
+{
+}
+
+bool Painter::begin()
+{
+ return pr->painter()->begin(pr->device());
+}
+bool Painter::begin(QPaintDevice *dev)
+{
+ return pr->painter()->begin(dev);
+}
+
+bool Painter::end()
+{
+ return pr->painter()->end();
+}
+
+QPixmap Painter::pixmap() const
+{
+ QPixmap *pix = dynamic_cast<QPixmap *>(pr->device());
+ if( pix )
+ {
+ return *pix;
+ }
+ return QPixmap();
+}
+
+void Painter::setPen( const QPen& pn )
+{
+ pr->painter()->setPen(pn);
+}
+
+QPen Painter::pen() const
+{
+ return pr->painter()->pen();
+}
+
+QRect Painter::textBox(const QString &text)
+{
+ QFontMetrics fnt = pr->painter()->fontMetrics();
+ return fnt.boundingRect(text);
+}
+
+void Painter::moveTo( int x, int y )
+{
+ pr->painter()->moveTo( x, y );
+}
+
+void Painter::lineTo( int x, int y )
+{
+ pr->painter()->lineTo( x, y );
+}
+
+void Painter::drawPoint( int x, int y )
+{
+ pr->painter()->drawPoint( x, y );
+}
+
+void Painter::drawLine( int x1, int y1, int x2, int y2 )
+{
+ pr->painter()->drawLine( x1, y1, x2, y2 );
+}
+
+void Painter::drawRect( int x, int y, int w, int h )
+{
+ pr->painter()->drawRect( x, y, w, h );
+}
+
+void Painter::drawRoundRect( int x, int y, int w, int h, int xrnd, int yrnd )
+{
+ pr->painter()->drawRoundRect( x, y, w, h, xrnd, yrnd );
+}
+
+void Painter::drawEllipse( int x, int y, int w, int h )
+{
+ pr->painter()->drawEllipse( x, y, w, h );
+}
+
+void Painter::drawText( int x, int y, const QString &txt )
+{
+ pr->painter()->drawText( x, y, txt );
+}
+
+void Painter::drawArc ( int x, int y, int w, int h, int a, int alen )
+{
+ pr->painter()->drawArc( x, y, w, h, a, alen );
+}
+void Painter::drawPie ( int x, int y, int w, int h, int a, int alen )
+{
+ pr->painter()->drawPie( x, y, w, h, a, alen);
+}
+void Painter::drawPixmap ( int x, int y, const QPixmap & pixmap, int sx, int sy, int sw, int sh )
+{
+ pr->painter()->drawPixmap( x, y, pixmap, sx, sy, sw, sh );
+}
+void Painter::drawImage ( int x, int y, const QImage &image, int sx , int sy, int sw , int sh, int conversionFlags)
+{
+ pr->painter()->drawImage( x, y, image, sx, sy, sw, sh, conversionFlags );
+}
+void Painter::drawTiledPixmap ( int x, int y, int w, int h, const QPixmap & pixmap, int sx, int sy )
+{
+ pr->painter()->drawTiledPixmap( x, y, w, h, pixmap, sx, sy );
+}
+
+void Painter::scale ( double sx, double sy )
+{
+ pr->painter()->scale( sx,sy );
+}
+void Painter::shear ( double sh, double sv )
+{
+ pr->painter()->shear( sh, sv );
+}
+void Painter::rotate ( double a )
+{
+ pr->painter()->rotate( a );
+}
+void Painter::translate ( double dx, double dy )
+{
+ pr->painter()->translate( dx, dy );
+}
+
+void KJSEmbed::Bindings::Painter::setFont( const QFont & font )
+{
+ pr->painter()->setFont(font);
+}
+
+QFont KJSEmbed::Bindings::Painter::font( ) const
+{
+ return pr->painter()->font();
+}
+
+QColor KJSEmbed::Bindings::Painter::backgroundColor( ) const
+{
+ return pr->painter()->backgroundColor();
+}
+
+void KJSEmbed::Bindings::Painter::setBackgroundColor( const QColor & color )
+{
+ pr->painter()->setBackgroundColor(color);
+}
+
+} // namespace Bindings
+} // namespace KJSEmbed
+
+
+void KJSEmbed::Bindings::Painter::setBrush( const QColor & brush )
+{
+ pr->painter()->setBrush(brush);
+}
+
+QColor KJSEmbed::Bindings::Painter::brush( ) const
+{
+ return pr->painter()->brush().color();
+}
+// Local Variables:
+// c-basic-offset: 4
+// End:
+
+