Compartilhar via


Função PropVariantToDoubleWithDefault (propvarutil.h)

Extrai um valor de propriedade dupla de uma estrutura PROPVARIANT . Se nenhum valor existir, o valor padrão especificado será retornado.

Sintaxe

PSSTDAPI_(DOUBLE) PropVariantToDoubleWithDefault(
  [in] REFPROPVARIANT propvarIn,
  [in] DOUBLE         dblDefault
);

Parâmetros

[in] propvarIn

Tipo: REFPROPVARIANT

Referência a uma estrutura PROPVARIANT de origem .

[in] dblDefault

Tipo: DOUBLE

Especifica o valor da propriedade padrão, para uso em que nenhum valor existe no momento.

Retornar valor

Tipo: DOUBLE

Retorna o valor duplo extraído ou padrão.

Comentários

Essa função auxiliar é usada em locais onde o aplicativo de chamada espera que um PROPVARIANT mantenha um valor duplo e gostaria de usar um valor padrão se não o fizer. Por exemplo, um aplicativo que obtém valores de um repositório de propriedades pode usá-lo para extrair com segurança o valor duplo para propriedades duplas.

Se o PROPVARIANT de origem tiver o tipo VT_R8, essa função auxiliar extrairá o valor duplo. Caso contrário, ele tentará converter o valor na estrutura PROPVARIANT em um duplo. Se o PROPVARIANT de origem tiver tipo VT_EMPTY ou uma conversão não for possível, PropVariantToDoubleWithDefault retornará o padrão fornecido por dblDefault. Consulte PropVariantChangeType para obter uma lista de conversões possíveis.

Exemplos

// IPropertyStore *ppropstore;
// Assume variable ppropstore is initialized and valid
PROPVARIANT propvar = {0};
HRESULT hr = ppropstore->GetValue(PKEY_Image_HorizontalResolution, &propvar);
if (SUCCEEDED(hr))
{
     // PKEY_Image_HorizontalResolution is expected to produce a VT_R8 or VT_EMPTY value.
     // The application developer decided to treat VT_EMPTY or invalid values as 72.0
     DOUBLE dblResolution = PropVariantToDoubleWithDefault(propvar, 72.0);
     // dblResolution is now valid.
     PropVariantClear(&propvar);
}

Requisitos

Requisito Valor
Cliente mínimo com suporte Windows XP com SP2, Windows Vista [somente aplicativos da área de trabalho]
Servidor mínimo com suporte Windows Server 2003 com SP1 [somente aplicativos da área de trabalho]
Plataforma de Destino Windows
Cabeçalho propvarutil.h
Biblioteca Propsys.lib
DLL Propsys.dll (versão 6.0 ou posterior)
Redistribuível Pesquisa da Área de Trabalho do Windows (WDS) 3.0

Confira também

InitPropVariantFromDouble

PropVariantChangeType

PropVariantToDoubleVector

VariantToDouble