當前位置: 首頁>>代碼示例>>Python>>正文


Python fontforge.open方法代碼示例

本文整理匯總了Python中fontforge.open方法的典型用法代碼示例。如果您正苦於以下問題:Python fontforge.open方法的具體用法?Python fontforge.open怎麽用?Python fontforge.open使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在fontforge的用法示例。


在下文中一共展示了fontforge.open方法的9個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: save

# 需要導入模塊: import fontforge [as 別名]
# 或者: from fontforge import open [as 別名]
def save(self):
        start_str = format_codepoint(self.start)
        end_str = format_codepoint(self.last_codepoint)
        base_name = 'tofu_{}_{}'.format(start_str, end_str)
        save_name_tmp = '{}.sfd'.format(base_name)
        with open(save_name_tmp, 'w') as file:
            file.write('\n'.join(self.data))

        font = fontforge.open(save_name_tmp)
        os.remove(save_name_tmp)
        font.familyname = 'Tofu'
        font.fontname = 'Tofu'
        font.fullname = 'Tofu {} - {}'.format(start_str, end_str)
        font.comment = 'The complete opposite of a font'
        font.version = '0.2'
        font.copyright = FONT_LICENSE

        self.needs_save = False
        return font 
開發者ID:JuanPotato,項目名稱:Tofu,代碼行數:21,代碼來源:gen_tofu.py

示例2: display_unicode_utf8

# 需要導入模塊: import fontforge [as 別名]
# 或者: from fontforge import open [as 別名]
def display_unicode_utf8(ctx, fd=sys.stdout):
    """display unicode characters as UTF-8
    :param MergingContext ctx: a merging font context
    :param file fd: display target"""
    font = fontforge.open(ctx.filename)
    unicode_range = ctx.unicode_range
    start = 0
    end = 0
    if len(unicode_range) >= 1:
        start = int(unicode_range[0], 16)
    if len(unicode_range) >= 2:
        end = int(unicode_range[1], 16)
    remap_start_point = ctx.remap_start_point
    delta = 0
    if remap_start_point is not None:
        delta = int(remap_start_point, 16) - start
    if start is 0:
        font.selection.all()
    else:
        font.selection.select(('ranges', 'unicode'), start, end)
    length = 0
    line = ''
    fd.write('{0:-^80}\n'.format(' ' + ctx.id + ' '))
    for glyph in list(font.selection.byGlyphs):
        line += unichr(glyph.encoding + delta)
        info = get_glyph_size_info(glyph)
        if info.width <= font.em / 2:
            # half width
            line += ' '
        length += 1
        if length is 40:
            fd.write(line.encode('utf-8') + '\n')
            length = 0
            line = ''
    if length > 0:
        fd.write(line.encode('utf-8') + '\n')
    fd.flush()
    font.close() 
開發者ID:iij,項目名稱:fontmerger,代碼行數:40,代碼來源:fontmerger.py

示例3: __init__

# 需要導入模塊: import fontforge [as 別名]
# 或者: from fontforge import open [as 別名]
def __init__(self, path):
        self.log = getLogger()
        self.base_font_path = path
        font = fontforge.open(path)
        if font.iscid:
            raise RuntimeError('CID font is not supported yet.')
        font.encoding = 'UnicodeFull'
        self.base_font = font
        self._hints = None 
開發者ID:iij,項目名稱:fontmerger,代碼行數:11,代碼來源:fontmerger.py

示例4: OpenFont

# 需要導入模塊: import fontforge [as 別名]
# 或者: from fontforge import open [as 別名]
def OpenFont(fontPath):
    obj = fontforge.open(fontPath)
    if __DEBUG__:
        print "OpenFont", fontPath
        print "result:", obj
    return RFont(obj) 
開發者ID:rsms,項目名稱:inter,代碼行數:8,代碼來源:objectsFF.py

示例5: processGlyphList

