More documentation.

This commit is contained in:
Gijs 2021-05-08 16:04:03 +02:00
parent 24c3d8af3e
commit 57d09002b4
4 changed files with 63 additions and 24 deletions

View File

@ -1,12 +1,18 @@
from random import choice from random import choice
from string import ascii_letters
def random (marks=['']): def random (marks=ascii_letters):
"""Random mark from provided marks."""
def func (): def func ():
return choice(marks) return choice(marks)
return func return func
def sentence (text): def sentence (text):
"""Deprecated. Use text."""
def text (text):
"""Loops through provided text."""
chars = list(text) chars = list(text)
def f(): def f():
char = chars.pop(0) char = chars.pop(0)
@ -15,10 +21,12 @@ def sentence (text):
return f return f
def single (char): def single (char):
"""Mark with a single character."""
def f(): def f():
return char return char
return f return f
def space (space=' '): def space (space=' '):
"""Convenience function to mark with spaces."""
return single(space) return single(space)

View File

@ -1,7 +1,7 @@
import math import math
# # Linear
def diagonal(): def diagonal():
"""Draw a diagnal line from top left to bottom right"""
def f (x, y, width, height, mark, blank): def f (x, y, width, height, mark, blank):
if x == math.floor((y / float(height)) * width): if x == math.floor((y / float(height)) * width):
return mark() return mark()
@ -12,6 +12,7 @@ def diagonal():
# Cross # Cross
def cross (): def cross ():
"""Draw two diagonals"""
def f (x, y, width, height, mark, blank): def f (x, y, width, height, mark, blank):
pos = math.floor((y / float(height)) * width) pos = math.floor((y / float(height)) * width)
@ -22,17 +23,20 @@ def cross ():
return f return f
def horizontal (position): def horizontal (position):
"""Draw horizontal line at given Y position."""
def f (x, y, width, height, mark, blank): def f (x, y, width, height, mark, blank):
return mark() if position == y else blank() return mark() if position == y else blank()
return f return f
def vertical (position): def vertical (position):
"""Draw a vertical line at given X position."""
def f (x, y, width, height, mark, blank): def f (x, y, width, height, mark, blank):
return mark() if position == x else blank() return mark() if position == x else blank()
return f return f
# Sinus # Sinus
def sinus_vertical (period=0.2, amplitude=0.5, offset_t=0, offset=0): def sinus_vertical (period=0.2, amplitude=0.5, offset_t=0, offset=0):
"""Draw a sinus shape vertically"""
period = (period / (math.pi * 2)) period = (period / (math.pi * 2))
def f (x, y, width, height, mark, blank): def f (x, y, width, height, mark, blank):
@ -42,6 +46,7 @@ def sinus_vertical (period=0.2, amplitude=0.5, offset_t=0, offset=0):
return f return f
def sinus_horizontal (period=0.2, amplitude=0.5, offset_t=0, offset=0): def sinus_horizontal (period=0.2, amplitude=0.5, offset_t=0, offset=0):
"""Draw a sinus shape horizontally"""
period = (period / (math.pi * 2)) period = (period / (math.pi * 2))
def f (x, y, width, height, mark, blank): def f (x, y, width, height, mark, blank):
middle = (height - 1) * .5 middle = (height - 1) * .5
@ -51,7 +56,12 @@ def sinus_horizontal (period=0.2, amplitude=0.5, offset_t=0, offset=0):
return f return f
def image (path, threshold=128): def image (path, threshold=128):
from PIL import Image """Put marks based on a mask. Requires Pillow"""
try:
from PIL import Image
except ImportError:
print('The image patter requires pillow to be installed.')
exit()
im = Image.open(path).convert('L') im = Image.open(path).convert('L')
image_width, image_height = im.size image_width, image_height = im.size

View File

