Skip to content

jacovis/Javi.MediaInfo

Repository files navigation

NuGet

Javi.MediaInfo

This .NET Standard package provides a wrapper for the MediaInfo library of functions.
MediaInfo is a convenient unified display of the most relevant technical and tag data for video and audio files.
With this package, using the MediaInfo library from your application and retrieving this data for video and audio files is as simple as making a method call and then examining the properties of this class.

Features

  • Wraps the MediaInfo.dll
  • Provides properties for almost all information available using the MediaInfo.dll
  • Targets .NET Standard 2.0

Getting Started

  • Install package using nuget

Install Javi.MediaInfo from NuGet using the Package Manager Console with the following command

PM> Install-Package Javi.MediaInfo

Alternatively search on NuGet Javi.MediaInfo

  • Download a copy of MediaInfo.dll

Since this package is only a wrapper for the MediaInfo dll, a copy of the dll must be available. Official releases can be downloaded using links from the MediaInfo download site.
The MediaInfo.dll is available in 32 and 64 bit versions, choose the correct version for your application and operating system.
This package uses dynamic DLL loading, so applications using this package still have the freedom to choose their target as appropriate, even AnyCPU remains an option.

Usage

Add to usings:

using Javi.MediaInfo

Instantiate an object of class MediaInfo, providing the full path to the local copy of the MediaInfo.dll.

MediaInfo MediaInfo = new MediaInfo(MediaInfoDLLFullName);

Call the method that calls into the MediaInfo.dll to update all properties.

MediaInfo.ReadMediaInformation(@"Sample.mp4");

Retrieve technical and tag data from the video or audio file:

var containerFormat = MediaInfo.General.Format;
var videoBitRate = (MediaInfo.Video.Count > 0 ? MediaInfo.Video[0].BitRate : 0);

Demo application

A C# .NET Core console demo application is available which shows the usage of the package. Code from this demo should not be used in production code, the code is merely to demonstrate the usage of this package. See demo output for the output of the demo.

License

This project is licensed under the MIT License.

Acknowledgments

Sample video courtesy of https://sample-videos.com/

Releases

No releases published

Packages

No packages published