本文章向大家介紹利用python怎么把圖片轉(zhuǎn)換成素描圖的基本知識(shí)點(diǎn)總結(jié)和需要注意事項(xiàng),具有一定的參考價(jià)值,需要的朋友可以參考一下。
創(chuàng)新互聯(lián)公司專注于咸寧網(wǎng)站建設(shè)服務(wù)及定制,我們擁有豐富的企業(yè)做網(wǎng)站經(jīng)驗(yàn)。 熱誠為您提供咸寧營銷型網(wǎng)站建設(shè),咸寧網(wǎng)站制作、咸寧網(wǎng)頁設(shè)計(jì)、咸寧網(wǎng)站官網(wǎng)定制、成都微信小程序服務(wù),打造咸寧網(wǎng)絡(luò)公司原創(chuàng)品牌,更為您提供咸寧網(wǎng)站排名全網(wǎng)營銷落地服務(wù)。Python主要應(yīng)用于:1、Web開發(fā);2、數(shù)據(jù)科學(xué)研究;3、網(wǎng)絡(luò)爬蟲;4、嵌入式應(yīng)用開發(fā);5、游戲開發(fā);6、桌面應(yīng)用開發(fā)。
安裝工具
pip install pillow pip install numpy
代碼實(shí)現(xiàn)
# -*- coding: utf-8 -*- from PIL import Image from random import randint old = Image.open(r"da.jpg") new = Image.new('L', old.size, 255) w, d = old.size old = old.convert('L') PEN_SIZE = 3 COLOR_DIFF = 7 LINE_LEN = 2 for i in range(PEN_SIZE + 1, w - PEN_SIZE - 1): for j in range(PEN_SIZE + 1, d - PEN_SIZE - 1): originalcolor = 255 lcolor = sum([old.getpixel((i - r, j)) for r in range(PEN_SIZE)]) // PEN_SIZE rcolor = sum([old.getpixel((i + r, j)) for r in range(PEN_SIZE)]) // PEN_SIZE if abs(lcolor - rcolor) > COLOR_DIFF: originalcolor -= (255 - old.getpixel((i, j))) // 4 for p in range(-LINE_LEN + randint(-1, 1), LINE_LEN + randint(-1, 1)): new.putpixel((i, j + p), originalcolor) ucolor = sum([old.getpixel((i, j - r)) for r in range(PEN_SIZE)]) // PEN_SIZE dcolor = sum([old.getpixel((i, j + r)) for r in range(PEN_SIZE)]) // PEN_SIZE if abs(ucolor - dcolor) > COLOR_DIFF: originalcolor -= (255 - old.getpixel((i, j))) // 4 for p in range(-LINE_LEN + randint(-1, 1), LINE_LEN + randint(-1, 1)): new.putpixel((i + p, j), originalcolor) lucolor = sum([old.getpixel((i - r, j - r)) for r in range(PEN_SIZE)]) // PEN_SIZE rdcolor = sum([old.getpixel((i + r, j + r)) for r in range(PEN_SIZE)]) // PEN_SIZE if abs(lucolor - rdcolor) > COLOR_DIFF: originalcolor -= (255 - old.getpixel((i, j))) // 4 for p in range(-LINE_LEN + randint(-1, 1), LINE_LEN + randint(-1, 1)): new.putpixel((i - p, j + p), originalcolor) rucolor = sum([old.getpixel((i + r, j - r)) for r in range(PEN_SIZE)]) // PEN_SIZE ldcolor = sum([old.getpixel((i - r, j + r)) for r in range(PEN_SIZE)]) // PEN_SIZE if abs(rucolor - ldcolor) > COLOR_DIFF: originalcolor -= (255 - old.getpixel((i, j))) // 4 for p in range(-LINE_LEN + randint(-1, 1), LINE_LEN + randint(-1, 1)): new.putpixel((i + p, j + p), originalcolor) new.save(r"pencil_drawing.jpg")
我們這第一份素描圖案時(shí)以線條為單位進(jìn)行素描的,而且還增加了隨機(jī)函數(shù),圖案中線條的長度不確定,這樣創(chuàng)作的素描看上去更加柔和,看起來更加接近真實(shí)的人類作畫的風(fēng)格。
但是這個(gè)方法有一些弊端,
一是代碼量較多
二是執(zhí)行速度過慢
你想通過這個(gè)方式實(shí)現(xiàn)一個(gè)素描圖案,需要等待很長時(shí)間。
那么有沒有更好的方式呢?
來,我們?cè)賮砜矗酉聛砦覀円靡环N更友好的方式來實(shí)現(xiàn)這個(gè)需求
from PIL import Image import numpy as np a = np.asarray(Image.open('牛.jpg').convert('L')).astype('float') depth = 10. # (0-100) grad = np.gradient(a) # 取圖像灰度的梯度值 grad_x, grad_y = grad # 分別取橫縱圖像梯度值 grad_x = grad_x * depth / 100. grad_y = grad_y * depth / 100. A = np.sqrt(grad_x ** 2 + grad_y ** 2 + 1.) uni_x = grad_x / A uni_y = grad_y / A uni_z = 1. / A vec_el = np.pi / 2.2 # 光源的俯視角度,弧度值 vec_az = np.pi / 4. # 光源的方位角度,弧度值 dx = np.cos(vec_el) * np.cos(vec_az) # 光源對(duì)x 軸的影響 dy = np.cos(vec_el) * np.sin(vec_az) # 光源對(duì)y 軸的影響 dz = np.sin(vec_el) # 光源對(duì)z 軸的影響 b = 255 * (dx * uni_x + dy * uni_y + dz * uni_z) # 光源歸一化 b = b.clip(0, 255) im = Image.fromarray(b.astype('uint8')) # 重構(gòu)圖像 im.save('new.jpg')
以上就是小編為大家?guī)淼睦胮ython怎么把圖片轉(zhuǎn)換成素描圖的全部內(nèi)容了,希望大家多多支持創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計(jì)公司!
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。