• Skip to content
  • Skip to link menu
KDE API Reference
  • KDE API Reference
  • kdelibs API Reference
  • KDE Home
  • Contact Us
 

kjsembed

  • sources
  • kde-4.12
  • kdelibs
  • kjsembed
  • kjsembed
svg_binding.cpp
Go to the documentation of this file.
1 /* This file is part of the KDE libraries
2  Copyright (C) 2005, 2006 Ian Reinhart Geiser <geiseri@kde.org>
3  Copyright (C) 2005, 2006 Matt Broadstone <mbroadst@gmail.com>
4  Copyright (C) 2005, 2006 Richard J. Moore <rich@kde.org>
5  Copyright (C) 2005, 2006 Erik L. Bunce <kde@bunce.us>
6 
7  This library is free software; you can redistribute it and/or
8  modify it under the terms of the GNU Library General Public
9  License as published by the Free Software Foundation; either
10  version 2 of the License, or (at your option) any later version.
11 
12  This library is distributed in the hope that it will be useful,
13  but WITHOUT ANY WARRANTY; without even the implied warranty of
14  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15  Library General Public License for more details.
16 
17  You should have received a copy of the GNU Library General Public License
18  along with this library; see the file COPYING.LIB. If not, write to
19  the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
20  Boston, MA 02110-1301, USA.
21 */
22 #include "svg_binding.h"
23 
24 #include <QtSvg/QSvgWidget>
25 #include <QtCore/QDebug>
26 
27 #include <kjs/object.h>
28 
29 #include "qwidget_binding.h"
30 #include "static_binding.h"
31 #include "kjseglobal.h"
32 
33 using namespace KJSEmbed;
34 
35 namespace SvgRendererNS {
36 START_QOBJECT_METHOD( animationDuration, QSvgRenderer )
37  result = KJS::jsNumber(object->animationDuration());
38 END_QOBJECT_METHOD
39 
40 START_QOBJECT_METHOD( defaultSize, QSvgRenderer )
41  result = KJSEmbed::createVariant(exec, "QSize", object->defaultSize() );
42 END_QOBJECT_METHOD
43 
44 START_QOBJECT_METHOD( isValid, QSvgRenderer )
45  result = KJS::jsBoolean(object->isValid());
46 END_QOBJECT_METHOD
47 
48 START_QOBJECT_METHOD( animated, QSvgRenderer )
49  result = KJS::jsBoolean(object->animated());
50 END_QOBJECT_METHOD
51 }
52 
53 START_METHOD_LUT( SvgRenderer )
54  {"animationDuration", 0, KJS::DontDelete|KJS::ReadOnly, &SvgRendererNS::animationDuration},
55  {"defaultSize", 0, KJS::DontDelete|KJS::ReadOnly, &SvgRendererNS::defaultSize},
56  {"isValid", 0, KJS::DontDelete|KJS::ReadOnly, &SvgRendererNS::isValid},
57  {"animated", 0, KJS::DontDelete|KJS::ReadOnly, &SvgRendererNS::animated}
58 END_METHOD_LUT
59 
60 NO_ENUMS( SvgRenderer )
61 NO_STATICS( SvgRenderer )
62 
63 KJSO_SIMPLE_BINDING_CTOR( SvgRenderer, QSvgRenderer, QObjectBinding )
64 KJSO_QOBJECT_BIND( SvgRenderer, QSvgRenderer )
65 
66 KJSO_START_CTOR( SvgRenderer, QSvgRenderer, 0 )
67  QSvgRenderer *renderer = 0;
68  if( args.size() == 1 )
69  {
70  QObject *arg0 = KJSEmbed::extractObject<QObject>(exec, args, 0, 0);
71  renderer = new QSvgRenderer(arg0);
72  }
73  else if( args.size() == 2 )
74  {
75  QString arg0 = KJSEmbed::extractVariant<QString>(exec, args, 0 );
76  QObject *arg1 = KJSEmbed::extractObject<QObject>(exec, args, 1, 0);
77  renderer = new QSvgRenderer(arg0,arg1);
78  }
79  else
80  {
81  renderer = new QSvgRenderer();
82  }
83 
84  KJS::JSObject *rendererObject = new SvgRenderer( exec, renderer );
85  return rendererObject;
86 KJSO_END_CTOR
87 
88 namespace SvgWidgetNS
89 {
90 START_QOBJECT_METHOD( renderer, QSvgWidget )
91  result = KJSEmbed::createQObject( exec, object->renderer(), ObjectBinding::QObjOwned );
92 END_QOBJECT_METHOD
93 }
94 
95 START_METHOD_LUT( SvgWidget )
96  {"renderer", 0, KJS::DontDelete|KJS::ReadOnly, &SvgWidgetNS::renderer}
97 END_METHOD_LUT
98 
99 NO_ENUMS( SvgWidget )
100 NO_STATICS( SvgWidget )
101 
102 KJSO_SIMPLE_BINDING_CTOR( SvgWidget, QSvgWidget, QWidgetBinding )
103 KJSO_QOBJECT_BIND( SvgWidget, QSvgWidget )
104 
105 KJSO_START_CTOR( SvgWidget, QSvgWidget, 0 )
106  QSvgWidget *widget = 0;
107  if( args.size() == 1 )
108  {
109  QWidget *arg0 = KJSEmbed::extractObject<QWidget>(exec, args, 0, 0);
110  widget = new QSvgWidget(arg0);
111  }
112  else if( args.size() == 2 )
113  {
114  QString arg0 = KJSEmbed::extractVariant<QString>(exec, args, 0 );
115  QWidget *arg1 = KJSEmbed::extractObject<QWidget>(exec, args, 1, 0);
116  widget = new QSvgWidget(arg0,arg1);
117  }
118  else
119  {
120  widget = new QSvgWidget();
121  }
122 
123  KJS::JSObject *rendererObject = new SvgWidget( exec, widget );
124  return rendererObject;
125 KJSO_END_CTOR
126 
127 //kate: indent-spaces on; indent-width 4; replace-tabs on; indent-mode cstyle;
KJSEmbed::QObjectBinding
Definition: qobject_binding.h:79
KJSO_QOBJECT_BIND
#define KJSO_QOBJECT_BIND(NAME, TYPE)
Definition: binding_support.h:205
KJSEmbed::createVariant
KJS::JSValue * createVariant(KJS::ExecState *exec, const KJS::UString &className, const T &value)
Can create any known KJSEmbed::VariantBinding object and set the value.
Definition: variant_binding.h:185
QWidget
KJSO_START_CTOR
KJSO_START_CTOR(UiLoaderBinding, QUiLoader, 1)
Definition: quiloader_binding.cpp:40
widget
END_METHOD_LUT QSvgWidget * widget
Definition: svg_binding.cpp:106
QObject
KJSEmbed::ObjectBinding
Definition: object_binding.h:88
KJSEmbed::createQObject
KJSEMBED_EXPORT KJS::JSObject * createQObject(KJS::ExecState *exec, QObject *value, KJSEmbed::ObjectBinding::Ownership owner=KJSEmbed::ObjectBinding::JSOwned)
Returns a binding object for the specified QObject.
Definition: qobject_binding.cpp:735
START_QOBJECT_METHOD
#define START_QOBJECT_METHOD(METHODNAME, TYPE)
A simple pointer syle method.
Definition: qobject_binding.h:45
END_QOBJECT_METHOD
#define END_QOBJECT_METHOD
End a variant method started by START_QOBJECT_METHOD.
Definition: qobject_binding.h:60
NO_ENUMS
#define NO_ENUMS(TYPE)
Definition: binding_support.h:147
if
if(args.size()==1)
Definition: svg_binding.cpp:68
qwidget_binding.h
KJSO_SIMPLE_BINDING_CTOR
#define KJSO_SIMPLE_BINDING_CTOR(NAME, TYPE, BASENAME)
Definition: binding_support.h:113
END_METHOD_LUT
#define END_METHOD_LUT
Definition: binding_support.h:135
SvgWidgetNS::result
result
Definition: svg_binding.cpp:91
rendererObject
KJS::JSObject * rendererObject
Definition: svg_binding.cpp:84
kjseglobal.h
svg_binding.h
arg0
END_OBJECT_METHOD QPolygon arg0
Definition: qpainter_binding.cpp:179
static_binding.h
arg1
Qt::FillRule arg1
Definition: qpainter_binding.cpp:307
START_METHOD_LUT
START_METHOD_LUT(SvgRenderer)
Definition: svg_binding.cpp:53
KJSO_END_CTOR
#define KJSO_END_CTOR
Definition: binding_support.h:178
NO_STATICS
#define NO_STATICS(TYPE)
Definition: binding_support.h:153
This file is part of the KDE documentation.
Documentation copyright © 1996-2014 The KDE developers.
Generated on Tue Oct 14 2014 22:47:53 by doxygen 1.8.7 written by Dimitri van Heesch, © 1997-2006

