前两天我的朋友肖和我说 “完啦完啦,现在微信公众号没法弄了”。我就纳闷了,问她怎么回事。她告诉我 “黑洞图片事件你不知道,好多微信公众号号都有被告图片侵权,赔偿还不少。虽然我一直注意,但是有些图片根本不知道有没有版权啊。自己的小号,被告了可赔偿啊不起。” 我本来想告诉她,你想多了,就你那破号,但是这样怕是没法做朋友了。机智的我转而告诉她 “太简单了,我帮你做个图片小程序吧,自动生成图片,一劳永逸”。肖立马说 “好啊,好啊,到时候赚钱了分你!” 于是就有了黑洞微信头图生成器。

使用 Pillow 处理图片

Pillow 是python的图片处理库,可以用来处理图片。核心代码大概如下:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
from PIL import Image, ImageDraw, ImageFont

...

# 生成图片
image = Image.new("RGBA", (WIDTH, HEIGHT), background_color)
draw = ImageDraw.Draw(image)

# 设置字体大小
font = ImageFont.truetype(font_name, 20)
w, h = font.getsize(word)

# 文字垂直和水平居中
draw.text(((WIDTH - w) / 2, (HEIGHT - h) / 2), word, fill=font_color, font=font)
# 生成图片文件
image.save("output/{}_{}.png".format(filename, idx, "png"))

核心功能都是使用 Pillow 提供的api,生成一个rgb图片,然后往上贴文本,步骤和Photoshop创建图片类似。创建的图片效果有:

Python

英文会生成10种,中文生成4种。更多效果图,请见github/game404

使用 click 封装cli

python的命令行工具有 docopt, fireclick。 比较了一下,觉得 click 更适合本项目。

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
@click.command(context_settings=CONTEXT_SETTINGS)
@click.option("--word", prompt="the word",
              help="图片文字")
@click.option("--bcolor", default="white", help="图片背景色,默认白色,支持颜色值['red', 'cyan', 'green', ...]及rgb hex值#ffffff")
@click.option("--fcolor", default="#2496ed",
              help="文字颜色,默认docker蓝,支持颜色值['red', 'cyan', 'green', ...]及rgb hex值#ffffff")
@click.option("--fpath", default=None, help="字体文件路径,默认空,使用预制字体。也许相对路径更合适。")
def generator(word, bcolor, fcolor, fpath):
    """
    黑洞图片生成器,协助生成微信公众号头图。自由不侵权,game404 出品。

    python运行示例:

        python blackhole.py --word docker

        python blackhole.py --word docker --bcolor black --fcolor #ffffff

        python blackhole.py --word docker --fpath some.ttf

    Docker运行示例:

        docker run -it --rm game404/blackhole docker

        ...

    """

运行效果如下:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
(pywork-Y7-meC5z) C:\pywork\blackhole>python blackhole.py --help
Usage: blackhole.py [OPTIONS] 

  黑洞图片生成器,协助生成微信公众号头图。自由不侵权,game404 出品。

  python运行示例:

      python blackhole.py --word docker

      python blackhole.py --word docker --bcolor black --fcolor #ffffff

      python blackhole.py --word docker --fpath some.ttf

  Docker运行示例:

      docker run -it --rm game404/blackhole docker

      ...

Options:
  --word TEXT    图片文字
  --bcolor TEXT  图片背景色,默认白色,支持颜色值['red', 'cyan', 'green', ...]及rgb hex值#ffffff
  --fcolor TEXT  文字颜色,默认docker蓝,支持颜色值['red', 'cyan', 'green', ...]及rgb
                 hex值#ffffff
  --fpath TEXT   字体文件路径,默认空,使用预制字体。也许相对路径更合适。
  -h, --help     Show this message and exit.

做完程序,我正在想怎么发给肖,封装成pypi package呢,还是exe呢。 这时候旁边的肖恩顿,突然插了一句。“直接编成docker镜像吧,多方便啊,还跨平台”。原来他都知道啊,希望分帐的消息他不知道。

应用docker镜像制作

Dockerfile 如下:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
FROM python:3.7-alpine3.9
LABEL maintainer="shawn <studyoo@foxmail.com>"

WORKDIR /app

COPY requirements.txt /app

RUN apk add --no-cache jpeg-dev \
                       zlib-dev \
                       freetype-dev \
                       lcms2-dev \
                       openjpeg-dev \
                       tiff-dev \
                       tk-dev \
                       tcl-dev \
                       harfbuzz-dev \
                       fribidi-dev \
                       gcc \
                       musl-dev \
    && echo "[global] \
index-url = http://pypi.tuna.tsinghua/simple \
trusted-host = pypi.tuna.tsinghua \
timeout = 120 \
" > /etc/pip.conf \
    && pip install --upgrade pip \
    && pip install -r requirements.txt \
    && mkdir output

COPY . /app

ENTRYPOINT ["python","blackhole.py"]

pillow涉及的dev包比较多,属于比较难装的package。

封装完成后,提交到docker hub,肖直接可以使用:

1
docker run -it -v $PWD/output:/app/output --rm game404/blackhole --word docker

和python方式运行类似,区别在于只用输入--word docker参数

docker

总结

简单总结一下:

  1. 使用pillow制作图片文件。
  2. 使用click封装代码命令行工具。
  3. 编写docker镜像方便使用。