Método IDWriteFontFace5::GetFontAxisValues (dwrite_3.h)

Recupera a lista de valores de eixo usados pela fonte.

Sintaxe

HRESULT GetFontAxisValues(
  [out] DWRITE_FONT_AXIS_VALUE *fontAxisValues,
        UINT32                 fontAxisValueCount
);

Parâmetros

[out] fontAxisValues

Tipo: DWRITE_FONT_AXIS_VALUE*

Um ponteiro para uma matriz de estruturas de DWRITE_FONT_AXIS_VALUE nas quais GetFontAxisValues grava a lista de valores do eixo da fonte. Você é responsável por gerenciar o tamanho e o tempo de vida dessa matriz. Chame GetFontAxisValueCount para determinar o tamanho da matriz a ser alocada.

fontAxisValueCount

Tipo: UINT32

O número máximo de valores de eixo de fonte a serem gravados no bloco de memória apontado por fontAxisValues.

Valor de retorno

Tipo: HRESULT

Se a função for bem-sucedida, ela retornará S_OK. Caso contrário, ele retornará um de código de erro HRESULT.

Valor de retorno Descrição
E_INVALIDARG fontAxisValueCount não corresponde ao valor retornado por GetFontAxisValueCount.

Observações

Os valores são retornados na ordem canônica definida pela fonte, presa ao intervalo real com suporte. Não é necessariamente a mesma matriz de valores de eixo que você passou para CreateFontFace.

Exemplos

// main.cpp
#include <unknwn.h>
#include <winrt/base.h>
#include <dwrite_3.h>

int main()
{
	winrt::init_apartment();

	winrt::com_ptr<IDWriteFactory> factory;

	winrt::check_hresult(::DWriteCreateFactory(
		DWRITE_FACTORY_TYPE_SHARED,
		__uuidof(factory),
		reinterpret_cast<IUnknown**>(factory.put())));

	std::wstring filePath{ L"C:\\WINDOWS\\FONTS\\AGENCYB.TTF" };

	winrt::com_ptr<IDWriteFontFile> fontFile;

	factory->CreateFontFileReference(
		filePath.c_str(),
		nullptr,
		fontFile.put());

	std::array<IDWriteFontFile*, 1> fontFiles{ fontFile.get() };

	winrt::com_ptr<IDWriteFontFace> fontFace;

	winrt::check_hresult(factory->CreateFontFace(
		DWRITE_FONT_FACE_TYPE_TRUETYPE,
		1,
		fontFiles.data(),
		0,
		DWRITE_FONT_SIMULATIONS_NONE,
		fontFace.put()
	));

	winrt::com_ptr<IDWriteFontFace5> fontFace5{ fontFace.as<IDWriteFontFace5>() };
	
	UINT32 axisValueCount{ fontFace5->GetFontAxisValueCount() };

	DWRITE_FONT_AXIS_VALUE* axisValues{ new DWRITE_FONT_AXIS_VALUE[axisValueCount] };

	winrt::check_hresult(
		fontFace5->GetFontAxisValues(axisValues, axisValueCount));

	DWRITE_FONT_AXIS_VALUE* eachAxisValue{ axisValues };

	for (int ix = 0; ix < axisValueCount; ++ix, ++eachAxisValue)
	{
		printf("%zu,%f\n\r", eachAxisValue->axisTag, eachAxisValue->value);
	}

	delete[] axisValues;
}

Requisitos

Requisito Valor
de cliente com suporte mínimo Windows 10 Build 20348
servidor com suporte mínimo Windows 10 Build 20348
da Plataforma de Destino Windows
cabeçalho dwrite_3.h
biblioteca Dwrite.lib