进程间通信(3) 剪贴板
生活随笔
收集整理的這篇文章主要介紹了
进程间通信(3) 剪贴板
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
1. 步驟
a. 打開剪貼板 BOOL OpenClipboard () b. 清空剪貼板 EmptyClipboard() c. 設置剪貼板數據 HANDLE SetClipboardData(UINT uFormat,HANDLE hMem ) ; d. 得到剪貼板數據 HANDLE GetClipboardData(UINT uFormat)2. HANDLE SetClipboardData(UINT uFormat,HANDLE hMem ) ;
-
uFormat
剪貼板格式, 得注冊
eg. CF_TEXT 文本格式
(每行數據以“Ox0AOxOD”(回車換行)這一-組合字符終止,并以空字符作為數據的結尾) -
hMem
指定格式的數據的句柄注:當前調用SetClipboardData函數的窗口必須是剪貼板的擁有者,而且已經open過。
3. 延遲提交技術
將hMem設置為NULL,直到有對剪貼板數據的請求時,,操作系統會向數據提供進程發送WM_RENDERFORMAT消息,數據提供進程可以響應這個消息,并在此消息的響應函數中,再一次調用SetClipboardData函數。
4. HGLOBAL GlobalAlloc( UINT uFlags, SIZE_TdwBytes);
從堆中分配內容
. uFlags取值GMEM_FIXED:某個確定的內容GMEM_MOVEABLE: 不是實際內存的地址,而是指向該進程中句柄表條目的指針,在該條目中包含有實際分配的內存指針。
5.code
server:
if(OpenClipboard()){CString str;HANDLE hClip;char *pBuf;EmptyClipboard();GetDlgItemText(IDC_EDIT_SEND,str);hClip=GlobalAlloc(GMEM_MOVEABLE,str.GetLength()+1);pBuf=(char*)GlobalLock(hClip);strcpy(pBuf,str);GlobalUnlock(hClip);SetClipboardData(CF_TEXT,hClip);CloseClipboard();}client:
if(OpenClipboard()){if(IsClipboardFormatAvailable(CF_TEXT)){HANDLE hClip;char *pBuf;hClip=GetClipboardData(CF_TEXT);pBuf=(char*)GlobalLock(hClip);GlobalUnlock(hClip);SetDlgItemText(IDC_EDIT_RECV,pBuf);}CloseClipboard();}6. qt eg.
//copyQGuiApplication::clipboard()->setImage(image); //paste if (const QMimeData *mimeData = QGuiApplication::clipboard()->mimeData()) {if (mimeData->hasImage()) {const QImage image = qvariant_cast<QImage>(mimeData->imageData());【引用】
總結
以上是生活随笔為你收集整理的进程间通信(3) 剪贴板的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 区块链BaaS云服务(10)用友iuap
- 下一篇: 进程间通信(4) 匿名管道