图片中每一个像素点,实际存储的是R,G,B三种颜色的权重,而颜色映射也就是使某些颜色加重或者变浅。
使用opencv来实现,就是通过将某颜色的权值增大或者缩小,得到一个新的像素。
首先导入模块
import cv2
import numpy as np
然后读取要处理的图片
img=cv2.imread('ziliao/image0.JPG',1) #读取图片
'''单引号里的内容就是图片的存储路径,
第二个参数1表示读取的是彩色图片,
如果该参数为0,则读取灰色图片'''
imInfo=img.shape #shape方法获取图片的
height=imInfo[0]
width=imInfo[1]
实现颜色的映射功能
dst=np.zeros((height,width,3),np.uint8) #用于存储处理后的图片
for i in range(0,height):
for j in range(0,width):
(b,g,r) = img[i,j] #img[i,j]即表示该点的像素值
b = b*1.8 #改变B,G两种颜色的权值
g = g*1.4
if b>255: #溢出处理
b = 255
if g>255:
g = 255
dst[i,j]=(b,g,r) #把新的像素值赋给新图片
#展示原图和处理后的图片
cv2,imshow('img',img)
cv2.imshow('dst',dst)
cv2.waitKey(0)
(左为原图)
import numpy as np
import cv2
img=cv2.imread('ziliao/image0.JPG',1)
imInfo=img.shape
height=imInfo[0]
width=imInfo[1]
dst=np.zeros((height,width,3),np.uint8)
for i in range(0,height):
for j in range(0,width):
(b,g,r) = img[i,j]
b = b*1.8
g = g*1.4
if b>255:
b = 255
if g>255:
g = 255
dst[i,j]=(b,g,r)
cv2.imshow('img',img)
cv2.imshow('dst',dst)
cv2.waitKey(0)