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判断文本中消息重复次数的方法
Apr 27 Python
Python实现破解猜数游戏算法示例
Sep 25 Python
对numpy.append()里的axis的用法详解
Jun 28 Python
Python进程间通信Queue消息队列用法分析
May 22 Python
Django网络框架之HelloDjango项目创建教程
Jun 06 Python
django+tornado实现实时查看远程日志的方法
Aug 12 Python
Python lambda表达式filter、map、reduce函数用法解析
Sep 11 Python
Python基于xlrd模块处理合并单元格
Jul 28 Python
PIP和conda 更换国内安装源的方法步骤
Sep 21 Python
python实现一个简单RPC框架的示例
Oct 28 Python
聊聊Python中关于a=[[]]*3的反思
Jun 02 Python
Golang Web 框架Iris安装部署
Aug 14 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
使用php统计字符串中中英文字符的个数
2013/06/23 PHP
php使用socket post数据到其它web服务器的方法
2015/06/02 PHP
教你识别简单的免查杀PHP后门
2015/09/13 PHP
PHP使用pear实现mail发送功能 windows环境下配置pear
2016/04/15 PHP
PHP简单实现DES加密解密的方法
2016/07/12 PHP
thinkPHP中钩子的使用方法实例分析
2017/11/16 PHP
php基于 swoole 实现的异步处理任务功能示例
2019/08/13 PHP
JavaScript使用cookie实现记住账号密码功能
2015/04/27 Javascript
JS实现屏蔽shift,Ctrl,alt等功能键的方法
2015/06/01 Javascript
移除AngularJS下URL中的#字符的方法
2015/06/19 Javascript
很不错的两款Bootstrap Icon图标选择组件
2016/01/28 Javascript
基于JavaScript代码实现自动生成表格
2016/06/15 Javascript
vue组件父与子通信详解(一)
2017/11/07 Javascript
浅谈Node.js 沙箱环境
2018/05/15 Javascript
微信小程序使用setData修改数组中单个对象的方法分析
2018/12/30 Javascript
vue-cli构建vue项目的步骤详解
2019/01/27 Javascript
JavaScript类型相关的常用操作总结
2019/02/14 Javascript
python操作ie登陆土豆网的方法
2015/05/09 Python
浅谈Python 集合(set)类型的操作——并交差
2016/06/30 Python
windows下搭建python scrapy爬虫框架步骤
2018/12/23 Python
Python遍历文件夹 处理json文件的方法
2019/01/22 Python
分享8个非常流行的 Python 可视化工具包
2019/06/05 Python
python使用配置文件过程详解
2019/12/28 Python
python 回溯法模板详解
2020/02/26 Python
Python 使用双重循环打印图形菱形操作
2020/08/09 Python
推荐WEB开发者最佳HTML5和CSS3代码生成器
2015/11/24 HTML / CSS
Sunglasses Shop荷兰站:英国最大的太阳镜独立在线零售商和供应商
2017/01/08 全球购物
Java模拟试题
2014/11/10 面试题
行政专员工作职责
2013/12/22 职场文书
优秀求职信范文分享
2014/01/26 职场文书
校运会入场式解说词
2014/02/10 职场文书
关于运动会广播稿50字
2014/10/18 职场文书
部门经理迟到检讨书
2015/02/16 职场文书
MySQL图形化管理工具Navicat安装步骤
2021/12/04 MySQL
基于Python实现流星雨效果的绘制
2022/03/18 Python
Elasticsearch Recovery 详细介绍
2022/04/19 Java/Android