Python实现PS图像调整颜色梯度效果示例


Posted in Python onJanuary 25, 2018

本文实例讲述了Python实现PS图像调整颜色梯度效果。分享给大家供大家参考,具体如下:

这里用 Python 实现 PS 中的色彩图,可以看到颜色的各种渐变,具体的效果可以参考附录说明

和之前的程序相比,这里利用矩阵的运算替代了 for 循环,提升了运行的效率。

import numpy as np
import matplotlib.pyplot as plt
from skimage import io
import numpy.matlib
from skimage import img_as_float
file_name='D:/Visual Effects/PS Algorithm/4.jpg';
img=io.imread(file_name)
img = img_as_float(img)
row, col, channel = img.shape
rNW = 0.5
rNE = 1.0
rSW = 1.0
rSE = 0.0
gNW = 0.0
gNE = 0.5
gSW = 0.0
gSE = 1.0
bNW = 1.0
bNE = 0.0
bSW = 1.0
bSE = 0.0
xx = np.arange (col)
yy = np.arange (row)
x_mask = numpy.matlib.repmat (xx, row, 1)
y_mask = numpy.matlib.repmat (yy, col, 1)
y_mask = np.transpose(y_mask)
fx = x_mask * 1.0 / col
fy = y_mask * 1.0 / row
p = rNW + (rNE - rNW) * fx
q = rSW + (rSE - rSW) * fx
r = ( p + (q - p) * fy )
r[r<0] = 0
r[r>1] =1
p = gNW + (gNE - gNW) * fx
q = gSW + (gSE - gSW) * fx
g = ( p + (q - p) * fy )
g[g<0] = 0
g[g>1] =1
p = bNW + (bNE - bNW) * fx
q = bSW + (bSE - bSW) * fx
b = ( p + (q - p) * fy )
b[b<0] = 0.0
b[b>1] = 1.0
img[:, :, 0] = r
img[:, :, 1] = g
img[:, :, 2] = b
plt.figure(1)
plt.imshow(img)
plt.axis('off');
plt.show();

附录:PS 色调— —颜色梯度

clc;
  clear all;
  close all;
  addpath('E:\PhotoShop Algortihm\Image Processing\PS Algorithm');
  I=imread('4.jpg');
  Image=double(I)/255;
  [height, width, depth]=size(Image);
  rNW=1.0;   gNW=0.0;  bNW=0.0;
  rNE=1.0;   gNE=1.0;  bNE=0.0;
  rSW=0.0;   gSW=0;   bSW=1.0;
  rSE=0.0;   gSE=1.0;  bSE=0.0;
  Img_new=Image;
  for ii=1:height
    for jj=1:width
      fx = jj / width;
      fy = ii / height;
      p = rNW + (rNE - rNW) * fx;
      q = rSW + (rSE - rSW) * fx;
      r = ( p + (q - p) * fy );
      r = min(max(r, 0), 1);
      p = gNW + (gNE - gNW) * fx;
      q = gSW + (gSE - gSW) * fx;
      g = ( p + (q - p) * fy );
      g = min(max(g, 0) ,1);
      p = bNW + (bNE - bNW) * fx;
      q = bSW + (bSE - bSW) * fx;
      b = ( p + (q - p) * fy );
      b = min(max(b, 0), 1);
      Img_new(ii, jj, 1)=r;
      Img_new(ii, jj, 2)=g;
      Img_new(ii, jj, 3)=b;
    end  
  end
  imshow(Img_new);
  imwrite(Img_new, 'out.jpg');

参考来源:http://www.jhlabs.com/index.html

本例Python运行效果图:

原图:

Python实现PS图像调整颜色梯度效果示例

运行效果:

Python实现PS图像调整颜色梯度效果示例

希望本文所述对大家Python程序设计有所帮助。

