| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061 |
- from django.core.management.base import BaseCommand
- from ...xword import extract_crossword
- class Command(BaseCommand):
- help = "Extracts a clean crossword image from a photograph."
- def add_arguments(self, parser):
- parser.add_argument('input_file_name')
- parser.add_argument('output_file_name')
- parser.add_argument('--filter-colours', action='store_true')
- parser.add_argument('--colour-filter-threshold', type=int, default=48)
- parser.add_argument('--gaussian-blur-size', type=int, default=11)
- parser.add_argument('--adaptive-threshold-block-size', type=int, default=11)
- parser.add_argument('--adaptive-threshold-mean-adjustment', type=int, default=2)
- parser.add_argument('--not-square', action='store_true')
- parser.add_argument('--num-dilations', type=int, default=1)
- parser.add_argument('--contour-erosion-kernel-size', type=int, default=5)
- parser.add_argument('--contour-erosion-iterations', type=int, default=5)
- parser.add_argument('--line-detector-element-size', type=int, default=51)
- parser.add_argument('--sampling-block-size-ratio', type=float, default=0.25)
- parser.add_argument('--sampling-threshold-quantile', type=float, default=0.3)
- parser.add_argument('--sampling-threshold', type=int)
- parser.add_argument('--grid-line-thickness', type=int, default=4)
- parser.add_argument('--grid-square-size', type=int, default=64)
- parser.add_argument('--grid-border-size', type=int, default=20)
- group = parser.add_mutually_exclusive_group()
- group.add_argument('--out')
- group.add_argument('--html')
- def handle(self, *args, **options):
- image, warnings = extract_crossword(
- options['input_file_name'],
- gaussian_blur_size=options['gaussian_blur_size'],
- adaptive_threshold_block_size=options['adaptive_threshold_block_size'],
- adaptive_threshold_mean_adjustment=options['adaptive_threshold_mean_adjustment'],
- square=not options['not_square'],
- num_dilations=options['num_dilations'],
- contour_erosion_kernel_size=options['contour_erosion_kernel_size'],
- contour_erosion_iterations=options['contour_erosion_iterations'],
- line_detector_element_size=options['line_detector_element_size'],
- sampling_block_size_ratio=options['sampling_block_size_ratio'],
- sampling_threshold_quantile=options['sampling_threshold_quantile'],
- sampling_threshold=options['sampling_threshold'],
- grid_line_thickness=options['grid_line_thickness'],
- grid_square_size=options['grid_square_size'],
- grid_border_size=options['grid_border_size']
- )
- for warning in warnings:
- print('WARNING: ' + warning)
- with open(options['output_file_name'], 'wb') as f:
- f.write(image)
|