python使用PIL和matplotlib获取图片像素点并合并解析

作者:muamaker 时间:2021-09-07 15:41:45 

python 版本 3.x

首先安装 PIL

由于PIL仅支持到Python 2.7,加上年久失修,于是一群志愿者在PIL的基础上创建了兼容的版本,名字叫Pillow,支持最新Python 3.x,又加入了许多新特性,因此,我们可以直接安装使用Pillow。

所以 安装:


pip install pillow

获取像素点


import numpy as np
from PIL import Image
img = Image.open("./b.png").convert('RGBA')
a_img = np.asarray(img)

获取的图片像素为 一个二维数组,相当于是二维左边系, x ,y 然后里面存了一个元组 值分别为 r g b a

分别计算改变了像素值之后,就需要将数据写入到图片了,这个时候就需要 matplotlib


import matplotlib.pyplot as plt

plt.figure("beauty") # 开启图层,名称为 beauty
plt.imshow(a_img) # 二维数组的数据
plt.axis('off')
#plt.show()
plt.savefig("./result.png")

下面给出一个完整的 demo

需要将两张图片合并计算,并输出结果:

python使用PIL和matplotlib获取图片像素点并合并解析

python使用PIL和matplotlib获取图片像素点并合并解析

将上面两个图片合并


from PIL import Image
import numpy as np
import matplotlib.pyplot as plt
def modeSuperposition(basePixel,mixPixel,alpha):
basePixel = int(basePixel)
mixPixel = int(mixPixel);
res=0
if basePixel <= 128 :
 res = int(mixPixel) * int(basePixel) / 128;
else:
 res = 255 - (255 - mixPixel)*(255 - basePixel) / 128;  
a = alpha / 255;
if a > 1:
 a = 1
res = (1-a)*basePixel + a*res
t = int(res)&-256
if t == 0:
 return int(res)
if res > 255:
 return 255
return 0
def mergePoint(x,y):
p1 = img1[x][y]
p2 = img2[x][y]
p1[1] = modeSuperposition(p1[0],p2[0],p2[3])
p1[2] = modeSuperposition(p1[1],p2[1],p2[3])
p1[3] = modeSuperposition(p1[2],p2[2],p2[3])  
imgA = Image.open('./b.png')
img1=np.array(imgA.convert('RGBA')) #打开图像并转化为数字矩
img2=np.array(Image.open("./light.png").convert('RGBA'))  
i = len(img1);
j = len(img1[0]);

for k in range(0,len(img2)):
for n in range(0,len(img2[0])):
 if k < i and n < j:
  mergePoint(k,n)  
#img = Image.new("RGBA",imgA.size)###创建一个5*5的图片
plt.figure("beauty") # 开启图层,名称为 beauty
plt.imshow(img1) # 二维数组的数据
plt.axis('off')
#plt.show()
plt.savefig("./result.png")

结果如下:

python使用PIL和matplotlib获取图片像素点并合并解析

来源:https://www.cnblogs.com/muamaker/p/10740551.html

标签:python,pil,matplotlib,像素点,合并
0
投稿

猜你喜欢

  • python 函数、变量中单下划线和双下划线的区别详解

    2021-06-29 11:32:33
  • 用Dreamweaver设计自动关闭的网页

    2010-09-02 12:29:00
  • sql server not in 语句使程充崩溃

    2012-01-05 19:05:00
  • 一段ASP单页显示文件夹下所有图片的代码

    2011-02-28 11:23:00
  • JavaScript的9个陷阱及评点

    2007-08-28 15:10:00
  • 使用python os模块复制文件到指定文件夹的方法

    2022-01-06 13:23:01
  • WPF自定义搜索框代码分享

    2023-07-18 23:31:04
  • Python实现判断给定列表是否有重复元素的方法

    2021-05-25 13:34:59
  • python使用pandas读xlsx文件的实现

    2021-01-21 05:00:10
  • 怎么才能限制SQL Server只能让指定的机器连接

    2010-07-30 13:30:00
  • asp中提示至少一个参数没有被指定值 解决方法

    2013-06-01 20:14:00
  • php返回相对时间(如:20分钟前,3天前)的方法

    2023-10-26 11:20:38
  • SqlServer表死锁的解决方法分享

    2011-09-30 11:16:16
  • 挑战! 纯Javascript 重现经典网游! <魔力宝贝>

    2008-10-04 10:37:00
  • python新手练习实例之万年历

    2021-01-29 02:20:35
  • python3环境搭建过程(利用Anaconda+pycharm)完整版

    2022-01-16 06:04:47
  • php引用计数器进行垃圾收集机制介绍

    2023-10-07 22:41:55
  • 跨浏览器的本地存储(二):DOM:Storage

    2008-08-15 13:39:00
  • JSP EL表达式详细介绍

    2023-07-02 22:32:32
  • 使用Filter实现信息的二次检索

    2007-10-08 19:19:00
  • asp之家 网络编程 m.aspxhome.com