# 需要導入模塊: import fontforge [as 別名]
# 或者: from fontforge import open [as 別名]
def processGlyphList():
  for line in open(glyphlist):
    li=line.strip()
    if not li.startswith("#"):
      char = line.split(";")
      if char[0][0].isupper():
        path = glyphPath+"upper/"
      else:
        path = glyphPath+"lower/"
      if os.path.isfile(path+char[0]+".svg"):
        createNamedChar(char[0], path+char[0]+".svg") 
開發者ID:jfsebastian,項目名稱:zx-spectrum-unicode-font,代碼行數:13,代碼來源:createFont.py

示例6: center_glyphs

# 需要導入模塊: import fontforge [as 別名]
# 或者: from fontforge import open [as 別名]
def center_glyphs(src_font_path, dst_font_path, dst_name):
    fnt = trim_font(fontforge.open(src_font_path))

    size = max(max(g.width for g in fnt.glyphs()),
               max(glyph_height(g) for g in fnt.glyphs()))
    fnt.ascent, fnt.descent = size, 0
    for glyph in fnt.glyphs():
        scale_single_glyph(glyph, size, size)

    fnt.sfnt_names = []
    fnt.fontname = fnt.familyname = fnt.fullname = dst_name
    fnt.generate(dst_font_path) 
開發者ID:cpitclaudel,項目名稱:coq-rst,代碼行數:14,代碼來源:fontsupport.py

示例7: merge_one

# 需要導入模塊: import fontforge [as 別名]
# 或者: from fontforge import open [as 別名]
def merge_one(self, ctx):
        self.log.debug('"%s" merging...', ctx.filename)
        font = fontforge.open(ctx.filename)
        unicode_range = ctx.unicode_range
        glyph_scale = ctx.scale
        ext_start = 0
        ext_end = 0
        if len(unicode_range) >= 1:
            ext_start = int(unicode_range[0], 16)
        if len(unicode_range) >= 2:
            ext_end = int(unicode_range[1], 16)
        base_start = ext_start
        remap_start_point = ctx.remap_start_point
        if remap_start_point is not None:
            base_start = int(remap_start_point, 16)
        base_font_height = get_height(self.base_font)
        font_height = get_height(font)

        # scale transform
        scale_ratio_x = round(float(self.base_font.em) / font.em, 3)
        scale_ratio_y = round(float(base_font_height) / font_height, 3)
        scale = psMat.scale(scale_ratio_x * glyph_scale, scale_ratio_y * glyph_scale)
        if ext_start is 0:
            font.selection.all()
        else:
            font.selection.select(('ranges', 'unicode'), ext_start, ext_end)

        # copy and transform glyphs
        for glyph in list(font.selection.byGlyphs):
            index = base_start + (glyph.encoding - ext_start)
            font.selection.select(glyph.encoding)
            font.copy()
            self.base_font.selection.select(index)
            self.base_font.paste()
            _glyph = self.base_font[index]
            _glyph.transform(scale)
            _glyph.glyphname = glyph.glyphname
            info = get_glyph_size_info(_glyph)
            move_x = 0
            move_y = 0
            if self.hints.ascent < info.ymax:
                move_y = self.hints.ascent - info.ymax
            if glyph_scale < 1.0 and ctx.adjust_position:
                move_x += info.width * (1.0 - glyph_scale) / 2.0
                move_y -= info.height * (1.0 - glyph_scale) / 2.0
            info = get_glyph_size_info(_glyph)
            if info.width + move_x < self.base_font.em:
                _glyph.left_side_bearing += move_x
            hint = self.get_hint(info.width)
            if hint.glyph_width < info.width and ctx.adjust_position:
                delta = info.width - hint.glyph_width
                move_x += 1.0 - (delta / hint.glyph_width)
            _glyph.transform(psMat.translate(move_x, move_y))
            _glyph.width = hint.glyph_width
            _glyph.vwidth = hint.glyph_vwidth

        # add copyright
        if font.copyright and font.copyright not in self.base_font.copyright:
            self.base_font.copyright += '\n' + font.copyright
        font.close()
        self.log.debug('"%s" merged.', ctx.filename) 
