Differenze tra le versioni di "Estrarre tutte le tracce di un CD audio convertendole in un unico file WAV con la funzione 'gst parse launch()' di GStreamer"

Da Gambas-it.org - Wikipedia.
(Creata pagina con "La funzione esterna ''gst_parse_launch()'' della libreria ''GStreamer'' consente di costruire e gestire in modo semplice una pipeline ''GStreamer''. La riga della pipeline ges...")
 
Riga 24: Riga 24:
 
  ' ''Sets the state of the element.''</font>
 
  ' ''Sets the state of the element.''</font>
 
  Private Extern gst_element_set_state(gstelement As Pointer, state As Integer) As Integer
 
  Private Extern gst_element_set_state(gstelement As Pointer, state As Integer) As Integer
 +
 +
<FONT Color=gray>' ''gboolean gst_element_query_duration(GstElement *element, GstFormat format, gint64 *duration)''
 +
' ''Queries an element for the total stream duration in nanoseconds.''</font>
 +
Private Extern gst_element_query_duration(gselement As Pointer, formatI As Integer, duration As Pointer) As Boolean
 
    
 
    
 
  <FONT Color=gray>' ''gboolean gst_element_query_position (GstElement *element, GstFormat format, gint64 *cur)''
 
  <FONT Color=gray>' ''gboolean gst_element_query_position (GstElement *element, GstFormat format, gint64 *cur)''
Riga 36: Riga 40:
 
  '''Public''' Sub Main()
 
  '''Public''' Sub Main()
 
    
 
    
   Dim tempus As Long
+
   Dim pos, dur As Long
 +
  Dim po, du As Date
 
        
 
        
 
   gst_init(0, 0)
 
   gst_init(0, 0)
Riga 46: Riga 51:
 
    
 
    
 
   While True
 
   While True
     gst_element_query_position(audio, GST_FORMAT_TIME, VarPtr(tempus))
+
     gst_element_query_position(audio, GST_FORMAT_TIME, VarPtr(pos))
     Write #File.Out, "\rTempo: " & Date(0, 0, 0, 0, 0, 0, tempus / 1000000)
+
     gst_element_query_duration(audio, GST_FORMAT_TIME, VarPtr(dur))
     Wait 0.01
+
    po = Date(0, 0, 0, 0, 0, 0, pos / 1000000)
 +
    du = Date(0, 0, 0, 0, 0, 0, dur / 1000000)
 +
     If (pos > 0) And (CStr(po) >= CStr(du)) Then Break
 +
    Write #File.Out, "\rDurata: " & du & "      " & "Tempo trascorso: " & po
 
   Wend
 
   Wend
 +
 
 +
  Termina()
 
        
 
        
 
  '''End'''
 
  '''End'''
Riga 56: Riga 66:
 
  '''Public''' Sub Application_Read()
 
  '''Public''' Sub Application_Read()
 
   
 
   
Dim s As String
+
  Dim s As String
 
   
 
   
  Input #File.In, s
+
  Input #File.In, s
 
    
 
    
  <FONT Color=gray>' ''Termina l'applicazione:''</font>
+
  <FONT Color=gray>' ''Se viene inviato dalla console il carattere "t", termina l'applicazione:''</font>
  If "t" Then
+
  If "t" Then Termina()
    gst_element_set_state(audio, GST_STATE_NULL)
+
 
    gst_object_unref(audio)
+
'''End'''
    Print "\nEsecuzione terminata."
+
    Quit
 
  Endif
 
 
   
 
   
 +
'''Private''' Procedure Termina()
 +
   
 +
  gst_object_unref(audio)
 +
  Print "\nEstrazione terminata."
 +
  Quit
 +
   
 
  '''End'''
 
  '''End'''
  

Versione delle 21:06, 5 mar 2016

La funzione esterna gst_parse_launch() della libreria GStreamer consente di costruire e gestire in modo semplice una pipeline GStreamer. La riga della pipeline gestita dalla funzione esterna gst_parse_launch() è un insieme di elementi separati da punti esclamativi (!). Le proprietà possono essere aggiunte agli elementi, sotto forma di: proprietà = valore.

Sarà necessario avere installata nel sistema e richiamare nell'applicazione Gambas la libreria dinamica condivisa: "libgstreamer-1.0"


Mostriamo un esempio pratico, nel quale verranno estratte e convertite in un unico file WAV tutte le tracce di un CD audio:

Private audio As Pointer


Library "libgstreamer-1.0"

Private Enum GST_STATE_VOID_PENDING = 0, GST_STATE_NULL, GST_STATE_READY, GST_STATE_PAUSED, GST_STATE_PLAYING
Private Const GST_FORMAT_TIME As Integer = 3

' gst_init (int *argc, char **argv[])
' Initializes the GStreamer library, setting up internal path lists, registering built-in elements, and loading standard plugins.
Private Extern gst_init(argc As Pointer, argv As Pointer)

' GstElement * gst_parse_launch (const gchar *pipeline_description, GError **error)
' Create a new pipeline based on command line syntax.
Private Extern gst_parse_launch(description As String, GError As Pointer) As Pointer

' GstStateChangeReturn gst_element_set_state(GstElement *element, GstState state)
' Sets the state of the element.
Private Extern gst_element_set_state(gstelement As Pointer, state As Integer) As Integer

' gboolean gst_element_query_duration(GstElement *element, GstFormat format, gint64 *duration)
' Queries an element for the total stream duration in nanoseconds.
Private Extern gst_element_query_duration(gselement As Pointer, formatI As Integer, duration As Pointer) As Boolean
 
' gboolean gst_element_query_position (GstElement *element, GstFormat format, gint64 *cur)
' Queries an element for the stream position in nanoseconds.
Private Extern gst_element_query_position(gstelement As Pointer, gstformat As Pointer, cur As Pointer) As Boolean

' void gst_object_unref(gpointer object)
' Decrements the reference count on object.
Private Extern gst_object_unref(gobject As Pointer)


Public Sub Main()
 
 Dim pos, dur As Long
 Dim po, du As Date
     
  gst_init(0, 0)
  
  audio = gst_parse_launch("cdparanoiasrc mode=continuous ! queue ! audioconvert ! wavenc ! filesink location=/percorso/del/file.wav", 0)
       
' Avviamo l'estrazione dell'intero CD audio:
  gst_element_set_state(audio, GST_STATE_PLAYING)
  
  While True
    gst_element_query_position(audio, GST_FORMAT_TIME, VarPtr(pos))
    gst_element_query_duration(audio, GST_FORMAT_TIME, VarPtr(dur))
    po = Date(0, 0, 0, 0, 0, 0, pos / 1000000)
    du = Date(0, 0, 0, 0, 0, 0, dur / 1000000)
    If (pos > 0) And (CStr(po) >= CStr(du)) Then Break
    Write #File.Out, "\rDurata: " & du & "      " & "Tempo trascorso: " & po
  Wend
  
  Termina()
      
End


Public Sub Application_Read()

 Dim s As String

  Input #File.In, s
  
' Se viene inviato dalla console il carattere "t", termina l'applicazione:
  If "t" Then Termina()
  
End


Private Procedure Termina()
   
  gst_object_unref(audio)
  Print "\nEstrazione terminata."
  Quit
   
End



Riferimenti