2022-04-13 08:00:18 +00:00
|
|
|
"""This script tests QGF functionality.
|
|
|
|
"""
|
|
|
|
from io import BytesIO
|
|
|
|
from qmk.path import normpath
|
2024-03-10 00:29:09 +00:00
|
|
|
from qmk.painter import generate_subs, render_header, render_source, valid_formats
|
2022-04-13 08:00:18 +00:00
|
|
|
from milc import cli
|
|
|
|
from PIL import Image
|
|
|
|
|
|
|
|
|
|
|
|
@cli.argument('-v', '--verbose', arg_only=True, action='store_true', help='Turns on verbose output.')
|
|
|
|
@cli.argument('-i', '--input', required=True, help='Specify input graphic file.')
|
|
|
|
@cli.argument('-o', '--output', default='', help='Specify output directory. Defaults to same directory as input.')
|
2024-03-10 00:29:09 +00:00
|
|
|
@cli.argument('-f', '--format', required=True, help=f'Output format, valid types: {", ".join(valid_formats.keys())}')
|
2022-04-13 08:00:18 +00:00
|
|
|
@cli.argument('-r', '--no-rle', arg_only=True, action='store_true', help='Disables the use of RLE when encoding images.')
|
|
|
|
@cli.argument('-d', '--no-deltas', arg_only=True, action='store_true', help='Disables the use of delta frames when encoding animations.')
|
2022-11-08 15:47:07 +00:00
|
|
|
@cli.argument('-w', '--raw', arg_only=True, action='store_true', help='Writes out the QGF file as raw data instead of c/h combo.')
|
2022-04-13 08:00:18 +00:00
|
|
|
@cli.subcommand('Converts an input image to something QMK understands')
|
|
|
|
def painter_convert_graphics(cli):
|
|
|
|
"""Converts an image file to a format that Quantum Painter understands.
|
|
|
|
|
|
|
|
This command uses the `qmk.painter` module to generate a Quantum Painter image defintion from an image. The generated definitions are written to a files next to the input -- `INPUT.c` and `INPUT.h`.
|
|
|
|
"""
|
|
|
|
# Work out the input file
|
|
|
|
if cli.args.input != '-':
|
|
|
|
cli.args.input = normpath(cli.args.input)
|
|
|
|
|
|
|
|
# Error checking
|
|
|
|
if not cli.args.input.exists():
|
|
|
|
cli.log.error('Input image file does not exist!')
|
|
|
|
cli.print_usage()
|
|
|
|
return False
|
|
|
|
|
|
|
|
# Work out the output directory
|
|
|
|
if len(cli.args.output) == 0:
|
|
|
|
cli.args.output = cli.args.input.parent
|
|
|
|
cli.args.output = normpath(cli.args.output)
|
|
|
|
|
|
|
|
# Ensure we have a valid format
|
|
|
|
if cli.args.format not in valid_formats.keys():
|
|
|
|
cli.log.error('Output format %s is invalid. Allowed values: %s' % (cli.args.format, ', '.join(valid_formats.keys())))
|
|
|
|
cli.print_usage()
|
|
|
|
return False
|
|
|
|
|
|
|
|
# Work out the encoding parameters
|
|
|
|
format = valid_formats[cli.args.format]
|
|
|
|
|
|
|
|
# Load the input image
|
|
|
|
input_img = Image.open(cli.args.input)
|
|
|
|
|
|
|
|
# Convert the image to QGF using PIL
|
|
|
|
out_data = BytesIO()
|
2024-03-10 00:29:09 +00:00
|
|
|
metadata = []
|
|
|
|
input_img.save(out_data, "QGF", use_deltas=(not cli.args.no_deltas), use_rle=(not cli.args.no_rle), qmk_format=format, verbose=cli.args.verbose, metadata=metadata)
|
2022-04-13 08:00:18 +00:00
|
|
|
out_bytes = out_data.getvalue()
|
|
|
|
|
2022-11-08 15:47:07 +00:00
|
|
|
if cli.args.raw:
|
2024-03-10 00:29:09 +00:00
|
|
|
raw_file = cli.args.output / f"{cli.args.input.stem}.qgf"
|
2022-11-08 15:47:07 +00:00
|
|
|
with open(raw_file, 'wb') as raw:
|
|
|
|
raw.write(out_bytes)
|
|
|
|
return
|
|
|
|
|
2022-04-13 08:00:18 +00:00
|
|
|
# Work out the text substitutions for rendering the output data
|
2024-11-21 06:16:46 +00:00
|
|
|
subs = generate_subs(cli, out_bytes, image_metadata=metadata, command_name="painter_convert_graphics")
|
2022-04-13 08:00:18 +00:00
|
|
|
|
|
|
|
# Render and write the header file
|
|
|
|
header_text = render_header(subs)
|
2024-03-10 00:29:09 +00:00
|
|
|
header_file = cli.args.output / f"{cli.args.input.stem}.qgf.h"
|
2022-04-13 08:00:18 +00:00
|
|
|
with open(header_file, 'w') as header:
|
|
|
|
print(f"Writing {header_file}...")
|
|
|
|
header.write(header_text)
|
|
|
|
|
|
|
|
# Render and write the source file
|
|
|
|
source_text = render_source(subs)
|
2024-03-10 00:29:09 +00:00
|
|
|
source_file = cli.args.output / f"{cli.args.input.stem}.qgf.c"
|
2022-04-13 08:00:18 +00:00
|
|
|
with open(source_file, 'w') as source:
|
|
|
|
print(f"Writing {source_file}...")
|
|
|
|
source.write(source_text)
|