[vlc-devel] [PATCH 4/4] Adds the user interface to the compressor module

Ronald Wright logiconcepts819 at gmail.com
Thu Jul 1 10:33:02 CEST 2010


---
 modules/gui/qt4/components/extended_panels.cpp |  174 ++++++++++++++++++++++++
 modules/gui/qt4/components/extended_panels.hpp |   27 ++++
 modules/gui/qt4/dialogs/extended.cpp           |    3 +
 3 files changed, 204 insertions(+), 0 deletions(-)

diff --git a/modules/gui/qt4/components/extended_panels.cpp b/modules/gui/qt4/components/extended_panels.cpp
index 874277a..bc3d661 100644
--- a/modules/gui/qt4/components/extended_panels.cpp
+++ b/modules/gui/qt4/components/extended_panels.cpp
@@ -1117,6 +1117,180 @@ void Equalizer::addCallbacks( aout_instance_t *p_aout )
  **********************************************************************/
 
 /**********************************************************************
+ * Dynamic range compressor
+ **********************************************************************/
+static const char *psz_comp_control_names[] =
+{
+    "compressor-lo-pregain", "compressor-mid-pregain", "compressor-hi-pregain",
+    "compressor-rms-peak", "compressor-attack", "compressor-release",
+    "compressor-threshold", "compressor-ratio", "compressor-knee",
+    "compressor-makeup-gain"
+};
+
+static const char *psz_comp_control_descs[] =
+{
+    "Lo\npre-gain", "Mid\npre-gain", "Hi\npre-gain", "RMS/peak", "Attack",
+    "Release", "Threshold", "Ratio", "Knee\nradius", "Makeup\ngain"
+};
+
+static const char *psz_comp_control_units[] =
+{
+    " dB", " dB", " dB", "", " ms", " ms", " dB", ":1", " dB", " dB"
+};
+
+static const float f_comp_min_max_val_res_data[] =
+{
+    // min     max   value  resolution
+    //----  ------  ------  ----------
+    -70.0f,   6.0f,   0.00f, 0.010f,  // Lo pre-gain
+    -70.0f,   6.0f,   0.00f, 0.010f,  // Mid pre-gain
+    -70.0f,   6.0f,   0.00f, 0.010f,  // Hi pre-gain
+      0.0f,   1.0f,   0.00f, 0.001f,  // RMS/peak
+      1.5f, 400.0f,  25.00f, 0.100f,  // Attack
+      2.0f, 800.0f, 100.00f, 0.100f,  // Release
+    -30.0f,   0.0f, -11.00f, 0.010f,  // Threshold
+      1.0f,  20.0f,   8.00f, 0.010f,  // Ratio
+      1.0f,  10.0f,   2.50f, 0.010f,  // Knee radius
+      0.0f,  24.0f,   7.00f, 0.010f   // Makeup gain
+};
+
+Compressor::Compressor( intf_thread_t *_p_intf, QWidget *_parent ) :
+    QWidget( _parent ) , p_intf( _p_intf )
+{
+    QFont smallFont = QApplication::font( static_cast<QWidget*>( 0 ) );
+    smallFont.setPointSize( smallFont.pointSize() - 3 );
+
+    QGridLayout *layout = new QGridLayout( this );
+    layout->setMargin( 0 );
+
+    enableCheck = new QCheckBox( qtr( "Enable dynamic range compressor" ) );
+    layout->addWidget( enableCheck, 0, 0, 1, NUM_CP_CTRL );
+
+    for( int i = 0 ; i < NUM_CP_CTRL ; i++ )
+    {
+        compCtrl[i] = new QSlider( Qt::Vertical );
+
+        const int i_min = (int)( f_comp_min_max_val_res_data[4 * i + 0]
+                               / f_comp_min_max_val_res_data[4 * i + 3] );
+        const int i_max = (int)( f_comp_min_max_val_res_data[4 * i + 1]
+                               / f_comp_min_max_val_res_data[4 * i + 3] );
+        const int i_val = (int)( f_comp_min_max_val_res_data[4 * i + 2]
+                               / f_comp_min_max_val_res_data[4 * i + 3] );
+
+        compCtrl[i]->setMinimum( i_min );
+        compCtrl[i]->setMaximum( i_max );
+        compCtrl[i]->setValue(   i_val );
+        oldControlVars[i] = f_comp_min_max_val_res_data[4 * i + 2];
+        CONNECT( compCtrl[i], valueChanged( int ), this, setInitValues() );
+        ctrl_texts[i] = new QLabel( qtr( psz_comp_control_descs[i] )
+                                  + qtr( "\n" ) );
+        ctrl_texts[i]->setFont( smallFont );
+        ctrl_texts[i]->setAlignment( Qt::AlignHCenter );
+        ctrl_readout[i] = new QLabel( qtr( "" ) );
+        ctrl_readout[i]->setFont( smallFont );
+        ctrl_readout[i]->setAlignment( Qt::AlignHCenter );
+        layout->addWidget( compCtrl[i], 1, i, Qt::AlignHCenter );
+        layout->addWidget( ctrl_readout[i], 2, i, Qt::AlignHCenter );
+        layout->addWidget( ctrl_texts[i], 3, i, Qt::AlignHCenter );
+    }
+
+    BUTTONACT( enableCheck, enable() );
+
+    /* Write down initial values */
+    aout_instance_t *p_aout = THEMIM->getAout();
+    char *psz_af;
+
+    if( p_aout )
+    {
+        psz_af = var_GetNonEmptyString( p_aout, "audio-filter" );
+        for( int i = 0; i < NUM_CP_CTRL; i++ )
+        {
+            controlVars[i] = var_GetFloat( p_aout,
+                                           psz_comp_control_names[i] );
+        }
+        vlc_object_release( p_aout );
+    }
+    else
+    {
+        psz_af = config_GetPsz( p_intf, "audio-filter" );
+        for( int i = 0; i < NUM_CP_CTRL; i++ )
+        {
+            controlVars[i] = config_GetFloat( p_intf,
+                                              psz_comp_control_names[i] );
+        }
+    }
+    if( psz_af && strstr( psz_af, "compressor" ) != NULL )
+    {
+        enableCheck->setChecked( true );
+    }
+    free( psz_af );
+    enable( enableCheck->isChecked() );
+    updateSliders( controlVars );
+    setValues( controlVars );
+}
+
+void Compressor::enable()
+{
+    bool en = enableCheck->isChecked();
+    aout_EnableFilter( THEPL, "compressor", en );
+    enable( en );
+}
+
+void Compressor::enable( bool en )
+{
+    for( int i = 0 ; i < NUM_CP_CTRL ; i++ )
+    {
+        compCtrl[i]->setEnabled( en );
+        ctrl_texts[i]->setEnabled( en );
+        ctrl_readout[i]->setEnabled( en );
+    }
+}
+
+void Compressor::updateSliders( float * controlVars )
+{
+    for( int i = 0 ; i < NUM_CP_CTRL ; i++ )
+    {
+        if( oldControlVars[i] != controlVars[i] )
+        {
+            const int i_val = (int)( controlVars[i]
+                                   / f_comp_min_max_val_res_data[4 * i + 3] );
+            compCtrl[i]->setValue( i_val );
+        }
+    }
+}
+
+void Compressor::setInitValues()
+{
+    setValues( controlVars );
+}
+
+void Compressor::setValues( float * controlVars )
+{
+    aout_instance_t *p_aout = THEMIM->getAout();
+
+    for( int i = 0 ; i < NUM_CP_CTRL ; i++ )
+    {
+        float f = (float)( compCtrl[i]->value() )
+                * ( f_comp_min_max_val_res_data[4 * i + 3] );
+        ctrl_readout[i]->setText( QString::number( f, 'f', 1 )
+                                + qtr( psz_comp_control_units[i] ) );
+        if( oldControlVars[i] != f )
+        {
+            if( p_aout )
+            {
+                var_SetFloat( p_aout, psz_comp_control_names[i], f );
+            }
+            config_PutFloat( p_intf, psz_comp_control_names[i], f );
+            oldControlVars[i] = f;
+        }
+    }
+    if( p_aout )
+    {
+        vlc_object_release( p_aout );
+    }
+}
+
+/**********************************************************************
  * Spatializer
  **********************************************************************/
 static const char *psz_control_names[] =
