Estrarre informazioni da un file Midi con le sole funzioni di Gambas
Da Gambas-it.org - Wikipedia.
Versione del 18 ago 2014 alle 17:51 di Vuott (Discussione | contributi)
Mostreremo un possibile codice per ottenere da un file Midi le seguenti informazioni:
- Nome;
- Dimensione;
- Tipo;
- Quantità di tracce presenti;
- Risoluzione PPQN;
- Tempo metronomico iniziale.
Public Sub Main() Dim file_midi As String = "/percorso/del/file.mid" Dim fl As File Dim bb As Byte[] Dim i As Integer Dim t As Short fl = Open file_midi For Read ' Mostra il nome del file Midi: Print "Nome del file Midi: "; File.Name(file_midi) ' Verifica la dimensione del file Midi: Print "Dimensione del file Midi: "; Lof(fl); " byte" ' Legge l'intero file Midi e carica i dati nella variabile "bb": With bb = New Byte[Lof(fl)] .Read(fl) End With ' Verifica che il file caricato sia un file Midi standard: If bb.ToString(0, 4) <> "MThd" Then Error.Raise("Il file caricato non è un file Midi !") ' Verifica il tipo di file Midi: Print "Tipo di file Midi: "; CStr(bb[9]) ' Verifica la quantità di tracce presenti nel File Midi: Print "Numero tracce presenti: "; CStr(bb[11]) ' Verifica la risoluzione PPQN del file Midi: Print "Risoluzione PPQN: "; legge_Byte(fl, 12, 2) ' Verifica il Tempo metronomico iniziale del file Midi: i = InStr(bb.ToString(0, Lof(fl)), Chr(&FF) & Chr(&51) & Chr(&03)) If i > 0 Then t = 60000000 \ legge_Byte(fl, i + 2, 3) Else t = 120 Endif Print "Tempo metronomico: "; t; " bpm" fl.Close End Private Function legge_Byte(f As File, s As Short, q As Byte) As Integer Dim ris As Integer Dim b As Byte Seek #f, s Do Read #f, b ris = (ris * CInt(2 ^ 8)) Or b Dec q Loop Until q = 0 Return ris End