zoukankan      html  css  js  c++  java
  • python 使用 PIL 和 matplotlib 获取图片像素点处理之后再写入

    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

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

    将上面两个图片合并

    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")
    

      

     结果如下:

      

  • 相关阅读:
    流媒体技术原理及播放方式(浅显易懂)
    实时音视频技术难点及解决方案
    流媒体技术简介
    DSP广告系统架构及关键技术解析(转)
    大型网站架构 图片服务器分离
    大话铁道部12306订票系统云架构
    技术揭秘12306改造(一):尖峰日PV值297亿下可每秒出票1032张
    12306火车票预定系统的需求分析
    PowerDesigner16.5 使用遇到的问题
    Ubuntu不输入密码执行sudo命令方法介绍
  • 原文地址:https://www.cnblogs.com/muamaker/p/10740551.html
Copyright © 2011-2022 走看看