IDWriteFontFace5::GetFontAxisValues 方法(dwrite_3.h)

检索字体使用的轴值列表。

语法

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

参数

[out] fontAxisValues

类型:DWRITE_FONT_AXIS_VALUE*

指向 DWRITE_FONT_AXIS_VALUE 结构的数组的指针,GetFontAxisValues 写入字体轴值列表。 你负责管理此数组的大小和生存期。 调用 GetFontAxisValueCount 以确定要分配的数组的大小。

fontAxisValueCount

类型:UINT32

要写入 fontAxisValues指向的内存块的最大字体轴值数。

返回值

类型:HRESULT

如果函数成功,则返回 S_OK。 否则,它将返回 HRESULT错误代码

返回值 描述
E_INVALIDARG fontAxisValueCountGetFontAxisValueCount返回的值不匹配。

言论

这些值以字体定义的规范顺序返回,并固定到支持的实际范围。 它不一定与传递给 CreateFontFace的轴值数组相同。

例子

// 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;
}

要求

要求 价值
最低支持的客户端 Windows 10 内部版本 16299
支持的最低服务器 Windows 10 内部版本 16299
目标平台 窗户
标头 dwrite_3.h
Dwrite.lib