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) 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 Dieser Tipp wurde bereits 19.442 mal aufgerufen. Voriger Tipp | Zufälliger Tipp | Nächster Tipp
Anzeige
Diesen und auch alle anderen Tipps & Tricks finden Sie auch auf unserer aktuellen vb@rchiv Vol.6 (einschl. Beispielprojekt!) Ein absolutes Muss - Geballtes Wissen aus mehr als 8 Jahren vb@rchiv! - nahezu alle Tipps & Tricks und Workshops mit Beispielprojekten - Symbol-Galerie mit mehr als 3.200 Icons im modernen Look Weitere Infos - 4 Entwickler-Vollversionen (u.a. sevFTP für .NET), Online-Update-Funktion u.v.m. |
sevAniGif (VB/VBA) Anzeigen von animierten GIF-Dateien Ab sofort lassen sich auch unter VB6 und VBA (Access ab Version 2000) animierte GIF-Grafiken anzeigen und abspielen, die entweder lokal auf dem System oder auf einem Webserver gespeichert sind. Tipp des Monats April 2024 Skyfloy Chart von Microsoft und dazu noch gratis Tutorial für Microsoft Chart Controls für Microsoft .NET Framework 3.5 Access-Tools Vol.1 Über 400 MByte Inhalt Mehr als 250 Access-Beispiele, 25 Add-Ins und ActiveX-Komponenten, 16 VB-Projekt inkl. Source, mehr als 320 Tipps & Tricks für Access und VB |
||||||||||||||||
Microsoft, Windows und Visual Basic sind entweder eingetragene Marken oder Marken der Microsoft Corporation in den USA und/oder anderen Ländern. Weitere auf dieser Homepage aufgeführten Produkt- und Firmennamen können geschützte Marken ihrer jeweiligen Inhaber sein. |