Differenze tra le versioni di "Estrarre informazioni da un file Midi con le sole funzioni di Gambas"
Da Gambas-it.org - Wikipedia.
Riga 13: | Riga 13: | ||
Dim bb As Byte[] | Dim bb As Byte[] | ||
Dim i As Integer | Dim i As Integer | ||
− | |||
Dim t As Short | Dim t As Short | ||
Riga 40: | Riga 39: | ||
<FONT color=gray>' ''Verifica la risoluzione PPQN del file Midi:''</font> | <FONT color=gray>' ''Verifica la risoluzione PPQN del file Midi:''</font> | ||
− | + | Print "Risoluzione PPQN: "; legge_Byte(fl, 12, 2) | |
− | |||
− | |||
− | |||
− | |||
− | Print "Risoluzione PPQN: "; | ||
<FONT color=gray>' ''Verifica il Tempo metronomico iniziale del file Midi:''</font> | <FONT color=gray>' ''Verifica il Tempo metronomico iniziale del file Midi:''</font> | ||
i = InStr(bb.ToString(0, Lof(fl)), Chr(&FF) & Chr(&51) & Chr(&03)) | i = InStr(bb.ToString(0, Lof(fl)), Chr(&FF) & Chr(&51) & Chr(&03)) | ||
If i > 0 Then | If i > 0 Then | ||
− | t = 60000000 \ | + | t = 60000000 \ legge_Byte(fl, i + 2, 3) |
Else | Else | ||
t = 120 | t = 120 | ||
Endif | Endif | ||
Print "Tempo metronomico: "; t; " bpm" | Print "Tempo metronomico: "; t; " bpm" | ||
+ | |||
+ | '''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''' | '''End''' |
Versione delle 17:50, 18 ago 2014
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" 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