剪貼簿:使用 OLE 剪貼簿機制
OLE 使用標準格式和部分 OLE 特定格式來透過剪貼簿傳輸資料。
當您將剪下或複製應用程式中的資料時,資料會儲存在剪貼簿上以便稍後在貼上作業中使用。 這個資料會有各種格式。 當使用者選取貼上剪貼簿中的資料時,應用程式可以選擇使用哪一種格式。 除非使用者明確要求某種格式,否則應使用 [選擇性貼上] 寫入應用程式以選擇提供最多資訊的格式。 在繼續之前,您可能想要閱讀 資料物件和資料來源 (OLE) 主題。 那些主題說明在應用程式中資料傳輸如何運作以及如何實作等基本知識。
Windows 會定義數種標準格式,可用於透過剪貼簿傳輸資料。 這些包括中繼檔、文字和點陣圖等。 OLE 也定義許多 OLE 特定格式。 對於除了這些標準格式外還需要提供更詳細資料的應用程式,最好能註冊它們自己的自訂剪貼簿格式。 使用 WIN32 API 函式 RegisterClipboardFormat 來執行此動作。
例如,Microsoft Excel 會註冊試算表的自訂格式。 這個格式會傳輸比諸如點陣圖更多更詳細的資訊。 將這個資料貼入支援試算表格式的應用程式時,試算表的所有公式和值都會保留且可在必要時進行更新。 Microsoft Excel 放在剪貼簿上的資料格式也可以貼成 OLE 項目。 所有 OLE 文件容器都可以將此資訊貼上為內嵌項目。 也可以使用 Microsoft Excel 變更此內嵌項目。 剪貼簿還包含試算表中所選取範圍的影像的簡單點陣圖。 這也可以貼入 OLE 文件容器或點陣圖編輯器 (如小畫家) 中。 不過,在點陣圖的情況下,沒有方法可將資料當做試算表來操作。
若要從剪貼簿擷取最大量的資訊,應用程式應該在從剪貼簿貼上資料之前,先檢查這些自訂格式。
例如,若要啟用 [剪下] 命令,您可以撰寫類似如下的處理常式:
void CMyListView::OnEditCut()
{
// Create an OLE data source on the heap
COleDataSource* pData = new COleDataSource;
// Get the currently selected data
HGLOBAL hGlob = GlobalAlloc(GMEM_FIXED, 64);
strcpy_s((char*)hGlob, 64, "Current selection\r\n");
// For the appropriate data formats...
pData->CacheGlobalData( CF_TEXT, hGlob );
// The Clipboard now owns the allocated memory
// and will delete this data object
// when new data is put on the Clipboard
pData->SetClipboard();
}