diff --git a/modules/gui/qt4/components/extended_panels.hpp b/modules/gui/qt4/components/extended_panels.hpp
index a4bbb4f..bd17ed7 100644
--- a/modules/gui/qt4/components/extended_panels.hpp
+++ b/modules/gui/qt4/components/extended_panels.hpp
@@ -38,6 +38,7 @@
 #include <QTabWidget>
 
 #define BANDS 10
+#define NUM_CP_CTRL 10
 #define NUM_SP_CTRL 5
 
 class QSignalMapper;
@@ -115,6 +116,32 @@ private slots:
     void setCorePreset(int);
 };
 
+class Compressor: public QWidget
+{
+    Q_OBJECT
+public:
+    Compressor( intf_thread_t *, QWidget * );
+
+private:
+    QSlider *compCtrl[NUM_CP_CTRL];
+    QLabel *ctrl_texts[NUM_CP_CTRL];
+    QLabel *ctrl_readout[NUM_CP_CTRL];
+    float controlVars[NUM_CP_CTRL];
+    float oldControlVars[NUM_CP_CTRL];
+
+    QCheckBox *enableCheck;
+
+    void delCallbacks( aout_instance_t * );
+    void addCallbacks( aout_instance_t * );
+    intf_thread_t *p_intf;
+private slots:
+    void enable(bool);
+    void enable();
+    void updateSliders(float *);
+    void setValues(float *);
+    void setInitValues();
+};
+
 class Spatializer: public QWidget
 {
     Q_OBJECT
diff --git a/modules/gui/qt4/dialogs/extended.cpp b/modules/gui/qt4/dialogs/extended.cpp
index 8fa1653..53bc667 100644
--- a/modules/gui/qt4/dialogs/extended.cpp
+++ b/modules/gui/qt4/dialogs/extended.cpp
@@ -54,6 +54,9 @@ ExtendedDialog::ExtendedDialog( intf_thread_t *_p_intf ): QVLCFrame( _p_intf )
     equal = new Equalizer( p_intf, audioTab );
     audioTab->addTab( equal, qtr( "Graphic Equalizer" ) );
 
+    Compressor *compres = new Compressor( p_intf, audioTab );
+    audioTab->addTab( compres, qtr( "Compressor" ) );
+
     Spatializer *spatial = new Spatializer( p_intf, audioTab );
     audioTab->addTab( spatial, qtr( "Spatializer" ) );
     audioLayout->addWidget( audioTab );
-- 
1.7.0.4




More information about the vlc-devel mailing list