X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;ds=sidebyside;f=modules%2Fgui%2Fqt4%2Fcomponents%2Fpreferences_widgets.hpp;h=d8b108a57ebe7d82f253b05154853be2cbf45772;hb=e512b8bdf4cf19ec5b7e0fe0831fbf3113e89ac6;hp=7881261f23e37b9241e6ff269ad2440f19aad4b3;hpb=3ede77e483e385fadd70b36906f6cb58199a7cd6;p=vlc diff --git a/modules/gui/qt4/components/preferences_widgets.hpp b/modules/gui/qt4/components/preferences_widgets.hpp index 7881261f23..d8b108a57e 100644 --- a/modules/gui/qt4/components/preferences_widgets.hpp +++ b/modules/gui/qt4/components/preferences_widgets.hpp @@ -23,27 +23,35 @@ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA. *****************************************************************************/ -#ifndef _INFOPANELS_H_ -#define _INFOPANELS_H_ +#ifndef _PREFERENCESWIDGETS_H_ +#define _PREFERENCESWIDGETS_H_ + #include + +#include "qt4.hpp" +#include + #include -#include + +#include +#include #include +#include #include +#include #include -#include -#include +#include #include #include -#include -#include -#include -#include -#include "qt4.hpp" -#include +class QFile; +class QTreeWidget; +class QTreeWidgetItem; +class QGroupBox; class QGridLayout; +class QDialogButtonBox; +class QVBoxLayout; class ConfigControl : public QObject { @@ -79,8 +87,11 @@ protected: QString _name; QWidget *widget; bool _advanced; +#if 0 +/* You shouldn't use that now..*/ signals: void Updated(); +#endif }; /******************************************************* @@ -96,7 +107,7 @@ public: ConfigControl(a,b) {}; virtual ~VIntConfigControl() {}; virtual int getValue() = 0; - virtual int getType() { return 1; } + virtual int getType() { return CONFIG_ITEM_INTEGER; } }; class IntegerConfigControl : public VIntConfigControl @@ -111,8 +122,8 @@ public: QLabel*, QSlider* ); virtual ~IntegerConfigControl() {}; virtual int getValue(); - virtual void show() { spin->show(); label->show(); } - virtual void hide() { spin->hide(); label->hide(); } + virtual void show() { spin->show(); if( label ) label->show(); } + virtual void hide() { spin->hide(); if( label ) label->hide(); } protected: QSpinBox *spin; @@ -155,8 +166,8 @@ public: QComboBox*, bool ); virtual ~IntegerListConfigControl() {}; virtual int getValue(); - virtual void hide() { combo->hide(); label->hide(); } - virtual void show() { combo->show(); label->show(); } + virtual void hide() { combo->hide(); if( label ) label->hide(); } + virtual void show() { combo->show(); if( label ) label->show(); } private: void finish( bool ); QLabel *label; @@ -174,6 +185,7 @@ public: virtual int getValue(); virtual void show() { checkbox->show(); } virtual void hide() { checkbox->hide(); } + virtual int getType() { return CONFIG_ITEM_BOOL; } private: QCheckBox *checkbox; void finish(); @@ -192,7 +204,7 @@ public: ConfigControl(a,b) {}; virtual ~VFloatConfigControl() {}; virtual float getValue() = 0; - virtual int getType() { return 2; } + virtual int getType() { return CONFIG_ITEM_FLOAT; } }; class FloatConfigControl : public VFloatConfigControl @@ -205,8 +217,8 @@ public: QLabel*, QDoubleSpinBox* ); virtual ~FloatConfigControl() {}; virtual float getValue(); - virtual void show() { spin->show(); label->show(); } - virtual void hide() { spin->hide(); label->hide(); } + virtual void show() { spin->show(); if( label ) label->show(); } + virtual void hide() { spin->hide(); if( label ) label->hide(); } protected: QDoubleSpinBox *spin; @@ -241,7 +253,7 @@ public: ConfigControl(a,b) {}; virtual ~VStringConfigControl() {}; virtual QString getValue() = 0; - virtual int getType() { return 3; } + virtual int getType() { return CONFIG_ITEM_STRING; } }; class StringConfigControl : public VStringConfigControl @@ -254,8 +266,8 @@ public: QLineEdit*, bool pwd ); virtual ~StringConfigControl() {}; virtual QString getValue() { return text->text(); }; - virtual void show() { text->show(); label->show(); } - virtual void hide() { text->hide(); label->hide(); } + virtual void show() { text->show(); if( label ) label->show(); } + virtual void hide() { text->hide(); if( label ) label->hide(); } private: void finish(); QLineEdit *text; @@ -272,8 +284,8 @@ public: QLineEdit *, QPushButton *, bool pwd ); virtual ~FileConfigControl() {}; virtual QString getValue() { return text->text(); }; - virtual void show() { text->show(); label->show(); browse->show(); } - virtual void hide() { text->hide(); label->hide(); browse->hide(); } + virtual void show() { text->show(); if( label ) label->show(); browse->show(); } + virtual void hide() { text->hide(); if( label ) label->hide(); browse->hide(); } public slots: virtual void updateField(); protected: @@ -318,14 +330,19 @@ public: QComboBox*, bool ); virtual ~ModuleConfigControl() {}; virtual QString getValue(); - virtual void hide() { combo->hide(); label->hide(); } - virtual void show() { combo->show(); label->show(); } + virtual void hide() { combo->hide(); if( label ) label->hide(); } + virtual void show() { combo->show(); if( label ) label->show(); } private: void finish( bool ); QLabel *label; QComboBox *combo; }; +struct checkBoxListItem { + QCheckBox *checkBox; + char *psz_module; +}; + class ModuleListConfigControl : public VStringConfigControl { Q_OBJECT; @@ -342,13 +359,14 @@ public slots: void onUpdate( int value ); private: void finish( bool ); - QVector modules; + QVector modules; QGroupBox *groupBox; QLineEdit *text; }; class StringListConfigControl : public VStringConfigControl { + Q_OBJECT; public: StringListConfigControl( vlc_object_t *, module_config_t *, QWidget *, bool, QGridLayout*, int& ); @@ -356,13 +374,20 @@ public: QComboBox*, bool ); virtual ~StringListConfigControl() {}; virtual QString getValue(); - virtual void hide() { combo->hide(); label->hide(); } - virtual void show() { combo->show(); label->show(); } + virtual void hide() { combo->hide(); if( label ) label->hide(); } + virtual void show() { combo->show(); if( label ) label->show(); } + QComboBox *combo; private: void finish( bool ); QLabel *label; - QComboBox *combo; +private slots: + void actionRequested( int ); + }; + +void setfillVLCConfigCombo(const char *configname, intf_thread_t *p_intf, + QComboBox *combo, QWidget *parent = 0 ); + #if 0 struct ModuleCheckBox { QCheckBox *checkbox; @@ -387,20 +412,17 @@ private slot: /********************************************************************** * Key selector widget **********************************************************************/ -class KeyInputDialog : public QDialog +class KeyShortcutEdit: public QLineEdit { + Q_OBJECT public: - KeyInputDialog( QList &, const char * ); - int keyValue; - bool conflicts; + void setValue( int _value ){ value = _value; } + int getValue(){ return value; } private: - void checkForConflicts( int i_vlckey ); - void keyPressEvent( QKeyEvent *); - void wheelEvent( QWheelEvent *); - QLabel *selected; - QLabel *warning; - const char * keyToChange; - QList values; + int value; + virtual void mousePressEvent( QMouseEvent *event ); +signals: + void pressed(); }; class KeySelectorControl : public ConfigControl @@ -409,18 +431,36 @@ class KeySelectorControl : public ConfigControl public: KeySelectorControl( vlc_object_t *, module_config_t *, QWidget *, QGridLayout*, int& ); - virtual int getType() { return 4; } + virtual int getType() { return CONFIG_ITEM_KEY; } virtual ~KeySelectorControl() {}; - virtual void hide() { table->hide(); label->hide(); } - virtual void show() { table->show(); label->show(); } + virtual void hide() { table->hide(); if( label ) label->hide(); } + virtual void show() { table->show(); if( label ) label->show(); } void doApply(); private: void finish(); QLabel *label; QTreeWidget *table; + KeyShortcutEdit *shortcutValue; QList values; private slots: - void selectKey( QTreeWidgetItem *); + void setTheKey(); + void selectKey( QTreeWidgetItem * = NULL ); + void select1Key( QTreeWidgetItem *); }; +class KeyInputDialog : public QDialog +{ +public: + KeyInputDialog( QTreeWidget *, QString, QWidget * ); + int keyValue; + bool conflicts; +private: + QTreeWidget *table; + void checkForConflicts( int i_vlckey ); + void keyPressEvent( QKeyEvent *); + void wheelEvent( QWheelEvent *); + QLabel *selected; + QVBoxLayout *vLayout; + QDialogButtonBox *buttonBox; +}; #endif