開發者ID:iij,項目名稱:fontmerger,代碼行數:63,代碼來源:fontmerger.py

示例8: dumpFontForgeAPI

# 需要導入模塊: import fontforge [as 別名]
# 或者: from fontforge import open [as 別名]
def dumpFontForgeAPI(testFontPath, printModule=False,
            printFont=False, printGlyph=False,
            printLayer=False, printContour=False, printPoint=False):
        def printAPI(item, name):
            print 
            print "-"*80
            print "API of", item
            names = dir(item)
            names.sort()
            print

            if printAPI:
                for n in names:
                    print
                    print "%s.%s"%(name, n)
                    try:
                        print getattr(item, n).__doc__
                    except:
                        print "# error showing", n
        # module
        if printModule:
            print "module file:", fontforge.__file__
            print "version:", fontforge.version()
            print "module doc:", fontforge.__doc__
            print "has User Interface:", fontforge.hasUserInterface()
            print "has Spiro:", fontforge.hasSpiro()
            printAPI(fontforge, "fontforge")
        
        # font
        fontObj = fontforge.open(testFontPath)
        if printFont:
            printAPI(fontObj, "font")
    
        # glyph
        glyphObj = fontObj["A"]
        if printGlyph:
                printAPI(glyphObj, "glyph")
        
        # layer
        layerObj = glyphObj.foreground
        if printLayer:
            printAPI(layerObj, "layer")

        # contour
        contourObj = layerObj[0]
        if printContour:
            printAPI(contourObj, "contour")
        
        # point
        if printPoint:
            pointObj = contourObj[0]
            printAPI(pointObj, "point")
        
        
        # other objects
        penObj = glyphObj.glyphPen()
        printAPI(penObj, "glyphPen")
        
    # use your own paths here. 
開發者ID:rsms,項目名稱:inter,代碼行數:61,代碼來源:objectsFF.py

示例9: main

# 需要導入模塊: import fontforge [as 別名]
# 或者: from fontforge import open [as 別名]
def main():
    arg_parser = argparse.ArgumentParser()
    arg_parser.add_argument('font_file')
    arg_parser.add_argument('chart_png_filename')
    arg_parser.add_argument('--font-size', type=int, default=16)
    arg_parser.add_argument('--bit-depth', choices=[1, 8], default=8, type=int)
    args = arg_parser.parse_args()
    font = fontforge.open(args.font_file)

    print("# fontname =", font.fontname)
    print("# familyname =", font.familyname)
    print("# fullname = ", font.fullname)

    font_images = {}

    temp_dir = tempfile.mkdtemp()
    try:
        for glyph in font.glyphs():
            print(glyph.unicode,
                  'U+{:04x}'.format(glyph.unicode) if glyph.unicode > 0 else '',
                  glyph.glyphname,
                  sep='\t'
                  )

            if glyph.unicode > 0:
                path = os.path.join(temp_dir, '{:04x}.png'.format(glyph.unicode))
                glyph.export(path, args.font_size, args.bit_depth)

                with open(path, 'rb') as file:
                    font_images[glyph.unicode] = file.read()
    finally:
        shutil.rmtree(temp_dir)

    cols = 32
    rows = int(math.ceil(len(font_images) / cols))
    col_width = 32
    row_height = 32

    draw_font = PIL.ImageFont.load_default()
    image = PIL.Image.new('L', (cols * col_width, rows * row_height), color=255)
    draw_context = PIL.ImageDraw.Draw(image)

    for index, char_code in enumerate(sorted(font_images.keys())):
        image_data = font_images[char_code]
        char_image = PIL.Image.open(io.BytesIO(image_data))

        col = index % cols
        row = index // cols

        image.paste(char_image, (col * col_width, row * row_height + 12))
        draw_context.text((col * col_width, row * row_height),
                          '{:02x}'.format(char_code), font=draw_font)

    image.save(args.chart_png_filename) 
開發者ID:chfoo,項目名稱:tppocr,代碼行數:56,代碼來源:dump_font.py


注:本文中的fontforge.open方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。