diff OrthancServer/Resources/Fonts/GenerateFont.py @ 4120:304842a0d152 framework-lgpl

adding missing license headers
author Sebastien Jodogne <s.jodogne@gmail.com>
date Tue, 07 Jul 2020 19:37:25 +0200
parents OrthancFramework/Resources/Fonts/GenerateFont.py@bf7b9edf6b81
children d9473bd5ed43
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/OrthancServer/Resources/Fonts/GenerateFont.py	Tue Jul 07 19:37:25 2020 +0200
@@ -0,0 +1,101 @@
+#!/usr/bin/python
+
+# Orthanc - A Lightweight, RESTful DICOM Store
+# Copyright (C) 2012-2016 Sebastien Jodogne, Medical Physics
+# Department, University Hospital of Liege, Belgium
+# Copyright (C) 2017-2020 Osimis S.A., Belgium
+#
+# This program is free software: you can redistribute it and/or
+# modify it under the terms of the GNU General Public License as
+# published by the Free Software Foundation, either version 3 of the
+# License, or (at your option) any later version.
+# 
+# This program is distributed in the hope that it will be useful, but
+# WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+# General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+
+
+
+# sudo pip install freetype-py
+
+
+
+import freetype
+import json
+import os
+import sys
+import unicodedata
+
+
+if len(sys.argv) != 3:
+    print('Usage: %s <Font> <Size>\n' % sys.argv[0])
+    print('Example: %s /usr/share/fonts/truetype/ubuntu-font-family/UbuntuMono-B.ttf 16\n' % sys.argv[0])
+    sys.exit(-1)
+
+
+
+FONT = sys.argv[1]
+PIXEL_SIZE = int(sys.argv[2])
+CHARSET = 'latin-1'
+
+
+# Load the font
+face = freetype.Face(FONT)
+face.set_char_size(PIXEL_SIZE * 64)
+
+# Generate all the characters between 0 and 255
+characters = ''.join(map(chr, range(0, 256)))
+
+# Interpret the string using the required charset
+characters = characters.decode(CHARSET, 'ignore')
+
+# Keep only non-control characters
+characters = filter(lambda c: unicodedata.category(c)[0] != 'C', characters)
+
+font = {
+    'Name' : os.path.basename(FONT),
+    'Size' : PIXEL_SIZE,
+    'Characters' : {}
+}
+
+
+def PrintCharacter(c):
+    pos = 0
+    for i in range(c['Height']):
+        s = ''
+        for j in range(c['Width']):
+            if c['Bitmap'][pos] > 127:
+                s += '*'
+            else:
+                s += ' '
+            pos += 1
+        print s
+
+
+for c in characters:
+    face.load_char(c)
+
+    info = {
+        'Width' : face.glyph.bitmap.width,
+        'Height' : face.glyph.bitmap.rows,
+        'Advance' : face.glyph.metrics.horiAdvance / 64,
+        'Top' : -face.glyph.metrics.horiBearingY / 64,
+        'Bitmap' : face.glyph.bitmap.buffer,
+    }
+
+    font['Characters'][ord(c)] = info
+
+    #PrintCharacter(info)
+
+minTop = min(map(lambda (k, v): v['Top'], font['Characters'].iteritems()))
+for c in font['Characters']:
+    font['Characters'][c]['Top'] -= minTop
+
+font['MaxAdvance'] = max(map(lambda (k, v): v['Advance'], font['Characters'].iteritems()))
+font['MaxHeight'] = max(map(lambda (k, v): v['Height'], font['Characters'].iteritems()))
+
+print json.dumps(font)