摘要:本文介绍一种使用opencv提取毛笔字轮廓的方法,用于DIY毛笔字帖。
程序员就不能写毛笔字了吗?
NONONO。
就像是问嫦娥是不是不能写代码?
不回答,只是静静地观察。
且不管吴刚是不是捧出了桂花酒,程序员要写毛笔字,python祭出便知有没有。
网上索索自己喜欢的字。
没有喜欢的,我们的桌子可能在中秋节还是这样的吧(图片来自网络)。就找“陋室”两个字练练吧。
陋室,我们只想写一下“陋室”,怎么办?提取出来啊!
像这样:
接下来用Python来写代码,提取出来轮廓
import cv2
import numpy as np
img = cv2.imread("loushi.png")
cv2.imshow("origin",img)
gray = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)
ret,binary = cv2.threshold(gray,128,255,cv2.THRESH_BINARY)
cv2.imshow("binary",binary)
contours, hierarchy = cv2.findContours(binary,cv2.RETR_TREE,cv2.CHAIN_APPROX_SIMPLE)
cv2.drawContours(img,contours,-1,(0,0,255),3)
cv2.imshow("result", img)
cv2.waitKey(0)
运行效果如下图所示
如果将这个字帖打印出来,黑底是不是太费墨?
那么我们就吧黑底和和白字都去掉,只留下轮廓。
怎么样计算?
就是按照原图的大小,新建一个白色的图片,然后把轮廓叠加到白底上就行了。
import cv2
import numpy as np
img = cv2.imread("loushi.png")
cv2.imshow("origin",img)
gray = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)
ret,binary = cv2.threshold(gray,128,255,cv2.THRESH_BINARY)
cv2.imshow("binary",binary)
height, width, _ = img.shape
img = np.zeros((height, width, 3), np.uint8)
img.fill(255)
contours, hierarchy = cv2.findContours(binary,cv2.RETR_TREE,cv2.CHAIN_APPROX_SIMPLE)
cv2.drawContours(img,contours,-1,(0,0,255),3)
cv2.imshow("result", img)
cv2.waitKey(0)
运算效果如下图所示
我们只需要把计算结果复制到一个图像编辑软件,或者一个word文件什么的,再打印就行了。
打印出来,就可以抽空写写字,洋洋生了。
除了泡泡枸杞,写写字是不是更加有逼格?
奥对了,抽空可以把自己的名字练练,免得老板看一眼我们写的名字都撇嘴。