python图像处理之反色实现方法


Posted in Python onMay 30, 2015

本文实例讲述了python图像处理之反色实现方法。分享给大家供大家参考。具体如下:

我们先加载一个8位灰度图像

每一个像素对应的灰度值从0-255

则只需要读取每个像素的灰度值A,再将255-A写入

这样操作一遍后,图像就会反色了

这里运行环境为:

Python为:Python2.7.6
OpenCV2.4.10版(可到http://sourceforge.net/projects/opencvlibrary/files/opencv-win/下载)
numpy为:numpy-1.9.1-win32-superpack-python2.7(可到http://sourceforge.net/projects/numpy/files/NumPy/1.9.1/下载)

具体python代码如下:

import cv2.cv as cv
image = cv.LoadImage('angelababy.jpg',0)
size = (image.width,image.height)
iTmp = cv.CreateImage(size,image.depth,image.nChannels)
for i in range(image.height):
  for j in range(image.width):
    iTmp[i,j] = 255 - image[i,j]
cv.NamedWindow('image')
cv.NamedWindow('iTmp')
cv.ShowImage('image',image)
cv.ShowImage('iTmp',iTmp)
cv.WaitKey(0)

运行结果如下图所示:

python图像处理之反色实现方法

我们再稍微改动一下上面的代码

对于彩色图片,对于每个像素点,OpenCV在Python中是以tuple(R,G,B)的形式存储的

所以对于彩色图片的反色,只需要获得tuple(255-R,255-G,255-B)就行了

代码如下:

import cv2.cv as cv
image = cv.LoadImage('angelababy.jpg',1)
size = (image.width,image.height)
iTmp = cv.CreateImage(size,image.depth,image.nChannels)
for i in range(image.height):
  for j in range(image.width):
    iTmp[i,j] = (255-image[i,j][0],255-image[i,j][1],255-image[i,j][2])
cv.NamedWindow('image')
cv.NamedWindow('iTmp')
cv.ShowImage('image',image)
cv.ShowImage('iTmp',iTmp)
cv.WaitKey(0)

运行效果如下图所示:

python图像处理之反色实现方法

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

Python 相关文章推荐
Python中为feedparser设置超时时间避免堵塞
Sep 28 Python
django+xadmin+djcelery实现后台管理定时任务
Aug 14 Python
对python多线程与global变量详解
Nov 09 Python
python交互模式下输入换行/输入多行命令的方法
Jul 02 Python
python 中pyqt5 树节点点击实现多窗口切换问题
Jul 04 Python
python 爬取学信网登录页面的例子
Aug 13 Python
Python3.7 pyodbc完美配置访问access数据库
Oct 03 Python
python多线程并发及测试框架案例
Oct 15 Python
python绘制动态曲线教程
Feb 24 Python
Python装饰器实现方法及应用场景详解
Mar 26 Python
Keras模型转成tensorflow的.pb操作
Jul 06 Python
详解Pycharm第三方库的安装及使用方法
Dec 29 Python
python中字典(Dictionary)用法实例详解
May 30 #Python
python集合用法实例分析
May 30 #Python
基于wxpython实现的windows GUI程序实例
May 30 #Python
python简单实现旋转图片的方法
May 30 #Python
Python实现控制台输入密码的方法
May 29 #Python
python删除过期文件的方法
May 29 #Python
Python的Django框架中TEMPLATES项的设置教程
May 29 #Python
You might like
浅析PHP程序防止ddos,dns,集群服务器攻击的解决办法
2013/06/18 PHP
IIS安装Apache伪静态插件的具体操作图文
2013/07/01 PHP
destoon实现底部添加你是第几位访问者的方法
2014/07/15 PHP
PHP版本如何选择?应该使用哪个版本?
2015/05/13 PHP
深入浅析PHP的session反序列化漏洞问题
2017/06/15 PHP
PHP学习记录之数组函数
2018/06/01 PHP
js、css、img等浏览器缓存问题的2种解决方案
2013/10/23 Javascript
JavaScript中的数组操作介绍
2014/12/30 Javascript
jQuery使用$.ajax进行异步刷新的方法(附demo下载)
2015/12/04 Javascript
jQuery simplePage+AJAX plus分页插件用法实例
2016/02/17 Javascript
bootstrap和jQuery.Gantt的css冲突 如何解决
2016/05/29 Javascript
jQuery ajax MD5实现用户注册即时验证功能
2016/10/11 Javascript
使用JS编写的随机抽取号码的小程序
2017/08/11 Javascript
详解JS函数防抖
2020/06/05 Javascript
[01:46]TI4西雅图DOTA2前线报道 中国选手抱团调时差
2014/07/08 DOTA
python实现简单的TCP代理服务器
2014/10/08 Python
python中urllib模块用法实例详解
2014/11/19 Python
Python实现针对中文排序的方法
2017/05/09 Python
Python从函数参数类型引出元组实例分析
2019/05/28 Python
python Django中models进行模糊查询的示例
2019/07/18 Python
pytorch制作自己的LMDB数据操作示例
2019/12/18 Python
解决pymysql cursor.fetchall() 获取不到数据的问题
2020/05/15 Python
Scrapy模拟登录赶集网的实现代码
2020/07/07 Python
美国正版电视节目和电影在线观看:Hulu
2018/05/24 全球购物
美国高档帽子网上商店:Hats.com
2018/08/09 全球购物
同步和异步有何异同,在什么情况下分别使用他们?举例说明
2014/02/27 面试题
小学班主任寄语大全
2014/04/04 职场文书
电视节目策划方案
2014/05/16 职场文书
公司副总经理任命书
2014/06/05 职场文书
党的群众路线教育实践活动批评与自我批评范文
2014/10/16 职场文书
2014年保险公司工作总结
2014/11/22 职场文书
入党培养人考察意见
2015/06/08 职场文书
2016廉政教育学习心得体会
2016/01/25 职场文书
Python中相见恨晚的技巧
2021/04/13 Python
Nginx隐藏式跳转(浏览器URL跳转后保持不变)
2022/04/07 Servers
MySQL中的 inner join 和 left join的区别解析(小结果集驱动大结果集)
2023/05/08 MySQL