我在Debian Sid笔记本上安装了两个Python,⑴系统的Python(v.2.7)包含一些实用程序包(包括Tkinter)和⑵Anaconda的Python 3.
很容易看出两个Python发行版可以使用哪些(好吧,这里有多少……)字体.
Python 2
>>> from Tkinter import Tk
>>> from tkFont import families
>>> Tk(); available = families() ### Tk() is needed to have a running tcl interpreter
<Tkinter.Tk instance at 0x7f977bcbfb90>
>>> len(available)
3011
Python 3
>>> from tkinter import Tk
>>> from tkinter.font import families
>>> Tk() ; available = families()
<tkinter.Tk object .>
>>> len(available)
68
在我看来,Anaconda的tkinter只关注下面的发布者编辑附带的基本X字体.
你知道一个程序吗?
>让Anaconda的tkinter知道系统字体(首选替代品)或
>在Anaconda的树中安装一些字体,以便tkinter可以使用它们?
TIA
编辑Anaconda可用的字体确实是系统字体,但只有xfontsel已知的字体,即字体路径中可以使用xset操作的字体.
我尝试了以下内容
$cd ~/.fonts ; mkfontscale ; mkfontdir ; xset fp+ `pwd`
和xfontsel展示了大约30多个字体系列.使用Python 3进行检查我确认只有两个字体系列被添加到可用字体列表中(即’go’和’gomono’ – 没有’consolas’等)并生成标签
...
r = Tk() ; Label(r, text="Go Mono", font=('gomono', 24)).pack()
在这两种情况下,Python 2和Python 3都取得了成功,但Debian的Python显示了一个很好的抗锯齿文本,而另一个是(粗略的)位图再现.
所以,从某种意义上说,我已经部分回答了我的问题,但是
>并非所有字体系列(如xfontsel所示)都被tkinter占用
>即使对于被认可的极少数人来说,引渡还有太多不足之处……
我想读一个更好,更有用的答案.
解决方法:
{tT} kinter工作链接到Tk / Tcl解释器,松散地说,它包含在几个DLL中,特别是图形库是libtk6.0.so.
tkinter没有看到的大多数额外字体由Freetype库管理,而Anaconda的libtk6.0.so不是针对Freetype构建的…
$ldd /usr/lib/x86_64-linux-gnu/libtk8.6.so | grep freetype
libfreetype.so.6 => /usr/lib/x86_64-linux-gnu/libfreetype.so.6 (0x00007f0a24597000)
$ldd miniconda3/lib/libtk8.6.so | grep freetype
$
我尝试过以下可怕的事情
$mv lib/miniconda3/lib/libtk8.6.so lib/miniconda3/lib/libtk8.6.sav
$ln -s /usr/lib/x86_64-linux-gnu/libtk8.6.so lib/miniconda3/lib/libtk8.6.so
$ipython
Python 3.6.3 |Anaconda, Inc.| (default, Nov 20 2017, 20:41:42)
Type 'copyright', 'credits' or 'license' for more information
IPython 6.2.1 -- An enhanced Interactive Python. Type '?' for help.
In [1]: from tkinter import Tk, Label ; from tkinter.font import families
In [2]: r = Tk() ; a = families() ; len(a)
Out[2]: 328
In [3]: r=Tk() ; Label(r, text="Constantia", font=("Constantia", 60)).pack()
In [4]: r.mainloop()
最后的想法.
>替换DLL不是一个干净的解决方案.
>字体不完全相同.肯定Anaconda有自己的Fontconfig子系统,可能扫描的目录不同,但我对字体数量的差异没有正确的理解.
>正确的行动方案是说服Anaconda,Inc.建立针对Freetype的libtk,但我不知道如何向他们报告,例如,如果我转到https://www.anaconda.com/search/issues,我看到的是关于分发的信息文章列表.
更新
W.r.to第3点,我通过a github issue Anaconda Inc.联系,我被告知
No we cannot do this. When building our software we need python built very early, well before anything graphical gets built. Adding Freetype as a dep for tkinter causes a cycle in the build graph and we can no longer build the distro.
Why not use something more modern than tkinter anyway?
— Ray Donnelly (aka mingwandroid)