Win32 API 日本語リファレンス
ホームGraphics.GdiPlus › GdipPlayMetafileRecord

GdipPlayMetafileRecord

関数
指定したメタファイルのレコードを再生して描画する。
DLLgdiplus.dll呼出規約winapi

シグネチャ

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

Status GdipPlayMetafileRecord(
    const GpMetafile* metafile,
    EmfPlusRecordType recordType,
    DWORD flags,
    DWORD dataSize,
    const BYTE* data
);

パラメーター

名前方向
metafileGpMetafile*in
recordTypeEmfPlusRecordTypein
flagsDWORDin
dataSizeDWORDin
dataBYTE*in

戻り値の型: Status

各言語での呼び出し定義

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

Status GdipPlayMetafileRecord(
    const GpMetafile* metafile,
    EmfPlusRecordType recordType,
    DWORD flags,
    DWORD dataSize,
    const BYTE* data
);
[DllImport("gdiplus.dll", ExactSpelling = true)]
static extern int GdipPlayMetafileRecord(
    IntPtr metafile,   // GpMetafile*
    int recordType,   // EmfPlusRecordType
    uint flags,   // DWORD
    uint dataSize,   // DWORD
    IntPtr data   // BYTE*
);
<DllImport("gdiplus.dll", ExactSpelling:=True)>
Public Shared Function GdipPlayMetafileRecord(
    metafile As IntPtr,   ' GpMetafile*
    recordType As Integer,   ' EmfPlusRecordType
    flags As UInteger,   ' DWORD
    dataSize As UInteger,   ' DWORD
    data As IntPtr   ' BYTE*
) As Integer
End Function
' metafile : GpMetafile*
' recordType : EmfPlusRecordType
' flags : DWORD
' dataSize : DWORD
' data : BYTE*
Declare PtrSafe Function GdipPlayMetafileRecord Lib "gdiplus" ( _
    ByVal metafile As LongPtr, _
    ByVal recordType As Long, _
    ByVal flags As Long, _
    ByVal dataSize As Long, _
    ByVal data As LongPtr) As Long
' VBA7前提(PtrSafe)。32bit Office では LongPtr→Long。Integer=16bit / Long=32bit / LongLong=64bit。
import ctypes
from ctypes import wintypes

GdipPlayMetafileRecord = ctypes.windll.gdiplus.GdipPlayMetafileRecord
GdipPlayMetafileRecord.restype = ctypes.c_int
GdipPlayMetafileRecord.argtypes = [
    ctypes.c_void_p,  # metafile : GpMetafile*
    ctypes.c_int,  # recordType : EmfPlusRecordType
    wintypes.DWORD,  # flags : DWORD
    wintypes.DWORD,  # dataSize : DWORD
    ctypes.POINTER(ctypes.c_ubyte),  # data : BYTE*
]
require 'fiddle'
require 'fiddle/import'

lib = Fiddle.dlopen('gdiplus.dll')
GdipPlayMetafileRecord = Fiddle::Function.new(
  lib['GdipPlayMetafileRecord'],
  [
    Fiddle::TYPE_VOIDP,  # metafile : GpMetafile*
    Fiddle::TYPE_INT,  # recordType : EmfPlusRecordType
    -Fiddle::TYPE_INT,  # flags : DWORD
    -Fiddle::TYPE_INT,  # dataSize : DWORD
    Fiddle::TYPE_VOIDP,  # data : BYTE*
  ],
  Fiddle::TYPE_INT)
