Win32 API 日本語リファレンス
ホームMedia.MediaFoundation › MFTEnum

MFTEnum

関数
条件に合致するMFT変換器のCLSID一覧を列挙する。
DLLMFPlat.dll呼出規約winapi対応OSWindows Vista 以降

シグネチャ

// MFPlat.dll
#include <windows.h>

HRESULT MFTEnum(
    GUID guidCategory,
    DWORD Flags,
    MFT_REGISTER_TYPE_INFO* pInputType,   // optional
    MFT_REGISTER_TYPE_INFO* pOutputType,   // optional
    IMFAttributes* pAttributes,   // optional
    GUID** ppclsidMFT,
    DWORD* pcMFTs
);

パラメーター

名前方向説明
guidCategoryGUIDin列挙対象とする MFT のカテゴリを示す GUID。
FlagsDWORDin予約フラグ。0 を指定する。
pInputTypeMFT_REGISTER_TYPE_INFO*inoptional絞り込み条件となる入力メディア種別 MFT_REGISTER_TYPE_INFO ポインタ。NULL 可。
pOutputTypeMFT_REGISTER_TYPE_INFO*inoptional絞り込み条件となる出力メディア種別 MFT_REGISTER_TYPE_INFO ポインタ。NULL 可。
pAttributesIMFAttributes*inoptional予約。NULL を指定する。
ppclsidMFTGUID**out該当 MFT の CLSID 配列を受け取る出力ポインタ。CoTaskMemFree で解放。
pcMFTsDWORD*out返された CLSID 配列の要素数を受け取る出力ポインタ。

戻り値の型: HRESULT

各言語での呼び出し定義

// MFPlat.dll
#include <windows.h>

HRESULT MFTEnum(
    GUID guidCategory,
    DWORD Flags,
    MFT_REGISTER_TYPE_INFO* pInputType,   // optional
    MFT_REGISTER_TYPE_INFO* pOutputType,   // optional
    IMFAttributes* pAttributes,   // optional
    GUID** ppclsidMFT,
    DWORD* pcMFTs
);
[DllImport("MFPlat.dll", ExactSpelling = true)]
static extern int MFTEnum(
    Guid guidCategory,   // GUID
    uint Flags,   // DWORD
    IntPtr pInputType,   // MFT_REGISTER_TYPE_INFO* optional
    IntPtr pOutputType,   // MFT_REGISTER_TYPE_INFO* optional
    IntPtr pAttributes,   // IMFAttributes* optional
    IntPtr ppclsidMFT,   // GUID** out
    out uint pcMFTs   // DWORD* out
);
<DllImport("MFPlat.dll", ExactSpelling:=True)>
Public Shared Function MFTEnum(
    guidCategory As Guid,   ' GUID
    Flags As UInteger,   ' DWORD
    pInputType As IntPtr,   ' MFT_REGISTER_TYPE_INFO* optional
    pOutputType As IntPtr,   ' MFT_REGISTER_TYPE_INFO* optional
    pAttributes As IntPtr,   ' IMFAttributes* optional
    ppclsidMFT As IntPtr,   ' GUID** out
    <Out> ByRef pcMFTs As UInteger   ' DWORD* out
) As Integer
End Function
' guidCategory : GUID
' Flags : DWORD
' pInputType : MFT_REGISTER_TYPE_INFO* optional
' pOutputType : MFT_REGISTER_TYPE_INFO* optional
' pAttributes : IMFAttributes* optional
' ppclsidMFT : GUID** out
' pcMFTs : DWORD* out
Declare PtrSafe Function MFTEnum Lib "mfplat" ( _
    ByVal guidCategory As LongPtr, _
    ByVal Flags As Long, _
    ByVal pInputType As LongPtr, _
    ByVal pOutputType As LongPtr, _
    ByVal pAttributes As LongPtr, _
    ByVal ppclsidMFT As LongPtr, _
    ByRef pcMFTs As Long) As Long
' VBA7前提(PtrSafe)。32bit Office では LongPtr→Long。Integer=16bit / Long=32bit / LongLong=64bit。
import ctypes
from ctypes import wintypes

