函数参考


_ClipBoard_SetData

使用指定格式放置一个数据到剪切板

#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

注意/说明

该函数执行将数据放入剪贴板的所有必须步骤.
它将分配全局内存对象, 打开剪贴板, 放入数据及关闭剪贴板.
如果需要更多控制, 可使用 _ClipBoard_SetDataEx 函数.

相关

_ClipBoard_GetData, _ClipBoard_SetDataEx, _ClipBoard_Empty, _ClipBoard_GetDataEx

示例/演示


#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