linux, c++, xft:如何使用它
linux, C++, xft : how to use it?
我尝试使用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状态。
:
-
忘记xft工作的任何快捷方式-就像上个世纪技术书籍中记录的X核心字体系统一样。这是完全不同的。它不是X核心字体与抗锯齿和truetype支持。它可以使用现代字体和做抗锯齿,但绝对不是X核心字体在任何形式
-
阅读fontconfig文档,系统上的fontconfig配置文件,并使用fontconfig实用程序(fc-query, fc-list等)来查询fontconfig状态
-
正如维护xorg(包括x core字体和fontconfig)的人已经告诉你的那样,不要尝试直接使用xft。XFT是第一次尝试编写新字体堆栈的产物。它的功能不足以管理现代文本和现代字体。处理现代字体格式复杂性的部分很久以前就已经在pango中分离出来了(因为事实证明它足够复杂,值得一个单独的项目)。如果您尝试单独使用xft,那么您迟早会碰到pre-pango代码中的缺陷,并且没有人会对修复您的问题感兴趣,因为相同的代码已经经过了10年的修复。避免pango不是捷径。避免pango是试图依靠一个半成品,废弃多年的项目。
-
忘记匹配特定的字体文件。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缺失
- 如何创建一个CMake变量,除非显式重写,否则使用默认值
- C++:TypeDef使用元组
- 使用std::multimap迭代器创建std::list
- 从不同线程使用int64的不同字节安全吗
- 比较并显示使用最小值(a,b)和最大值(a、b)升序排列的4个数字
- 为什么在全局范围内使用"extern int a"似乎不行?
- 在C#中处理C++指针而不使用unsafe的最佳方法
- 使用C++库在Android项目中修改gradle中的cmake参数,用于插入指令的测试
- 如何使用Google Mock来模拟gettimeofday()
- 如何使用默认参数等选择模板专业化
- 为什么使用 "this" 指针调用派生成员函数?
- 使用新行和不使用新行读取文件
- 如何使用 < 和 > 命令获取 c++ 中的输入和输出?
- 如何确定我已使用非编码文件到达 EOF?
- 如何使用X11中的XFT字体在窗口中央对齐文本
- 使用 LLVM 的 libc++ 时,__1 符号从何而来?
- 在std::cout之后使用std::cin时,换行符从何而来
- 为什么以及在何处在C++中使用引用和指针
- linux, c++, xft:如何使用它
- 基例如何影响使用递归函数的哪些行