/MfPack

Delphi translations for Microsoft Media Foundation and related API's

Primary LanguagePascalMozilla Public License 2.0MPL-2.0

Before going on, some policy:

  • If you have a request, question, idea or need help, please commit to Discussions.

  • If you encounter a bug then Issues is the one and only place to be.

About MfPack

Delphi translations for Microsoft Media Foundation and related API's.

MfPack covers the Delphi translations of:

  • Core Audio API's:
    • Windows Audio Session API (WASAPI)
    • DeviceTopology API
    • EndpointVolume API
    • Multimedia Device (MMDevice) API
  • Microsoft Media Foundation API (successor of DirectShow).
  • XAudio2 API (XBox game development, successor of DirectSound).
  • Microsoft DirectX API's (D2D1, D3D9, D3D11, D3D12, DirectComposition, DXGI, DirectWrite and DXVA) Note that D3D11 and above are part of Media Foundation.
  • Windows Imaging Component (WIC) API.
  • MPEG2 API.
  • The COMPLETE Windows Media (WinMM) API.
  • Media Foundation samples.

Latest release:

MfPack

Version X 3.1.7 Delphi XE2 up to and including Delphi 12 SDK version: 10.0.26100.0 (Windows 11)

Samples

MfVideoThumbNails sample

This sample app needs the D2D1 Api. If your Delphi version doesn't have the latest D2D1 Api (May 2019 update), use the D2D1 MfPack version.

MediaEngine Player 2 & IMFTimedText sample

MediaEngine player (IMFMediaEngine(Ex)) with support for subtitles (closed captions) using the IMFTimedTextNotify interface.

MfTranscode sample

Demonstrates using the transcode API to transcode a source file (audio or video) to a different format (audio or video) supported by Media Foundation.

Supported, but not limited, formats in this sample are:

  • Audio

    • Waveform Audio File Format (wav)
    • MPEG Audio Layer III (mp3)
    • Free Lossless Audio Codec (flac)
    • MPEG-4 Audio (m4a)
    • Windows Media Audio (wma)
  • Video

    • Audio Video Interleave (avi)
    • MPEG-4 Video with AAC Audio (mp4)
    • MPEG-4 Video with Dolby AC-3 Audio (mp4)
    • Windows Media Video (wmv)

MfSimpleCapture sample

This example shows, how you have to implement capturing within a session.

Note: The old MS sample used the deprecated IMFplayer interface.

Sample 2

This sample shows how to implement camera and video controls using

IAMCameraControl and IAMVideoProcAmp.

MfPeakMeter and MfPeakMeterEx component sample

An example about how to create a MfPeakMeter control. This sample is part of the Samples/MfComponents package.

AudioClip and AudioClipEx sample

Demonstrates using the IMFSourceReader API to extract uncompressed media data from a media file. This sample application reads audio data from a media file and writes the uncompressed audio to a WAVE file.

The AudioClipEx sample demonstrates using the IMFSourceReader and IMFSourceReaderCallback API to extract uncompressed mediadata from a media file.

AudioClip sample

MfPlayer

Player samples, based on the CPlayer sample.

There are 3 samples in 3 project degrees.

  • MfPlayer I : The basic player sample.

  • MfPlayer II : The extended version I sample.

  • MfPlayer X : This is an example that shows how to use the IMFTimer, language tags,
    subtitles (SubRip, MicroDvd and WebVTT), RegEx (Regular Expressions) and how to get media properties.


Ducking Media Player

This sample implements a simple media player that responds to the "ducking" feature in Windows 7 and later. It also implements a volume control which tracks to the volume control in the volume mixer.

Ducking Capture Sample

This sample implements a simple "Chat" that demonstrates to the "ducking" feature in Windows 7 and later. It simply captures samples from the sound card and discards them.

MFFrameCapture sample

Demonstrates how to capture an image (synchronous or A-synchronous) using the IMFSourceReader.

CameraFrameCapture sample Demonstrates how to capture a still image or so called snapshot (A-synchronous) from a capture device such as a webcam or camera using the IMFSourceReader.

CaptureEngineVideoCapture sample Demonstrates how to capture a snapshot or a recording (A-synchronous) from a capture device, such as a webcam using the IMFCaptureEngine and IMFCapturePreviewSink. This sample also demonstrates how to use the MfMediaTypeDebug API.

SinkWriterToEncodeVideo Sample

