用Python製作迷宮GIF

用Python製作迷宮GIF

來自專欄 python熱愛者

安裝

可以通過PyPi安裝

或者通過Git

為什麼你需要這個庫?

問:我是一個Python迷,並且對迷宮的生成和迷宮解決的辦法非常感興趣。我很羨慕別人能夠做出生成迷宮的動畫。我如何能夠用Python自己做一個迷宮動畫,然後把我的成果展示給其他人呢?(我知道tkinter, pyglet 和 pyqt,但是它們很難發布給別人看)

答:現在,你可以使用庫gifmaz來做這件事了,它有一些很好的特性:

1、它是純Python編寫的,沒有第三方依賴,只使用內置模塊!(如果你想把動畫嵌入圖片,那麼你需要PIL,PIL雖然不是內置模塊,但是任何Python版都支持PIL。除此之外再沒有其他的依賴了)

2、它運行速度很快,而且幾秒鐘就能生成優化過的GIF圖片。每個GIF通常都包含上千幀,但是GIF大小確只有幾百KB。

3、你可以繪製各種各樣的迷宮動畫,和解迷宮動畫。

4、代碼都有很好的注釋,文檔有很好的範例,而且文檔很完整。

這個庫的一個教程

首先我們需要構建一個GIFSurface對象(類似cairo的ImageSurface類),我們的動畫將會畫在這個對象上。同時,我們需要指定圖片的大小和可用的顏色數量。

這裡color_depth=2意味著調色板中有2^2=4種顏色,bg_color=0說明調色板中的第0個顏色被作為背景色。

只要你還沒有最後保存圖片,你都可以更改設置調色板,你可以這樣做

所以圖片中可以用的顏色有:黑、白、品紅、黑。

然後我們構建一個環境,生成的動畫基於這個環境構建(類似cairo的Context類)。

然後我們設置這個動畫的控制參數

這些參數的意思是「每20步渲染一幀,幀之間間隙0.05s,調色板中第四個顏色作為通明度通道」。

我們有了繪製動畫的「桌面」,和繪製動畫需要的參數,接下來就是實際地畫一個迷宮了。

這個語句在圖片中央繪製了一個迷宮,然後在四邊留了8像素的空白,迷宮中每一格在圖片中佔據5像素*5像素的大小。

然後讓我們運行Prim的迷宮演算法。

其中我加了兩個延遲幀,以便我們能夠看清楚動畫的過程。

完成了!讓我們把這個動畫保存到GIF文件。

下面是運行結果,大小小於300K,很贊吧!

當然,你也可以把多個演算法整合進一個動畫。下面的動畫展示了隨機深度優先搜索演算法和A*搜索演算法。(這個圖片只有120K)

這個庫的原理是什麼?

這個庫實際上是一個GIF的編碼庫,演算法運行過程中,動畫幀被編碼為BytesIO文件。只有在調用save方法時,動畫才會真正地被存入圖片。

深度資料

1、什麼是GIF:matthewflickinger.com/l

2、迷宮生成演算法:weblog.jamisbuck.org/20

英文原文:github.com/neozhaoliang

譯者:詩書塞外

推薦閱讀:

[論文翻譯]Learnable pooling——視頻分類
3D LUT --色彩校正的利器
目標檢測演算法綜述 | 基於候選區域的目標檢測器 | CV | 機器視覺
每天一練P17-Python和OpenCV做圖像處理(平移和旋轉)

TAG:GIF | 計算機視覺 | 編程語言 |