ホーム › Graphics.Printing › SetJobW
SetJobW
関数印刷ジョブの設定変更や一時停止・削除を行う(Unicode版)。
シグネチャ
// winspool.drv (Unicode / -W)
#include <windows.h>
BOOL SetJobW(
PRINTER_HANDLE hPrinter,
DWORD JobId,
DWORD Level,
BYTE* pJob, // optional
DWORD Command
);パラメーター
| 名前 | 型 | 方向 |
|---|---|---|
| hPrinter | PRINTER_HANDLE | in |
| JobId | DWORD | in |
| Level | DWORD | in |
| pJob | BYTE* | inoptional |
| Command | DWORD | in |
戻り値の型: BOOL
各言語での呼び出し定義
// winspool.drv (Unicode / -W)
#include <windows.h>
BOOL SetJobW(
PRINTER_HANDLE hPrinter,
DWORD JobId,
DWORD Level,
BYTE* pJob, // optional
DWORD Command
);[return: MarshalAs(UnmanagedType.Bool)]
[DllImport("winspool.drv", CharSet = CharSet.Unicode, ExactSpelling = true)]
static extern bool SetJobW(
PRINTER_HANDLE hPrinter, // PRINTER_HANDLE
uint JobId, // DWORD
uint Level, // DWORD
IntPtr pJob, // BYTE* optional
uint Command // DWORD
);<DllImport("winspool.drv", CharSet:=CharSet.Unicode, ExactSpelling:=True)>
Public Shared Function SetJobW(
hPrinter As PRINTER_HANDLE, ' PRINTER_HANDLE
JobId As UInteger, ' DWORD
Level As UInteger, ' DWORD
pJob As IntPtr, ' BYTE* optional
Command As UInteger ' DWORD
) As Boolean
End Function' hPrinter : PRINTER_HANDLE
' JobId : DWORD
' Level : DWORD
' pJob : BYTE* optional
' Command : DWORD
Declare PtrSafe Function SetJobW Lib "winspool.drv" ( _
ByVal hPrinter As LongPtr, _
ByVal JobId As Long, _
ByVal Level As Long, _
ByVal pJob As LongPtr, _
ByVal Command As Long) As Long
' Unicode(W): 文字列は ByVal As LongPtr とし StrPtr(unicodeStr) を渡す
' VBA7前提(PtrSafe)。32bit Office では LongPtr→Long。Integer=16bit / Long=32bit / LongLong=64bit。import ctypes
from ctypes import wintypes
SetJobW = ctypes.windll.LoadLibrary("winspool.drv").SetJobW
SetJobW.restype = wintypes.BOOL
SetJobW.argtypes = [
PRINTER_HANDLE, # hPrinter : PRINTER_HANDLE
wintypes.DWORD, # JobId : DWORD
wintypes.DWORD, # Level : DWORD
ctypes.POINTER(ctypes.c_ubyte), # pJob : BYTE* optional
wintypes.DWORD, # Command : DWORD
]require 'fiddle'
require 'fiddle/import'
lib = Fiddle.dlopen('winspool.drv')
SetJobW = Fiddle::Function.new(
lib['SetJobW'],
[
Fiddle::TYPE_VOIDP, # hPrinter : PRINTER_HANDLE
-Fiddle::TYPE_INT, # JobId : DWORD
-Fiddle::TYPE_INT, # Level : DWORD
Fiddle::TYPE_VOIDP, # pJob : BYTE* optional
-Fiddle::TYPE_INT, # Command : DWORD
],
Fiddle::TYPE_INT)
# Wide strings: pass str.encode("UTF-16LE") + "\x00\x00"#[link(name = "winspool.drv")]
extern "system" {
fn SetJobW(
hPrinter: PRINTER_HANDLE, // PRINTER_HANDLE
JobId: u32, // DWORD
Level: u32, // DWORD
pJob: *mut u8, // BYTE* optional
Command: u32 // DWORD
) -> i32;
}
// crates: windows-sys provides ready-made bindings for this API.$sig = @"
[return: MarshalAs(UnmanagedType.Bool)]
[DllImport("winspool.drv", CharSet = CharSet.Unicode)]
public static extern bool SetJobW(PRINTER_HANDLE hPrinter, uint JobId, uint Level, IntPtr pJob, uint Command);
"@
$api = Add-Type -MemberDefinition $sig -Name 'winspool.drv_SetJobW' -Namespace Win32 -PassThru
# $api::SetJobW(hPrinter, JobId, Level, pJob, Command)#uselib "winspool.drv"
#func global SetJobW "SetJobW" wptr, wptr, wptr, wptr, wptr
; SetJobW hPrinter, JobId, Level, varptr(pJob), Command ; 戻り値は stat
; hPrinter : PRINTER_HANDLE -> "wptr"
; JobId : DWORD -> "wptr"
; Level : DWORD -> "wptr"
; pJob : BYTE* optional -> "wptr"
; Command : DWORD -> "wptr"
; ※値渡し構造体は直接渡せません。intにパック、または var で構造体変数を渡してください。
; ※HSP3.7は #func のため戻り値はシステム変数 stat に格納されます。出力引数:
#uselib "winspool.drv" #cfunc global SetJobW "SetJobW" int, int, int, var, int ; res = SetJobW(hPrinter, JobId, Level, pJob, Command) ; hPrinter : PRINTER_HANDLE -> "int" ; JobId : DWORD -> "int" ; Level : DWORD -> "int" ; pJob : BYTE* optional -> "var" ; Command : DWORD -> "int" ; ※値渡し構造体は直接渡せません。intにパック、または var で構造体変数を渡してください。 ; ※出力/バッファ引数は var 方式(変数を直接渡す)。varptr 方式にも切替可。#uselib "winspool.drv" #cfunc global SetJobW "SetJobW" int, int, int, sptr, int ; res = SetJobW(hPrinter, JobId, Level, varptr(pJob), Command) ; hPrinter : PRINTER_HANDLE -> "int" ; JobId : DWORD -> "int" ; Level : DWORD -> "int" ; pJob : BYTE* optional -> "sptr" ; Command : DWORD -> "int" ; ※値渡し構造体は直接渡せません。intにパック、または var で構造体変数を渡してください。 ; ※出力/バッファ引数はポインタ方式(token=sptr / 呼び出しは varptr(変数))。
出力引数:
; BOOL SetJobW(PRINTER_HANDLE hPrinter, DWORD JobId, DWORD Level, BYTE* pJob, DWORD Command) #uselib "winspool.drv" #cfunc global SetJobW "SetJobW" int, int, int, var, int ; res = SetJobW(hPrinter, JobId, Level, pJob, Command) ; hPrinter : PRINTER_HANDLE -> "int" ; JobId : DWORD -> "int" ; Level : DWORD -> "int" ; pJob : BYTE* optional -> "var" ; Command : DWORD -> "int" ; ※値渡し構造体は直接渡せません。intにパック、または var で構造体変数を渡してください。 ; ※出力/バッファ引数は var 方式(変数を直接渡す)。varptr 方式にも切替可。; BOOL SetJobW(PRINTER_HANDLE hPrinter, DWORD JobId, DWORD Level, BYTE* pJob, DWORD Command) #uselib "winspool.drv" #cfunc global SetJobW "SetJobW" int, int, int, intptr, int ; res = SetJobW(hPrinter, JobId, Level, varptr(pJob), Command) ; hPrinter : PRINTER_HANDLE -> "int" ; JobId : DWORD -> "int" ; Level : DWORD -> "int" ; pJob : BYTE* optional -> "intptr" ; Command : DWORD -> "int" ; ※値渡し構造体は直接渡せません。intにパック、または var で構造体変数を渡してください。 ; ※出力/バッファ引数はポインタ方式(token=intptr / 呼び出しは varptr(変数))。
import (
"golang.org/x/sys/windows"
"unsafe"
)
var (
winspool_drv = windows.NewLazySystemDLL("winspool.drv")
procSetJobW = winspool_drv.NewProc("SetJobW")
)
// hPrinter (PRINTER_HANDLE), JobId (DWORD), Level (DWORD), pJob (BYTE* optional), Command (DWORD)
r1, _, err := procSetJobW.Call(
uintptr(hPrinter),
uintptr(JobId),
uintptr(Level),
uintptr(pJob),
uintptr(Command),
)
_ = err // syscall.Errno (valid when the call sets last-error)
_ = r1 // BOOLfunction SetJobW(
hPrinter: PRINTER_HANDLE; // PRINTER_HANDLE
JobId: DWORD; // DWORD
Level: DWORD; // DWORD
pJob: Pointer; // BYTE* optional
Command: DWORD // DWORD
): BOOL; stdcall;
external 'winspool.drv' name 'SetJobW';result := DllCall("winspool.drv\SetJobW"
, "Ptr", hPrinter ; PRINTER_HANDLE
, "UInt", JobId ; DWORD
, "UInt", Level ; DWORD
, "Ptr", pJob ; BYTE* optional
, "UInt", Command ; DWORD
, "Int") ; return: BOOL●SetJobW(hPrinter, JobId, Level, pJob, Command) = DLL("winspool.drv", "bool SetJobW(void*, dword, dword, void*, dword)")
# 呼び出し: SetJobW(hPrinter, JobId, Level, pJob, Command)
# hPrinter : PRINTER_HANDLE -> "void*"
# JobId : DWORD -> "dword"
# Level : DWORD -> "dword"
# pJob : BYTE* optional -> "void*"
# Command : DWORD -> "dword"
# なでしこ1は32bit・ANSI(Shift_JIS)。文字列=char*(ANSI)、ポインタ/ハンドル=void*(4byte)。
# ※-W(Unicode)関数。なでしこ1はANSIのため -A 版の利用を推奨。