Differenze tra le versioni di "Convertire un file MP3 in un file WAV usando una linea di pipeline con la funzione 'gst parse launch()'"

Da Gambas-it.org - Wikipedia.
 
Riga 2: Riga 2:
  
 
Sarà necessario avere installata nel sistema e richiamare nell'applicazione Gambas la libreria condivisa: "''libgstreamer-1.0'' ".
 
Sarà necessario avere installata nel sistema e richiamare nell'applicazione Gambas la libreria condivisa: "''libgstreamer-1.0'' ".
 
  
 
Mostriamo un esempio pratico di conversione di un file audio di formato MP3 in un file audio di formato WAV:
 
Mostriamo un esempio pratico di conversione di un file audio di formato MP3 in un file audio di formato WAV:
Riga 27: Riga 26:
 
   
 
   
 
   
 
   
  '''Public''' Sub Main()
+
  Public Sub Main()
 
    
 
    
 
   Dim audio As Pointer
 
   Dim audio As Pointer
Riga 34: Riga 33:
 
    
 
    
 
  <FONT Color=gray>' ''Il percorso ed il nome del file origine .mp3 e quelli del file convertito .wav  NON devono contenere spazi !''</font>
 
  <FONT Color=gray>' ''Il percorso ed il nome del file origine .mp3 e quelli del file convertito .wav  NON devono contenere spazi !''</font>
   audio = gst_parse_launch("filesrc location=<FONT Color=gray>''/percorso/del/file/audio.mp3''</font> ! mpegaudioparse ! mpg123audiodec ! wavenc ! filesink location=<FONT Color=gray>''/percorso/del/file/audio.wav''</font>", 0)
+
   audio = gst_parse_launch("filesrc location=<FONT Color=darkgreen>''/percorso/del/file/audio.mp3''</font> ! mpegaudioparse ! mpg123audiodec ! wavenc ! filesink location=<FONT Color=darkgreen>''/percorso/del/file/audio.wav''</font>", 0)
 
          
 
          
 
  <FONT Color=gray>' ''Avviamo la conversione audio:''</font>
 
  <FONT Color=gray>' ''Avviamo la conversione audio:''</font>
Riga 44: Riga 43:
 
   gst_object_unref(audio)
 
   gst_object_unref(audio)
 
        
 
        
  '''End'''
+
  End
 
 
  
  

Versione attuale delle 05:29, 12 dic 2023

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 condivisa: "libgstreamer-1.0 ".

Mostriamo un esempio pratico di conversione di un file audio di formato MP3 in un file audio di formato WAV:

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
  
' void gst_object_unref(gpointer object)
' Decrements the reference count on object.
Private Extern gst_object_unref(gobject As Pointer)


Public Sub Main()
 
 Dim audio As Pointer
     
 gst_init(0, 0)
  
' Il percorso ed il nome del file origine .mp3 e quelli del file convertito .wav  NON devono contenere spazi !
 audio = gst_parse_launch("filesrc location=/percorso/del/file/audio.mp3 ! mpegaudioparse ! mpg123audiodec ! wavenc ! filesink location=/percorso/del/file/audio.wav", 0)
       
' Avviamo la conversione audio:
 gst_element_set_state(audio, GST_STATE_PLAYING)

' Pone un'attesa sufficiente per far creare il file wav:
 Wait 5
  
 gst_object_unref(audio)
      
End


Riferimenti