在请求 API 之前,请先运行后端服务
python delopy_api.py
下面的请求示例是请求脚本与后端服务处于同一机子下的,如在不同机器,请更换-u
参数值。
python requests_api.py -u <URL> -t <TYPE> -i <INPUT_IMAGE_DIR> -o <OUTPUT_IMAGE_DIR> [-s <SIZE>] [-c <COLOR>] [-k <KB>]
-
-u
,--url
- 描述: API 服务的 URL。
- 默认值:
http://127.0.0.1:8080
-
-t
,--type
- 描述: 请求 API 的种类,可选值有
idphoto
、add_background
和generate_layout_photos
。分别代表证件照制作、透明图加背景和排版照生成。 - 默认值:
idphoto
- 描述: 请求 API 的种类,可选值有
-
-i
,--input_image_dir
- 描述: 输入图像路径。
- 必需: 是
- 示例:
./input_images/photo.jpg
-
-o
,--output_image_dir
- 描述: 保存图像路径。
- 必需: 是
- 示例:
./output_images/processed_photo.jpg
-
-s
,--size
- 描述: 标准证件照的输出尺寸,格式为
(高度, 宽度)
。 - 默认值:
(413,295)
- 描述: 标准证件照的输出尺寸,格式为
-
-c
,--color
- 描述: 给透明图增加背景色,格式为
(R, G, B)
,仅在 type 为add_background
时生效 - 默认值:
(255,255,255)
- 描述: 给透明图增加背景色,格式为
-
-k
,--kb
- 描述: 输出照片的 KB 值,仅在 type 为
add_background
和generate_layout_photos
时生效,值为 None 时不做设置。 - 默认值:
None
- 示例:
50
- 描述: 输出照片的 KB 值,仅在 type 为
生成证件照
接口的逻辑是发送一张 RGB 图像,输出一张标准证件照和一张高清证件照:
- 高清证件照:根据
size
的宽高比例制作的证件照,文件名为output_image_dir
增加_hd
后缀 - 标准证件照:尺寸等于
size
,由高清证件照缩放而来,文件名为output_image_dir
需要注意的是,生成的两张照片都是透明的(RGBA 四通道图像),要生成完整的证件照,还需要下面的添加背景色
接口。
问:为什么这么设计?
答:因为在实际产品中,经常用户会频繁切换底色预览效果,直接给透明底图像,由前端 js 代码合成颜色是更好体验的做法。
python requests_api.py \
-u http://127.0.0.1:8080 \
-t idphoto \
-i ./photo.jpg \
-o ./idphoto.png \
-s '(413,295)'
添加背景色
接口的逻辑是发送一张 RGBA 图像,根据color
添加背景色,合成一张 JPG 图像。
python requests_api.py \
-u http://127.0.0.1:8080 \
-t add_background \
-i ./idphoto.png \
-o ./idphoto_with_background.jpg \
-c '(99,126,194)' \
-k 50
生成六寸排版照
接口的逻辑是发送一张 RGB 图像(一般为添加背景色之后的证件照),根据size
进行照片排布,然后生成一张六寸排版照。
python requests_api.py \
-u http://127.0.0.1:8080 \
-t generate_layout_photos \
-i ./idphoto_with_background.jpg \
-o ./layout_photo.jpg \
-s '(413,295)' \
-k 200
- 照片中检测到的人脸大于 1,则失败