使用指定格式放置一个数据到剪切板
#Include <Clipboard.au3>
_ClipBoard_SetData($vData[, $iFormat = 1])
$vData | 二进制数据或字符串格式,或设置为零值(0) (所有者必须提供数据,见下文) 注意:如果一个字符串已获得通过,并且不是 $CF_TEXT, $CF_OEMTEXT, 或 $CF_UNICODETEXT,将被视为一个 ANSI 字符串. 要强制其他类型为 Unicode 字符串,你必须传递二进制格式的数据. 另外,不要将二进制数据传递给 $CF_UNICODETEXT 格式(会造成乱码数据). 当 $vData 为 NULL(空值), 表明窗口按指定的剪贴板格式要求提供数据. 如果窗口延迟执行, 表明必须处理 $WM_RENDERFORMAT 和 $WM_RENDERALLFORMATS 信息. 果此函数调用成功: $hMemory 参数确定的对象 (译注:虽然此页未见有 $hMemory 参数, 但原英文文档确实是 $hMemory 这个词,下同) 一旦数据所有权已经转移到系统, 应用程序可能无法写入或释放数据, 但是可以锁定和读取, 直到调用 _ClipBoard_Close 函数时为止; 关闭剪贴板前, 内存必须解锁. 如果 $hMemory 参数标识为一个内存对象,对象必须使用函数与 $GMEM_MOVEABLE 标记关联. |
$iFormat | [可选参数] 指定剪切板格式: $CF_TEXT - 文本格式 $CF_BITMAP - 位图句柄 (HBITMAP) $CF_METAFILEPICT - 图片的图元文件句柄 (METAFILEPICT) $CF_SYLK - Microsoft 符号链接格式 (SYLK) $CF_DIF - 软件艺术数据( Arts' Data )交换格式 $CF_TIFF - 标记映像文件格式 $CF_OEMTEXT - OEM 字符集中包含字符的文本格式 $CF_DIB - 图位的 BITMAPINFO 结构 $CF_PALETTE - 调色板句柄 $CF_PENDATA - 扩展画笔计算数据 $CF_RIFF - RIFF 格式音频数据 $CF_WAVE - WAVE 格式音频数据 $CF_UNICODETEXT - Unicode 文本格式 $CF_ENHMETAFILE - 增强型图元文件句柄 (HENHMETAFILE) $CF_HDROP - 识别文件列表的 HDROP 句柄 $CF_LOCALE - 与剪贴板文本相关的标识符句柄 $CF_DIBV5 - 带位图颜色和图位的 BITMAPV5HEADER 结构 $CF_OWNERDISPLAY - 属主显示格式 $CF_DSPTEXT - 与私有格式相关的文字显示格式 $CF_DSPBITMAP - 与私有格式相关的位图显示格式 $CF_DSPMETAFILEPICT - 与私有格式相关的图元显示格式 $CF_DSPENHMETAFILE - 与私有格式相关的增强型图元显示格式 |
成功: | 返回数据句柄 |
失败: | 返回 0 |
#include <GUIConstantsEx.au3>
#include <Clipboard.au3>
#include <WindowsConstants.au3>
Global $iMemo
_Main()
Func _Main()
Local $btn_SetData, $btn_GetData
; 创建 GUI
GUICreate("Clipboard", 600, 450)
$iMemo = GUICtrlCreateEdit("", 2, 2, 596, 396, $WS_VSCROLL)
GUICtrlSetFont($iMemo, 9, 400, 0, "Courier New")
$btn_SetData = GUICtrlCreateButton("Set ClipBoard Data", 150, 410, 120, 30)
$btn_GetData = GUICtrlCreateButton("Get ClipBoard Data", 300, 410, 120, 30)
GUISetState()
; 循环直到用户退出
While 1
Switch GUIGetMsg()
Case $GUI_EVENT_CLOSE
ExitLoop
Case $btn_SetData
_ClipBoard_SetData("ClipBoard Library")
Case $btn_GetData
MemoWrite(_ClipBoard_GetData())
EndSwitch
WEnd
EndFunc ;==>_Main
; 写入消息到 memo
Func MemoWrite($sMessage = "")
GUICtrlSetData($iMemo, $sMessage & @CRLF, 1)
EndFunc ;==>MemoWrite