本文小編為大家詳細(xì)介紹“Python如何實(shí)現(xiàn)PIL圖像處理庫(kù)繪制國(guó)際象棋棋盤(pán)”,內(nèi)容詳細(xì),步驟清晰,細(xì)節(jié)處理妥當(dāng),希望這篇“Python如何實(shí)現(xiàn)PIL圖像處理庫(kù)繪制國(guó)際象棋棋盤(pán)”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來(lái)學(xué)習(xí)新知識(shí)吧。
創(chuàng)新互聯(lián)公司專(zhuān)業(yè)為企業(yè)提供包河網(wǎng)站建設(shè)、包河做網(wǎng)站、包河網(wǎng)站設(shè)計(jì)、包河網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁(yè)設(shè)計(jì)與制作、包河企業(yè)網(wǎng)站模板建站服務(wù),10多年包河做網(wǎng)站經(jīng)驗(yàn),不只是建網(wǎng)站,更提供有價(jià)值的思路和整體網(wǎng)絡(luò)服務(wù)。
步驟1:創(chuàng)建空白圖片和繪畫(huà)對(duì)象
步驟2:繪制網(wǎng)格
步驟3:填充顏色
步驟1:創(chuàng)建空白圖片和繪畫(huà)對(duì)象
imageTemp = Image.new("RGB", size, bgcolor) draw = ImageDraw.Draw(imageTemp) # 允許在imageTemp圖片上畫(huà)畫(huà)
步驟2:繪制網(wǎng)格
繪制網(wǎng)格的關(guān)鍵是使用 Python PIL ImageDraw.Draw.line() 方法。
具體而言,本文采用分別繪制平均橫直線和平均豎直線的方法。
下例為繪制平均豎直線:
for i in range(7): for j in range(7): i = i + 1 j = j + 1 everage_line = size[0] / 8 everage_line = everage_line * j start = (everage_line, 0) end = (everage_line, size[1]) draw.line([start, end], fill=(0, 0, 0), width=3)
注:采用 for 循環(huán)遍歷列
因?yàn)?i,j 在分母,避免為0可能的報(bào)錯(cuò),故+1
計(jì)算每?jī)蓷l豎線之間的距離
start起始值為“左”、“上”兩值,end結(jié)束值為“右”,“下”兩值
循環(huán)繪制7條豎線將白底繪板均分為8份
并設(shè)置繪制線條顏色及線條寬度等
步驟3:填充顏色
值得注意的是,填充顏色要保證相鄰兩塊顏色不一致。
填充顏色的關(guān)鍵是使用 Python PIL ImageDraw.Draw.rectangle() 方法。
具體做法是先填充第一、第二行,再將生成圖像復(fù)制粘貼。
填充第一、第二行方格時(shí)要注意填充矩形的起始點(diǎn)和結(jié)束點(diǎn)值,保證相鄰兩塊顏色不一致。
下例為填充第一行方格(間隔填充):
draw.rectangle((0, 0, 50, 50), fill = (0, 0, 0)) draw.rectangle((100, 0, 150, 50), fill = (0, 0, 0)) draw.rectangle((200, 0, 250, 50), fill = (0, 0, 0)) draw.rectangle((300, 0, 350, 50), fill = (0, 0, 0))
填充好前兩行方格后接下來(lái)就進(jìn)入復(fù)制粘貼部分了;
對(duì)于第三第四行,就直接粘貼第一、二行圖像就可以了:
region = imageTemp.crop((0,0,400,100)) imageTemp.paste(region, (0, 100))
對(duì)于第五到第八行,在進(jìn)行一遍復(fù)制粘貼,這回復(fù)制的是前四行的圖像結(jié)果:
region = imageTemp.crop((0,0,400,200)) imageTemp.paste(region, (0, 200))
# coding=utf-8 from PIL import Image, ImageDraw # 定義顏色、大小 size = (400, 400) bgcolor = (255, 255, 255) # 創(chuàng)建空白圖片和繪畫(huà)對(duì)象 imageTemp = Image.new("RGB", size, bgcolor) draw = ImageDraw.Draw(imageTemp) # 繪制平均豎直線 for i in range(7): for j in range(7): i = i + 1 j = j + 1 everage_line = size[0] / 8 everage_line = everage_line * j start = (everage_line, 0) end = (everage_line, size[1]) draw.line([start, end], fill=(0, 0, 0), width=3) # 繪制平均橫直線 for i in range(7): for j in range(7): i = i + 1 j = j + 1 everage_line = size[0] / 8 everage_line = everage_line * i start = (0, everage_line) end = (size[0], everage_line) draw.line([start, end], fill=(0, 0, 0), width=3) # 先涂?jī)尚蟹礁? # 第一行間隔涂黑 draw.rectangle((0, 0, 50, 50), fill = (0, 0, 0)) draw.rectangle((100, 0, 150, 50), fill = (0, 0, 0)) draw.rectangle((200, 0, 250, 50), fill = (0, 0, 0)) draw.rectangle((300, 0, 350, 50), fill = (0, 0, 0)) # 第二行間隔涂黑 draw.rectangle((50, 50, 100, 100), fill = (0, 0, 0)) draw.rectangle((150, 50, 200, 100), fill = (0, 0, 0)) draw.rectangle((250, 50, 300, 100), fill = (0, 0, 0)) draw.rectangle((350, 50, 400, 100), fill = (0, 0, 0)) # 復(fù)制粘貼 # 操作第三行和第四行 region = imageTemp.crop((0,0,400,100)) imageTemp.paste(region, (0, 100)) # 操作第五行到第八行 region = imageTemp.crop((0,0,400,200)) imageTemp.paste(region, (0, 200)) # 顯示 imageTemp.show()
from PIL import Image, ImageDraw imageTemp = Image.new("RGB", (400, 400), 0) draw = ImageDraw.Draw(imageTemp) h,w = imageTemp.size for x in range(7): for y in range(7): x = x + 1 y = y + 1 x_zuobiao = w/8 x_zuobiao = x_zuobiao*x start = (x_zuobiao, 0) end = (x_zuobiao, h) draw.line([start, end], fill=(256, 256, 256), width=3) for x in range(7): for y in range(7): x = x + 1 y = y + 1 y_zuobiao = h/8 y_zuobiao = y_zuobiao * y start = (0, y_zuobiao) end = (w, y_zuobiao) draw.line([start, end], fill=(256, 256, 256), width=3) x = 0 y = 0 z = 50 t = 50 for i in range(4): for i in range(2): for j in range(4): if(y<450): draw.rectangle((x, y, z, t), fill=(255, 255, 255)) x = x + 100 z = z + 100 for i in range(4): x = x - 100 z = z - 100 x = x + 50 y = y + 50 z = z + 50 t = t + 50 x = x - 100 z = z - 100 imageTemp.show()
from PIL import Image, ImageDraw imageTemp=Image.new("RGB",(400,400),0) draw = ImageDraw.Draw(imageTemp) h,w = imageTemp.size x=0; y=0;z=50;t=50 for a in range(4): for i in range(2): for j in range(4): if(y<450): draw.rectangle((x, y, z, t), fill = (255, 255, 255)) x=x+100 z=z+100 x = 0;z = 50;x=x+50;y=y+50;z=z+50;t=t+50 x=0;z=50 imageTemp.show()
讀到這里,這篇“Python如何實(shí)現(xiàn)PIL圖像處理庫(kù)繪制國(guó)際象棋棋盤(pán)”文章已經(jīng)介紹完畢,想要掌握這篇文章的知識(shí)點(diǎn)還需要大家自己動(dòng)手實(shí)踐使用過(guò)才能領(lǐng)會(huì),如果想了解更多相關(guān)內(nèi)容的文章,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。
網(wǎng)頁(yè)標(biāo)題:Python如何實(shí)現(xiàn)PIL圖像處理庫(kù)繪制國(guó)際象棋棋盤(pán)
文章來(lái)源:http://muchs.cn/article40/ghcpeo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供定制網(wǎng)站、自適應(yīng)網(wǎng)站、網(wǎng)站收錄、App開(kāi)發(fā)、營(yíng)銷(xiāo)型網(wǎng)站建設(shè)、電子商務(wù)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)