vb@rchiv
VB Classic
VB.NET
ADO.NET
VBA
C#

https://www.vbarchiv.net
Rubrik: Multimedia & Sound · Audio   |   VB-Versionen: VB2005, VB200815.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 OtterBewertung:  Views:  19.366 
www.tools4vb.deSystem:  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



Anzeige

Kauftipp Unser Dauerbrenner!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.
 
 
Copyright ©2000-2024 vb@rchiv Dieter OtterAlle Rechte vorbehalten.


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.