MFTEnum = ctypes.windll.mfplat.MFTEnum
MFTEnum.restype = ctypes.c_int
MFTEnum.argtypes = [
    ctypes.c_void_p,  # guidCategory : GUID
    wintypes.DWORD,  # Flags : DWORD
    ctypes.c_void_p,  # pInputType : MFT_REGISTER_TYPE_INFO* optional
    ctypes.c_void_p,  # pOutputType : MFT_REGISTER_TYPE_INFO* optional
    ctypes.c_void_p,  # pAttributes : IMFAttributes* optional
    ctypes.c_void_p,  # ppclsidMFT : GUID** out
    ctypes.POINTER(wintypes.DWORD),  # pcMFTs : DWORD* out
]
require 'fiddle'
require 'fiddle/import'

lib = Fiddle.dlopen('MFPlat.dll')
MFTEnum = Fiddle::Function.new(
  lib['MFTEnum'],
  [
    Fiddle::TYPE_VOIDP,  # guidCategory : GUID
    -Fiddle::TYPE_INT,  # Flags : DWORD
    Fiddle::TYPE_VOIDP,  # pInputType : MFT_REGISTER_TYPE_INFO* optional
    Fiddle::TYPE_VOIDP,  # pOutputType : MFT_REGISTER_TYPE_INFO* optional
    Fiddle::TYPE_VOIDP,  # pAttributes : IMFAttributes* optional
    Fiddle::TYPE_VOIDP,  # ppclsidMFT : GUID** out
    Fiddle::TYPE_VOIDP,  # pcMFTs : DWORD* out
  ],
  Fiddle::TYPE_INT)
#[link(name = "mfplat")]
extern "system" {
    fn MFTEnum(
        guidCategory: GUID,  // GUID
        Flags: u32,  // DWORD
        pInputType: *mut MFT_REGISTER_TYPE_INFO,  // MFT_REGISTER_TYPE_INFO* optional
        pOutputType: *mut MFT_REGISTER_TYPE_INFO,  // MFT_REGISTER_TYPE_INFO* optional
        pAttributes: *mut core::ffi::c_void,  // IMFAttributes* optional
        ppclsidMFT: *mut *mut GUID,  // GUID** out
        pcMFTs: *mut u32  // DWORD* out
    ) -> i32;
}
// crates: windows-sys provides ready-made bindings for this API.
$sig = @"
[DllImport("MFPlat.dll")]
public static extern int MFTEnum(Guid guidCategory, uint Flags, IntPtr pInputType, IntPtr pOutputType, IntPtr pAttributes, IntPtr ppclsidMFT, out uint pcMFTs);
"@
$api = Add-Type -MemberDefinition $sig -Name 'MFPlat_MFTEnum' -Namespace Win32 -PassThru
# $api::MFTEnum(guidCategory, Flags, pInputType, pOutputType, pAttributes, ppclsidMFT, pcMFTs)
#uselib "MFPlat.dll"
#func global MFTEnum "MFTEnum" sptr, sptr, sptr, sptr, sptr, sptr, sptr
; MFTEnum guidCategory, Flags, varptr(pInputType), varptr(pOutputType), pAttributes, varptr(ppclsidMFT), varptr(pcMFTs)   ; 戻り値は stat
; guidCategory : GUID -> "sptr"
; Flags : DWORD -> "sptr"
; pInputType : MFT_REGISTER_TYPE_INFO* optional -> "sptr"
; pOutputType : MFT_REGISTER_TYPE_INFO* optional -> "sptr"
; pAttributes : IMFAttributes* optional -> "sptr"
; ppclsidMFT : GUID** out -> "sptr"
; pcMFTs : DWORD* out -> "sptr"
; ※値渡し構造体は直接渡せません。intにパック、または var で構造体変数を渡してください。
; ※HSP3.7は #func のため戻り値はシステム変数 stat に格納されます。
出力引数:
#uselib "MFPlat.dll"
#cfunc global MFTEnum "MFTEnum" int, int, var, var, sptr, var, var
; res = MFTEnum(guidCategory, Flags, pInputType, pOutputType, pAttributes, ppclsidMFT, pcMFTs)
; guidCategory : GUID -> "int"
; Flags : DWORD -> "int"
; pInputType : MFT_REGISTER_TYPE_INFO* optional -> "var"
; pOutputType : MFT_REGISTER_TYPE_INFO* optional -> "var"
; pAttributes : IMFAttributes* optional -> "sptr"
; ppclsidMFT : GUID** out -> "var"
; pcMFTs : DWORD* out -> "var"
; ※値渡し構造体は直接渡せません。intにパック、または var で構造体変数を渡してください。
; ※出力/バッファ引数は var 方式(変数を直接渡す)。varptr 方式にも切替可。
出力引数:
; HRESULT MFTEnum(GUID guidCategory, DWORD Flags, MFT_REGISTER_TYPE_INFO* pInputType, MFT_REGISTER_TYPE_INFO* pOutputType, IMFAttributes* pAttributes, GUID** ppclsidMFT, DWORD* pcMFTs)
#uselib "MFPlat.dll"
#cfunc global MFTEnum "MFTEnum" int, int, var, var, intptr, var, var
; res = MFTEnum(guidCategory, Flags, pInputType, pOutputType, pAttributes, ppclsidMFT, pcMFTs)
; guidCategory : GUID -> "int"
; Flags : DWORD -> "int"
; pInputType : MFT_REGISTER_TYPE_INFO* optional -> "var"
; pOutputType : MFT_REGISTER_TYPE_INFO* optional -> "var"
; pAttributes : IMFAttributes* optional -> "intptr"
; ppclsidMFT : GUID** out -> "var"
; pcMFTs : DWORD* out -> "var"
; ※値渡し構造体は直接渡せません。intにパック、または var で構造体変数を渡してください。
; ※出力/バッファ引数は var 方式(変数を直接渡す)。varptr 方式にも切替可。
import (
	"golang.org/x/sys/windows"
	"unsafe"
)

