函数参考


_ClipBoard_GetData

使用返回剪切板中指定格式的数据

#Include <Clipboard.au3>
_ClipBoard_GetData([$iFormat = 1])

参数

$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 - 与私有格式相关的增强型图元显示格式

返回值

成功: 返回基于文本格式的文本或其他格式的二进制数据
@extended 设置为 # 字符的文本, 或 # 字符的二进制字节
失败: 返回 0

注意/说明

 该函数执行从剪贴板获取数据的所有必要步骤:
检查格式是否可用,打开剪贴板,关闭剪贴板及返回两种类型的格式数据
$CF_TEXT, $CF_OEMTEXT, 或 $CF_UNICODETEXT 类型的字符串格式数据,
 或所有其他类型的二进制格式
如果需要对剪贴板检索数据进行更好的控制, 可以使用 _ClipBoard_GetDataEx 函数.

相关

_ClipBoard_GetDataEx, _ClipBoard_SetData, _ClipBoard_SetDataEx

示例/演示


#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