【VBA×WindowsAPI】OpenClipboard関数の使い方

OpenClipboard関数

OpenClipboard関数はクリップボードを開く関数です。
クリップボードを開くことで、プログラム(VBA)がクリップボード内のデータにアクセスすることができるようになります。これによりクリップボードを空にしたり、クリップボード内にあるデータを取得したり、クリップボード内にデータをセットしたりと様々な操作を行うことができるようになります。

OpenClipboard関数を実行してクリップボードが開かれるとき、クリップボードは他のアプリケーションが内容を変更できないようにして開かれます。これによりプログラム(VBA)でクリップボード内の操作を行うときにプログラム外部でクリップボードの操作が行われても影響を受けることが無いようになっています。ただし、プログラム終了時には必ずCloseClipboard関数を使ってクリップボードを閉じる必要があります。(※他のアプリケーションがクリップボードにアクセスできないままになります)

クリップボード関連の関数としては下記のような様々な関数が存在しています。

関数名 内容
OpenClipboard関数 クリップボードを開く
CloseClipboard関数 クリップボードを閉じる
EmptyClipboard関数 クリップボード内のデータを空にする
GetClipboardData関数 クリップボード内のデータを取得する
SetClipboardData関数 クリップボード内にデータをセットにする
IsClipboardFormatAvailable関数 クリップボード内のデータのフォーマットを調べる

実際にクリップボードとデータのやり取りをするコードを書く際は、これら関数だけでなくメモリを操作する系の関数(GlobalAlloc関数やMoveMemory関数など)と合わせて利用されることが多いです。

 

使用方法

OpenClipboard関数を使用するにはあらかじめ関数の宣言しておく必要があります。
※宣言をしないと関数は使えずにエラーとなるので書き忘れに注意しましょう。

使用しているWindowsが32bitか64bitかによって宣言時に書く文言が違います。
環境に合わせて以下のいずれかをコードの一番初め(Option Explicitの次の行あたり)に書いておくことで、そのモジュール内で各関数を使うことができるようになります。

 icon-code  64bit  

Declare PtrSafe Function OpenClipboard Lib “user32” (ByVal hwnd As LongPtr) As Long

icon-code  32bit  

Declare Function OpenClipboard Lib “user32” (ByVal hwnd As Long) As Long

上記のどちらを書けばいいかわからない場合は以下のコードをコピペして、モジュールの最上部に書いておきましょう。この構文を書いておくことで自動的に使うことのできる方の構文が使用されます。
VBE上では使えない方の構文が赤色で表示される場合がありますが、実行に影響はありません。

 
各関数の宣言文は「Private/Public」を付けて各関数の有効範囲を指定することもできます。

Private Declare PtrSafe Function~ :モジュール内でのみ呼び出し有効
Public Declare PtrSafe Function~ :モジュール外で呼び出し有効

 
 

構文

OpenClipboard関数の構文は下記のように書きます。

icon-code OpenClipboard関数 

lRet = OpenClipboard(hwnd)

引数

 hwnd   (64bit:LongPtr型 / 32bit:Long型)

クリップボードと関連付けるウィンドウのハンドルを指定します。
NULL値(0)を指定した場合、クリップボードは現在のタスクに紐づけられます。
基本的にはNULL値(0)を設定すれば問題ないです。
 

戻り値

 lRet   (Long型) 

戻り値は関数が成功した場合は「0以外」です。
失敗した場合は「0」が返されます。

 

サンプルコード

以下はOpenClipboard関数EmptyClipboard関数CloseClipboard関数を使って、クリップボード内のデータを空にするサンプルコードです。クリップボード内のデータを取得したり、クリップボードに別のデータをセットしたりする操作はもっと複雑になりますが、処理のはじめにOpenClipboard関数でクリップボードを開き、終わりにCloseClipboard関数でクリップボードを閉じる流れは同じです。

 

 icon-share-square  VBA×WindowsAPIまとめページ

その他のWindowsAPI関数は下記ページにまとまっているので合わせて参照下さい。

 icon-share-square  参考

Microsoft公式:OpenClipboard 関数 (winuser.h) – Win32 apps

2023年7月23日Excel, VBA, Windows API

Posted by Lic