linux, c++, xft:如何使用它

linux, C++, xft : how to use it?

本文关键字:何使用 xft c++ linux      更新时间:2023-10-16

我尝试使用Xft,教程,好吧,让他们称之为教程…看起来像是在朝鲜集中营里写的…我也找到了这个。让我一步一步来:

// g++ XftTest.cc -lX11 -lXft `pkg-config --cflags freetype2`
#include<unistd.h>
#include<X11/Xlib.h>
#include<X11/Xutil.h>
#include<X11/Xft/Xft.h>
int main()
{
  Display *display;
  XftFont      *font;
  XftDraw      *xftdraw;
  XRenderColor xrcolor;
  XftColor     xftcolor;
  display = XOpenDisplay(0);
  Window XP = XCreateSimpleWindow(display,DefaultRootWindow(display),0,0,360,90,0,0,0);
  XMapWindow(display,XP);
  font = NULL; /* added 6/16 */
  //font = XftFontOpenName(display,0,"NorthKorea-50"); // how to check if this is good ?
  font = XftFontOpenName(display,0,"") /* added 6/16 */
  if (!font) return 1;
  xftdraw = XftDrawCreate(display,XP,DefaultVisual(display,0),DefaultColormap(display,0));
  xrcolor.red  =65535;
  xrcolor.green=0;
  xrcolor.blue =0;
  xrcolor.alpha=65535;
  XftColorAllocValue(display,DefaultVisual(display,0),DefaultColormap(display,0),&xrcolor,&xftcolor);
  XftDrawString8(xftdraw, &xftcolor, font, 20,70 , (XftChar8 *)"Joe Dalton", 10);
  XFlush(display);
  sleep(2);
  XftDrawDestroy(xftdraw);
  XftColorFree(display,DefaultVisual(display,0),DefaultColormap(display,0),&xftcolor);
  return 0;
}

可以看到,在XftFontOpenName中:XftFontOpenName(display,0,"NorthKorea-50")如果你像我一样写了一个废话,就不会有错误或其他东西告诉我,我没有一个名为NorthKorea的字体。这是有意义的,因为XftFontOpenName从字符串返回最近的字体。

我如何检查字体是否匹配呢?我如何使用arial之类的字体?我试过XftFontOpenName(display,0,"arial-50"),没有什么不同。

在我的系统中,我的字体文件夹中有这些文件夹:

$ls /usr/share/fonts/
100dpi  75dpi  cyrillic  encodings  misc  OTF  TTF  Type1  util

我可以用同样的方式在这些文件夹中使用任何字体吗?

如果你们有一些不错的网络链接,我很乐意去看看。

的被害者。:没有XFT标签…

<标题>更新6/16

我仍然被数据的东西困住了…我不明白,如果我替换

font = XftFontOpenName(display,0,"NorthKorea-50");

font = XftFontOpenName(display,0,"");

它还在加载字体…

xlsfonts返回很多东西,比如数据1:

-monotype-courier new-bold-r-normal--0-0-0-0-m-0-iso8859-10

但是把它作为参数传递给XftFontOpenName改变不了什么;我也试着用XftFontOpenXlfd加载字体,它总是返回NULL

xft使用fontconfig进行字体发现。xlsfonts是一种查询旧的X核心字体系统fontconfig所取代的方法。Xlsfonts结果不会以任何可靠的方式映射到fontconfig状态。

:

  1. 忘记xft工作的任何快捷方式-就像上个世纪技术书籍中记录的X核心字体系统一样。这是完全不同的。它不是X核心字体与抗锯齿和truetype支持。它可以使用现代字体和做抗锯齿,但绝对不是X核心字体在任何形式

  2. 阅读fontconfig文档,系统上的fontconfig配置文件,并使用fontconfig实用程序(fc-query, fc-list等)来查询fontconfig状态

  3. 正如维护xorg(包括x core字体和fontconfig)的人已经告诉你的那样,不要尝试直接使用xft。XFT是第一次尝试编写新字体堆栈的产物。它的功能不足以管理现代文本和现代字体。处理现代字体格式复杂性的部分很久以前就已经在pango中分离出来了(因为事实证明它足够复杂,值得一个单独的项目)。如果您尝试单独使用xft,那么您迟早会碰到pre-pango代码中的缺陷,并且没有人会对修复您的问题感兴趣,因为相同的代码已经经过了10年的修复。避免pango不是捷径。避免pango是试图依靠一个半成品,废弃多年的项目。

  4. 忘记匹配特定的字体文件。Fontconfig将积极对抗任何以这种方式工作的尝试。在后核心字体世界中,您为字体系统提供一个字体模式,它将为您构建一个匹配的字体。如果结果不是您期望的字体文件,那是因为对该文件进行了评估,发现存在不足。如果你想让fontconfig使用这个文件,你必须修复字体文件(添加缺失的字形,缺失的字体样式等),而不是写代码来强迫它。Fontconfig认为,呈现用户可以阅读的文本比只呈现您喜欢的字体能做的部分更重要。是的,这就是你们在其他系统中习惯的思考方式。字体配置是不同的。只有重写才能使它像您期望的那样运行。没有人对这次重写感兴趣,因为总的来说,过去几年fontconfig已经相当成功了。

您不应该将空字符串传递给XftFontOpenName并期望匹配字体。Xft提供对核心字体的支持,嵌套在XftFont中的结构是XftFontStruct和XftFontStruct的联合。X11在创建新实例时填充XFontStruct中的默认字体,因此在空字符串的情况下,您可能会获得默认的核心字体。

在最简单的方法中,可以像这样硬编码字体名称:

const char *font_name = "Arial-20";
XftFont *font = XftFontOpenName (display, DefaultScreen(display), font_name);

或者您可以使用XftFontMatch并在将模式传递给XftFontOpenPattern之前检查"结果"。见http://keithp.com/~ keithp/谈判/xtc2001/纸/xft.html # sec-editing

注意XCloseDisplay缺失