1. 程式人生 > >Python影象處理庫PIL中影象格式轉換(二)

Python影象處理庫PIL中影象格式轉換(二)

參考:https://blog.csdn.net/icamera0/article/details/50843196?utm_source=blogxgwz0

接上一篇《Python影象處理庫PIL中影象格式轉換(一)

二、其他不同模式轉換為“RGB”模式

模式“RGB”為24位彩色影象,它的每個畫素用24個bit表示,分別表示紅色、綠色和藍色三個通道。

在PIL中,對於彩色影象,open後都會轉換為“RGB”模式,然後該模式可以轉換為其他模式,比如“1”、“L”、“P”和“RGBA”,這幾種模式也可以轉換為“RGB”模式。

1、 模式“1”轉換為模式“RGB”

模式“RGB”轉換為模式“1”以後,畫素點變成黑白兩種點,要麼是0,要麼是255。而從模式“1”轉換成“RGB”時,“RGB”的三個通道都是模式“1”的畫素值的拷貝。

例子:

>>> from PILimport Image
 
>>> lena =Image.open("D:\\Code\\Python\\test\\img\\lena.jpg")
 
>>> lena_1 =lena.convert("1")
 
>>> lena_1_rgb =lena_1.convert("RGB")
 
>>> lena.getpixel((0,0))
 
(197, 111, 78)
 
>>>lena_1.getpixel((0,0))
 
255
 
>>>lena_1_rgb.getpixel((0,0))
 
(255, 255, 255)

2、 模式“L”轉換為模式“RGB”

模式“RGB”轉換為模式“L”以後,畫素值為[0,255]之間的某個數值。而從模式“L”轉換成“RGB”時,“RGB”的三個通道都是模式“L”的畫素值的拷貝。

例子:

 
>>> from PIL import Image
 
>>> lena = Image.open("D:\\Code\\Python\\test\\img\\lena.jpg")
 
>>> lena_L =lena.convert("L")
 
>>> lena_L_rgb =lena_L.convert("RGB")
 
>>>lena.getpixel((0,0))
 
(197, 111, 78)
 
>>>lena_L.getpixel((0,0))
 
132
 
>>>lena_rgb.getpixel((0,0))
 
(132, 132, 132)

3、 模式“P”轉換為模式“RGB”

模式“RGB”轉換為模式“P”以後,畫素值為[0,255]之間的某個數值,但它為調色盤的索引值,其最終還是彩色影象。從模式“P”轉換成“RGB”時,“RGB”的三個通道會變成模式“P”的畫素值索引的彩色值。

例子:

>>> from PIL import Image
 
>>> lena =Image.open("D:\\Code\\Python\\test\\img\\lena.jpg")
 
>>> lena_P =lena.convert("P")
 
>>> lena_P_rgb =lena_P.convert("RGB")
 
>>>lena.getpixel((0,0))
 
(197, 111, 78)
 
>>>lena_P.getpixel((0,0))
 
62
 
>>>lena_P_rgb.getpixel((0,0))
 
(204, 102, 51)

4、 模式“RGBA”轉換為模式“RGB”

模式“RGB”轉換為模式“RGBA”以後,影象從三通道變成了四通道,其R、G、B三個通道的數值沒有變化,新增的alpha通道均為255,表示不透明。從模式“RGBA”轉換成“RGB”時,“RGB”的三個通道又變回原來的數值。

例子:

>>> from PILimport Image
 
>>> lena =Image.open("D:\\Code\\Python\\test\\img\\lena.jpg")
 
>>> lena_RGBA =lena.convert("RGBA")
 
>>> lena_RGBA_rgb= lena_RGBA.convert("RGB")
 
>>>lena.getpixel((0,0))
 
(197, 111, 78)
 
>>>lena_RGBA.getpixel((0,0))
 
(197, 111, 78, 255)
 
>>>lena_RGBA_rgb.getpixel((0,0))
 
(197, 111, 78)

5、 模式“CMYK”轉換為模式“RGB”

模式“RGB”轉換為模式“CMYK”以後,影象從三通道變成了四通道,其C、M、Y三個通道的數值是通過之前的公式計算得到,K通道被直接賦值為0。

C = 255 - R
M = 255 - G
Y = 255 - B
K = 0

從模式“CMYK”轉換成“RGB”時,“RGB”的三個通道又變回原來的數值,這是無損的轉換。

R = 255 - C
G = 255 - M
B = 255 - Y

例子:

>>> from PIL import Image
 
>>> lena =Image.open("D:\\Code\\Python\\test\\img\\lena.jpg")
 
>>> lena_CMYK =lena.convert("CMYK")
 
>>> lena_CMYK_rgb= lena_CMYK.convert("RGB")
 
>>>lena.getpixel((0,0))
 
(197, 111, 78)
 
>>>lena_CMYK.getpixel((0,0))
 
(58, 144, 177, 0)
 
>>>lena_CMYK_rgb.getpixel((0,0))
 
(197, 111, 78)

6、 模式“YCbCr”轉換為模式“RGB”

模式“RGB”轉換為模式“YCbCr”,通常都是使用下面的公式計算,但PIL中並沒有嚴格按照這個公式進行轉換。

Y= 0.257*R+0.564*G+0.098*B+16
Cb = -0.148*R-0.291*G+0.439*B+128
Cr = 0.439*R-0.368*G-0.071*B+128

從模式“YCbCr”轉換成“RGB”時,通常是按照下面的公式計算,但PIL中並沒有嚴格按照這個公式進行轉換。