#[link(name = "gdiplus")]
extern "system" {
    fn GdipPlayMetafileRecord(
        metafile: *const GpMetafile,  // GpMetafile*
        recordType: i32,  // EmfPlusRecordType
        flags: u32,  // DWORD
        dataSize: u32,  // DWORD
        data: *const u8  // BYTE*
    ) -> i32;
}
// crates: windows-sys provides ready-made bindings for this API.
$sig = @"
[DllImport("gdiplus.dll")]
public static extern int GdipPlayMetafileRecord(IntPtr metafile, int recordType, uint flags, uint dataSize, IntPtr data);
"@
$api = Add-Type -MemberDefinition $sig -Name 'gdiplus_GdipPlayMetafileRecord' -Namespace Win32 -PassThru
# $api::GdipPlayMetafileRecord(metafile, recordType, flags, dataSize, data)
#uselib "gdiplus.dll"
#func global GdipPlayMetafileRecord "GdipPlayMetafileRecord" sptr, sptr, sptr, sptr, sptr
; GdipPlayMetafileRecord varptr(metafile), recordType, flags, dataSize, varptr(data)   ; 戻り値は stat
; metafile : GpMetafile* -> "sptr"
; recordType : EmfPlusRecordType -> "sptr"
; flags : DWORD -> "sptr"
; dataSize : DWORD -> "sptr"
; data : BYTE* -> "sptr"
; ※HSP3.7は #func のため戻り値はシステム変数 stat に格納されます。
出力引数:
#uselib "gdiplus.dll"
#cfunc global GdipPlayMetafileRecord "GdipPlayMetafileRecord" var, int, int, int, var
; res = GdipPlayMetafileRecord(metafile, recordType, flags, dataSize, data)
; metafile : GpMetafile* -> "var"
; recordType : EmfPlusRecordType -> "int"
; flags : DWORD -> "int"
; dataSize : DWORD -> "int"
; data : BYTE* -> "var"
; ※出力/バッファ引数は var 方式(変数を直接渡す)。varptr 方式にも切替可。
出力引数:
; Status GdipPlayMetafileRecord(GpMetafile* metafile, EmfPlusRecordType recordType, DWORD flags, DWORD dataSize, BYTE* data)
#uselib "gdiplus.dll"
#cfunc global GdipPlayMetafileRecord "GdipPlayMetafileRecord" var, int, int, int, var
; res = GdipPlayMetafileRecord(metafile, recordType, flags, dataSize, data)
; metafile : GpMetafile* -> "var"
; recordType : EmfPlusRecordType -> "int"
; flags : DWORD -> "int"
; dataSize : DWORD -> "int"
; data : BYTE* -> "var"
; ※出力/バッファ引数は var 方式(変数を直接渡す)。varptr 方式にも切替可。
import (
	"golang.org/x/sys/windows"
	"unsafe"
)

var (
	gdiplus = windows.NewLazySystemDLL("gdiplus.dll")
	procGdipPlayMetafileRecord = gdiplus.NewProc("GdipPlayMetafileRecord")
)

// metafile (GpMetafile*), recordType (EmfPlusRecordType), flags (DWORD), dataSize (DWORD), data (BYTE*)
r1, _, err := procGdipPlayMetafileRecord.Call(
	uintptr(metafile),
	uintptr(recordType),
	uintptr(flags),
	uintptr(dataSize),
	uintptr(data),
)
_ = err  // syscall.Errno (valid when the call sets last-error)
_ = r1   // Status
function GdipPlayMetafileRecord(
  metafile: Pointer;   // GpMetafile*
  recordType: Integer;   // EmfPlusRecordType
  flags: DWORD;   // DWORD
  dataSize: DWORD;   // DWORD
  data: Pointer   // BYTE*
): Integer; stdcall;
  external 'gdiplus.dll' name 'GdipPlayMetafileRecord';
result := DllCall("gdiplus\GdipPlayMetafileRecord"
    , "Ptr", metafile   ; GpMetafile*
    , "Int", recordType   ; EmfPlusRecordType
    , "UInt", flags   ; DWORD
    , "UInt", dataSize   ; DWORD
    , "Ptr", data   ; BYTE*
    , "Int")   ; return: Status
●GdipPlayMetafileRecord(metafile, recordType, flags, dataSize, data) = DLL("gdiplus.dll", "int GdipPlayMetafileRecord(void*, int, dword, dword, void*)")
# 呼び出し: GdipPlayMetafileRecord(metafile, recordType, flags, dataSize, data)
# metafile : GpMetafile* -> "void*"
# recordType : EmfPlusRecordType -> "int"
# flags : DWORD -> "dword"
# dataSize : DWORD -> "dword"
# data : BYTE* -> "void*"
# なでしこ1は32bit・ANSI(Shift_JIS)。文字列=char*(ANSI)、ポインタ/ハンドル=void*(4byte)。