You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
188 lines
5.0 KiB
188 lines
5.0 KiB
/*
|
|
* KMix -- KDE's full featured mini mixer
|
|
*
|
|
*
|
|
* Copyright (C) 1996-2004 Christian Esken <esken@kde.org>
|
|
*
|
|
* This program 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 program 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 program; if not, write to the Free
|
|
* Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
*/
|
|
|
|
#include "viewbase.h"
|
|
|
|
// QT
|
|
#include <tqlabel.h>
|
|
#include <tqcursor.h>
|
|
|
|
// KDE
|
|
#include <kaction.h>
|
|
#include <kpopupmenu.h>
|
|
#include <klocale.h>
|
|
#include <kiconloader.h>
|
|
|
|
// KMix
|
|
#include "dialogviewconfiguration.h"
|
|
#include "mixdevicewidget.h"
|
|
#include "mixer.h"
|
|
|
|
|
|
ViewBase::ViewBase(TQWidget* parent, const char* name, const TQString & caption, Mixer* mixer, WFlags f, ViewBase::ViewFlags vflags)
|
|
: TQWidget(parent, name, f), _vflags(vflags), _caption(caption)
|
|
{
|
|
_mixer = mixer;
|
|
_mixSet = new MixSet();
|
|
|
|
/* Can't use the following construct:
|
|
setMixSet( & mixer->getMixSet());
|
|
C++ does not use overloaded methods like getMixSet() as long as the constructor has not completed :-(((
|
|
*/
|
|
_actions = new KActionCollection( this );
|
|
|
|
// Plug in the "showMenubar" action, if the caller wants it. Typically this is only neccesary for views in the KMix main window.
|
|
if ( vflags & ViewBase::HasMenuBar ) {
|
|
KToggleAction *m = static_cast<KToggleAction*>(KStdAction::showMenubar( TQT_TQOBJECT(this), TQT_SLOT(toggleMenuBarSlot()), _actions ));
|
|
if ( vflags & ViewBase::MenuBarVisible ) {
|
|
m->setChecked(true);
|
|
}
|
|
else {
|
|
m->setChecked(false);
|
|
}
|
|
}
|
|
new KAction(i18n("&Channels"), 0, TQT_TQOBJECT(this), TQT_SLOT(configureView()), _actions, "toggle_channels");
|
|
connect ( _mixer, TQT_SIGNAL(newVolumeLevels()), this, TQT_SLOT(refreshVolumeLevels()) );
|
|
}
|
|
|
|
ViewBase::~ViewBase() {
|
|
delete _mixSet;
|
|
}
|
|
|
|
void ViewBase::init() {
|
|
const MixSet& mixset = _mixer->getMixSet();
|
|
setMixSet( const_cast<MixSet*>(&mixset)); // const_cast<>
|
|
}
|
|
|
|
void ViewBase::setMixSet(MixSet *)
|
|
{
|
|
// do nothing. Subclasses can do something if they feel like it
|
|
}
|
|
|
|
/**
|
|
* Dummy implementation for add().
|
|
*/
|
|
TQWidget* ViewBase::add(MixDevice* mdw) {
|
|
TQWidget* label = new TQLabel( mdw->name(), this, mdw->name().latin1());
|
|
label->move(0, mdw->num()*12);
|
|
return label;
|
|
}
|
|
|
|
void ViewBase::configurationUpdate() {
|
|
}
|
|
|
|
/**
|
|
* Create all widgets.
|
|
* This is a loop over all supported devices of the corresponding view.
|
|
* On each device add() is called - the derived class must implement add() for creating and placing
|
|
* the real MixDeviceWidget.
|
|
* The added MixDeviceWidget is appended to the _mdws list.
|
|
*/
|
|
void ViewBase::createDeviceWidgets()
|
|
{
|
|
// create devices
|
|
MixDevice *mixDevice;
|
|
for ( mixDevice = _mixSet->first(); mixDevice != 0; mixDevice = _mixSet->next())
|
|
{
|
|
TQWidget* mdw = add(mixDevice);
|
|
_mdws.append(mdw);
|
|
}
|
|
// allow view to "polish" itself
|
|
constructionFinished();
|
|
}
|
|
|
|
// ---------- Popup stuff START ---------------------
|
|
void ViewBase::mousePressEvent( TQMouseEvent *e )
|
|
{
|
|
if ( e->button()==Qt::RightButton )
|
|
showContextMenu();
|
|
}
|
|
|
|
/**
|
|
* Return a popup menu. This contains basic entries.
|
|
* More can be added by the caller.
|
|
*/
|
|
KPopupMenu* ViewBase::getPopup()
|
|
{
|
|
popupReset();
|
|
return _popMenu;
|
|
}
|
|
|
|
void ViewBase::popupReset()
|
|
{
|
|
KAction *a;
|
|
|
|
_popMenu = new KPopupMenu( this );
|
|
_popMenu->insertTitle( SmallIcon( "kmix" ), i18n("Device Settings") );
|
|
|
|
a = _actions->action( "toggle_channels" );
|
|
if ( a ) a->plug( _popMenu );
|
|
|
|
a = _actions->action( "options_show_menubar" );
|
|
if ( a ) a->plug( _popMenu );
|
|
}
|
|
|
|
|
|
/**
|
|
This will only get executed, when the user has removed all items from the view.
|
|
Don't remove this method, because then the user cannot get a menu for getting his
|
|
channels back
|
|
*/
|
|
void ViewBase::showContextMenu()
|
|
{
|
|
//kdDebug(67100) << "ViewBase::showContextMenu()" << endl;
|
|
popupReset();
|
|
|
|
TQPoint pos = TQCursor::pos();
|
|
_popMenu->popup( pos );
|
|
}
|
|
|
|
|
|
void ViewBase::refreshVolumeLevels()
|
|
{
|
|
// is virtual
|
|
}
|
|
|
|
Mixer* ViewBase::getMixer() {
|
|
return _mixer;
|
|
}
|
|
|
|
/**
|
|
* Open the View configuration dialog. The user can select which channels he wants
|
|
* to see and which not.
|
|
*/
|
|
void ViewBase::configureView() {
|
|
|
|
DialogViewConfiguration* dvc = new DialogViewConfiguration(0, *this);
|
|
dvc->show();
|
|
// !! The dialog is modal. Does it delete itself?
|
|
}
|
|
|
|
void ViewBase::toggleMenuBarSlot() {
|
|
//kdDebug(67100) << "ViewBase::toggleMenuBarSlot() start\n";
|
|
emit toggleMenuBar();
|
|
//kdDebug(67100) << "ViewBase::toggleMenuBarSlot() done\n";
|
|
}
|
|
|
|
// ---------- Popup stuff END ---------------------
|
|
|
|
#include "viewbase.moc"
|