Estrutura VIDEOPARAMETERS (tvout.h)
O driver de miniporto de vídeo recebe um ponteiro para uma estrutura VIDEOPARAMETERS no membro InputBuffer de um VIDEO_REQUEST_PACKET quando a solicitação IOCTL é IOCTL_VIDEO_HANDLE_VIDEOPARAMETERS. Dependendo do membro dwCommand da estrutura VIDEOPARAMETERS, o driver de miniport deve obter ou definir os recursos de proteção de cópia e conector de televisão do dispositivo.
Sintaxe
typedef struct _VIDEOPARAMETERS {
GUID Guid;
ULONG dwOffset;
ULONG dwCommand;
ULONG dwFlags;
ULONG dwMode;
ULONG dwTVStandard;
ULONG dwAvailableModes;
ULONG dwAvailableTVStandard;
ULONG dwFlickerFilter;
ULONG dwOverScanX;
ULONG dwOverScanY;
ULONG dwMaxUnscaledX;
ULONG dwMaxUnscaledY;
ULONG dwPositionX;
ULONG dwPositionY;
ULONG dwBrightness;
ULONG dwContrast;
ULONG dwCPType;
ULONG dwCPCommand;
ULONG dwCPStandard;
ULONG dwCPKey;
ULONG bCP_APSTriggerBits;
UCHAR bOEMCopyProtection[256];
} VIDEOPARAMETERS, *PVIDEOPARAMETERS, *LPVIDEOPARAMETERS;
Membros
Guid
Especifica o GUID (identificador global exclusivo) para essa estrutura {02C62061-1097-11d1-920F-00A024DF156E}. Um driver de miniporto de vídeo deve verificar o GUID no início da estrutura antes de processar a estrutura.
dwOffset
É reservado e deve ser ignorado pelo driver de miniporto de vídeo.
dwCommand
Indica a ação a ser executada pelo driver. Esse membro pode ser um dos seguintes valores:
VP_COMMAND_GET
O driver de miniporte deve retornar todos os recursos do conector de TV do dispositivo, as configurações atuais do conector de TV, os recursos de proteção de cópia e as configurações atuais de proteção de cópia definindo os sinalizadores apropriados em dwFlags e definindo os valores dos membros que correspondem a esses sinalizadores definidos.
VP_COMMAND_SET
O driver de miniporte deve definir o conector de TV e copiar o hardware de proteção de acordo com os membros dessa estrutura que correspondem aos sinalizadores definidos em dwFlags.
dwFlags
Indica quais membros dessa estrutura contêm dados válidos. Quando dwCommand é VP_COMMAND_GET, o driver deve definir os bits apropriados neste membro para indicar em quais membros correspondentes ele retornou dados válidos. Quando dwCommand é VP_COMMAND_SET, o driver deve definir a funcionalidade no hardware de acordo com os valores nos membros que correspondem aos bits definidos neste membro. Esse membro pode ser um OR bit a bit dos valores listados na primeira coluna da tabela a seguir.
Sinalizador | Membros correspondentes | Comandos |
---|---|---|
VP_FLAGS_BRIGHTNESS | dwBrightness | get/set |
VP_FLAGS_CONTRAST | dwContrast | get/set |
VP_FLAGS_COPYPROTECT |
dwCPType
dwCPCommand dwCPStandard dwCPKey bCP_APSTriggerBits bOEMCopyProtection |
get/set set get set set get/set |
VP_FLAGS_FLICKER | dwFlickerFilter | get/set |
VP_FLAGS_MAX_UNSCALED |
dwMaxUnscaledX
dwMaxUnscaledY |
get get |
VP_FLAGS_OVERSCAN |
dwOverscanX
dwOverscanY |
get/set get/set |
VP_FLAGS_POSITION |
dwPositionX
dwPositionY |
get/set get/set |
VP_FLAGS_TV_MODE |
Dwmode
dwAvailableModes |
get/set get |
VP_FLAGS_TV_STANDARD |
dwTVStandard
dwAvailableTVStandard |
get/set get |
dwMode
Especifica o modo de reprodução atual. Esse membro é válido para os comandos VP_COMMAND_SET e VP_COMMAND_GET e pode ser um dos seguintes valores:
VP_MODE_TV_PLAYBACK
Descreve um conjunto ideal de campos para reprodução de vídeo, com o filtro de cintilação desativado e a exibição overscan ativada.
VP_MODE_WIN_GRAPHICS
Descreve as configurações de exibição ideais para exibição do Windows, com o filtro máximo de cintilação ativado e qualquer exibição overscan desativada.
dwTVStandard
É o atual padrão mundial de televisão. Esse membro é válido para os comandos VP_COMMAND_SET e VP_COMMAND_GET e pode ser um dos seguintes valores:
VP_TV_STANDARD_NTSC_M
VP_TV_STANDARD_NTSC_M_J
VP_TV_STANDARD_NTSC_433
VP_TV_STANDARD_PAL_B
VP_TV_STANDARD_PAL_D
VP_TV_STANDARD_PAL_G
VP_TV_STANDARD_PAL_H
VP_TV_STANDARD_PAL_I
VP_TV_STANDARD_PAL_M
VP_TV_STANDARD_PAL_N
VP_TV_STANDARD_PAL_60
VP_TV_STANDARD_SECAM_B
VP_TV_STANDARD_SECAM_D
VP_TV_STANDARD_SECAM_G
VP_TV_STANDARD_SECAM_H
VP_TV_STANDARD_SECAM_K
VP_TV_STANDARD_SECAM_K1
VP_TV_STANDARD_SECAM_L
VP_TV_STANDARD_SECAM_L1
VP_TV_STANDARD_WIN_VGA
dwAvailableModes
Indica os modos de reprodução dos quais o dispositivo é capaz. Esse membro só é válido para o comando VP_COMMAND_GET e pode ser um OR bit a bit dos seguintes valores:
VP_MODE_TV_PLAYBACK
VP_MODE_WIN_GRAPHICS
dwAvailableTVStandard
Especifica todos os padrões de televisão mundiais disponíveis. Esse membro só é válido para o comando VP_COMMAND_GET e pode ser um OR bit a bit dos seguintes valores:
VP_TV_STANDARD_NTSC_M
VP_TV_STANDARD_NTSC_M_J
VP_TV_STANDARD_NTSC_433
VP_TV_STANDARD_PAL_B
VP_TV_STANDARD_PAL_D
VP_TV_STANDARD_PAL_G
VP_TV_STANDARD_PAL_H
VP_TV_STANDARD_PAL_I
VP_TV_STANDARD_PAL_M
VP_TV_STANDARD_PAL_N
VP_TV_STANDARD_PAL_60
VP_TV_STANDARD_SECAM_B
VP_TV_STANDARD_SECAM_D
VP_TV_STANDARD_SECAM_G
VP_TV_STANDARD_SECAM_H
VP_TV_STANDARD_SECAM_K
VP_TV_STANDARD_SECAM_K1
VP_TV_STANDARD_SECAM_L
VP_TV_STANDARD_SECAM_L1
VP_TV_STANDARD_WIN_VGA
dwFlickerFilter
É um valor em décimos de uma porcentagem que indica o estado do filtro de cintilação. Esse membro pode ser um valor entre [0.1000] e é válido para VP_COMMAND_GET e VP_COMMAND_SET.
dwOverScanX
É um valor em décimos de um percentual que indica a quantidade de overscan em x. Esse membro pode ser um valor entre [0.1000] e é válido para VP_COMMAND_GET e VP_COMMAND_SET.
dwOverScanY
É um valor em décimos de um percentual que indica a quantidade de overscan em y. Esse membro pode ser um valor entre [0.1000] e é válido para VP_COMMAND_GET e VP_COMMAND_SET.
dwMaxUnscaledX
É a resolução x máxima que a TV pode exibir sem que o hardware dimensione a imagem de vídeo. O driver de miniporta deve definir um valor nesse membro quando dwCommand é VP_COMMAND_GET. Esse membro é inválido para VP_COMMAND_SET.
dwMaxUnscaledY
É a resolução máxima y que a TV pode exibir sem que o hardware dimensione a imagem de vídeo. O driver de miniporta deve definir um valor nesse membro quando dwCommand é VP_COMMAND_GET. Esse membro é inválido para VP_COMMAND_SET.
dwPositionX
É o valor usado pelo hardware para determinar a posição x atual da imagem na TV. Esse membro é especificado em pixels e é válido para VP_COMMAND_GET e VP_COMMAND_SET.
dwPositionY
É o valor usado pelo hardware para determinar a posição y atual da imagem na TV. Esse membro é especificado em linhas de verificação e é válido para VP_COMMAND_GET e VP_COMMAND_SET.
dwBrightness
É um valor percentual que indica a configuração de brilho na TV. Esse membro pode ser um valor entre [0,100] e é válido para VP_COMMAND_GET e VP_COMMAND_SET.
dwContrast
É um valor percentual que indica a configuração de contraste na TV. Esse membro pode ser um valor entre [0,100] e é válido para VP_COMMAND_GET e VP_COMMAND_SET.
dwCPType
Especifica o tipo de proteção de cópia compatível com o dispositivo. Esse membro é válido para os comandos VP_COMMAND_SET e VP_COMMAND_GET e pode ser CP_TYPE_APS_TRIGGER.
dwCPCommand
É o comando de proteção de cópia. Esse membro só é válido para o comando VP_COMMAND_SET e pode ser um dos seguintes valores:
VP_CP_CMD_ACTIVATE
O driver de miniporta deve ativar a proteção de cópia e gerar e retornar uma chave de proteção de cópia exclusiva em dwCPKey.
VP_CP_CMD_CHANGE
Se a chave de proteção de cópia em dwCPKey for válida, o driver de miniporte deverá alterar a proteção de cópia com base nos dados de gatilho no bCP_APSTriggerBits.
VP_CP_CMD_DEACTIVATE
Se a chave de proteção de cópia em dwCPKey for válida, o driver de miniporte deverá desativar a proteção de cópia.
dwCPStandard
São os padrões de TV para os quais os tipos de proteção de cópia estão disponíveis. Esse membro só é válido para o comando VP_COMMAND_GET e pode ser um OR bit a bit dos seguintes valores:
VP_TV_STANDARD_NTSC_M
VP_TV_STANDARD_NTSC_M_J
VP_TV_STANDARD_NTSC_433
VP_TV_STANDARD_PAL_B
VP_TV_STANDARD_PAL_D
VP_TV_STANDARD_PAL_G
VP_TV_STANDARD_PAL_H
VP_TV_STANDARD_PAL_I
VP_TV_STANDARD_PAL_M
VP_TV_STANDARD_PAL_N
VP_TV_STANDARD_PAL_60
VP_TV_STANDARD_SECAM_B
VP_TV_STANDARD_SECAM_D
VP_TV_STANDARD_SECAM_G
VP_TV_STANDARD_SECAM_H
VP_TV_STANDARD_SECAM_K
VP_TV_STANDARD_SECAM_K1
VP_TV_STANDARD_SECAM_L
VP_TV_STANDARD_SECAM_L1
VP_TV_STANDARD_WIN_VGA
dwCPKey
É uma chave de proteção de cópia gerada pelo driver que é exclusiva para essa instância do driver. Esse membro é válido somente para o comando VP_COMMAND_SET. O driver de miniporta gera e retorna essa chave quando dwCPCommand é definido como VP_CP_CMD_ACTIVATE. O chamador deve definir essa chave quando o campo dwCPCommand for VP_CP_CMD_DEACTIVATE ou VP_CP_CMD_CHANGE. Se o chamador definir uma chave incorreta, o driver não deverá alterar as configurações atuais de proteção de cópia.
bCP_APSTriggerBits
Especifica dados de bits de gatilho do APS (sistema de proteção analógico) de DVD. Os bits zero e 1 são válidos. Esse membro é válido somente para o comando VP_COMMAND_SET.
bOEMCopyProtection[256]
Dados de proteção de cópia específicos do OEM. Esse membro é válido para os comandos VP_COMMAND_SET e VP_COMMAND_GET.
Requisitos
Requisito | Valor |
---|---|
Cabeçalho | tvout.h (inclua Tvout.h) |