用python实现你的绘画梦想
导语:

你是否还在为当时年少时没有选择自己的梦想而伤心,是否还在为自己的无法成为绘画名家而苦恼,这一切都不需要担心。python都能帮你实现,诶!python怎么能画画呢,一些简单的图案没问题,但是我要是想画素描那肯定没有办法了呀!
需求分析:
通过python代码脚本,实现绘制素描

安装工具
pip install pillow
pip install numpy
代码实现
首先我们需要看一下我们需要的原图:

这是一头大水牛,那我们要如何将它变成一幅素描画呢?
来看我们第一种方案:
# -*- coding: utf-8 -*-
from PIL import Image
from random import randint
old = Image.open(r"da.jpg")
new = Image.new('L', old.size, 255)
w, d = old.size
old = old.convert('L')
PEN_SIZE = 3
COLOR_DIFF = 7
LINE_LEN = 2
for i in range(PEN_SIZE + 1, w - PEN_SIZE - 1):
for j in range(PEN_SIZE + 1, d - PEN_SIZE - 1):
originalcolor = 255
lcolor = sum([old.getpixel((i - r, j))
for r in range(PEN_SIZE)]) // PEN_SIZE
rcolor = sum([old.getpixel((i + r, j))
for r in range(PEN_SIZE)]) // PEN_SIZE
if abs(lcolor - rcolor) > COLOR_DIFF:
originalcolor -= (255 - old.getpixel((i, j))) // 4
for p in range(-LINE_LEN + randint(-1, 1), LINE_LEN + randint(-1, 1)):
new.putpixel((i, j + p), originalcolor)
ucolor = sum([old.getpixel((i, j - r))
for r in range(PEN_SIZE)]) // PEN_SIZE
dcolor = sum([old.getpixel((i, j + r))
for r in range(PEN_SIZE)]) // PEN_SIZE
if abs(ucolor - dcolor) > COLOR_DIFF:
originalcolor -= (255 - old.getpixel((i, j))) // 4
for p in range(-LINE_LEN + randint(-1, 1), LINE_LEN + randint(-1, 1)):
new.putpixel((i + p, j), originalcolor)
lucolor = sum([old.getpixel((i - r, j - r))
for r in range(PEN_SIZE)]) // PEN_SIZE
rdcolor = sum([old.getpixel((i + r, j + r))
for r in range(PEN_SIZE)]) // PEN_SIZE
if abs(lucolor - rdcolor) > COLOR_DIFF:
originalcolor -= (255 - old.getpixel((i, j))) // 4
for p in range(-LINE_LEN + randint(-1, 1), LINE_LEN + randint(-1, 1)):
new.putpixel((i - p, j + p), originalcolor)
rucolor = sum([old.getpixel((i + r, j - r))
for r in range(PEN_SIZE)]) // PEN_SIZE
ldcolor = sum([old.getpixel((i - r, j + r))
for r in range(PEN_SIZE)]) // PEN_SIZE
if abs(rucolor - ldcolor) > COLOR_DIFF:
originalcolor -= (255 - old.getpixel((i, j))) // 4
for p in range(-LINE_LEN + randint(-1, 1), LINE_LEN + randint(-1, 1)):
new.putpixel((i + p, j + p), originalcolor)
new.save(r"pencil_drawing.jpg")

我们这第一份素描图案时以线条为单位进行素描的,而且还增加了随机函数,图案中线条的长度不确定,这样创作的素描看上去更加柔和,看起来更加接近真实的人类作画的风格。
但是这个方法有一些弊端,
一是代码量较多
二是执行速度过慢
你想通过这个方式实现一个素描图案,需要等待很长时间。
那么有没有更好的方式呢?

来,我们再来看,接下来我们要用一种更友好的方式来实现这个需求
from PIL import Image
import numpy as np
a = np.asarray(Image.open('牛.jpg').convert('L')).astype('float')
depth = 10. # (0-100)
grad = np.gradient(a) # 取图像灰度的梯度值
grad_x, grad_y = grad # 分别取横纵图像梯度值
grad_x = grad_x * depth / 100.
grad_y = grad_y * depth / 100.
A = np.sqrt(grad_x ** 2 + grad_y ** 2 + 1.)
uni_x = grad_x / A
uni_y = grad_y / A
uni_z = 1. / A
vec_el = np.pi / 2.2 # 光源的俯视角度,弧度值
vec_az = np.pi / 4. # 光源的方位角度,弧度值
dx = np.cos(vec_el) * np.cos(vec_az) # 光源对x 轴的影响
dy = np.cos(vec_el) * np.sin(vec_az) # 光源对y 轴的影响
dz = np.sin(vec_el) # 光源对z 轴的影响
b = 255 * (dx * uni_x + dy * uni_y + dz * uni_z) # 光源归一化
b = b.clip(0, 255)
im = Image.fromarray(b.astype('uint8')) # 重构图像
im.save('new.jpg')

可能细心一点,大家可以看到我使用的是,数据分析,金融量化,机器学习,人工智能的必备工具包numpy,而且代码量缩短的二十几行了,效果相较于上面那种方式,还要更好一些,运行的速度也要快很多倍。

