diff options
author | toma <toma@283d02a7-25f6-0310-bc7c-ecb5cbfe19da> | 2009-11-25 17:56:58 +0000 |
---|---|---|
committer | toma <toma@283d02a7-25f6-0310-bc7c-ecb5cbfe19da> | 2009-11-25 17:56:58 +0000 |
commit | e2de64d6f1beb9e492daf5b886e19933c1fa41dd (patch) | |
tree | 9047cf9e6b5c43878d5bf82660adae77ceee097a /kmid/kmid_part.cpp | |
download | tdemultimedia-e2de64d6f1beb9e492daf5b886e19933c1fa41dd.tar.gz tdemultimedia-e2de64d6f1beb9e492daf5b886e19933c1fa41dd.zip |
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
Diffstat (limited to 'kmid/kmid_part.cpp')
-rw-r--r-- | kmid/kmid_part.cpp | 144 |
1 files changed, 144 insertions, 0 deletions
diff --git a/kmid/kmid_part.cpp b/kmid/kmid_part.cpp new file mode 100644 index 00000000..98241ac1 --- /dev/null +++ b/kmid/kmid_part.cpp @@ -0,0 +1,144 @@ +#include "kmid_part.h" + +#include <kinstance.h> +#include <kiconloader.h> +#include <klocale.h> +#include <kaboutdata.h> +#include <kaction.h> +#include <qiconset.h> + +#include <kparts/partmanager.h> + +#include "kmidclient.h" +#include <qtimer.h> +#include <kdelibs_export.h> + +K_EXPORT_COMPONENT_FACTORY( libkmidpart, KMidFactory ) + +/** + * We need one static instance of the factory for our C 'main' + * function + */ +KInstance *KMidFactory::s_instance = 0L; + +KMidFactory::KMidFactory() +{ + s_instance=0L; +} + +KMidFactory::~KMidFactory() +{ + if (s_instance) + { + delete s_instance->aboutData(); + delete s_instance; + } + + s_instance = 0; +} + +KParts::Part *KMidFactory::createPartObject(QWidget *parentWidget, const char *widgetName, + QObject *parent, const char *name, const char*, + const QStringList& ) +{ + KParts::Part *obj = new KMidPart(parentWidget, widgetName, parent, name); + return obj; +} + +KAboutData *KMidFactory::aboutData() +{ + KAboutData *aboutdata = new KAboutData("kmid", "KMid", "2.0", + I18N_NOOP("MIDI/Karaoke file player"), KAboutData::License_GPL, + I18N_NOOP("(c) 1997,98,99,2000, Antonio Larrosa Jimenez"),"", + "http://perso.wanadoo.es/antlarr/kmid.html"); + aboutdata->addAuthor("Antonio Larrosa Jimenez", + I18N_NOOP("Original Developer/Maintainer"),"larrosa@kde.org", + "http://perso.wanadoo.es/antlarr/index.html"); + return aboutdata; +} + +KInstance *KMidFactory::instance() +{ + if ( !s_instance ) + s_instance = new KInstance( aboutData() ); + + return s_instance; +} + + KMidPart::KMidPart(QWidget *parentWidget, const char *widgetName, + QObject *parent, const char *name) +: KParts::ReadOnlyPart(parent, name) +{ + setInstance(KMidFactory::instance()); + + widget = new kmidClient(parentWidget, actionCollection()); + widget->show(); + widget->setFocusPolicy(QWidget::ClickFocus); + setWidget(widget); + + // create and connect our actions + (void)new KAction(i18n("Play"), "player_play", 0, this, + SLOT(slotPlay()), actionCollection(), + "play"); + + (void)new KAction(i18n("Stop"), "player_stop", 0, this, + SLOT(slotStop()), actionCollection(), + "stop"); + + (void)new KAction(i18n("Backward"), + "2leftarrow", 0, this, + SLOT(slotBackward()), actionCollection(), + "backward"); + + (void)new KAction(i18n("Forward"), + "2rightarrow", 0, this, + SLOT(slotForward()), actionCollection(), + "forward"); + + m_extension = new KMidBrowserExtension(this); + + setXMLFile("kmid_partui.rc"); + + +} + +KMidPart::~KMidPart() +{ +} + +bool KMidPart::openFile() +{ + widget->openURL(m_file); + widget->stop(); + widget->show(); + QTimer::singleShot(2000, this, SLOT(slotPlay())); + + return true; +} + +bool KMidPart::closeURL() +{ + slotStop(); + return true; +} + +void KMidPart::slotPlay() +{ + widget->stop(); + widget->play(); +} + + +void KMidPart::slotStop() +{ + widget->stop(); +} +KMidBrowserExtension::KMidBrowserExtension(KMidPart *parent) + : KParts::BrowserExtension(parent, "KMidBrowserExtension") +{ +} + +KMidBrowserExtension::~KMidBrowserExtension() +{ +} +#include "kmid_part.moc" |