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.405 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. |
Neu! sevEingabe 3.0 Einfach stark! Ein einziges Eingabe-Control für alle benötigten Eingabetypen und -formate, inkl. Kalender-, Taschenrechner und Floskelfunktion, mehrspaltige ComboBox mit DB-Anbindung, ImageComboBox u.v.m. 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. |