CDC::CreateCompatibleDC
Cria um contexto de dispositivo de armazenamento que seja compatível com o dispositivo especificado por pDC.
BOOL CreateCompatibleDC(
CDC* pDC
);
Parâmetros
- pDC
Um ponteiro para um contexto de dispositivo. Se pDC é NULO, a função cria um contexto de dispositivo de armazenamento que seja compatível com a exibição do sistema.
Valor de retorno
Diferente de zero se a função é com êxito; se não 0.
Comentários
Um contexto do dispositivo de memória é um bloco de memória que representa uma superfície de exibição. Pode ser usado para preparar imagens na memória antes de copiar-las para a superfície de dispositivo real de dispositivo correspondente.
Quando um contexto de dispositivo de memória é criado, GDI automaticamente seleciona um bitmap 1 do estoque de monochrome by-1 para ele. Funções de saída do GDI podem ser usadas com um contexto do dispositivo de memória somente se um bitmap foi criado e selecionado em esse contexto.
Essa função somente pode ser usada para criar contextos compatíveis de dispositivo para dispositivos que suportam operações de varredura. Consulte a função de membro de CDC::BitBlt para obter informações sobre as transferências de bits bloco entre contextos de dispositivo. Para determinar se um contexto de dispositivo suporta operações de varredura, consulte o recurso de varredura de RC_BITBLT na função de membro CDC::GetDeviceCaps.
Exemplo
// This handler loads a bitmap from system resources,
// centers it in the view, and uses BitBlt() to paint the bitmap
// bits.
void CDCView::DrawBitmap(CDC* pDC)
{
// load IDB_BITMAP1 from our resources
CBitmap bmp;
if (bmp.LoadBitmap(IDB_BITMAP1))
{
// Get the size of the bitmap
BITMAP bmpInfo;
bmp.GetBitmap(&bmpInfo);
// Create an in-memory DC compatible with the
// display DC we're using to paint
CDC dcMemory;
dcMemory.CreateCompatibleDC(pDC);
// Select the bitmap into the in-memory DC
CBitmap* pOldBitmap = dcMemory.SelectObject(&bmp);
// Find a centerpoint for the bitmap in the client area
CRect rect;
GetClientRect(&rect);
int nX = rect.left + (rect.Width() - bmpInfo.bmWidth) / 2;
int nY = rect.top + (rect.Height() - bmpInfo.bmHeight) / 2;
// Copy the bits from the in-memory DC into the on-
// screen DC to actually do the painting. Use the centerpoint
// we computed for the target offset.
pDC->BitBlt(nX, nY, bmpInfo.bmWidth, bmpInfo.bmHeight, &dcMemory,
0, 0, SRCCOPY);
dcMemory.SelectObject(pOldBitmap);
}
else
{
TRACE0("ERROR: Where's IDB_BITMAP1?\n");
}
}
Requisitos
Cabeçalho: afxwin.h