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 20.089 mal aufgerufen.
Anzeige
![]() ![]() ![]() (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 ![]() Dieter Otter sevTabStrip: Rechtsklick auf Reiter erkennen Eine Funktion, mit der sich prüfen lässt, auf welchen Tab-Reiter ein Mausklick erfolgte 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. |