Rubrik: Multimedia & Sound · Audio | VB-Versionen: VB2005, VB2008 | 15.09.09 |
Länge (Spieldauer) einer MP3-Datei ermitteln Schnelles Auslesen der Länge (Spieldauer) einer MP3-Datei unter Verwendung der mciSendString-Funktion | ||
Autor: Dieter Otter | Bewertung: | Views: 19.366 |
www.tools4vb.de | System: Win2k, WinXP, Win7, Win8, Win10, Win11 | Beispielprojekt auf CD |
Um die Spieldauer (Länge) einer MP3-Datei auszulesen, kann man bequem auf auf die API-Funktion "mciSendString" zurückgreifen. Der Code ist klein und nicht sonderlich schwer zu verstehen. Er besteht lediglich aus einer API-Deklaration und einer Funktion, die die Länge der übergebenen MP3-Datei in Millisekunden zurück liefert.
' API-Deklaration Private Declare Auto Function mciSendString Lib "winmm.dll" ( _ ByVal lpstrCommand As String, _ ByVal lpstrReturnString As String, _ ByVal uReturnLength As Integer, _ ByVal hwndCallback As Integer) As Integer
''' <summary> ''' Ermittelt die Länge einer MP3-Datei in Millisekunden ''' </summary> ''' <param name="FileName">Dateiname</param> ''' <returns>Millisekunden</returns> Public Function GetMP3Length(ByVal FileName As String) As Integer ' MP3-Datei öffnen mciSendString("open " & Chr(34) & FileName & Chr(34) & _ " type MPEGVideo alias mp3audio", 0, 0, 0) ' Länge der Datei in Millisekunden auslesen Dim sReturn As String = Strings.Space(256) Dim lRet As Integer = mciSendString("status mp3audio length", _ sReturn, sReturn.Length, 0&) ' MP3-Datei schliessen mciSendString("close mp3audio", 0, 0, 0) Return Val(sReturn) End Function
Für das Umwandeln der Zeitrückgabe (Millisekunden) in ein besser lesbares Format (Minuten:Sekunden) können Sie zusätzlich nachfolgende Funktion einsetzen:
' Millisekunden nach mm:ss umrechnen Public Function FormatMilliSeconds(ByVal Milliseconds As Integer, _ Optional ByVal sFormat As String = "mm:ss") As String Return CDate("00:00:00").AddMilliseconds(MilliSeconds).ToString(sFormat) End Function
Erweiterung von ictea123 (16.09.09)
Wenn man den Funktionsrückgabewert als TimeSpan deklariert, spart man sich die Umwandlung "FormatMilliSeconds", da man sich dann die Spieldauer nach den eigenen Wünschen formatieren kann.
Außerdem sollte man Val(sReturn) durch Integer.Parse(sReturn.Trim) ersetzen, da die Val-Funktion nicht ohne Umwege aus anderen .NET-Sprachen erreichbar ist.
Die geänderte Version sähe dann so aus:
''' <summary> ''' Ermittelt die Länge einer MP3-Datei in Millisekunden ''' </summary> ''' <param name="FileName">Dateiname</param> ''' <returns>TimeSpan-Objekt</returns> Public Function GetMP3Length(ByVal FileName As String) As TimeSpan ' MP3-Datei öffnen mciSendString("open " & Chr(34) & FileName & Chr(34) & _ " type MPEGVideo alias mp3audio", 0, 0, 0) ' Länge der Datei in Millisekunden auslesen Dim sReturn As String = Strings.Space(256) Dim lRet As Integer = mciSendString("status mp3audio length", _ sReturn, sReturn.Length, 0&) ' MP3-Datei schliessen mciSendString("close mp3audio", 0, 0, 0) Return TimeSpan.FromMilliseconds(Double.Parse(sReturn.Trim)) End Function