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