acmFormatEnumW-Funktion (msacm.h)
Die acmFormatEnum-Funktion listet Waveform-Audioformate auf, die für ein bestimmtes Formattag von einem ACM-Treiber verfügbar sind. Diese Funktion wird weiterhin aufgezählt, bis es keine geeigneten Formate für das Formattag gibt, oder die Rückruffunktion gibt FALSEzurück.
Syntax
MMRESULT ACMAPI acmFormatEnumW(
HACMDRIVER had,
LPACMFORMATDETAILSW pafd,
ACMFORMATENUMCBW fnCallback,
DWORD_PTR dwInstance,
DWORD fdwEnum
);
Parameter
had
Behandeln Sie den ACM-Treiber, um Details im Waveform-Audioformat abzufragen. Wenn dieser Parameter NULL-ist, verwendet das ACM die Details des ersten geeigneten ACM-Treibers.
pafd
Zeigen Sie auf eine ACMFORMATDETAILS- Struktur, um die an die fnCallback--Funktion übergebenen Formatdetails zu enthalten. Diese Struktur muss die cbStruct, pwfxund cbwfx Member der ACMFORMATDETAILS Struktur initialisiert haben. Das dwFormatTag Member muss auch für WAVE_FORMAT_UNKNOWN oder ein gültiges Formattag initialisiert werden.
Das fdwSupport- Element der Struktur muss auf Null initialisiert werden.
Um die erforderliche Größe des pwfx Puffers zu finden, rufen Sie acmMetrics- mit dem ACM_METRIC_MAX_SIZE_FORMAT-Flag auf.
fnCallback
Adresse einer anwendungsdefinierten Rückruffunktion. Siehe acmFormatEnumCallback. Dieser Parameter kann nicht NULL-werden.
dwInstance
Ein anwendungsdefinierter 64-Bit-Wert (DWORD_PTR) oder 32-Bit (DWORD), der zusammen mit ACM-Formatdetails an die Rückruffunktion übergeben wird.
fdwEnum
Flags zum Aufzählen der Formate für ein bestimmtes Formattag. Die folgenden Werte sind definiert.
[ACMFORMATDETAILS](./nf-msacm-acmformatdetails.md) Struktur ist gültig. Der Enumerator enumeriert nur Zielformate, die aus dem angegebenen pwfx--Format konvertiert werden können. Wenn dieses Flag verwendet wird, kann das wFormatTag Member der WAVEFORMATEX- Struktur nicht WAVE_FORMAT_UNKNOWN werden. [ACMFORMATDETAILS](./nf-msacm-acmformatdetails.md) Struktur ist gültig. Der Enumerator enumeriert nur ein Format, das diesem Attribut entspricht. [ACMFORMATDETAILS](./nf-msacm-acmformatdetails.md) Struktur ist gültig. Der Enumerator enumeriert alle vorgeschlagenen Zielformate für das angegebene pwfx--Format. Dieser Mechanismus kann anstelle der acmFormatSuggest-Funktion verwendet werden, damit eine Anwendung das am besten vorgeschlagene Format für die Konvertierung auswählen kann. Das dwFormatIndex- Member wird immer auf Null festgelegt, wenn es zurückgegeben wird. Wenn dieses Flag verwendet wird, kann das wFormatTag Member der WAVEFORMATEX- Struktur nicht WAVE_FORMAT_UNKNOWN werden.Wert | Bedeutung |
---|---|
ACM_FORMATENUMF_CONVERT | |
ACM_FORMATENUMF_HARDWARE | Der Enumerator sollte nur Formate aufzählen, die als systemeigene Eingabe- oder Ausgabeformate auf einem oder mehreren der installierten Waveform-Audiogeräte unterstützt werden. Dieses Kennzeichen bietet eine Möglichkeit für eine Anwendung, nur systemeigene Formate für ein installiertes Waveform-Audiogerät auszuwählen. Dieses Kennzeichen muss mit einem oder beiden ACM_FORMATENUMF_INPUT und ACM_FORMATENUMF_OUTPUT Flags verwendet werden. Wenn Sie sowohl ACM_FORMATENUMF_INPUT als auch ACM_FORMATENUMF_OUTPUT angeben, werden nur Formate aufgelistet, die für die Eingabe oder Ausgabe geöffnet werden können. Dies gilt unabhängig davon, ob dieses Kennzeichen angegeben ist. |
ACM_FORMATENUMF_INPUT | Enumerator sollte nur Formate aufzählen, die für die Eingabe (Aufzeichnung) unterstützt werden. |
ACM_FORMATENUMF_NCHANNELS | |
ACM_FORMATENUMF_NSAMPLESPERSEC | Das nSamplesPerSec Mitglied der WAVEFORMATEX- Struktur, auf die das pwfx- Mitglied der ACMFORMATDETAILS Struktur verweist, ist gültig. Der Enumerator enumeriert nur ein Format, das diesem Attribut entspricht. |
ACM_FORMATENUMF_OUTPUT | Enumerator sollte nur Formate aufzählen, die für die Ausgabe (Wiedergabe) unterstützt werden. |
ACM_FORMATENUMF_SUGGEST | |
ACM_FORMATENUMF_WBITSPERSAMPLE | Das wBitsPerSample Mitglied der WAVEFORMATEX- Struktur, auf die pwfx Member der ACMFORMATDETAILS Struktur verweist, ist gültig. Der Enumerator enumeriert nur ein Format, das diesem Attribut entspricht. |
ACM_FORMATENUMF_WFORMATTAG | Das wFormatTag- Mitglied der WAVEFORMATEX- Struktur, auf die das pwfx- Mitglied der ACMFORMATDETAILS Struktur verweist, ist gültig. Der Enumerator enumeriert nur ein Format, das diesem Attribut entspricht. Das dwFormatTag- Mitglied der ACMFORMATDETAILS--Struktur muss dem wFormatTag-element entsprechen. Der Wert von wFormatTag- kann in diesem Fall nicht WAVE_FORMAT_UNKNOWN werden. |
Rückgabewert
Gibt Null zurück, wenn dies erfolgreich ist oder andernfalls ein Fehler auftritt. Mögliche Fehlerwerte sind:
Rückgabecode | Beschreibung |
---|---|
|
Die Details für das Format können nicht zurückgegeben werden. |
|
Mindestens ein Kennzeichen ist ungültig. |
|
Der angegebene Handle ist ungültig. |
|
Mindestens ein Parameter ist ungültig. |
Bemerkungen
Diese Funktion gibt MMSYSERR_NOERROR (Null) zurück, wenn keine geeigneten ACM-Treiber installiert sind. Darüber hinaus wird die Rückruffunktion nicht aufgerufen.
Beispiele
Das folgende Beispiel zeigt, wie Formate mit dem WAVE_FORMAT_MPEGLAYER3 Formattag aufgezählt werden.
MMRESULT EnumerateMP3Codecs()
{
DWORD cbMaxSize = 0;
MMRESULT result = MMSYSERR_NOERROR;
ACMFORMATDETAILS acmFormatDetails;
// Buffer to hold the format information.
BYTE *pFormat = NULL; // Caller allocated.
// Find the largest format buffer needed.
result = acmMetrics(NULL, ACM_METRIC_MAX_SIZE_FORMAT, &cbMaxSize);
if (result != MMSYSERR_NOERROR)
{
return result;
}
// Allocate the format buffer.
pFormat = new BYTE[cbMaxSize];
if (pFormat == NULL)
{
return MMSYSERR_NOMEM;
}
ZeroMemory(pFormat, cbMaxSize);
// Ask for WAVE_FORMAT_MPEGLAYER3 formats.
WAVEFORMATEX* pWaveFormat = (WAVEFORMATEX*)pFormat;
pWaveFormat->wFormatTag = WAVE_FORMAT_MPEGLAYER3;
// Set up the acmFormatDetails structure.
ZeroMemory(&acmFormatDetails, sizeof(acmFormatDetails));
acmFormatDetails.cbStruct = sizeof(ACMFORMATDETAILS);
acmFormatDetails.pwfx = pWaveFormat;
acmFormatDetails.cbwfx = cbMaxSize;
// For the ACM_FORMATENUMF_WFORMATTAG request, the format
// tag in acmFormatDetails must match the format tag in
// the pFormat buffer.
acmFormatDetails.dwFormatTag = WAVE_FORMAT_MPEGLAYER3;
result = acmFormatEnum(NULL, &acmFormatDetails, acmFormatEnumCallback,
0, ACM_FORMATENUMF_WFORMATTAG);
delete [] pFormat;
return result;
}
Das nächste Beispiel zeigt die Rückruffunktion für das vorherige Beispiel. Die Rückruffunktion wird einmal für jedes übereinstimmende Format aufgerufen oder bis der Rückruf FALSE-zurückgibt.
BOOL CALLBACK acmFormatEnumCallback(
HACMDRIVERID hadid,
LPACMFORMATDETAILS pafd,
DWORD_PTR dwInstance,
DWORD fdwSupport
)
{
BOOL bContinue = TRUE;
MPEGLAYER3WAVEFORMAT *pMP3WaveFormat = NULL;
if (pafd->pwfx->wFormatTag == WAVE_FORMAT_MPEGLAYER3)
{
pMP3WaveFormat = (MPEGLAYER3WAVEFORMAT*)pafd->pwfx;
// TODO: Examine the format.
// To halt the enumeration, set bContinue to FALSE.
}
return bContinue;
}
Anmerkung
Der msacm.h-Header definiert acmFormatEnum als Alias, der die ANSI- oder Unicode-Version dieser Funktion basierend auf der Definition der UNICODE-Präprozessorkonstante automatisch auswählt. Das Mischen der Verwendung des codierungsneutralen Alias mit Code, der nicht codierungsneutral ist, kann zu Nichtübereinstimmungen führen, die zu Kompilierungs- oder Laufzeitfehlern führen. Weitere Informationen finden Sie unter Konventionen für Funktionsprototypen.
Anforderungen
Anforderung | Wert |
---|---|
mindestens unterstützte Client- | Windows 2000 Professional [nur Desktop-Apps] |
mindestens unterstützte Server- | Windows 2000 Server [nur Desktop-Apps] |
Zielplattform- | Fenster |
Header- | msacm.h |
Library | Msacm32.lib |
DLL- | Msacm32.dll |