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

kjsembed

  • 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
33using namespace KJSEmbed;
34
35namespace SvgRendererNS {
36START_QOBJECT_METHOD( animationDuration, QSvgRenderer )
37 result = KJS::jsNumber(object->animationDuration());
38END_QOBJECT_METHOD
39
40START_QOBJECT_METHOD( defaultSize, QSvgRenderer )
41 result = KJSEmbed::createVariant(exec, "QSize", object->defaultSize() );
42END_QOBJECT_METHOD
43
44START_QOBJECT_METHOD( isValid, QSvgRenderer )
45 result = KJS::jsBoolean(object->isValid());
46END_QOBJECT_METHOD
47
48START_QOBJECT_METHOD( animated, QSvgRenderer )
49 result = KJS::jsBoolean(object->animated());
50END_QOBJECT_METHOD
51}
52
53START_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}
58END_METHOD_LUT
59
60NO_ENUMS( SvgRenderer )
61NO_STATICS( SvgRenderer )
62
63KJSO_SIMPLE_BINDING_CTOR( SvgRenderer, QSvgRenderer, QObjectBinding )
64KJSO_QOBJECT_BIND( SvgRenderer, QSvgRenderer )
65
66KJSO_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;
86KJSO_END_CTOR
87
88namespace SvgWidgetNS
89{
90START_QOBJECT_METHOD( renderer, QSvgWidget )
91 result = KJSEmbed::createQObject( exec, object->renderer(), ObjectBinding::QObjOwned );
92END_QOBJECT_METHOD
93}
94
95START_METHOD_LUT( SvgWidget )
96 {"renderer", 0, KJS::DontDelete|KJS::ReadOnly, &SvgWidgetNS::renderer}
97END_METHOD_LUT
98
99NO_ENUMS( SvgWidget )
100NO_STATICS( SvgWidget )
101
102KJSO_SIMPLE_BINDING_CTOR( SvgWidget, QSvgWidget, QWidgetBinding )
103KJSO_QOBJECT_BIND( SvgWidget, QSvgWidget )
104
105KJSO_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;
125KJSO_END_CTOR
126
127//kate: indent-spaces on; indent-width 4; replace-tabs on; indent-mode cstyle;
START_METHOD_LUT
#define START_METHOD_LUT(TYPE)
Definition: binding_support.h:127
NO_ENUMS
#define NO_ENUMS(TYPE)
Definition: binding_support.h:147
KJSO_START_CTOR
#define KJSO_START_CTOR(TYPE, JSNAME, ARGS)
Definition: binding_support.h:169
NO_STATICS
#define NO_STATICS(TYPE)
Definition: binding_support.h:153
KJSO_QOBJECT_BIND
#define KJSO_QOBJECT_BIND(NAME, TYPE)
Definition: binding_support.h:205
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
KJSO_END_CTOR
#define KJSO_END_CTOR
Definition: binding_support.h:178
KJSEmbed::ObjectBinding
Definition: object_binding.h:89
KJSEmbed::QObjectBinding
Definition: qobject_binding.h:80
QObject
QWidget
result
END_VARIANT_METHOD result
Definition: color.cpp:85
if
if(file->open((QIODevice::OpenModeFlag) KJSEmbed::extractInt(exec, args, 0)))
Definition: fileio.cpp:64
kjseglobal.h
KJSEmbed
Definition: application.h:33
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
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
KJS
Implement QString-KJS::UString conversion methods.
Definition: kjs_object_model.h:29
SvgRendererNS
Definition: svg_binding.cpp:35
SvgRendererNS::result
result
Definition: svg_binding.cpp:37
SvgWidgetNS
Definition: svg_binding.cpp:89
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
arg0
END_OBJECT_METHOD QPolygon arg0
Definition: qpainter_binding.cpp:179
arg1
Qt::FillRule arg1
Definition: qpainter_binding.cpp:307
qwidget_binding.h
static_binding.h
widget
END_METHOD_LUT QSvgWidget * widget
Definition: svg_binding.cpp:106
rendererObject
KJS::JSObject * rendererObject
Definition: svg_binding.cpp:84
svg_binding.h
This file is part of the KDE documentation.
Documentation copyright © 1996-2023 The KDE developers.
Generated on Mon Feb 20 2023 00:00:00 by doxygen 1.9.6 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-4.14.38 API Reference

Skip menu "kdelibs-4.14.38 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
  •   WTF
  • kjsembed
  • KNewStuff
  • KParts
  • KPty
  • Kross
  • KUnitConversion
  • KUtils
  • Nepomuk
  • Plasma
  • Solid
  • Sonnet
  • ThreadWeaver
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