Função PropVariantGetDoubleElem (propvarutil.h)
Extrai um único elemento duplo de uma estrutura PROPVARIANT do tipo VT_R8
, VT_VECTOR | VT_R8
ou VT_ARRAY | VT_R8
.
Sintaxe
PSSTDAPI PropVariantGetDoubleElem(
[in] REFPROPVARIANT propvar,
[in] ULONG iElem,
[out] DOUBLE *pnVal
);
Parâmetros
[in] propvar
Tipo: REFPROPVARIANT
Referência à estrutura PROPVARIANT de origem.
[in] iElem
Tipo: ULONG
Especifica o vetor ou índice de matriz; caso contrário, iElem deve ser 0.
[out] pnVal
Tipo: DOUBLE*
Quando essa função retorna, contém o valor duplo extraído.
Valor retornado
Tipo: HRESULT
Se essa função for bem-sucedida, ela retornará S_OK. Caso contrário, ele retornará um código de erro HRESULT.
Comentários
Se o PROPVARIANT de origem tiver o tipo VT_R8
, iElem deverá ser 0. Caso contrário , iElem deve ser menor que o número de elementos no vetor ou na matriz. Você pode usar PropVariantGetElementCount para obter o número de elementos no vetor ou na matriz.
O exemplo a seguir usa essa função para percorrer os valores em uma estrutura PROPVARIANT .
Exemplos
// PROPVARIANT propvar;
// assume propvar is initialized and valid
if ((propvar.vt & VT_TYPEMASK) == VT_R8)
{
UINT cElem = PropVariantGetElementCount(propvar);
HRESULT hr = <mark type="const">S_OK</mark>;
for (UINT iElem = 0; SUCCEEDED(hr) && iElem < cElem; iElem ++)
{
DOUBLE nValue;
hr = PropVariantGetDoubleElem(propvar, iElem, &nValue);
if (SUCCEEDED(hr))
{
// nValue is valid now
}
}
}
Requisitos
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 |