婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Python實現PIL圖像處理庫繪制國際象棋棋盤

Python實現PIL圖像處理庫繪制國際象棋棋盤

熱門標簽:煙臺電話外呼營銷系統 外賣地址有什么地圖標注 企業彩鈴地圖標注 長春極信防封電銷卡批發 電銷機器人錄音要學習什么 預覽式外呼系統 銀川電話機器人電話 如何地圖標注公司 上海正規的外呼系統最新報價

網頁上搜索 “python繪制國際象棋棋盤”,索引結果均為調用 turtle 庫繪制棋盤結果;為了填充使用 python PIL 圖像處理庫繪制國際象棋棋盤的空白,今日分享此文。

1 PIL繪制國際象棋棋盤流程

1.1 思路秒懂

步驟1:創建空白圖片和繪畫對象

步驟2:繪制網格

步驟3:填充顏色

1.2 分塊解析

步驟1:創建空白圖片和繪畫對象

imageTemp = Image.new("RGB", size, bgcolor)
draw = ImageDraw.Draw(imageTemp)     # 允許在imageTemp圖片上畫畫

步驟2:繪制網格

繪制網格的關鍵是使用 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 循環遍歷列
       因為 i,j 在分母,避免為0可能的報錯,故+1
       計算每兩條豎線之間的距離
       start起始值為“左”、“上”兩值,end結束值為“右”,“下”兩值
       循環繪制7條豎線將白底繪板均分為8份
       并設置繪制線條顏色及線條寬度等

步驟3:填充顏色

值得注意的是,填充顏色要保證相鄰兩塊顏色不一致。

填充顏色的關鍵是使用 Python PIL ImageDraw.Draw.rectangle() 方法。

具體做法是先填充第一、第二行,再將生成圖像復制粘貼。

填充第一、第二行方格時要注意填充矩形的起始點和結束點值,保證相鄰兩塊顏色不一致。

下例為填充第一行方格(間隔填充): 

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))

填充好前兩行方格后接下來就進入復制粘貼部分了;

對于第三第四行,就直接粘貼第一、二行圖像就可以了:

region = imageTemp.crop((0,0,400,100))
imageTemp.paste(region, (0, 100))

對于第五到第八行,在進行一遍復制粘貼,這回復制的是前四行的圖像結果:

region = imageTemp.crop((0,0,400,200))
imageTemp.paste(region, (0, 200))

2 完整代碼

2.1 方法一

# coding=utf-8
from PIL import Image, ImageDraw
 
# 定義顏色、大小
size = (400, 400)
bgcolor = (255, 255, 255)
 
# 創建空白圖片和繪畫對象
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))
 
# 復制粘貼
# 操作第三行和第四行
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()

2.2 方法二

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(y450):
                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()

2.3 方法三(精簡版)

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(y450):
                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()

3 結果展示

到此這篇關于Python實現PIL圖像處理庫繪制國際象棋棋盤的文章就介紹到這了,更多相關Python 國際象棋棋盤內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • python輸出國際象棋棋盤的實例分享
  • python圖形工具turtle繪制國際象棋棋盤
  • python使用turtle繪制國際象棋棋盤

標簽:西寧 宜昌 上饒 潮州 盤錦 佳木斯 珠海 湖北

