zoukankan      html  css  js  c++  java
  • Pygame详解:font 模块


    pygame.font

    Pygame 中加载和表示字体的模块。
    函数

    1     pygame.font.init()  ——  初始化字体模块
    2     pygame.font.quit()  ——  还原字体模块
    3     pygame.font.get_init()  ——  检查字体模块是否被初始化
    4     pygame.font.get_default_font()  ——  获得默认字体的文件名
    5     pygame.font.get_fonts()  ——  获取所有可使用的字体
    6     pygame.font.match_font()  ——  在系统中搜索一种特殊的字体
    7     pygame.font.SysFont()  ——  从系统字体库创建一个 Font 对象

    1    pygame.font.Font   ——  从一个字体文件创建一个 Font 对象


    字体模块可以在一个新的 Surface 对象上表示 TrueType 字体。它接受所有 UCS-2 字符('u0001' 到 'uFFFF')。此模块为可选择模块,并且依赖于 SDL_ttf。在使用之前,你需要先测试该模块是否可用,而且对其进行初始化。

    通过使用现有的 Font 对象,可以完成大多数与字体有关的工作。Pygame.font 模块自身仅可以完成常规的初始化以及通过 pygame.font.Font() 创建 Font 对象。

    你可以通过使用 pygame.font.SysFont() 函数从系统内加载字体。另外还有其他几个函数可以帮助你搜索系统的字体。

    Pygame 配备了内建的默认字体。通过传递 "None" 为文件名访问此字体。

    在 pygame 第一次导入之前,当pygame.font 模块确定环境变量 PYGAME_FREETYPE 时使用基于 pygame.ftfont 的 pygame.freetype 模块。 Pygame.ftfont 是一个pygame.font 可兼容模块,兼容绝大部分,除开其中某个字体模块单元测试:Pygame.ftfont 并没有基于字体模块的 SDL_ttf 的 UCS-2 字符限制,所以对于大于 'uFFFF' 的码点会产生异常。如果 pygame.freetype 是不可使用的,那么 SDL_ttf 字体模块将会被加载用于替代。
    函数详解

     pygame.font.init()


    初始化字体模块。

    init() -> None

    在调用 pygame.init() 时,该函数会被自动调用。

    该函数用于初始化字体模块。在使用其他任何函数前,该模块必须被初始化。

    多次调用该函数是安全的。

     pygame.font.quit()


    还原字体模块。

    quit() -> None

    手动还原 SDL_ttf 的字体系统。该函数会被 pygame.quit() 自动调用。

    即使模块没有被初始化,调用该函数也是安全的。

    pygame.font.get_init()


    检查字体模块是否被初始化。

    get_init() -> bool

    如果该字体模块已经初始化,返回 True,否则返回 False。

    pygame.font.get_default_font()


    获得默认字体的文件名。

    get_default_font() -> string

    返回系统字体的文件名。

    注意,并不是字体文件的完整路径。

    这个文件通常与字体模块处于同一文件目录下,但是它也可以在程序附随的独立文档中。

    pygame.font.get_fonts()

    获取所有可使用的字体。

    get_fonts() -> list of strings

    返回系统可使用的字体列表。

    字体名将会被设置成小写、所有的空格和标点符号也会将被删除。

    该函数在大多数系统内是有效的,但是一些系统如果没有找到字体库会返回一个空的列表。

    pygame.font.match_font()

    在系统中搜索一种特殊的字体。

    match_font(name, bold=False, italic=False) -> path

    返回字体文件在系统中的完整路径。

    如果你要搜索的字体是粗体或者斜体的,则要把 bold 参数和 italic 参数设置成 True,该函数将会尝试去搜索一个正确的字体族。

    尝试搜索的 name 参数可以是一个用逗号隔开的列表。如果根据提供的名字没有找到任何东西,则返回 None 。

    例子:

        print pygame.font.match_font('bitstreamverasans')
        # output is: /usr/share/fonts/truetype/ttf-bitstream-vera/Vera.ttf
        # (but only if you have Vera on your system)

    pygame.font.SysFont()

    从系统字体库创建一个 Font 对象。

    SysFont(name, size, bold=False, italic=False) -> Font

    从系统字体库中加载并返回一个新的字体对象。

    该字体将会匹配 bold(加粗)和 italic(斜体)参数的要求。

    如果找不到一个合适的系统字体,该函数将会回退并加载默认的 pygame 字体。

    尝试搜索的 name 参数可以是一个用逗号隔开的列表。
    类 class pygame.font.Font

    从一个字体文件创建一个 Font 对象。

    Font(filename, size) -> Font

    Font(object, size) -> Font
    方法 

     1    pygame.font.Font.render()  ——  在一个新 Surface 对象上绘制文本
     2     pygame.font.Font.size()  ——  确定多大的空间用于表示文本
     3     pygame.font.Font.set_underline()  ——  控制文本是否用下划线渲染
     4     pygame.font.Font.get_underline()  ——  检查文本是否绘制下划线
     5     pygame.font.Font.set_bold()  ——  启动粗体字渲染
     6     pygame.font.Font.get_bold()  ——  检查文本是否使用粗体渲染
     7     pygame.font.Font.set_italic()  ——  启动斜体字渲染
     8     pygame.font.Font.metrics()  ——  获取字符串参数每个字符的参数
     9     pygame.font.Font.get_italic()  ——  检查文本是否使用斜体渲染
    10     pygame.font.Font.get_linesize()  ——  获取字体文本的行高
    11     pygame.font.Font.get_height()  ——  获取字体的高度
    12     pygame.font.Font.get_ascent()  ——  获取字体顶端到基准线的距离
    13     pygame.font.Font.get_descent()  ——  获取字体底端到基准线的距离


    根据提供的文件名或者 python 文件对象加载一个新的字体。字体的高度是以像素为单位。如果文件名是 "None",则加载 Pygame 的默认字体。如果一个字体无法由给定的参数加载,将会产生一个异常。一旦字体已经创建完毕,那么字体的尺寸将不能修改。

    字体对象主要被用于在新 Surface 对象中渲染文本。文本可以渲染为仿真的粗体或者斜体特征,但最好是加载的字体本身就带有粗体或者斜体字形。可以用普通字符串或者 Unicode 编码字符来渲染文本。
    方法详解

    pygame.font.Font.render()

    在一个新 Surface 对象上绘制文本。

    render(text, antialias, color, background=None) -> Surface

    该函数创建一个新的 Surface 对象,并在上边渲染指定的文本。Pygame 没有提供直接的方式在一个现有的 Surface 对象上绘制文本,取而代之的方法是:使用 Font.render() 函数创建一个渲染了文本的图像(Surface 对象),然后将这个图像绘制到目标 Surface 对象上。

    仅支持渲染一行文本:“换行”字符不会被渲染。空字符('x00')被渲染将产生一个 TypeError 错误。Unicode 和 char(字节)字符串都可以被接受。对于 Unicode 字符串,仅 UCS-2 字符范围('u0001' 到 'uFFFF')被认为是有效的。任何编码值更大字符的字符会产生一个 UnicodeError 的错误;对于 char 字符串,默认的是使用 LATIN1 编码。color 参数决定的是文本的颜色(例如:(0, 0, 255) 表示蓝色)。可选参数 background 决定了文本的背景颜色。如果没有传递 background 参数,则对应区域内表示的文本背景将会被设置为透明。

    返回的 Surface 对象将保持表示文本所需要的尺寸(与 Font.size() 所返回的尺寸相同)。如果将一个空字符串渲染为文本,将会返回一个空白 Surface 对象,它仅有一个像素点的宽度,但高度与字体高度一样。

    由于取决于文本背景的类型和抗锯齿功能的使用,该函数将会返回不同类型的 Surface 对象。出于性能上的考虑,了解何种类型的图像会被使用是很有帮助的:如果抗锯齿功能没有被使用,返回的图像将采用二元调色的 8 位图像。此时如果背景是透明的,只设置一个 colorkey 来实现;抗锯齿图像会被渲染为 24 位 RGB 图像。此时如果背景是透明的,每个像素都将包含一个 alpha 通道。

    优化:如果你已知文本最终将绘制在一个纯色的背景上,那么文本是抗锯齿的,你可以通过指定文本的背景色来提高性能(将文本背景色设置目标 Surface 对象的颜色)。使用这个技巧,你只需用一个 colorkey 即可保持透明信息,而不需要设置每个像素的 alpha 通道值(这样效率会低很多)。

    如果你尝试渲染 ' ',通常是显示为一个矩形(未知字符)。因此,你需要自己想办法处理换行。

    字体渲染并不是线程安全的行为:在任何时候仅有一个线程可以渲染文本。

    pygame.font.Font.size()

    确定多大的空间用于表示文本。

    size(text) -> (width, height)

    该函数返回渲染文本所需要的尺寸。这可以被用于在文本显示之前,确定文本的显示位置。当然也有助于实现自动换行和其他布局效果。

    注意:大多数字体使用字距调整来调整指定字母间的宽度。例如,"ae" 的宽度并不总是等同于 'a' + 'e' 的宽度。

    pygame.font.Font.set_underline()

    控制文本是否用下划线渲染。

    set_underline(bool) -> None

    启用后,所有字体的渲染都会包含下划线。下划线一般是和一个像素点一样细,与字体尺寸无关。

    该函数可以与粗体和斜体模式混合使用。

    pygame.font.Font.get_underline()

    检查文本是否绘制下划线。

    get_underline() -> bool

    如果字体下划线被启用,返回 True。

    pygame.font.Font.set_bold()

    启动粗体字渲染。

    set_bold(bool) -> None

    该函数启用文本的粗体渲染。该函数是通过虚拟拉伸实现加粗,对大多数字体格式来说并不是很好看。如果可能,请加载真粗体格式的字体文件。当渲染的字体为粗体时,该字体将比普通模式下更宽一些。

    该函数可以和斜体及下划线模式混合使用。

    pygame.font.Font.get_bold()

    检查文本是否使用粗体渲染。

    get_bold() -> bool

    如果字体的粗体渲染模式被启用,返回 True。

    pygame.font.Font.set_italic()

    启动斜体字渲染。

    set_italic(bool) -> None

    该函数启用文本的斜体渲染。该函数是通过虚拟倾斜字体实现斜体,对大多数字体格式来说并不是很好看。如果可能,请加载真斜体格式的字体文件。当渲染的字体为斜体时,该字体将比普通模式下更宽一些。

    该函数可以和粗体及下划线模式混合使用。

    pygame.font.Font.metrics()

    获取字符串参数每个字符的参数。

    metrics(text) -> list

    返回一个列表,包含每个字符的属性元组。形式如:[(minx, maxx, miny, maxy, advance), (minx, maxx, miny, maxy, advance), ...]

    元组内各个元素的含义如下图:



    列表内不可识别的字符对应的元组内参数均为 None。

    pygame.font.Font.get_italic()

    检查文本是否使用斜体渲染。

    get_italic() -> bool

    如果字体的斜体渲染模式被启用,返回 True。

    pygame.font.Font.get_linesize()

    获取字体文本的行高。

    get_linesize() -> int

    返回该字体下文本的单行的高度(以像素为单位)。

    当需要渲染很多行文本时,推荐使用该返回值作为行间距。

    pygame.font.Font.get_height()

    获取字体的高度。

    get_height() -> int

    返回实际渲染的文本的高度(以像素为单位)。

    返回值是字体内每个字符的平均规格。

    pygame.font.Font.get_ascent()

    获取字体顶端到基准线的距离。

    get_ascent() -> int

    获取字体顶端到基准线的距离(以像素为单位)。

    以防大家脑补错方向,补充下图:

    pygame.font.Font.get_descent()

    获取字体底端到基准线的距离。

    get_descent() -> int

    获取字体底端到基准线的距离(以像素为单位)。
    ————————————————
    版权声明:本文为CSDN博主「来自江南的你」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
    原文链接:https://blog.csdn.net/qq_41556318/article/details/86303502

  • 相关阅读:
    hdu 3068 Manacher算法
    用gitolite新建项目,clone后首次push,可能会出现: git: No refs in common and none specified; doing no
    Linux命令之nano
    linux下git使用记录1 git 提交
    Linux 删除文件夹和文件的命令
    UBUNTU 下GIT的安装
    mysql 常用命令
    mysql 数据类型
    SQL优化
    CSS入门教程——定位(positon)
  • 原文地址:https://www.cnblogs.com/hilnx/p/12497380.html
Copyright © 2011-2022 走看看