一起看爱情的模样,程序员带你花式表白,赶紧get!(附代码)

举报
Srius 发表于 2020/04/13 17:53:51 2020/04/13
【摘要】 每到情人节、七夕节,不少小伙伴大伙伴们都会遇到这样一个世纪问题——怎么给女朋友/老婆一个与众不同的节日惊喜~今天,我就和大家分享一个独特的表白方法——用“我爱你”拼出心爱人的模样~

每到情人节、七夕节,不少小伙伴大伙伴们都会遇到这样一个世纪问题——怎么给女朋友/老婆一个与众不同的节日惊喜。

你说送花吧,到时候朋友圈里一划,全部都是送花的,女票:“没创意!”,遂卒;

你说送礼物吧,要是送的礼物不合心意,女票:“你根本不懂我!”,又卒;

你说逛街买买买吧,摸摸空空的口袋,默默把这个想法丢到一边...


今天,就和大家分享一个独特的表白方法——用“我爱你”拼出心爱人的模样!


成品图!


什么?看不清长啥样?放大来康康



(满眼都是爱你的形状~)


想做出这样的照片吗?那么~我们现在就开始啦~




1. 需要准备的有

女票超级无敌可爱美腻的照片 1张!

python (这里用的是python3.7)

需要的用到的库

cv2:用来读取照片

PIL:用来生成新的图片

(如果没有接触过python,不想/不会配环境、装cv2、PIL之类的库,或者电脑性能不太够,强烈推荐使用华为云的ModelArts进行开发~直接解决环境配置、电脑性能的各种问题~)

2. 基本思路

要实现这样的效果,首先需要有一张照片,提取其像素信息,然后赋给排布满文字的新图片,就能得到如上图所示的一张新图片啦!

废话不多说,接下来就开始吧~

3.操作流程

1.首先导入用到的库(两者的作用在1中已有介绍)

import cv2
from PIL import Image, ImageDraw, ImageFont


2.然后开始声明绘图的方法

这里有两个参数,分别是原图片的路径和要写的文字

def draw(pic, draw_text):


3.接着读取图片

使用cv2中的imread方法读取图片信息,

使用PIL中的Image方法创建一个新的图片,其尺寸和源图片一致,背景为白色

  img = cv2.imread(pic)    
  blank = Image.new("RGB", [img.shape[1], img.shape[0]], "white")
  drawObj = ImageDraw.Draw(blank) # 告诉程序,我们接下来就要在这个图上写字啦!


4.声明绘图的一些参数(这些参数都是我经过多次试验得到的最佳大小~)

  n = 10 # 读取像素的间隔
  m = 9 # 字体的大小
  font_path = '你使用字体的位置' # 字体的路径

  font = ImageFont.truetype(font_path, size=m) # 将字体信息赋给font变量,供后续使用


5.接下来就是最关键的一步!把文字写上去,并按照源图片给图片上色

通过两个for循环,依次定位到每个文字所在的色块(中间间隔n是因为文字比像素块大得多,不可能完全按照每个像素的位置和色彩来排布)

使用text()方法填入带色彩的文字,几个参数分别代表:

[j, i] -- 坐标位置

draw_text[int(j / n) % len(draw_text)] -- 找到当前该写入哪个文字了(比如“我爱你”中的第几个字)

fill=(img[i][j][2], img[i][j][1], img[i][j][0]) -- 代表源图片对应位置的颜色(三个分别代表RBG颜色值)

font -- 显然就是字体信息啦~

  for i in range(0, img.shape[0], n):    
      for j in range(0, img.shape[1], n):
        drawObj.text(
                  [j, i],
            draw_text[int(j / n) % len(draw_text)],
            fill=(img[i][j][2], img[i][j][1], img[i][j][0]),
            font=font
            ) # 按句子的顺序填充文字


6.写入完成,导出图片

    blank.save('img_' + pic) # 保存生成的图片


7.调用我们封装好的方法~

输入图片路径和目标文字,运行~一张独一无二的表白图就大功告成!

draw('1.jpg', "我爱你")


附上全代码(记得把字体路径改成自己电脑的哟~)

import cv2
from PIL import Image, ImageDraw, ImageFont


def draw(pic, draw_text):
    img = cv2.imread(pic)
    blank = Image.new("RGB", [img.shape[1], img.shape[0]], "white")
    drawObj = ImageDraw.Draw(blank)

    n = 10
    m = 9

    font = ImageFont.truetype(font_path, size=m)

    for i in range(0, img.shape[0], n):
        for j in range(0, img.shape[1], n):
            drawObj.text(
                        [j, i],
                        draw_text[int(j / n) % len(draw_text)],
                        fill=(img[i][j][2], img[i][j][1], img[i][j][0]),
                        font=font
                        )

    blank.save('img_' + pic)

    
draw('1.jpg', "我爱你")




进阶~

既然都能做成一帧一帧的图片了,为什么不把他们连接起来~做成一个表白视频呢?

当然阔以!

具体实现的方法和代码都在这里:【2020华为云AI实战营】520到了!亲手给TA做一个独一无二的表白视频吧~

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。