Estrutura COLORMATCHSETUPA (icm.h)
A estrutura COLORMATCHSETUP contém informações que a função SetupColorMatchingW usa para inicializar a caixa de diálogo ColorManagement . Depois que o usuário fecha a caixa de diálogo, SetupColorMatching retorna informações sobre a seleção do usuário nessa estrutura.
Sintaxe
typedef struct _tagCOLORMATCHSETUPA {
DWORD dwSize;
DWORD dwVersion;
DWORD dwFlags;
HWND hwndOwner;
PCSTR pSourceName;
PCSTR pDisplayName;
PCSTR pPrinterName;
DWORD dwRenderIntent;
DWORD dwProofingIntent;
PSTR pMonitorProfile;
DWORD ccMonitorProfile;
PSTR pPrinterProfile;
DWORD ccPrinterProfile;
PSTR pTargetProfile;
DWORD ccTargetProfile;
DLGPROC lpfnHook;
LPARAM lParam;
PCMSCALLBACKA lpfnApplyCallback;
LPARAM lParamApplyCallback;
} COLORMATCHSETUPA, *PCOLORMATCHSETUPA, *LPCOLORMATCHSETUPA;
Membros
dwSize
Tamanho da estrutura. Deve ser definido como sizeof ( COLORMATCHSETUP ).
dwVersion
Versão da estrutura COLORMATCHSETUP . Isso deve ser definido como COLOR_MATCH_VERSION.
dwFlags
Um conjunto de sinalizadores de bits usados para inicializar a caixa de diálogo. Se definido como 0 na entrada, todos os controles assumem seus estados padrão.
Quando a caixa de diálogo retorna, esses sinalizadores são definidos para indicar a entrada do usuário.
Esse membro pode ser definido usando uma combinação dos sinalizadores a seguir.
Sinalizador | Significado |
---|---|
CMS_DISABLEICM | Se definido na entrada, esse sinalizador indicará que a caixa de marcar "Habilitar Gerenciamento de Cores" está desmarcada, desabilitando todos os outros controles. Se definido na saída, isso significa que o usuário não deseja que o gerenciamento de cores seja executado. |
CMS_ENABLEPROOFING | Se definido na entrada, esse sinalizador indica que os controles revisores de texto devem ser habilitados e a caixa Revisão de marcar está marcada. Se definido na saída, significa que o usuário deseja executar o gerenciamento de cores para um dispositivo de destino diferente da impressora selecionada. |
CMS_SETRENDERINTENT | Se definido na entrada, esse sinalizador indicará que o membro dwRenderIntent contém o valor a ser usado para inicializar o controle Intenção de Renderização. Caso contrário, o controle usará como padrão a renderização de imagem. Esse sinalizador será definido na saída se o WCS estiver habilitado. |
CMS_SETPROOFINTENT | Ignorado, a menos que CMS_ENABLEPROOFING também esteja definido. Se definido na entrada e CMS_ENABLEPROOFING também estiver definido, esse sinalizador indicará que o membro dwProofingIntent deve ser usado para inicializar o controle De intenção de renderização de destino. Caso contrário, o controle usará como padrão a renderização de imagem. Esse sinalizador será definido na saída se o revisor estiver habilitado. |
CMS_SETMONITORPROFILE | Se definido na entrada, esse sinalizador indica que o perfil de gerenciamento de cores nomeado no membro pMonitorProfile deve ser a seleção inicial no controle de perfil do monitor. Se o perfil especificado não estiver associado ao monitor, esse sinalizador será ignorado e o perfil padrão do monitor será usado. |
CMS_SETPRINTERPROFILE | Se definido na entrada, esse sinalizador indica que o perfil de gerenciamento de cores nomeado no membro pPrinterProfile deve ser a seleção inicial no controle de perfil da impressora. Se o perfil especificado não estiver associado à impressora, esse sinalizador será ignorado e o perfil padrão da impressora será usado. |
CMS_SETTARGETPROFILE | Se definido na entrada, esse sinalizador indica que o perfil de cor nomeado no membro pTargetProfile deve ser a seleção inicial no controle de perfil de destino. Se o perfil especificado não estiver instalado, esse sinalizador será ignorado e o perfil padrão da impressora será usado. Se a impressora não tiver nenhum perfil padrão, o primeiro perfil em ordem alfabética será exibido. |
CMS_USEHOOK | Esse sinalizador especifica que o membro lpfnHook contém o endereço de um procedimento de gancho e o membro lParam contém um valor a ser passado para o procedimento de gancho quando a mensagem WM_INITDIALOG é enviada. |
CMS_MONITOROVERFLOW | Esse sinalizador será definido na saída se o gerenciamento de cores for habilitado e o tamanho do buffer fornecido em ccMonitorProfile for insuficiente para o nome do perfil selecionado. GetLastError retorna ERROR_INSUFFICIENT_BUFFER nesse caso. |
CMS_PRINTERROVERFLOW | Esse sinalizador será definido na saída se o gerenciamento de cores for habilitado e o tamanho do buffer fornecido em ccPrinterProfile for insuficiente para o nome do perfil selecionado. GetLastError retorna ERROR_INSUFFICIENT_BUFFER nesse caso. |
CMS_TARGETOVERFLOW | Esse sinalizador será definido na saída se o revisor for habilitado e o tamanho do buffer fornecido em ccTargetProfile for insuficiente para o nome do perfil selecionado. GetLastError retorna ERROR_INSUFFICIENT_BUFFER nesse caso. |
CMS_USEAPPLYCALLBACK | Se definido na entrada, esse sinalizador indica que a função SetupColorMatching deve chamar a função PCMSCALLBACKW. O endereço da função de retorno de chamada está contido em lpfnApplyCallback. |
CMS_USEDESCRIPTION | Se definido na entrada, esse sinalizador instruirá a função SetupColorMatching a recuperar a descrição do perfil contida nas marcas de descrição do perfil (consulte Especificação de formato de perfil do ICC v3.4). Ele os inserirá nas caixas de edição Perfil de Monitor, Perfil de Impressora, Perfil de Dispositivo Emulado na caixa de diálogo Comum gerenciamento de cores . |
hwndOwner
O identificador de janela para o proprietário da caixa de diálogo ou NULL se a caixa de diálogo não tiver proprietário.
pSourceName
Ponteiro para uma cadeia de caracteres especificada pelo aplicativo que descreve o perfil de origem do item para o qual o gerenciamento de cores deve ser executado. Se for NULL, o controle Fonte da Imagem exibirá o nome do perfil de cor padrão do Windows.
pDisplayName
Aponta para uma cadeia de caracteres nomeando o monitor a ser usado para o gerenciamento de cores. Se esse não for o nome de um monitor válido, o primeiro monitor enumerado será usado.
pPrinterName
Aponta para uma cadeia de caracteres nomeando a impressora na qual a imagem deve ser renderizada. Se esse não for um nome de impressora válido, a impressora padrão será usada e nomeada na caixa de diálogo.
dwRenderIntent
O tipo de gerenciamento de cores desejado. Os valores válidos são:
INTENT_PERCEPTUAL
INTENT_SATURATION
INTENT_RELATIVE_COLORIMETRIC
INTENT_ABSOLUTE_COLORIMETRIC
Para obter mais informações, consulte Intenções de renderização.
dwProofingIntent
O tipo de gerenciamento de cores desejado para a imagem à prova. Os valores válidos são:
INTENT_PERCEPTUAL
INTENT_SATURATION
INTENT_RELATIVE_COLORIMETRIC
INTENT_ABSOLUTE_COLORIMETRIC
Para obter mais informações, consulte Intenções de renderização.
pMonitorProfile
Ponteiro para um buffer no qual colocar o nome do perfil de monitor selecionado pelo usuário. Se o sinalizador CMS_SETMONITORPROFILE for usado, esse sinalizador também poderá ser usado para selecionar um perfil diferente do padrão do monitor quando a caixa de diálogo for exibida pela primeira vez.
ccMonitorProfile
O tamanho do buffer apontado pelo membro pMonitorProfile , em caracteres. Se o buffer não for grande o suficiente para manter o nome selecionado, o nome será truncado para esse tamanho e ERROR_INSUFFICIENT_BUFFER será retornado. Um buffer de tamanho de MAX_PATH sempre funciona.
pPrinterProfile
Aponta para um buffer no qual colocar o nome do perfil de impressora selecionado pelo usuário. Se o sinalizador CMS_SETPRINTERPROFILE for usado, esse sinalizador também poderá ser usado para selecionar um perfil diferente do padrão da impressora quando a caixa de diálogo for exibida pela primeira vez.
ccPrinterProfile
O tamanho do buffer apontado pelo membro pPrinterProfile , em caracteres. Se o buffer não for grande o suficiente para manter o nome selecionado, o nome será truncado para esse tamanho e ERROR_INSUFFICIENT_BUFFER será retornado. Um buffer de tamanho de MAX_PATH sempre funciona.
pTargetProfile
Aponta para um buffer no qual colocar o nome do perfil de destino selecionado pelo usuário para revisão de texto. Se o sinalizador CMS_SETTARGETPROFILE for usado, esse sinalizador também poderá ser usado para selecionar um perfil diferente do padrão da impressora quando a caixa de diálogo for exibida pela primeira vez.
ccTargetProfile
O tamanho do buffer apontado pelo membro pTargetProfile , em caracteres. Se o buffer não for grande o suficiente para manter o nome selecionado, o nome será truncado para esse tamanho e ERROR_INSUFFICIENT_BUFFER será retornado. Um buffer de tamanho de MAX_PATH sempre funciona.
lpfnHook
Se o sinalizador CMS_USEHOOK estiver definido, esse membro será o endereço de um procedimento de caixa de diálogo (consulte DialogProc ) que pode filtrar ou manipular mensagens para a caixa de diálogo. O procedimento de gancho não recebe mensagens emitidas antes de WM_INITDIALOG. Ele é chamado na mensagem WM_INITDIALOG depois que o procedimento de diálogo fornecido pelo sistema processa a mensagem. Em todas as outras mensagens, o procedimento de gancho recebe a mensagem antes do procedimento fornecido pelo sistema. Se o procedimento de gancho retornar TRUE para essas mensagens, o procedimento fornecido pelo sistema não será chamado.
O procedimento de gancho pode chamar a função EndDialog .
lParam
Se o sinalizador CMS_USEHOOK estiver definido, esse membro será passado para o procedimento de gancho fornecido pelo aplicativo como o parâmetro lParam quando a mensagem WM_INITDIALOG for processada.
lpfnApplyCallback
Contém um ponteiro para uma função de retorno de chamada que é invocada quando o botão Aplicar da caixa de diálogo Gerenciamento de Cores é selecionado. Se nenhuma função de retorno de chamada for fornecida, esse membro deverá ser definido como NULL. Confira PCMSCALLBACKW.
lParamApplyCallback
Contém um valor que será passado para a função ApplyCallbackFunction por meio de seu parâmetro lParam . O significado e o conteúdo do valor são especificados pelo aplicativo.
Requisitos
Cliente mínimo com suporte | Windows 2000 Professional [somente aplicativos da área de trabalho] |
Servidor mínimo com suporte | Windows 2000 Server [somente aplicativos da área de trabalho] |
Cabeçalho | icm.h |