From e2de64d6f1beb9e492daf5b886e19933c1fa41dd 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/kdemultimedia@1054174 283d02a7-25f6-0310-bc7c-ecb5cbfe19da --- arts/gui/kde/kartswidget.h | 92 ++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 92 insertions(+) create mode 100644 arts/gui/kde/kartswidget.h (limited to 'arts/gui/kde/kartswidget.h') diff --git a/arts/gui/kde/kartswidget.h b/arts/gui/kde/kartswidget.h new file mode 100644 index 00000000..049e4657 --- /dev/null +++ b/arts/gui/kde/kartswidget.h @@ -0,0 +1,92 @@ + /* + + Copyright (C) 2001 Stefan Westerfeld + stefan@space.twc.de + 2003 Arnold Krille + + 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., 59 Temple Place - Suite 330, + Boston, MA 02111-1307, USA. + + */ + +#ifndef ARTS_GUI_KARTSWIDGET_H +#define ARTS_GUI_KARTSWIDGET_H + +#include +#include "artsgui.h" +#include +class KArtsWidgetPrivate; + +/** + * KArtsWidget provides a simple way to treat Arts::Widget classes like + * native Qt widgets. Suppose you use Qt, and want to put an Arts::Widget + * type into a layout, you can do so using this code + * + *
+ *    Arts::Widget widget = ...get widget from somewhere...;
+ *    KArtsWidget *w = new KArtsWidget(widget, this);
+ *    layout->addWidget(w);
+ * 
+ * + * In line 2 of the code, the "this" is the parent widget (which is usually + * this in Qt code). + * + * The KArtsWidget class keeps a reference to the content widget, so the + * content widget will not be freed until the KArtsWidget gets destroyed. + */ +class KDE_EXPORT KArtsWidget : public QWidget { +private: + KArtsWidgetPrivate *d; + +protected: + Arts::Widget _content; + +public: + /** + * creates a new KArtsWidget + */ + KArtsWidget( QWidget* parent, const char* name ); + + /** + * creates a new KArtsWidget and sets the content to an Arts::Widget + */ + KArtsWidget( Arts::Widget content, QWidget* parent, const char* name ); + + /** + * creates a new KArtsWidget with WidgetFlags and content + * + * BCI: should replace the above in the next major release. ( akrille ) + */ + KArtsWidget( Arts::Widget, QWidget* =0, const char* =0, WFlags =0 ); + // same without the content + KArtsWidget( QWidget* =0, const char* =0, WFlags =0 ); + + /** + * destructor + */ + ~KArtsWidget(); + + /** + * sets the content to a new Arts::Widget + */ + void setContent(Arts::Widget content); + + /** + * gets the content widget + */ + Arts::Widget content(); +}; + +#endif /* ARTS_GUI_KARTSWIDGET_H*/ -- cgit v1.2.1