VC字体接口SDK有点怪异

  首先看看字的结构:

字体结构的Baseline/Leading/Ascent/Descent的图示_柳鲲鹏的博客-CSDN博客_ascent descent 字体

  由图中看到, 正常的接口应该是提供相应的访问功能。因为工作原因,了解了一下VC字体的接口,觉得甚是奇怪。

  • 怪异一:获取字体结构信息的办法
	font=CreateMyFont(L"宋体", fontSize);
	SelectObject(hDC,font); //将创建的字体句柄选入设备环境

	TEXTMETRIC tm;
	GetTextMetrics(hDC, &tm);

  有了字体,应该直接从字体中获取信息,为什么要经过HDC?

  • 怪异二:新建字体不能用字号,只能用高度
CreateFont 
(	height,    //字体的高度
	0,       //由系统根据高宽比选取字体最佳宽度值
	0,       //文本的倾斜度为,表示水平
	0,		 //字体的倾斜度为
	FW_HEAVY,			
	0,					//非斜体字
	0,					//无下划线
	0,					//无删除线
	GB2312_CHARSET,     //表示所用的字符集为ANSI_CHARSET
	OUT_DEFAULT_PRECIS,	//输出精度为默认精度
	CLIP_DEFAULT_PRECIS,	   //剪裁精度为默认精度
	DEFAULT_QUALITY,		   //输出质量为默认值
	DEFAULT_PITCH|FF_DONTCARE, //字间距和字体系列使用默认值
	fontName				   //字体名称
	);

  吾想指定的是字号,怎么要指定高度?这不科学啊。吾只知道字号,不知道高度,怎么办?

  有人说字号可以换算为高度,这个想法应该是错的。理由参考下文。

  • 怪异3:实际高度要加上leading

  指定height=1000,结果是:ascent=859,descent=141,leading=141。

  这是怎么回事?吾试了一下JDK,指定字号1000,结果是:ascent=860, descent=141, leading=141。这样一算正好。这可能是接口的定义不同,倒是无所谓了。

  注意ascent,为什么会差一个像素?谁错了?简单分析了一下,可能是JDK算错了。理由就是ascent+leading != 1000。

猜你喜欢

转载自blog.csdn.net/quantum7/article/details/125501576