/*****************************************************************************
- * ToolbarEdit.cpp : ToolbarEdit and About dialogs
+ * ToolbarEdit.cpp : ToolbarEdit dialog
****************************************************************************
- * Copyright (C) 2008 the VideoLAN team
+ * Copyright (C) 2008-2009 the VideoLAN team
* $Id$
*
* Authors: Jean-Baptiste Kempf <jb (at) videolan.org>
#include <QLabel>
#include <QComboBox>
#include <QListWidget>
+#include <QSpinBox>
#include <QDragEnterEvent>
+#include <QDialogButtonBox>
+#include <QInputDialog>
-ToolbarEditDialog *ToolbarEditDialog::instance = NULL;
+#include <assert.h>
-ToolbarEditDialog::ToolbarEditDialog( intf_thread_t *_p_intf)
- : QVLCFrame( _p_intf )
+ToolbarEditDialog::ToolbarEditDialog( QWidget *_w, intf_thread_t *_p_intf)
+ : QVLCDialog( _w, _p_intf )
{
setWindowTitle( qtr( "Toolbars Editor" ) );
+ setWindowRole( "vlc-toolbars-editor" );
QGridLayout *mainLayout = new QGridLayout( this );
setMinimumWidth( 600 );
+ setAttribute( Qt::WA_DeleteOnClose );
/* main GroupBox */
- QGroupBox *widgetBox = new QGroupBox( "Toolbar Elements", this );
+ QGroupBox *widgetBox = new QGroupBox( qtr( "Toolbar Elements") , this );
widgetBox->setSizePolicy( QSizePolicy::Preferred,
QSizePolicy::MinimumExpanding );
QGridLayout *boxLayout = new QGridLayout( widgetBox );
+ QLabel *styleLabel = new QLabel( qtr( "Next widget style:" ) );
flatBox = new QCheckBox( qtr( "Flat Button" ) );
bigBox = new QCheckBox( qtr( "Big Button" ) );
shinyBox = new QCheckBox( qtr( "Native Slider" ) );
- shinyBox->setChecked( true );
boxLayout->addWidget( new WidgetListing( p_intf, this ), 0, 0, 1, -1);
- boxLayout->addWidget( flatBox, 1, 0 );
- boxLayout->addWidget( bigBox, 1, 1 );
- boxLayout->addWidget( shinyBox, 1, 2 );
- mainLayout->addWidget( widgetBox, 0, 0, 1, -1 );
+ boxLayout->addWidget( styleLabel, 1, 0 );
+ boxLayout->addWidget( flatBox, 1, 1 );
+ boxLayout->addWidget( bigBox, 1, 2 );
+ boxLayout->addWidget( shinyBox, 2, 1 );
+ mainLayout->addWidget( widgetBox, 0, 0, 5, 1 );
/* Main ToolBar */
- QGroupBox *mainToolbarBox = new QGroupBox( "Main Toolbar", this );
+ QGroupBox *mainToolbarBox = new QGroupBox( qtr( "Main Toolbar" ), this );
QGridLayout *mainTboxLayout = new QGridLayout( mainToolbarBox );
- QLabel *label = new QLabel( "Toolbar position:" );
+ QLabel *label = new QLabel( qtr( "Toolbar position:" ) );
mainTboxLayout->addWidget(label, 0, 0, 1, 2);
- QComboBox *positionCombo = new QComboBox;
- positionCombo->addItems( QStringList() << "Over the Video"
- << "Under the Video" );
+ positionCombo = new QComboBox;
+ positionCombo->addItem( qtr( "Under the Video" ), QVariant( 0 ) );
+ positionCombo->addItem( qtr( "Above the Video" ), QVariant( 1 ) );
+ positionCombo->setCurrentIndex( positionCombo->findData(
+ getSettings()->value( "MainWindow/ToolbarPos", 0 ).toInt() ) );
mainTboxLayout->addWidget( positionCombo, 0, 2, 1, 1 );
- QLabel *line1Label = new QLabel( "Line 1:" );
- QString line1 = getSettings()->value( "MainWindow/Controls1",
- "64;36;37;38;65").toString();
- DroppingController *controller1 = new DroppingController( p_intf, line1,
+ QLabel *line1Label = new QLabel( qtr("Line 1:") );
+ QString line1 = getSettings()->value( "MainWindow/MainToolbar1",
+ MAIN_TB1_DEFAULT ).toString();
+ controller1 = new DroppingController( p_intf, line1,
this );
mainTboxLayout->addWidget( line1Label, 1, 0, 1, 1 );
mainTboxLayout->addWidget( controller1, 1, 1, 1, 2 );
- QLabel *line2Label = new QLabel( "Line 2:" );
- QString line2 = getSettings()->value( "MainWindow/Controls2",
- "0-2;64;3;1;4;64;7;10;9;65;34-4" ).toString();
- DroppingController *controller2 = new DroppingController( p_intf, line2,
+ QLabel *line2Label = new QLabel( qtr("Line 2:") );
+ QString line2 = getSettings()->value( "MainWindow/MainToolbar2",
+ MAIN_TB2_DEFAULT ).toString();
+ controller2 = new DroppingController( p_intf, line2,
this );
mainTboxLayout->addWidget( line2Label, 2, 0, 1, 1 );
mainTboxLayout->addWidget( controller2, 2, 1, 1, 2);
/* Advanced ToolBar */
- QLabel *advLabel = new QLabel( "Advanced Widget toolbar:" );
- QString lineA = getSettings()->value( "MainWindow/AdvControl",
- "12;11;13;14").toString();
- DroppingController *controllerA = new DroppingController( p_intf, lineA,
+ QLabel *advLabel = new QLabel( qtr( "Advanced Widget toolbar:" ) );
+ QString lineA = getSettings()->value( "MainWindow/AdvToolbar",
+ ADV_TB_DEFAULT ).toString();
+ controllerA = new DroppingController( p_intf, lineA,
this );
mainTboxLayout->addWidget( advLabel, 3, 0, 1, 2 );
mainTboxLayout->addWidget( controllerA, 3, 2, 1, 1 );
- mainLayout->addWidget( mainToolbarBox, 1, 0, 1, -1 );
+ mainLayout->addWidget( mainToolbarBox, 0, 1, 1, -1 );
/* TimeToolBar */
- QGroupBox *timeToolbarBox = new QGroupBox( "Time Toolbar", this );
+ QGroupBox *timeToolbarBox = new QGroupBox( qtr( "Time Toolbar" ) , this );
QGridLayout *timeTboxLayout = new QGridLayout( timeToolbarBox );
- QString line = getSettings()->value( "timeWindow/InputControl",
- "5-1;33;6-1").toString();
- DroppingController *controller = new DroppingController( p_intf, line,
+ QString line = getSettings()->value( "MainWindow/InputToolbar",
+ INPT_TB_DEFAULT ).toString();
+ controller = new DroppingController( p_intf, line,
this );
timeTboxLayout->addWidget( controller, 0, 0, 1, -1 );
- mainLayout->addWidget( timeToolbarBox, 2, 0, 1, -1 );
+ mainLayout->addWidget( timeToolbarBox, 1, 1, 1, -1 );
/* FSCToolBar */
- QGroupBox *FSCToolbarBox = new QGroupBox( "Fullscreen Controller", this );
+ QGroupBox *FSCToolbarBox = new QGroupBox( qtr( "Fullscreen Controller" ),
+ this );
QGridLayout *FSCTboxLayout = new QGridLayout( FSCToolbarBox );
- QString lineFSC = getSettings()->value( "MainWindow/FSCline",
- "0-2;64;3;1;4;64;36;64;37;64;8;65;35-4;34" ).toString();
- DroppingController *controllerFSC = new DroppingController( p_intf,
+ QString lineFSC = getSettings()->value( "MainWindow/FSCtoolbar",
+ FSC_TB_DEFAULT ).toString();
+ controllerFSC = new DroppingController( p_intf,
lineFSC, this );
FSCTboxLayout->addWidget( controllerFSC, 0, 0, 1, -1 );
- mainLayout->addWidget( FSCToolbarBox, 3, 0, 1, -1 );
+ mainLayout->addWidget( FSCToolbarBox, 2, 1, 1, -1 );
+ /* Profile */
+ QGroupBox *profileBox = new QGroupBox( qtr( "Profile" ), this );
+ QGridLayout *profileBoxLayout = new QGridLayout( profileBox );
+ profileCombo = new QComboBox;
+ QLabel *profileLabel = new QLabel( qtr( "Select profile:" ), this );
+
+ QToolButton *newButton = new QToolButton;
+ newButton->setIcon( QIcon( ":/new" ) );
+ QToolButton *deleteButton = new QToolButton;
+ deleteButton->setIcon( QIcon( ":/toolbar/clear" ) );
+ deleteButton->setToolTip( qtr( "Delete the current profile" ) );
+
+ profileBoxLayout->addWidget( profileLabel, 0, 0 );
+ profileBoxLayout->addWidget( profileCombo, 0, 1 );
+ profileBoxLayout->addWidget( newButton, 0, 2 );
+ profileBoxLayout->addWidget( deleteButton, 0, 3 );
+
+ mainLayout->addWidget( profileBox, 3, 1, 1, -1 );
+
+ /* Fill combos */
+ int i_size = getSettings()->beginReadArray( "ToolbarProfiles" );
+ for( int i = 0; i < i_size; i++ )
+ {
+ getSettings()->setArrayIndex(i);
+ profileCombo->addItem( getSettings()->value( "ProfileName" ).toString(),
+ getSettings()->value( "Value" ).toString() );
+ }
+ getSettings()->endArray();
+
+ /* Load defaults ones if we have no combos */
+ /* We could decide that we load defaults on first launch of the dialog
+ or when the combo is back to 0. I choose the second solution, because some clueless
+ user might hit on delete a bit too much, but discussion is opened. -- jb */
+ if( i_size == 0 )
+ {
+ profileCombo->addItem( PROFILE_NAME_1, QString( VALUE_1 ) );
+ profileCombo->addItem( PROFILE_NAME_2, QString( VALUE_2 ) );
+ profileCombo->addItem( PROFILE_NAME_3, QString( VALUE_3 ) );
+ profileCombo->addItem( PROFILE_NAME_4, QString( VALUE_4 ) );
+ profileCombo->addItem( PROFILE_NAME_5, QString( VALUE_5 ) );
+ }
+ profileCombo->setCurrentIndex( -1 );
+
+ /* Buttons */
+ QDialogButtonBox *okCancel = new QDialogButtonBox;
+ QPushButton *okButton = new QPushButton( qtr( "Cl&ose" ), this );
+ okButton->setDefault( true );
+ QPushButton *cancelButton = new QPushButton( qtr( "&Cancel" ), this );
+ okCancel->addButton( okButton, QDialogButtonBox::AcceptRole );
+ okCancel->addButton( cancelButton, QDialogButtonBox::RejectRole );
+
+ BUTTONACT( deleteButton, deleteProfile() );
+ BUTTONACT( newButton, newProfile() );
+ CONNECT( profileCombo, currentIndexChanged( int ), this, changeProfile( int ) );
+ BUTTONACT( okButton, close() );
+ BUTTONACT( cancelButton, cancel() );
+ mainLayout->addWidget( okCancel, 5, 2 );
}
ToolbarEditDialog::~ToolbarEditDialog()
{
+ getSettings()->beginWriteArray( "ToolbarProfiles" );
+ for( int i = 0; i < profileCombo->count(); i++ )
+ {
+ getSettings()->setArrayIndex(i);
+ getSettings()->setValue( "ProfileName", profileCombo->itemText( i ) );
+ getSettings()->setValue( "Value", profileCombo->itemData( i ) );
+ }
+ getSettings()->endArray();
+}
+
+void ToolbarEditDialog::newProfile()
+{
+ bool ok;
+ QString name = QInputDialog::getText( this, qtr( "Profile Name" ),
+ qtr( "Please enter the new profile name." ), QLineEdit::Normal, 0, &ok );
+ if( !ok ) return;
+
+ QString temp = QString::number( positionCombo->currentIndex() );
+ temp += "|" + controller1->getValue();
+ temp += "|" + controller2->getValue();
+ temp += "|" + controllerA->getValue();
+ temp += "|" + controller->getValue();
+ temp += "|" + controllerFSC->getValue();
+
+ profileCombo->addItem( name, temp );
+ profileCombo->setCurrentIndex( profileCombo->count() - 1 );
+}
+
+void ToolbarEditDialog::deleteProfile()
+{
+ profileCombo->removeItem( profileCombo->currentIndex() );
+}
+
+void ToolbarEditDialog::changeProfile( int i )
+{
+ QStringList qs_list = profileCombo->itemData( i ).toString().split( "|" );
+ if( qs_list.count() < 6 )
+ return;
+
+ positionCombo->setCurrentIndex( positionCombo->findData( qs_list[0].toInt() ) );
+ controller1->resetLine( qs_list[1] );
+ controller2->resetLine( qs_list[2] );
+ controllerA->resetLine( qs_list[3] );
+ controller->resetLine( qs_list[4] );
+ controllerFSC->resetLine( qs_list[5] );
+}
+
+void ToolbarEditDialog::close()
+{
+ msg_Dbg( p_intf, "Close and save" );
+ getSettings()->setValue( "MainWindow/ToolbarPos",
+ positionCombo->itemData( positionCombo->currentIndex() ).toInt() );
+ getSettings()->setValue( "MainWindow/MainToolbar1", controller1->getValue() );
+ getSettings()->setValue( "MainWindow/MainToolbar2", controller2->getValue() );
+ getSettings()->setValue( "MainWindow/AdvToolbar", controllerA->getValue() );
+ getSettings()->setValue( "MainWindow/InputToolbar", controller->getValue() );
+ getSettings()->setValue( "MainWindow/FSCtoolbar", controllerFSC->getValue() );
+ getSettings()->sync();
+ accept();
+}
+
+void ToolbarEditDialog::cancel()
+{
+ reject();
}
+/************************************************
+ * Widget Listing:
+ * Creation of the list of drawed lovely buttons
+ ************************************************/
WidgetListing::WidgetListing( intf_thread_t *p_intf, QWidget *_parent )
: QListWidget( _parent )
{
setViewMode( QListView::IconMode );
setSpacing( 20 );
setDragEnabled( true );
- setMinimumHeight( 250 );
/* All the buttons do not need a special rendering */
for( int i = 0; i < BUTTON_MAX; i++ )
{
QListWidgetItem *widgetItem = new QListWidgetItem( this );
- widgetItem->setText( nameL[i] );
+ widgetItem->setText( qtr( nameL[i] ) );
widgetItem->setIcon( QIcon( iconL[i] ) );
widgetItem->setData( Qt::UserRole, QVariant( i ) );
addItem( widgetItem );
}
/* Spacers are yet again a different thing */
- QListWidgetItem *widgetItem = new QListWidgetItem( QIcon( ":/space" ),
+ QListWidgetItem *widgetItem = new QListWidgetItem( QIcon( ":/toolbar/space" ),
qtr( "Spacer" ), this );
widgetItem->setData( Qt::UserRole, WIDGET_SPACER );
addItem( widgetItem );
- widgetItem = new QListWidgetItem( QIcon( ":/space" ),
+ widgetItem = new QListWidgetItem( QIcon( ":/toolbar/space" ),
qtr( "Expanding Spacer" ), this );
widgetItem->setData( Qt::UserRole, WIDGET_SPACER_EXTEND );
addItem( widgetItem );
}
widgetItem->setText( qtr("Volume") );
break;
+ case VOLUME_SPECIAL:
+ {
+ QListWidgetItem *widgetItem = new QListWidgetItem( this );
+ widgetItem->setText( qtr("Small Volume") );
+ widgetItem->setIcon( QIcon( ":/toolbar/volume-medium" ) );
+ widgetItem->setData( Qt::UserRole, QVariant( i ) );
+ addItem( widgetItem );
+ }
+ continue;
case TIME_LABEL:
{
QLabel *timeLabel = new QLabel( "12:42/2:12:42", this );
case MENU_BUTTONS:
{
QWidget *discFrame = new QWidget( this );
+ //discFrame->setLineWidth( 1 );
QHBoxLayout *discLayout = new QHBoxLayout( discFrame );
discLayout->setSpacing( 0 ); discLayout->setMargin( 0 );
QToolButton *prevSectionButton = new QToolButton( discFrame );
- prevSectionButton->setIcon( QIcon( ":/dvd_prev" ) );
+ prevSectionButton->setIcon( QIcon( ":/toolbar/dvd_prev" ) );
discLayout->addWidget( prevSectionButton );
QToolButton *menuButton = new QToolButton( discFrame );
- menuButton->setIcon( QIcon( ":/dvd_menu" ) );
+ menuButton->setIcon( QIcon( ":/toolbar/dvd_menu" ) );
discLayout->addWidget( menuButton );
QToolButton *nextButton = new QToolButton( discFrame );
- nextButton->setIcon( QIcon( ":/dvd_next" ) );
+ nextButton->setIcon( QIcon( ":/toolbar/dvd_next" ) );
discLayout->addWidget( nextButton );
widget = discFrame;
telexLayout->setSpacing( 0 ); telexLayout->setMargin( 0 );
QToolButton *telexOn = new QToolButton( telexFrame );
- telexOn->setIcon( QIcon( ":/tv" ) );
+ telexOn->setIcon( QIcon( ":/toolbar/tv" ) );
telexLayout->addWidget( telexOn );
QToolButton *telexTransparent = new QToolButton;
- telexOn->setIcon( QIcon( ":/tvtelx-trans" ) );
+ telexOn->setIcon( QIcon( ":/toolbar/tvtelx" ) );
telexLayout->addWidget( telexTransparent );
QSpinBox *telexPage = new QSpinBox;
void WidgetListing::startDrag( Qt::DropActions /*supportedActions*/ )
{
- QListWidgetItem *item =currentItem();
+ QListWidgetItem *item = currentItem();
QByteArray itemData;
QDataStream dataStream( &itemData, QIODevice::WriteOnly );
int i_option = parent->getOptions();
dataStream << i_type << i_option;
+ /* Create a new dragging event */
+ QDrag *drag = new QDrag( this );
+
+ /* With correct mimedata */
QMimeData *mimeData = new QMimeData;
mimeData->setData( "vlc/button-bar", itemData );
-
- QDrag *drag = new QDrag( this );
drag->setMimeData( mimeData );
-// drag->setHotSpot(QPoint(pixmap.width()/2, pixmap.height()/2));
- drag->exec(Qt::CopyAction | Qt::MoveAction );
-}
+ /* And correct pixmap */
+ QPixmap aPixmap = item->icon().pixmap( QSize( 22, 22 ) );
+ drag->setPixmap( aPixmap );
+ drag->setHotSpot( QPoint( 20, 20 ) );
+ /* We want to keep a copy */
+ drag->exec( Qt::CopyAction | Qt::MoveAction );
+}
-DroppingController::DroppingController( intf_thread_t *_p_intf, QString line, QWidget *_parent )
+/*
+ * The special controller with drag'n drop abilities.
+ * We don't do this in the main controller, since we don't want the OverHead
+ * to propagate there too
+ */
+DroppingController::DroppingController( intf_thread_t *_p_intf,
+ const QString& line,
+ QWidget *_parent )
: AbstractController( _p_intf, _parent )
{
rubberband = NULL;
+ b_draging = false;
setAcceptDrops( true );
controlLayout = new QHBoxLayout( this );
- controlLayout->setSpacing( 0 );
+ controlLayout->setSpacing( 5 );
controlLayout->setMargin( 0 );
setFrameShape( QFrame::StyledPanel );
setFrameShadow( QFrame::Raised );
-
parseAndCreate( line, controlLayout );
+}
+void DroppingController::resetLine( const QString& line )
+{
+ hide();
+ QLayoutItem *child;
+ while( (child = controlLayout->takeAt( 0 ) ) != 0 )
+ {
+ child->widget()->hide();
+ delete child;
+ }
+
+ parseAndCreate( line, controlLayout );
+ show();
}
/* Overloading the AbstractController one, because we don't manage the
- Spacing in the same ways */
+ Spacing items in the same ways */
void DroppingController::createAndAddWidget( QBoxLayout *controlLayout,
int i_index,
buttonType_e i_type,
int i_option )
{
+ doubleInt *value = new doubleInt;
+ value->i_type = i_type;
+ value->i_option = i_option;
+
/* Special case for SPACERS, who aren't QWidgets */
if( i_type == WIDGET_SPACER || i_type == WIDGET_SPACER_EXTEND )
{
- QLabel *label = new QLabel;
- label->setPixmap( QPixmap( ":/space" ) );
+ QLabel *label = new QLabel( this );
+ label->setPixmap( QPixmap( ":/toolbar/space" ) );
if( i_type == WIDGET_SPACER_EXTEND )
{
- label->setScaledContents( true );
label->setSizePolicy( QSizePolicy::MinimumExpanding,
QSizePolicy::Preferred );
+
+ /* Create a box around it */
+ label->setFrameStyle( QFrame::Panel | QFrame::Sunken );
+ label->setLineWidth ( 1 );
+ label->setAlignment( Qt::AlignCenter );
}
else
label->setSizePolicy( QSizePolicy::Fixed,
QSizePolicy::Preferred );
+ /* Install event Filter for drag'n drop */
+ label->installEventFilter( this );
controlLayout->insertWidget( i_index, label );
}
+
+ /* Normal Widgets */
else
{
QWidget *widg = createWidget( i_type, i_option );
if( !widg ) return;
+ /* Install the Event Filter in order to catch the drag */
+ widg->setParent( this );
+ widg->installEventFilter( this );
+
+ /* We are in a complex widget, we need to stop events on children too */
+ if( i_type >= VOLUME && i_type < SPECIAL_MAX )
+ {
+ QList<QObject *>children = widg->children();
+
+ QObject *child;
+ foreach( child, children )
+ {
+ QWidget *childWidg;
+ if( ( childWidg = qobject_cast<QWidget *>( child ) ) )
+ {
+ child->installEventFilter( this );
+ childWidg->setEnabled( true );
+ }
+ }
+
+ /* Decorating the frames when possible */
+ QFrame *frame;
+ if( i_type >= MENU_BUTTONS /* Don't bother to check for volume */
+ && ( frame = qobject_cast<QFrame *>( widg ) ) != NULL )
+ {
+ frame->setFrameStyle( QFrame::Panel | QFrame::Raised );
+ frame->setLineWidth ( 1 );
+ }
+ }
+
/* Some Widgets are deactivated at creation */
widg->setEnabled( true );
widg->show();
controlLayout->insertWidget( i_index, widg );
}
+
+ /* QList and QBoxLayout don't act the same with insert() */
+ if( i_index < 0 ) i_index = controlLayout->count() - 1;
+
+ widgetList.insert( i_index, value );
+}
+
+DroppingController::~DroppingController()
+{
+ qDeleteAll( widgetList );
+ widgetList.clear();
+}
+
+QString DroppingController::getValue()
+{
+ QString qs = "";
+
+ for( int i = 0; i < controlLayout->count(); i++ )
+ {
+ doubleInt *dI = widgetList.at( i );
+ assert( dI );
+
+ qs.append( QString::number( dI->i_type ) );
+ if( dI->i_option ) qs.append( "-" + QString::number( dI->i_option ) );
+ qs.append( ';' );
+ }
+ return qs;
}
void DroppingController::dragEnterEvent( QDragEnterEvent * event )
rubberband->show();
}
-inline int DroppingController::getParentPosInLayout( QPoint point)
+inline int DroppingController::getParentPosInLayout( QPoint point )
{
point.ry() = height() / 2 ;
QPoint origin = mapToGlobal ( point );
QWidget *tempWidg = QApplication::widgetAt( origin );
+ if( tempWidg == NULL )
+ return -1;
- int i = -1;
- if( tempWidg != NULL)
+ int i = controlLayout->indexOf( tempWidg );
+ if( i == -1 )
{
- i = controlLayout->indexOf( tempWidg );
- if( i == -1 )
- {
- i = controlLayout->indexOf( tempWidg->parentWidget() );
- tempWidg = tempWidg->parentWidget();
- }
+ i = controlLayout->indexOf( tempWidg->parentWidget() );
+ tempWidg = tempWidg->parentWidget();
}
/* Return the nearest position */
{
int i = getParentPosInLayout( event->pos() );
+ /* Workaround: do not let the item move to its current
+ position + 1 as it breaks the widgetList */
+ if ( i - 1 == i_dragIndex )
+ --i;
+
QByteArray data = event->mimeData()->data( "vlc/button-bar" );
QDataStream dataStream(&data, QIODevice::ReadOnly);
void DroppingController::dragLeaveEvent ( QDragLeaveEvent * event )
{
if( rubberband ) rubberband->hide();
+ event->accept();
}
/**
* Overloading doAction to block any action
**/
-void DroppingController::doAction( int i ){}
+void DroppingController::doAction( int i )
+{
+ VLC_UNUSED( i );
+}
+
+bool DroppingController::eventFilter( QObject *obj, QEvent *event )
+{
+ switch( event->type() )
+ {
+ case QEvent::MouseButtonPress:
+ b_draging = true;
+ return true;
+ case QEvent::MouseButtonRelease:
+ b_draging = false;
+ return true;
+ case QEvent::MouseMove:
+ {
+ if( !b_draging ) return true;
+ QWidget *widg = static_cast<QWidget*>(obj);
+
+ QByteArray itemData;
+ QDataStream dataStream( &itemData, QIODevice::WriteOnly );
+
+ int i = -1;
+ i = controlLayout->indexOf( widg );
+ if( i == -1 )
+ {
+ i = controlLayout->indexOf( widg->parentWidget() );
+ widg = widg->parentWidget();
+ /* NOTE: be extra-careful Now with widg access */
+ }
+
+ if( i == -1 ) return true;
+ i_dragIndex = i;
+
+ doubleInt *dI = widgetList.at( i );
+
+ int i_type = dI->i_type;
+ int i_option = dI->i_option;
+ dataStream << i_type << i_option;
+
+ /* With correct mimedata */
+ QMimeData *mimeData = new QMimeData;
+ mimeData->setData( "vlc/button-bar", itemData );
+
+ QDrag *drag = new QDrag( widg );
+ drag->setMimeData( mimeData );
+
+ /* Remove before the drag to not mess DropEvent,
+ that will createAndAddWidget */
+ widgetList.removeAt( i );
+
+ /* Start the effective drag */
+ drag->exec(Qt::CopyAction | Qt::MoveAction, Qt::MoveAction);
+ widg->hide();
+ controlLayout->removeWidget( widg );
+ b_draging = false;
+ }
+ return true;
+
+ case QEvent::MouseButtonDblClick:
+ case QEvent::EnabledChange:
+ case QEvent::Hide:
+ case QEvent::HideToParent:
+ case QEvent::Move:
+ case QEvent::ZOrderChange:
+ return true;
+ default:
+ return false;
+ }
+}