[vlc-devel] [RESEND] [PATCH] Qt: Enable Stop Time in media convert dialog

Rajeesh K V rajeeshknambiar at gmail.com
Mon Nov 7 16:06:16 CET 2016


Hi Filip,

On Thu, Oct 27, 2016 at 3:34 PM, Filip Roséen wrote:
> This could be written a lot simpler by updating the format-string so 
> that you are generating the string-representation of a floating-point 
> with the value of QTime::msecsTo divided by 1000.
> 
> Remember that you can specify the number of decimals, as well as 
> padding, directly in the format-string; there’s no explicit need to 
> do this by hand.
> 
> I reckon you are basing your implementation on what is done for 
> :start-time, so if you fix your implementation - you could refactor 
> :start-time at the same time.
> 
Thanks for the review comments. Please find the revised patch:

Author: Rajeesh K V <rajeeshknambiar at gmail.com>
Date:   Tue Aug 16 10:38:46 2016 +0530

    Qt: Enable Stop Time in media convert dialog

    Changes in V2: Revise QTime formatting as suggested by Filip Roséen

    Convert/Save dialog has had option to specify 'start time' but
    no option for setting 'stop time' in the interface. The backend
    'stop-time' option was already present. This patch simply adds
    and enables the edit widget for end time in Qt interface.

diff --git a/modules/gui/qt/dialogs/open.cpp 
b/modules/gui/qt/dialogs/open.cpp
index 224cfa5..86f5d00 100644
--- a/modules/gui/qt/dialogs/open.cpp
+++ b/modules/gui/qt/dialogs/open.cpp
@@ -156,6 +156,7 @@ OpenDialog::OpenDialog( QWidget *parent,
     CONNECT( ui.slaveText, textChanged( const QString& ), this, 
updateMRL() );
     CONNECT( ui.cacheSpinBox, valueChanged( int ), this, updateMRL() );
     CONNECT( ui.startTimeTimeEdit, timeChanged ( const QTime& ), this, 
updateMRL() );
+    CONNECT( ui.stopTimeTimeEdit, timeChanged ( const QTime& ), this, 
updateMRL() );
     BUTTONACT( ui.advancedCheckBox, toggleAdvancedPanel() );
     BUTTONACT( ui.slaveBrowseButton, browseInputSlave() );

@@ -179,6 +180,7 @@ OpenDialog::OpenDialog( QWidget *parent,

     /* enforce section due to .ui bug */
     ui.startTimeTimeEdit->setCurrentSection( 
QDateTimeEdit::SecondSection );
+    ui.stopTimeTimeEdit->setCurrentSection( 
QDateTimeEdit::SecondSection );

     setMinimumSize( sizeHint() );
     setMaximumWidth( 900 );
@@ -436,12 +438,12 @@ void OpenDialog::updateMRL() {
     mrl += QString( " :%1=%2" ).arg( storedMethod ).
                                 arg( ui.cacheSpinBox->value() );
     if( ui.startTimeTimeEdit->time() != 
ui.startTimeTimeEdit->minimumTime() ) {
-        mrl += QString( " :start-time=%1.%2" )
-                .arg( QString::number(
-                    ui.startTimeTimeEdit->minimumTime().secsTo(
-                        ui.startTimeTimeEdit->time()
-                ) ) )
-               .arg( ui.startTimeTimeEdit->time().msec(), 3, 10, 
QChar('0') );
+        mrl += " :start-time=" + 
QString::number(static_cast<double>(ui.startTimeTimeEdit->
+                                
minimumTime().msecsTo(ui.startTimeTimeEdit->time() ) )/1000.0,'f',3);
+    }
+    if( ui.stopTimeTimeEdit->time() > ui.startTimeTimeEdit->time() ) {
+        mrl += " :stop-time=" + 
QString::number(static_cast<double>(ui.stopTimeTimeEdit->
+                                
minimumTime().msecsTo(ui.stopTimeTimeEdit->time() ) )/1000.0,'f',3);
     }
     ui.advancedLineInput->setText( mrl );
     ui.mrlLine->setText( itemsMRL.join( " " ) );
diff --git a/modules/gui/qt/ui/open.ui b/modules/gui/qt/ui/open.ui
index ea510db..05d8193 100644
--- a/modules/gui/qt/ui/open.ui
+++ b/modules/gui/qt/ui/open.ui
@@ -169,6 +169,19 @@
         </property>
        </widget>
       </item>
+      <item row="1" column="3">
+       <widget class="QLabel" name="label_3">
+        <property name="text">
+         <string>Stop Time</string>
+        </property>
+        <property name="alignment">
+         <set>Qt::AlignRight|Qt::AlignTrailing|Qt::AlignVCenter</set>
+        </property>
+        <property name="buddy">
+         <cstring>stopTimeTimeEdit</cstring>
+        </property>
+       </widget>
+      </item>
       <item row="8" column="0">
        <widget class="QLabel" name="label">
         <property name="text">
@@ -241,6 +254,25 @@
         </property>
        </widget>
       </item>
+      <item row="1" column="4" colspan="2">
+       <widget class="QTimeEdit" name="stopTimeTimeEdit">
+        <property name="toolTip">
+         <string>Change the stop time for the media</string>
+        </property>
+        <property name="alignment">
+         <set>Qt::AlignRight|Qt::AlignTrailing|Qt::AlignVCenter</set>
+        </property>
+        <property name="currentSection">
+         <enum>QDateTimeEdit::HourSection</enum>
+        </property>
+        <property name="displayFormat">
+         <string>HH'H':mm'm':ss's'.zzz</string>
+        </property>
+        <property name="timeSpec">
+         <enum>Qt::LocalTime</enum>
+        </property>
+       </widget>
+      </item>
       <item row="4" column="0" colspan="6">
        <widget class="QCheckBox" name="slaveCheckbox">
         <property name="text">
@@ -271,6 +303,7 @@
   <tabstop>advancedCheckBox</tabstop>
   <tabstop>cacheSpinBox</tabstop>
   <tabstop>startTimeTimeEdit</tabstop>
+  <tabstop>stopTimeTimeEdit</tabstop>
   <tabstop>slaveCheckbox</tabstop>
   <tabstop>slaveText</tabstop>
   <tabstop>slaveBrowseButton</tabstop>





More information about the vlc-devel mailing list