摘要:實現(xiàn)思路把一張圖片分成多個塊,每個塊的顏色都等于這個色塊中顏色最多的顏色,如下圖。這個圖取的像素為塊的大小,把快中顏色與每個顏色出現(xiàn)的數(shù)量存放到字典里,取最大的顏色,填充整個塊。
起因
看到網(wǎng)上的像素圖片,感覺蠻有趣的,就打算用python一些PIL類庫寫一個。
把一張圖片分成多個塊,每個塊的顏色都等于這個色塊中顏色最多的顏色,如下圖。
這個圖取2×2的像素為塊的大小,把快中顏色與每個顏色出現(xiàn)的數(shù)量存放到字典里,取最大的顏色,填充整個塊。
from PIL import Image def init(): # 設(shè)置每個像素區(qū)塊的大小 block_size = 75 img = Image.open("a.jpg") # 獲取圖片的寬高 width, height = img.size # 獲取像素點對應(yīng)RGB顏色值,可以改變img_array中的值來改變顏色值 img_array = img.load() # 為了處理最后的區(qū)塊,加了一次循環(huán) max_width = width + block_size max_height = height + block_size for x in range(block_size - 1, max_width, block_size): for y in range(block_size - 1, max_height, block_size): # 如果是最后一次循環(huán),則x坐標等于width - 1 if x == max_width - max_width % block_size - 1: x = width - 1 # 如果是最后一次循環(huán),則x坐標等于height - 1 if y == max_height - max_height % block_size - 1: y = height - 1 # 改變每個區(qū)塊的顏色值 change_block(x, y, block_size, img_array) y += block_size x += block_size img.save(r"D:pythonpixel_imageawesome_copy.png") img.show() """ :param x坐標 x: :param y坐標 y: :param 區(qū)塊大小 black_size: :param 可操作圖片數(shù)組 img_array: """ def change_block(x, y, black_size, img_array): color_dist = {} block_pos_list = [] for pos_x in range(-black_size + 1, 1): for pos_y in range(-black_size + 1, 1): # todo print(x + pos_x,y + pos_y) block_pos_list.append([x + pos_x, y + pos_y]) for pixel in block_pos_list: if not str(img_array[pixel[0], pixel[1]]) in color_dist.keys(): color_dist[str(img_array[pixel[0], pixel[1]])] = 1 else: color_dist[str(img_array[pixel[0], pixel[1]])] += 1 # key-->value => value-->key new_dict = {v: k for k, v in color_dist.items()} max_color = new_dict[max(color_dist.values())] # 將區(qū)塊內(nèi)所有的顏色值設(shè)置為顏色最多的顏色 for a in block_pos_list: img_array[a[0], a[1]] = tuple(list(map(int, max_color[1:len(max_color) - 1].split(",")))) def get_key(dict, value): return [k for k, v in dict.items() if v == value] if __name__ == "__main__": init()效果對比
開源地址https://github.com/MasakiOvO/...
還有很多改進的地方,比如取色值的算法上,應(yīng)該有更好的解決方法,應(yīng)該用多進程來實現(xiàn),這樣程序速度會快很多。OvO
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/42766.html
摘要:不同尺寸的圖像,要達到最佳的像素化的顯示效果,所需要設(shè)置的單位像素塊的大小也是不同的,實踐出真知。我們需要圖像的指定一個處理范圍,并對該范圍內(nèi)的每一個坐標像素點進行像素化的處理。公眾號專欄后臺回復(fù)馬賽克,獲取本文所涉及的完整代碼。 目錄0 引言1 環(huán)境2 需求分析3 代碼實現(xiàn)4 代碼全景展示5 后記 0 引言 所謂的像素圖,就是對圖像做一個顆?;男Ч?,使其產(chǎn)生一種妙不可言的朦朧感。費...
摘要:首先介紹跟圖像處理顯示有關(guān)兩個庫和,然后介紹增強圖像對比度的實現(xiàn)原理。直方圖均衡化就是為了達到這個目的,均衡化后的圖像,像素落在每個灰度級上的個數(shù)是相等的。 首先介紹跟圖像處理、顯示有關(guān)兩個庫:NumPy和Matplotlib,然后介紹增強圖像對比度的實現(xiàn)原理。 NumPy NumPy是Python用于科學計算的基礎(chǔ)庫,提供了一些很有用的概念,如:N維數(shù)組對象,可用于表示向量、矩陣、圖...
閱讀 1919·2021-09-23 11:21
閱讀 1704·2019-08-29 17:27
閱讀 1062·2019-08-29 17:03
閱讀 729·2019-08-29 15:07
閱讀 1927·2019-08-29 11:13
閱讀 2385·2019-08-26 12:14
閱讀 931·2019-08-26 11:52
閱讀 1736·2019-08-23 17:09