From 7b4acc2cdbe8052635b77771076452b21281634b Mon Sep 17 00:00:00 2001 From: mdraw Date: Fri, 10 Dec 2021 04:19:50 +0100 Subject: [PATCH] Update documentation and apply PEP8 --- README.md | 26 +++++++++++++++----------- deface/deface.py | 14 +++++++------- 2 files changed, 22 insertions(+), 18 deletions(-) diff --git a/README.md b/README.md index f0f8b07..1c7f25e 100644 --- a/README.md +++ b/README.md @@ -54,22 +54,22 @@ The output may vary depending on your installed version, but it should look simi ``` usage: deface [--output O] [--thresh T] [--scale WxH] [--preview] [--boxes] [--draw-scores] [--mask-scale M] - [--replacewith {blur,solid,none}] + [--replacewith {blur,solid,none,img}] [--replaceimg REPLACEIMG] [--ffmpeg-config FFMPEG_CONFIG] [--backend {auto,onnxrt,opencv}] [--version] [--help] - [input [input ...]] + [input ...] Video anonymization by face detection positional arguments: input File path(s) or camera device name. It is possible to pass multiple paths by separating them by spaces or by - using shell expansion (e.g. `$ deface vids/*.mp4`). - Additionally you can pass a directory as an input in - which case all files in the directory will be used as - input. If a camera is installed, a live webcam demo can - be started by running `$ deface cam` (which is a - shortcut for `$ deface -p ''`). + using shell expansion (e.g. `$ deface vids/*.mp4`). + Alternatively, you can pass a directory as an input, + in which case all files in the directory will be used + as inputs. If a camera is installed, a live webcam + demo can be started by running `$ deface cam` (which + is a shortcut for `$ deface -p ''`. optional arguments: --output O, -o O Output file name. Defaults to input path + postfix @@ -83,11 +83,15 @@ optional arguments: --draw-scores Draw detection scores onto outputs. --mask-scale M Scale factor for face masks, to make sure that masks cover the complete face. Default: 1.3. - --replacewith {blur,solid,none} + --replacewith {blur,solid,none,img} Anonymization filter mode for face regions. "blur" applies a strong gaussian blurring, "solid" draws a - solid black box and "none" does leaves the input - unchanged. Default: "blur". + solid black box, "none" does leaves the input + unchanged and "img" replaces the face with a custom + image. Default: "blur". + --replaceimg REPLACEIMG + Anonymization image for face regions. Requires + --replacewith img option. --ffmpeg-config FFMPEG_CONFIG FFMPEG config arguments for encoding output videos. This argument is expected in JSON notation. For a list diff --git a/deface/deface.py b/deface/deface.py index 8cd80c6..a530dc0 100755 --- a/deface/deface.py +++ b/deface/deface.py @@ -56,12 +56,12 @@ def draw_det( frame[y1:y2, x1:x2] = roibox else: frame[y1:y2, x1:x2] = blurred_box - elif replacewith == "img": - target_size = (x2-x1, y2-y1) + elif replacewith == 'img': + target_size = (x2 - x1, y2 - y1) resized_replaceimg = cv2.resize(replaceimg, target_size) - if replaceimg.shape[2] == 3: + if replaceimg.shape[2] == 3: # RGB frame[y1:y2, x1:x2] = resized_replaceimg - elif replaceimg.shape[2] == 4: + elif replaceimg.shape[2] == 4: # RGBA frame[y1:y2, x1:x2] = frame[y1:y2, x1:x2] * (1 - resized_replaceimg[:, :, 3:] / 255) + resized_replaceimg[:, :, :3] * (resized_replaceimg[:, :, 3:] / 255) elif replacewith == 'none': pass @@ -241,7 +241,7 @@ def parse_cli_args(): parser = argparse.ArgumentParser(description='Video anonymization by face detection', add_help=False) parser.add_argument( 'input', nargs='*', - help=f'File path(s) or camera device name. It is possible to pass multiple paths by separating them by spaces or by using shell expansion (e.g. `$ deface vids/*.mp4`). If a camera is installed, a live webcam demo can be started by running `$ deface cam` (which is a shortcut for `$ deface -p \'\'`.') + help=f'File path(s) or camera device name. It is possible to pass multiple paths by separating them by spaces or by using shell expansion (e.g. `$ deface vids/*.mp4`). Alternatively, you can pass a directory as an input, in which case all files in the directory will be used as inputs. If a camera is installed, a live webcam demo can be started by running `$ deface cam` (which is a shortcut for `$ deface -p \'\'`.') parser.add_argument( '--output', '-o', default=None, metavar='O', help='Output file name. Defaults to input path + postfix "_anonymized".') @@ -265,10 +265,10 @@ def parse_cli_args(): help='Scale factor for face masks, to make sure that masks cover the complete face. Default: 1.3.') parser.add_argument( '--replacewith', default='blur', choices=['blur', 'solid', 'none', 'img'], - help='Anonymization filter mode for face regions. "blur" applies a strong gaussian blurring, "solid" draws a solid black box, "none" does leaves the input unchanged and "img" replace the face with a custom image. Default: "blur".') + help='Anonymization filter mode for face regions. "blur" applies a strong gaussian blurring, "solid" draws a solid black box, "none" does leaves the input unchanged and "img" replaces the face with a custom image. Default: "blur".') parser.add_argument( '--replaceimg', default='replace_img.png', - help='Anonymization img for face regions. Requires --replacewith img option.') + help='Anonymization image for face regions. Requires --replacewith img option.') parser.add_argument( '--ffmpeg-config', default={"codec": "libx264"}, type=json.loads, help='FFMPEG config arguments for encoding output videos. This argument is expected in JSON notation. For a list of possible options, refer to the ffmpeg-imageio docs. Default: \'{"codec": "libx264"}\'.'