var (
	mfplat = windows.NewLazySystemDLL("MFPlat.dll")
	procMFTEnum = mfplat.NewProc("MFTEnum")
)

// guidCategory (GUID), Flags (DWORD), pInputType (MFT_REGISTER_TYPE_INFO* optional), pOutputType (MFT_REGISTER_TYPE_INFO* optional), pAttributes (IMFAttributes* optional), ppclsidMFT (GUID** out), pcMFTs (DWORD* out)
r1, _, err := procMFTEnum.Call(
	uintptr(guidCategory),
	uintptr(Flags),
	uintptr(pInputType),
	uintptr(pOutputType),
	uintptr(pAttributes),
	uintptr(ppclsidMFT),
	uintptr(pcMFTs),
)
_ = err  // syscall.Errno (valid when the call sets last-error)
_ = r1   // HRESULT
function MFTEnum(
  guidCategory: TGUID;   // GUID
  Flags: DWORD;   // DWORD
  pInputType: Pointer;   // MFT_REGISTER_TYPE_INFO* optional
  pOutputType: Pointer;   // MFT_REGISTER_TYPE_INFO* optional
  pAttributes: Pointer;   // IMFAttributes* optional
  ppclsidMFT: PGUID;   // GUID** out
  pcMFTs: Pointer   // DWORD* out
): Integer; stdcall;
  external 'MFPlat.dll' name 'MFTEnum';
result := DllCall("MFPlat\MFTEnum"
    , "Ptr", guidCategory   ; GUID
    , "UInt", Flags   ; DWORD
    , "Ptr", pInputType   ; MFT_REGISTER_TYPE_INFO* optional
    , "Ptr", pOutputType   ; MFT_REGISTER_TYPE_INFO* optional
    , "Ptr", pAttributes   ; IMFAttributes* optional
    , "Ptr", ppclsidMFT   ; GUID** out
    , "Ptr", pcMFTs   ; DWORD* out
    , "Int")   ; return: HRESULT
●MFTEnum(guidCategory, Flags, pInputType, pOutputType, pAttributes, ppclsidMFT, pcMFTs) = DLL("MFPlat.dll", "int MFTEnum(void*, dword, void*, void*, void*, void*, void*)")
# 呼び出し: MFTEnum(guidCategory, Flags, pInputType, pOutputType, pAttributes, ppclsidMFT, pcMFTs)
# guidCategory : GUID -> "void*"
# Flags : DWORD -> "dword"
# pInputType : MFT_REGISTER_TYPE_INFO* optional -> "void*"
# pOutputType : MFT_REGISTER_TYPE_INFO* optional -> "void*"
# pAttributes : IMFAttributes* optional -> "void*"
# ppclsidMFT : GUID** out -> "void*"
# pcMFTs : DWORD* out -> "void*"
# なでしこ1は32bit・ANSI(Shift_JIS)。文字列=char*(ANSI)、ポインタ/ハンドル=void*(4byte)。