python图像转字符画_python图像、视频转字符画

python图像转字符画需要用到matplotlib.pyplot库,视频转字符画需要用到opencv库,这里的代码基于python 3.5

图像转字符画需要先将图像转为灰度图,转灰度图的公式是gray = 0.2126 * r + 0.7152 * g + 0.0722 * b,因为matplotlib图像的色彩排序是RGB的(opencv是BGR),所以如果不用库函数,可以使用以下代码实现灰度转换:

gray = 0.2126 * pic[:,:,0] + 0.7152 * pic[:,:,1] + 0.0722 * pic[:,:,2]

转成灰度图以后,对于每一个像素值,都要对应一个字符值。然后从图像中均匀取一些像素出来作映射即可实现图像到字符画的转换,代码如下:

importmatplotlib.pyplot as plt

show_heigth= 30show_width= 40

#这两个数字是调出来的

ascii_char= list("$@B%8&WM#*oahkbdpqwmZO0QLCJUYXzcvunxrjft/\|()1{}[]?-_+~<>i!lI;:,\"^`'.")#生成一个ascii字符列表

char_len =len(ascii_char)

pic= plt.imread("wm.jpg")#使用plt.imread方法来读取图像,对于彩图,返回size = heigth*width*3的图像#matplotlib 中色彩排列是R G B#opencv的cv2中色彩排列是B G R

pic_heigth,pic_width,_=pic.shape#获取图像的高、宽

gray= 0.2126 * pic[:,:,0] + 0.7152 * pic[:,:,1] + 0.0722 * pic[:,:,2]#RGB转灰度图的公式 gray = 0.2126 * r + 0.7152 * g + 0.0722 * b

#思路就是根据灰度值,映射到相应的ascii_char

for i inrange(show_heigth):#根据比例映射到对应的像素

y = int(i * pic_heigth /show_heigth)

text= ""

for j inrange(show_width):

x= int(j * pic_width /show_width)

text+= ascii_char[int(gray[y][x] / 256 *char_len)]print(text)

效果:

969627-20180116221023084-949998223.png

对于视频,其实也就是将每一帧转成字符画,这里用opencv来读取视频的每一帧。

如果遇到numpy core的问题,可以更新一下numpy。

为了有更好的显示效果,先将每一帧的转换的字符画保存下来,最后再统一输出出去。

importcv2importos

show_heigth= 30show_width= 80ascii_char= list("$@B%8&WM#*oahkbdpqwmZO0QLCJUYXzcvunxrjft/\|()1{}[]?-_+~<>i!lI;:,\"^`'.")#生成一个ascii字符列表

char_len =len(ascii_char)

vc= cv2.VideoCapture("v.mkv") #加载一个视频

if vc.isOpened(): #判断是否正常打开

rval , frame =vc.read()else:

rval=False

frame_count=0

outputList= [] #初始化输出列表

while rval: #循环读取视频帧

gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY) #使用opencv转化成灰度图

gray = cv2.resize(gray,(show_width,show_heigth))#resize灰度图

text = ""

for pixel_line ingray:for pixel in pixel_line: #字符串拼接

text += ascii_char[int(pixel / 256 *char_len )]

text+= "\n"outputList.append(text)

frame_count= frame_count + 1

if frame_count % 100 ==0:print("已处理" + str(frame_count) + "帧")

rval, frame=vc.read()print("处理完毕")for frame inoutputList:

os.system("cls") #清屏

print(frame)print()print()

这里用的bad apple的视频来进行转换:

969627-20180117125411849-850713954.gif

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值