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 | 00bb99ac80741fc50ef8a289719373032f2391eb (patch) | |
tree | 3a5a9bf72f942784b38bf77dd66c534662fab5f2 /ksayit/KTTSD_Lib/kttsdlib.cpp | |
download | tdeaccessibility-00bb99ac80741fc50ef8a289719373032f2391eb.tar.gz tdeaccessibility-00bb99ac80741fc50ef8a289719373032f2391eb.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/kdeaccessibility@1054174 283d02a7-25f6-0310-bc7c-ecb5cbfe19da
Diffstat (limited to 'ksayit/KTTSD_Lib/kttsdlib.cpp')
-rw-r--r-- | ksayit/KTTSD_Lib/kttsdlib.cpp | 221 |
1 files changed, 221 insertions, 0 deletions
diff --git a/ksayit/KTTSD_Lib/kttsdlib.cpp b/ksayit/KTTSD_Lib/kttsdlib.cpp new file mode 100644 index 0000000..224cd21 --- /dev/null +++ b/ksayit/KTTSD_Lib/kttsdlib.cpp @@ -0,0 +1,221 @@ +// +// C++ Implementation: kttsdplugin +// +// Description: +// +// +// Author: Robert Vogl <voglrobe@lapislazuli>, (C) 2004 +// +// Copyright: See COPYING file that comes with this distribution +// +// +// #include <time.h> // nanosleep + +// Qt includes +#include <qstring.h> +#include <qstringlist.h> + +// KDE includes +#include <kglobal.h> +#include <klocale.h> +#include <kstandarddirs.h> +#include <kdebug.h> + +// App specific includes +#include "kttsdlib.h" +#include "kttsdlibtalker2.h" +#include "kttsdlibsetupimpl.h" + + +KTTSDLib::KTTSDLib(QObject *parent, const char *name, KApplication *Appl) + : QObject(parent, name), m_Appl(Appl) +{ + KGlobal::locale()->insertCatalogue("libKTTSD"); + m_talker = new kttsdlibtalker2(static_cast<QObject*>(this), "kttsdlibtalker"); + connect(m_talker, SIGNAL(signalTextFinished(const uint)), + this, SLOT(slotTextFinished(const uint)) ); + connect(m_talker, SIGNAL(signalTextStopped(const uint)), + this, SLOT(slotTextStopped(const uint)) ); + connect(m_talker, SIGNAL(signalTextStarted(const uint)), + this, SLOT(slotTextStarted(const uint)) ); + + // reset list of currently processed jobs + while ( !jobList.empty() ){ + jobList.pop(); + } + + // initialize the talker + m_talker->KTTSD_init(m_Appl); + + // some presets + // m_config = new KSimpleConfig("ksayit_kttsdpluginrc"); + // m_usersetupimpl = NULL; +} + + +KTTSDLib::~KTTSDLib() +{ + // delete m_config; +} + + +QString KTTSDLib::getName() const +{ + return "KDE KTTSD"; +} + + +QString KTTSDLib::getDescription() const +{ + QString str; + str = i18n("<qt><big><u>Description:</u></big><br>"); + str += i18n("This plugin uses the KDE TTS Daemon for speech output."); + + return str; +} + + +int KTTSDLib::getActions() +{ + return ACTIONS::PLAY | ACTIONS::STOP | ACTIONS::PAUSE | ACTIONS::FFWD | ACTIONS::FREV; +} + + +int KTTSDLib::getStatus() const +{ + return TTS::AUDIOFILE; +} + + +const QWidget* KTTSDLib::getGUI(QFrame *frame) +{ + kdDebug(100200) << "KTTSDLib::getGUI()" << endl; + + return new KTTSDlibSetupImpl( frame, "kttsdlibsetup" ); +} + + +void KTTSDLib::reloadConfiguration() +{ + kdDebug(100200) << "KTTSDLib::reloadConfiguration()" << endl; + // N.A. +} + + +bool KTTSDLib::saveWasClicked() const +{ + kdDebug(100200) << "KTTSDLib::saveWasClicked()" << endl; + // N.A. + + return true; +} + + +void KTTSDLib::setText(const QString &text) +{ + kdDebug(100200) << "KTTSDLib::setText()" << endl; + + uint jobNum = m_talker->KTTSD_setText(text, ""); + jobList.push(jobNum); +} + + + +void KTTSDLib::sayText() +{ + kdDebug(100200) << "KTTSDLib::sayText()" << endl; + + if( !jobList.empty() ){ + m_curJobNum = jobList.front(); + jobList.pop(); + kdDebug(100200) << " Starting job No.: " << m_curJobNum << endl; + m_talker->KTTSD_startText( m_curJobNum ); + } +} + + +void KTTSDLib::removeAllJobsFromList() +{ + kdDebug(100200) << "KTTSDLib::removeAllJobsFromList()" << endl; + + m_talker->KTTSD_removeText(m_curJobNum); + + while( !jobList.empty() ){ + uint job = jobList.front(); + jobList.pop(); + kdDebug(100200) << "*** removing... " << job << endl; + m_talker->KTTSD_removeText( job ); + } +} + +void KTTSDLib::stop() +{ + kdDebug(100200) << "***** KTTSDLib::stop(" << m_curJobNum << ")" << endl; + m_talker->KTTSD_stopText(m_curJobNum); + removeAllJobsFromList(); + emit signalFinished(); +} + + +void KTTSDLib::pause() +{ + kdDebug(100200) << "void KTTSDLib::pause(" << m_curJobNum << ")" << endl; + + m_talker->KTTSD_pauseText( m_curJobNum ); +} + + +void KTTSDLib::resume() +{ + kdDebug(100200) << "void KTTSDLib::resume(" << m_curJobNum << ")" << endl; + + m_talker->KTTSD_resumeText( m_curJobNum ); +} + + +void KTTSDLib::ffwd() +{ + kdDebug(100200) << "void KTTSDLib::ffwd(" << m_curJobNum << ")" << endl; + m_talker->KTTSD_moveRelTextSentence(1, m_curJobNum); +} + + +void KTTSDLib::frev() +{ + kdDebug(100200) << "void KTTSDLib::frev(" << m_curJobNum << ")" << endl; + m_talker->KTTSD_moveRelTextSentence(-1, m_curJobNum); +} + + +////////////////////////////////////// +// Signals from the talker +////////////////////////////////////// + +void KTTSDLib::slotTextFinished(const uint job) +{ + kdDebug(100200) << "---- KTTSDLib::slotTextFinished(" << job << ")" << endl; + + // check if List is empty. If yes, send signalFinished(). + if ( jobList.empty() ){ + kdDebug(100200) << " All jobs processed." << endl; + emit signalFinished(); + } else { + sayText(); + } +} + +void KTTSDLib::slotTextStopped(const uint job) +{ + kdDebug(100200) << "---- KTTSDLib::slotTextStopped(" << job << ")" << endl; + // removeAllJobsFromList(); + // emit signalFinished(); +} + + +void KTTSDLib::slotTextStarted(const uint job) +{ + kdDebug(100200) << "---- KTTSDLib::slotTextStarted(" << job << ")" << endl; + // m_curJobNum = job; +} + +#include "kttsdlib.moc" |