KDE's Doxygen guidelines are available online.

kjsembed

Skip menu "kjsembed"
  • Main Page
  • Namespace List
  • Namespace Members
  • Alphabetical List
  • Class List
  • Class Hierarchy
  • Class Members
  • File List
  • File Members

kdelibs API Reference

Skip menu "kdelibs API Reference"
  • DNSSD
  • Interfaces
  •   KHexEdit
  •   KMediaPlayer
  •   KSpeech
  •   KTextEditor
  • kconf_update
  • KDE3Support
  •   KUnitTest
  • KDECore
  • KDED
  • KDEsu
  • KDEUI
  • KDEWebKit
  • KDocTools
  • KFile
  • KHTML
  • KImgIO
  • KInit
  • kio
  • KIOSlave
  • KJS
  •   KJS-API
  • kjsembed
  •   WTF
  • KNewStuff
  • KParts
  • KPty
  • Kross
  • KUnitConversion
  • KUtils
  • Nepomuk
  • Nepomuk-Core
  • Nepomuk
  • Plasma
  • Solid
  • Sonnet
  • ThreadWeaver

Search



Report problems with this website to our bug tracking system.
Contact the specific authors with questions and comments about the page contents.

KDE® and the K Desktop Environment® logo are registered trademarks of KDE e.V. | Legal