用python实现你的绘画梦想的更多相关文章
- python奇闻杂技
第一天 01 从计算机到程序设计语言 02 python环境配置 03 实例一:温度转换 04 python语法分析 第二天 01 深入理解python语言 02 实例二,python蟒蛇配置 03 ...
- 简述python的turtle绘画命令及解释
一 基础认识 turtle库是python的标准库之一,它是一个直观有趣的图形绘制数据库,turtle(海龟)图形绘制的概念诞生1969年.它的应用十分广,而且使用简单,只要在编写python程序时写 ...
- 七夕特别篇|用Python绘画牛郎织女在鹊桥相见
大家好,我是辰哥~ 今天就是七夕节,首先提前祝福有伴侣的小伙伴,七夕快乐,没有伴侣的小伙伴,今天就会找到伴侣,(给看到这句话的你好运加持,哈哈哈). 作为会Python的我们必须做点好玩且有意义的东西 ...
- Python subplot 绘画
环境 Anaconda3 Python 3.6, Window 64bit 目的 利用 matplotlib 画图模块,汇至子图 # -*- coding: utf-8 -*- import matp ...
- Python Turtle绘画初学编程——六芒星,浪形圈
老师上课说可以自学一下python中的绘图turtle,就自己初步学习了一下,做了两个简单的绘图——六芒星和浪形圈(其实我也不知道该叫它什么,就照样子编了个词
- 用python绘画一些简单图片
python画笑脸 程序源代码 import turtle #画脸 t = turtle.Pen() t.speed(15) #t.circle(150) #t.color('orange') t.f ...
- python之路:Day03 --- Python基础3 >>函数
本节内容 1.函数基本语法及特性 2.参数 3.局部变量与全局变量 4.返回值 嵌套函数 5.递归 6.匿名函数 7.高阶函数 8.内置函数 一.函数基本语法及特性 区别 面向过程编程:根据业务逻辑从 ...
- Python黑帽编程2.9 面向对象编程
Python黑帽编程2.9 面向对象编程 我个人认为,计算机语言的发展,有两个方向,一个是从低到高的发展过程,在这个过程中,语言的思考和解决问题的方式是面向硬件的.硬件本质上处理的是信号,在此基础上, ...
- Python开源框架
info:更多Django信息url:https://www.oschina.net/p/djangodetail: Django 是 Python 编程语言驱动的一个开源模型-视图-控制器(MVC) ...
随机推荐
- C# 读取控制台的Console.Write
一个程序去调用另一个xxx.exe的时候,需要记录下这个exe里面的console.write的输出 public static string InvokeExcute(string Command) ...
- 关于未来实现API管理系统的几个关键词
下面将通过几个关键词的形式说明API管理的重要性和未来的实现方式. 1.生命周期管理 在整个API生命周期中更深入地集成所有工具将进一步提高生命周期循环的速度,而且更重要的是提供满足消费者需求的API ...
- 2019.10.15 CSP初赛知识点整理
初赛需要的知识点整理如下: (1)计算机的硬件组成与基本常识 (2)单位/进制的转换 (3)进制/逻辑运算相关 (4)概率与期望 (5)排序的各种性质 (6)简单数据结构的使用(栈.队列.链表等) ( ...
- Jackson日期转换少一天
1. 案例 添加一个学生,前端把生日传给后端,后端使用Datel类型接收到后,然后调用其它服务进行保存入库. 与其它服务交互时,使用的是JSON格式,出现日期少一天. @Data @AllArgsCo ...
- HOOK 技术
在介绍 截获系统消息钩子 之前,这几个函数是密切相关的: SetWindowsHookEx() 介绍: 功能:将应用程序定义的挂钩过程安装到挂钩链中. 函数原型:HHOOK SetWindowsHoo ...
- cobalt strike笔记-常用beacon扫盲
最近还是重新补一下cs的东西 0x01 Beacon命令 Beacon Commands =============== Command Description ------- ----------- ...
- windows自带的netsh的使用
0x01netsh简介 自Windows XP开始,Windows中就内置网络端口转发的功能.任何传入到本地端口的TCP连接(IPv4或IPv6)都可以被重定向到另一个本地端口,或远程计算机上的端口, ...
- 内网转发之reGeorg+proxifier
先将reGeorg的对应脚本上传到服务器端,reGeorg提供了PHP.ASPX.JSP脚本,直接访问显示“Georg says, 'All seems fine'”,表示脚本运行正常. 运行 pyt ...
- Hadoop和YARN :map+shuffle+reduce走读
今天做了一个hadoop分享,总结下来,包括mapreduce,及shuffle深度讲解,还有YARN框架的详细说明等. v\:* {behavior:url(#default#VML);} o\:* ...
- [UWP]使用CompositionLinearGradientBrush实现渐变画笔并制作动画
1. 什么是 CompositionBrush CompositionBrush(合成画笔)是操作可视化层时用于绘制 SpriteVisual 区域的画笔. 使UWP 应用时可以选择使用 XAML 画 ...