R= 1.164*(Y-16)+1.596*(Cr-128)
G = 1.164*(Y-16)-0.392*(Cb-128)-0.813*(Cr-128)
B = 1.164*(Y-16)+2.017*(Cb-128)

>>> from PILimport Image
 
>>> lena =Image.open("D:\\Code\\Python\\test\\img\\lena.jpg")
 
>>> lena_YCbCr =lena.convert("YCbCr")
 
>>> lena_YCbCr_rgb= lena_YCbCr.convert("RGB")
 
>>>lena.getpixel((0,0))
 
(197, 111, 78) 
 
>>>lena_YCbCr.getpixel((0,0))
 
(132, 97, 173)
 
>>>lena_YCbCr_rgb.getpixel((0,0))
 
(195, 110, 77)

7、 模式“I”轉換為模式“RGB”

模式“RGB”轉換為模式“I”,將三通道變成了單通道,使用下面的公式計算獲得畫素值:

I = R * 299/1000+ G * 587/1000 + B * 114/1000

從模式“I”轉換成“RGB”時,“RGB”的三個通道都是模式“I”的畫素值的拷貝。

例子:

>>> from PILimport Image
 
>>> lena =Image.open("D:\\Code\\Python\\test\\img\\lena.jpg")
 
>>> lena_I =lena.convert("I")
 
>>> lena_I_rgb =lena_I.convert("RGB")
 
>>>lena.getpixel((0,0))
 
(197, 111, 78)
 
>>>lena_I.getpixel((0,0))
 
132
 
>>>lena_I_rgb.getpixel((0,0))
 
(132, 132, 132)

8、 模式“F”轉換為模式“RGB”

模式“RGB”轉換為模式“F”,將彩色影象變成了32位浮點灰色影象。在PIL中,從模式“RGB”轉換為“F”模式是按照下面的公式轉換的:

F = R * 299/1000+ G * 587/1000 + B * 114/1000

從模式“F”轉換成“RGB”時,“RGB”的三個通道都是模式“F”的畫素值整數部分的拷貝。

例子:

>>> from PILimport Image
 
>>> lena =Image.open("D:\\Code\\Python\\test\\img\\lena.jpg")
 
>>> lena_F =lena.convert("F")
 
>>> lena_F_rgb =lena_F.convert("RGB")
 
>>>lena.getpixel((0,0))
 
(197, 111, 78)
 
>>> lena_F.getpixel((0,0))
 
132.95199584960938
 
>>>lena_F_rgb.getpixel((0,0))
 
(132, 132, 132)

三、調色盤影象的轉換

在PIL中,將“RGB”影象轉換為“P”模式影象時,有對應的convert()函式定義,如下:

im.convert(“P”,**options) ⇒ image

這個定義將模式固定為“P”,後面可以帶幾個可選引數。它們分別為:dither,palette和colors。

引數dither用於控制顏色抖動。預設是FLOYDSTEINBERG,不使能該功能,則賦值為NONE。

引數palette用於控制調色盤的產生。預設是WEB,這是標準的216色的“web palette”。要使用優化的調色盤,則賦值為ADAPTIVE。

引數colors用於控制調色盤顏色數目。當引數palette為ADAPTIVE時,colors數值表示調色盤的顏色數目。預設是最大值,即256種顏色。

使用預設值,將“RGB”轉換為“P”模式影象後如下:

引數dither預設為FLOYDSTEINBERG;如果不開啟顏色抖動功能,則賦值為NONE。其轉換結果如下:

引數palette預設是WEB。要使用優化的調色盤,則賦值為ADAPTIVE。其轉換結果為:

當引數palette為ADAPTIVE時,colors數值表示調色盤的顏色數目。預設值為256。當colors設定為10時,其轉換結果為:

>>> from PILimport Image
 
>>> lena =Image.open("D:\\Code\\Python\\test\\img\\lena.jpg")
 
>>> lena_P_dither= lena.convert("P", dither = Image.NONE)
 
>>> lena_P_palette= lena.convert("P", palette = Image.ADAPTIVE)
 
>>>lena_P_palette_colors = lena.convert("P", palette = Image.ADAPTIVE,colors = 10)

四、帶矩陣的模式轉換

模式轉換函式convert()的第三種定義如下:

im.convert(mode,matrix) ⇒ image

這種定義只適合將一個“RGB”影象轉換為“L”或者“RGB”影象,不能轉換為其他模式的影象。變數matrix為4或者16元組。

例子:下面的例子將一個RGB影象(根據ITU-R709線性校準,使用D65亮度)轉換到CIE XYZ顏色空間:

>>>from PIL import Image
 
>>> lena =Image.open("D:\\Code\\Python\\test\\img\\lena.jpg")
 
>>> lena.mode
 
'RGB'
 
>>> rgb2xyz= (
 
             0.412453,0.357580, 0.180423, 0,
 
                       0.212671,0.715160, 0.072169, 0,
 
                       0.019334,0.119193, 0.950227, 0 )
 
 
 
>>>lena_L = lena.convert("L", rgb2xyz)
 
>>>lena_rgb = lena.convert("RGB", rgb2xyz)

影象lena_L如下:

影象lena_rgb如下:

五、小結

PIL中對影象格式及模式的轉換,相對都是非常簡潔。使用者可以根據自己的需求,將影象轉換為目標模式,進而進行各種處理。對於不同的影象處理目的,需要選擇在哪種模式上設計影象演算法,設計什麼樣的演算法,這個是一個極為關鍵的問題。希望之後的學習中,能夠有比較深刻的認識。

(完)