@ -3,7 +3,7 @@ from .wrap_single_line import wrap_single_line
from .utils import translate, merge from .utils import translate, merge
def make_column(text, line_width=50, height=200, use_hyphenator=None, line_offset=0): def make_column(text, line_width=50, height=200, use_hyphenator=None, line_offset=0):
"""Generate a layer width a text column."""
lines = [] lines = []
remaining = text remaining = text
@ -31,8 +31,8 @@ def make_column(text, line_width=50, height=200, use_hyphenator=None, line_offse
return lines, remaining return lines, remaining
def make_multi_column(text, height=200, column_width=40, column_count=2, column_gap=5, use_hyphenator=None, space_char=None): def make_multi_column(text, height=200, column_width=40, column_count=2, column_gap=5, use_hyphenator=None, space_char=None):
# todo: vertical offset? """Generate a layer with multiple text columns."""
remaining = text remaining = text
i = 0 i = 0

View File

@ -1,6 +1,7 @@
from sys import stdout from sys import stdout
def rotate(layer): def rotate(layer):
""" Rotates a layer 90 degrees """
new_width = len(layer) new_width = len(layer)
new_height = len(layer[0]) new_height = len(layer[0])
rotated = [['' for x in range(new_width)] for l in range(new_height)] rotated = [['' for x in range(new_width)] for l in range(new_height)]
@ -12,6 +13,12 @@ def rotate(layer):
return rotated return rotated
def merge(width, height, space_char, layers): def merge(width, height, space_char, layers):
"""Merges given layers in a new grid with given width and height.
Merges layers into a new grid with the given width and height.
For each cell the last value is taken, unless it is empty.
Cells with the provided space char are considered empty.
"""
output = [[space_char for x in range(width)] for y in range(height)] output = [[space_char for x in range(width)] for y in range(height)]
for layer in layers: for layer in layers:
@ -22,40 +29,54 @@ def merge(width, height, space_char, layers):
return output return output
# Make a multidimensional array
# with the given dimensions
def make_lines (width, height, fill_char = ''): def make_lines (width, height, fill_char = ''):
"""Deprecated. Use make_layer instead."""
return make_layer(width, height, fill_char)
def make_layer (width, height, fill_char = ''):
"""Construct a layer with given width and height.
Construct a layer with given width and height.
If fillchar is provided it is used to fill the grid.
"""
return [[ fill_char for _ in range(width) ] for __ in range(height)] return [[ fill_char for _ in range(width) ] for __ in range(height)]
def visit (lines, callback, mark, blank): def visit (layer, pattern, mark, blank):
height = len(lines) """Apply pattern on the provided layer. Row by row."""
width = len(lines[0]) height = len(layer)
width = len(layer[0])
for y in range(height): for y in range(height):
for x in range(width): for x in range(width):
lines[y][x] = callback(x, y, width, height, mark, blank) layer[y][x] = pattern(x, y, width, height, mark, blank)
return lines return layer
def visit_horizontal (lines, callback, mark, blank): def visit_horizontal (layer, pattern, mark, blank):
height = len(lines) """Apply pattern on the provided layer. Column by column."""
width = len(lines[0]) height = len(layer)
width = len(layer[0])
for x in range(width): for x in range(width):
for y in range(height): for y in range(height):
lines[y][x] = callback(x, y, width, height, mark, blank) layer[y][x] = pattern(x, y, width, height, mark, blank)
return lines return layer
def print_lines (lines): def print_lines (lines):
for line in lines: """Deprecated. Use print_layer instead."""
stdout.write('{}\n'.format(''.join(line))) print_layer(lines, out=stdout)
def print_layer(layer, out=stdout):
"""Print / write layer to provided output."""
for line in layer:
out.write('{}\n'.format(''.join(line)))
def translate(shape, x=0, y=0): def translate(layer, x=0, y=0, fill_char=None):
## TODO implement a negative translation? """Translate layer by provided x and y lengths."""
translated = [[] for _ in range(y)] translated = [[] for _ in range(y)]
for line in shape: for line in layer:
translated.append([None for _ in range(x)] + line) translated.append([fill_char for _ in range(x)] + line)
return translated return translated