Udostępnij za pośrednictwem


CWnd::OpenClipboard

Otwiera Schowek.

BOOL OpenClipboard( );

Wartość zwracana

Niezerowa, jeśli Schowka zostanie otwarty za pomocą CWnd, lub 0, jeśli inna aplikacja lub okno Schowka Otwórz.

Uwagi

Inne aplikacje nie będą mogli modyfikować w Schowku do momentu Funkcja CloseClipboard wywoływana jest funkcja Windows.

Bieżący CWnd obiektu nie staną się właściciela do Schowka Funkcja EmptyClipboard wywoływana jest funkcja Windows.

Przykład

//handler for Edit | Copy menu
void CMdiView::OnEditCopy()
{
   if (!OpenClipboard())
   {
      AfxMessageBox(_T("Cannot open the Clipboard"));
      return;
   }
   // Remove the current Clipboard contents  
   if(!EmptyClipboard())
   {
      AfxMessageBox(_T("Cannot empty the Clipboard"));
      return;  
   }

   // Get the currently selected data, hData handle to 
   // global memory of data
   CString str;
   m_Edit.GetWindowText(str);
   size_t cbStr = (str.GetLength() + 1) * sizeof(TCHAR);
   HGLOBAL hData = GlobalAlloc(GMEM_MOVEABLE, cbStr);
   memcpy_s(GlobalLock(hData), cbStr, str.LockBuffer(), cbStr);
   GlobalUnlock(hData);
   str.UnlockBuffer();

   // For the appropriate data formats...
   UINT uiFormat = (sizeof(TCHAR) == sizeof(WCHAR)) ? CF_UNICODETEXT : CF_TEXT;
   if (::SetClipboardData(uiFormat, hData) == NULL)  
   {
      AfxMessageBox(_T("Unable to set Clipboard data"));    
      CloseClipboard();
      return;  
   }  

   CloseClipboard();
}

Wymagania

Nagłówek: afxwin.h

Zobacz też

Informacje

Klasa CWnd

Wykres hierarchii

CloseClipboard

EmptyClipboard

OpenClipboard