Example 1 creates a simple green bitmap (640x480) and store it to a file with a length of 20 seconds. Example 2 demonstrates how to use the SinkWriter to create a video from one or more bitmap files.

Example 3 demonstrates how to use the SinkWriter to create a video from one or more image files including audio.

LoopBackCapture Sample 1

This sample shows, how to capture sound from your soundcard using WASAPI and save this capture with the quality that is supported by your soundcard.

LoopBackCapture Sample 2

This sample demonstrates how to capture system audio either from a specific process tree or for all process except a process tree and the use of ActivateAudioInterfaceAsync Win32 API with a new initialization structure. The new data structure makes it possible to restrict captured audio data to that rendered by a specific process and any of its child processes. Windows 10 has always supported capturing all audio that is played on an audio endpoint (referred to as "system" loopback capture), which captures all audio from all apps that are playing sounds on the chosen audio endpoint.

With the new structure, only audio from the specified process, and its children, will be captured. Audio rendered by other processes will not be captured. A flag is also provided to reverse the behavior, capturing all system audio except those from the the specified process (and its children). Furthermore, the capture is not tied to a specific audio endpoint, eliminating the need to create a separate IAudioClient to capture from each physical audio endpoint.

If the processes whose audio will be captured does not have any audio rendering streams, then the capturing process receives silence.

It also demonstrates how to get a process by using the tlhelp32 API, to list a snapshot of running processes and be able to pick one. The application is provided with a dialog to select a running process from the process tree you want to pick and has a button to get the current PID of your application.

The application is using MMCSS and runs the rendering part in a separate thread.

Threaded Loopback Capture Sample

Demonstrates how to capture sound from a rendering or capture device (one of the soundcard's endpoints) using WASAPI in combination with mmio to write wav-files. This sample lets you to choose between different latency's and buffersize for better sound to eliminate buffer related gliches.

It has some more advanced features like:

  • The rendering part is running in a separate thread to eliminate glitches.
  • Able to use MMCSS (Multimedia Class Scheduler service).
  • Stream switch detection.
  • possibility to write wav data in native format 44.1 kHz/ 16 bit PCM or the soundcard's audio format (including Uncompressed IEEE floating-point audio).

XAudio2Player Basic Player

XAudio2 is the long-awaited replacement for DirectSound. It addresses several outstanding issues and feature requests, like low latency etc.

This sample demonstrates how to use XAudio2 to render different file formats like WAV, FLAC, MP3 etc. The sample uses the IMFSourceReader to decode the format suitable for playing in XAudio2. It shows you the basics of using XAudio2 without formatting the mediatypes yourself. The sample uses the MfPeakMeter component. This requires that you install the MfComponents. In your projectsettings you have to add ..MfPack\Samples\MfComponents in the project options searchpath.

XAudio2Player Sample 2

This sample shows you how to implement the IXAudio2VoiceCallback. The sample uses the MfPeakMeter component. This requires that you install the MfComponents. In your projectsettings you must add ..MfPack\Samples\MfComponents in the project options searchpath.
It also has a pitch control.

XAudio2Player Sample 3

This sample demonstrates how to implement XAudio2 effects and how to go forward or backward during playing with a progressbar and keeping up progress.

It shows you how to implement events and methods instead of using messages from the XaudioEngine. The sample uses the MfPeakMeter component. This requires that you install the MfComponents. In your projectsettings you have to add ..MfPack\Samples\MfComponents in the project options searchpath.

WASAPI Player Sample 1

This sample demonstrates how to use the IAudioClient to render different audio formats like WAV, FLAC, MP3 etc. using the IMFSourceReader to decode the format suitable for playing in WASAPI's IAudioClient and renderer.

This sample plays formats like WAV (pcm and floatingpoint), MP3 and FLAC. It shows you the basics of using the IAudioClient, iAudioRenderer, IAudioClock and IAudioStreamVolume interfaces. The sample uses the MfPeakMeter component. This requires that you install the MfComponents. In your projectsettings you have to add ..MfPack\Samples\MfComponents in the project options searchpath.

Tools

HResult Lookup Tool Application

This tool can be used to determine HResult or Error codes returned by the Windows OS, featuring a detailed build in "HResult Lookup tool", the "Windows System Error Code Lookup Tool" and the "System.SysUtils.SysErrorMessage" function, that provides the localized translation (language of your OS) of the HResult.

© FactoryX. All rights reserved.