巨人網絡通訊聲明:本文標題《Python實現PIL圖像處理庫繪制國際象棋棋盤》,本文關鍵詞  Python,實現,PIL,圖像處理,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Python實現PIL圖像處理庫繪制國際象棋棋盤》相關的同類信息!
  • 本頁收集關于Python實現PIL圖像處理庫繪制國際象棋棋盤的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    成人av电影免费在线播放| 日本乱人伦一区| 亚洲天堂免费看| 久久精品人人做人人综合 | 欧美日韩欧美一区二区| 欧美日韩中文精品| 欧美一区二区三区四区在线观看| 欧美日韩国产电影| 国产视频一区不卡| 亚洲欧美色一区| 日韩专区一卡二卡| 欧美日韩免费一区二区三区| 91成人在线免费观看| 欧美精品v日韩精品v韩国精品v| 欧美日韩不卡在线| 538在线一区二区精品国产| 欧美日本高清视频在线观看| 在线精品视频免费播放| 欧美一区二区三区小说| 久久久亚洲精品一区二区三区 | 1区2区3区精品视频| 亚洲综合视频在线| 精品中文字幕一区二区 | 日本一区二区三区视频视频| 自拍偷拍欧美激情| 六月丁香婷婷色狠狠久久| 国内外成人在线视频| 91在线免费视频观看| 欧美韩国日本不卡| 亚洲午夜精品在线| 韩国欧美国产一区| 日本精品裸体写真集在线观看| 91精品国产综合久久精品app | 国产剧情一区在线| 风间由美一区二区三区在线观看 | 久久综合色播五月| 国产亚洲午夜高清国产拍精品 | 日韩成人精品在线观看| 亚洲国产精品激情在线观看| 99久久婷婷国产| 午夜久久福利影院| 精品国产一区二区三区久久影院| 青椒成人免费视频| 精品视频在线免费| 日韩电影在线看| 韩国精品在线观看| 久久久久久日产精品| 日本欧美一区二区在线观看| 欧美日本一区二区三区四区| 中日韩av电影| 欧美片网站yy| 欧美一区日韩一区| 国产真实乱对白精彩久久| 免费精品视频在线| 岛国一区二区在线观看| 亚洲大片一区二区三区| 欧美午夜宅男影院| 成人教育av在线| 亚洲精品视频一区二区| 欧美一区在线视频| 成人av免费网站| 亚洲欧美日韩一区二区| 4438x亚洲最大成人网| 色哟哟国产精品免费观看| 五月婷婷综合网| 欧美高清你懂得| 国产91精品入口| 国产精品欧美精品| 欧美婷婷六月丁香综合色| 国产麻豆欧美日韩一区| 欧美在线色视频| 国产一区二区美女诱惑| 国产毛片精品国产一区二区三区| 久久国产精品区| 国产性色一区二区| 国产欧美日韩另类一区| 精品亚洲国产成人av制服丝袜| 亚洲欧洲色图综合| 国产不卡在线播放| 欧美综合欧美视频| 国产精品中文有码| 免费一级片91| 国产欧美日韩另类一区| 51久久夜色精品国产麻豆| 国产伦精品一区二区三区免费| 日本色综合中文字幕| 粉嫩高潮美女一区二区三区| 久久不见久久见免费视频7| 夜夜嗨av一区二区三区中文字幕| 久久99蜜桃精品| 亚洲成年人影院| 成人午夜激情影院| 激情深爱一区二区| 亚洲最色的网站| 中文字幕高清不卡| 亚洲欧美一区二区三区孕妇| 国产欧美日韩三区| 久久久久久久久免费| 中文字幕一区二区不卡| 一区二区三区精品| 久久成人免费网站| 黑人巨大精品欧美一区| 成人综合婷婷国产精品久久免费| 国产精品99久久久久久久vr| 97久久精品人人做人人爽 | 日韩高清不卡一区二区三区| 日本精品一区二区三区高清| 精品国产网站在线观看| 亚洲精品成人悠悠色影视| 成人a级免费电影| 高清不卡在线观看| 91行情网站电视在线观看高清版| 91国在线观看| 日韩精品1区2区3区| 国产一区二区在线免费观看| 韩国成人精品a∨在线观看| 成人晚上爱看视频| 国产乱人伦偷精品视频免下载| 日韩精品成人一区二区在线| 亚瑟在线精品视频| 日韩免费成人网| 欧美影院一区二区三区| 91在线你懂得| 国产精品国产三级国产a| 麻豆一区二区99久久久久| 不卡的av在线播放| 欧美日韩久久不卡| 国产人久久人人人人爽| 亚洲综合在线视频| 日韩美女精品在线| 欧美另类变人与禽xxxxx| 国产精品女人毛片| 国内久久精品视频| 麻豆91在线观看| 欧美一区二区三区性视频| 欧美日韩国产综合一区二区| 亚洲国产精品一区二区www| 夜夜嗨av一区二区三区| 精品粉嫩超白一线天av| 处破女av一区二区| 亚洲欧洲成人精品av97| 久久精品国产免费看久久精品| 国产成人免费网站| 色噜噜狠狠成人中文综合| 欧美日本一道本| 日韩一区二区电影网| 欧美精品第1页| 亚洲乱码国产乱码精品精小说 | 久久综合狠狠综合| 一区二区三区四区不卡视频| 欧美视频在线观看一区二区| 国产乱码精品一区二区三| 日韩一区二区三区精品视频| 五月激情六月综合| 亚洲日本青草视频在线怡红院| 亚洲欧美一区二区三区国产精品 | 国产午夜亚洲精品羞羞网站| 欧美肥胖老妇做爰| 91精品在线麻豆| 欧美一级久久久| 6080国产精品一区二区| 91久久精品一区二区三区| 成人午夜看片网址| 91捆绑美女网站| 99久久综合精品| 成人av片在线观看| 欧美色区777第一页| 欧美日韩一区在线观看| 精品美女一区二区| 国产精品午夜春色av| 一级中文字幕一区二区| 麻豆精品一区二区综合av| 国产69精品久久99不卡| 成人精品视频一区二区三区 | 国产精品综合av一区二区国产馆| 狠狠狠色丁香婷婷综合激情 | 精品国产百合女同互慰| 久久综合九色综合欧美就去吻 | 久久99久久久欧美国产| 丁香激情综合国产| 一本色道久久综合亚洲91| 欧美国产一区视频在线观看| 亚洲欧洲另类国产综合| 日韩av电影天堂| 国产a级毛片一区| 在线观看av一区| 欧美精品自拍偷拍动漫精品| 日韩欧美一区电影| 国产精品久久久99| 日韩精品一二三区| 福利91精品一区二区三区| 欧美日韩精品一区二区三区蜜桃| 日韩电影网1区2区| 波多野结衣中文字幕一区| 欧美日韩欧美一区二区| 精品无人码麻豆乱码1区2区| 国产美女精品人人做人人爽| 91麻豆自制传媒国产之光| 欧美日韩国产一二三| 欧美国产乱子伦|