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下singleton模式的实现方法
Jul 16 Python
浅谈pyhton学习中出现的各种问题(新手必看)
May 17 Python
python爬虫入门教程--利用requests构建知乎API(三)
May 25 Python
Python实现加载及解析properties配置文件的方法
Mar 29 Python
Django 路由控制的实现
Jul 17 Python
Python发送邮件的实例代码讲解
Oct 16 Python
在win64上使用bypy进行百度网盘文件上传功能
Jan 02 Python
mac 上配置Pycharm连接远程服务器并实现使用远程服务器Python解释器的方法
Mar 19 Python
使用 django orm 写 exists 条件过滤实例
May 20 Python
pytorch随机采样操作SubsetRandomSampler()
Jul 07 Python
详解python with 上下文管理器
Sep 02 Python
python爬虫筛选工作实例讲解
Nov 23 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优化那些事(经验分享)
2014/11/27 PHP
从wamp到xampp的升级之路
2015/04/08 PHP
PHP编译configure时常见错误的总结
2017/08/17 PHP
JavaScript 联动的无限级封装类,数据采用非Ajax方式,随意添加联动
2010/06/29 Javascript
javascript for循环从入门到偏门(效率优化+奇特用法)
2012/08/01 Javascript
快速解决FusionCharts联动的中文乱码问题
2013/12/04 Javascript
JavaScript实现计算字符串中出现次数最多的字符和出现的次数
2015/03/12 Javascript
JavaScript对象反射用法实例
2015/04/17 Javascript
jquery实现简单的遮罩层
2016/01/08 Javascript
jQuery实现一个简单的轮播图
2017/02/19 Javascript
基于pako.js实现gzip的压缩和解压功能示例
2017/06/13 Javascript
简单谈谈require模块化jquery和angular的问题
2017/06/23 jQuery
ajax+node+request爬取网络图片的实例(宅男福利)
2017/08/28 Javascript
微信小程序methods中定义的方法互相调用的实例代码
2018/08/07 Javascript
脚手架vue-cli工程webpack的基本用法详解
2018/09/29 Javascript
angular中子控制器向父控制器传值的实例
2018/10/08 Javascript
electron实现qq快捷登录的方法示例
2018/10/22 Javascript
微信小程序实现多行文字超出部分省略号显示功能
2019/10/23 Javascript
Vue3项目打包后部署到服务器 请求不到后台接口解决方法
2020/02/06 Javascript
Python基于回溯法子集树模板解决最佳作业调度问题示例
2017/09/08 Python
Python通过matplotlib绘制动画简单实例
2017/12/13 Python
django自带的server 让外网主机访问方法
2018/05/14 Python
对pandas里的loc并列条件索引的实例讲解
2018/11/15 Python
解决python使用list()时总是报错的问题
2020/05/05 Python
Python如何在循环内使用list.remove()
2020/06/01 Python
用sleep间隔进行python反爬虫的实例讲解
2020/11/30 Python
Urban Outfitters英国官网:美国平价服饰品牌
2016/11/25 全球购物
师范学院教师自荐书
2014/01/31 职场文书
领导干部考核评语
2015/01/04 职场文书
给女朋友道歉的话大全
2015/01/20 职场文书
罚站检讨书
2015/01/29 职场文书
房产电话营销开场白
2015/05/29 职场文书
导游词范文之颐和园/重庆/云台山
2019/09/10 职场文书
某学校的2019年度工作报告范本
2019/10/11 职场文书
Python 数据可视化之Bokeh详解
2021/11/02 Python
关于的python五子棋的算法
2022/05/02 Python