Python 相关文章推荐
Python生成随机MAC地址
Mar 10 Python
python 读取目录下csv文件并绘制曲线v111的方法
Jul 06 Python
Django 反向生成url实例详解
Jul 30 Python
Django1.11配合uni-app发起微信支付的实现
Oct 12 Python
Win10下python 2.7与python 3.7双环境安装教程图解
Oct 12 Python
Python线程指南分享
Nov 19 Python
基于Django实现日志记录报错信息
Dec 17 Python
解决jupyter notebook 前面书写后面内容消失的问题
Apr 13 Python
keras.utils.to_categorical和one hot格式解析
Jul 02 Python
Python通过len函数返回对象长度
Oct 22 Python
详解python polyscope库的安装和例程
Nov 13 Python
浅析python字符串前加r、f、u、l 的区别
Jan 24 Python
Python使用requests发送POST请求实例代码
Jan 25 #Python
python使用pandas实现数据分割实例代码
Jan 25 #Python
python实现闹钟定时播放音乐功能
Jan 25 #Python
python实现壁纸批量下载代码实例
Jan 25 #Python
python命令行解析之parse_known_args()函数和parse_args()使用区别介绍
Jan 24 #Python
Python动刷新抢12306火车票的代码(附源码)
Jan 24 #Python
python中的set实现不重复的排序原理
Jan 24 #Python
You might like
基于xcache的配置与使用详解
2013/06/18 PHP
CodeIgniter常用知识点小结
2016/05/26 PHP
php实现通过soap调用.Net的WebService asmx文件
2017/02/27 PHP
PHP实现表单提交数据的验证处理功能【防SQL注入和XSS攻击等】
2017/07/21 PHP
php屏蔽错误及提示的方法
2020/05/10 PHP
获取页面高度,窗口高度,滚动条高度等参数值getPageSize,getPageScroll
2006/09/22 Javascript
jquery 全局AJAX事件使用代码
2010/11/05 Javascript
JS按位非(~)运算符与~~运算符的理解分析
2011/07/31 Javascript
javascript获取鼠标点击元素对象(示例代码)
2013/12/20 Javascript
js判断60秒以及倒计时示例代码
2014/01/24 Javascript
jquery提交form表单简单示例分享
2014/03/03 Javascript
node.js回调函数之阻塞调用与非阻塞调用
2015/11/13 Javascript
js微信扫描二维码登录网站技术原理
2016/12/01 Javascript
浅析BootStrap中Modal(模态框)使用心得
2016/12/24 Javascript
JS正则验证多个邮箱完整实例【邮箱用分号隔开】
2017/04/19 Javascript
JavaScript链式调用实例浅析
2018/12/19 Javascript
JavaScript实现省市区三级联动
2020/02/13 Javascript
详解JS预解析原理
2020/06/16 Javascript
动态规划之矩阵连乘问题Python实现方法
2017/11/27 Python
Python2.X/Python3.X中urllib库区别讲解
2017/12/19 Python
django admin 后台实现三级联动的示例代码
2018/06/22 Python
Django框架模板的使用方法示例
2019/05/25 Python
Python生成一个迭代器的实操方法
2019/06/18 Python
python  logging日志打印过程解析
2019/10/22 Python
python-xpath获取html文档的部分内容
2020/03/06 Python
Pretty Little Thing爱尔兰:时尚女性服饰
2017/03/27 全球购物
Toppik顶丰增发纤维官网:解决头发稀疏
2017/12/30 全球购物
《夏夜多美》教学反思
2014/02/17 职场文书
文秘应聘自荐书范文
2014/02/18 职场文书
大学毕业感言200字
2014/03/09 职场文书
论文指导教师评语
2014/04/28 职场文书
主题党日活动总结
2014/07/08 职场文书
文员岗位职责范本
2015/04/16 职场文书
六一文艺汇演主持词
2015/06/30 职场文书
使用GO语言实现Mysql数据库CURD的简单示例
2021/08/07 Golang
SONY AN-LP1 短波有源天线放大器图
2022/04/05 无线电