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通过pil模块将raw图片转换成png图片的方法
Mar 16 Python
python中的文件打开与关闭操作命令介绍
Apr 26 Python
使用python3+xlrd解析Excel的实例
May 04 Python
Django框架实现分页显示内容的方法详解
May 10 Python
Django单元测试工具test client使用详解
Aug 02 Python
Python装饰器使用你可能不知道的几种姿势
Oct 25 Python
Python之——生成动态路由轨迹图的实例
Nov 22 Python
学习Python列表的基础知识汇总
Mar 10 Python
python操作redis数据库的三种方法
Sep 10 Python
Selenium关闭INFO:CONSOLE提示的解决
Dec 07 Python
python SOCKET编程基础入门
Feb 27 Python
总结Python使用过程中的bug
Jun 18 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
什么是短波收听SWL
2021/03/01 无线电
用PHP的超级变量$_POST获取HTML表单(HTML Form) 数据
2011/05/07 PHP
PHP获取和操作配置文件php.ini的几个函数介绍
2013/06/24 PHP
php出现web系统多域名登录失败的解决方法
2014/09/30 PHP
简单谈谈php浮点数精确运算
2016/03/10 PHP
Symfony2实现在controller中获取url的方法
2016/03/18 PHP
php+jQuery实现的三级导航栏下拉菜单显示效果
2017/08/10 PHP
学习YUI.Ext 第六天--关于树TreePanel(Part 1)
2007/03/10 Javascript
让FireFox支持innerText的实现代码
2009/12/01 Javascript
juqery 学习之五 文档处理 包裹、替换、删除、复制
2011/02/11 Javascript
google jQuery 引用文件,jQuery 引用地址集合(jquery 1.2.6至jquery1.5.2)
2011/04/24 Javascript
javascript的渐进增强与平稳退化浅谈
2013/11/12 Javascript
带左右箭头图片轮播的JS代码
2013/12/18 Javascript
JavaScript函数的4种调用方法详解
2014/04/22 Javascript
jquery点击切换背景色的简单实例
2016/08/25 Javascript
Vue.js路由组件vue-router使用方法详解
2016/12/02 Javascript
javascript replace()第二个参数为函数时的参数用法
2016/12/26 Javascript
JavaScript函数apply()和call()用法与异同分析
2018/08/10 Javascript
js 下拉菜单点击旁边收起实现(踩坑记)
2019/09/29 Javascript
[01:44]剑指西雅图 展望TI之CIS战队专访
2014/06/25 DOTA
[54:15]DOTA2-DPC中国联赛 正赛 DLG vs Dragon BO3 第二场2月1日
2021/03/11 DOTA
利用matplotlib+numpy绘制多种绘图的方法实例
2017/05/03 Python
浅析python3中的os.path.dirname(__file__)的使用
2018/08/30 Python
浅谈Python中的全局锁(GIL)问题
2019/01/11 Python
python networkx 根据图的权重画图实现
2019/07/10 Python
Python在OpenCV里实现极坐标变换功能
2019/09/02 Python
linux环境下安装python虚拟环境及注意事项
2020/01/07 Python
python+adb命令实现自动刷视频脚本案例
2020/04/23 Python
python实现读取类别频数数据画水平条形图案例
2020/04/24 Python
IntelliJ 中配置 Anaconda的过程图解
2020/06/01 Python
详解H5 活动页之移动端 REM 布局适配方法
2017/12/07 HTML / CSS
教师中国梦演讲稿
2014/04/23 职场文书
员工安全责任书范本
2014/07/24 职场文书
2014大学辅导员工作总结
2014/12/02 职场文书
股权转让协议书
2014/12/07 职场文书
《卖火柴的小女孩》教学反思
2016/02/19 职场文书