欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

使用Python制作一盞 3D 花燈喜迎元宵佳節(jié)

 更新時(shí)間:2021年02月26日 14:28:28   作者:酸菜魚編程  
這篇文章主要介紹了用Python制作一盞 3D 花燈喜迎元宵佳節(jié),本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

說(shuō)起元宵節(jié),各位有沒(méi)有覺得這是咱們中國(guó)人最浪漫的節(jié)日呢?國(guó)人向來(lái)拘謹(jǐn)古板,一年到頭都是小心謹(jǐn)慎地過(guò)日子,唯有元宵節(jié)這天可以縱情豪放一把。東風(fēng)夜放花千樹,寶馬雕車香滿路,火樹銀花霓虹閃爍,豪車遍地美女如云。細(xì)品,你甚至都能嗅到香奈兒的味道!月上柳梢頭,人約黃昏后,這又是何等的浪漫!比起燭光晚宴、鮮花加持,這份浪漫更顯純真。晚至明清,民間元宵節(jié)的喜慶氣氛,堪比西班牙的奔牛節(jié)、巴西的狂歡節(jié)、泰國(guó)的潑水節(jié)。

由于眾所周知的原因,估計(jì)今年的趵突泉元宵節(jié)燈會(huì)又要黃了。去哪兒體驗(yàn)“花市燈如晝”的節(jié)日氣氛呢?Don't worry,沒(méi)有什么事能夠難倒程序員——用3D技術(shù)也可以做出下圖這樣的走馬燈,算是聊勝于無(wú)吧。

1.原材料

花燈紙

如下所示,還可以加上自己喜歡的圖案、文字等。

Python環(huán)境和模塊

一臺(tái)安裝了Python環(huán)境的電腦,Python環(huán)境需要安裝以下模塊。

  • numpy
  • pillow
  • wxgl

如果沒(méi)有上述模塊,請(qǐng)參考下面的命令安裝。

pip install numpy
pip install pillow
pip install wxgl

NumPy和 pillow 是 Python 旗下最常用的科學(xué)計(jì)算庫(kù)和圖像處理庫(kù),屬于常用模塊。WxGL 是一個(gè)基于 PyOpenGL 的三維數(shù)據(jù)可視化庫(kù),以 wx 為顯示后端,提供 Matplotlib 風(fēng)格的交互式應(yīng)用模式,同時(shí),也可以和 wxPython 無(wú)縫結(jié)合,在wx的窗體上繪制三維模型。

2.制作工序

花燈制作工序非常簡(jiǎn)單,只需要三十行代碼,可以直接在Python IDLE中以交互方式逐行執(zhí)行。

導(dǎo)入模塊

>>> import numpy as np
>>> from PIL import Image
>>> import wxgl.wxplot as plt

打開花燈紙圖像

>>> fn = r'D:\temp\light0115\res\paper.png'
>>> im = np.array(Image.open(fn))/255
>>> im.shape
(400, 942, 3)

fn定義的是圖像存儲(chǔ)路徑,請(qǐng)據(jù)實(shí)修改。Image.open(fn)打開文件,返回一個(gè)PIL對(duì)象,np.array()將PIL對(duì)象轉(zhuǎn)成numpy.ndarray數(shù)組對(duì)象。除以255,將圖像數(shù)據(jù)從0到255的值域范圍變成0到1,適應(yīng)WxGL的接口要求。查看數(shù)組的shape,顯示圖像分辨率為400像素高、942像素寬,每個(gè)像素有三種顏色(此處為RGB)。

根據(jù)花燈紙的大小制作龍骨

紙長(zhǎng)942像素,卷成圓筒,半徑就是149.9像素,如果把半徑視為1個(gè)單位,則高度400像素相當(dāng)于2.668個(gè)單位。

>>> rows, cols, deep = im.shape
>>> cols/(2*np.pi)
149.9239563925654
>>> r = 1
>>> h = 2*np.pi*rows/cols
>>> h
2.6680192387174464

接下來(lái)需要制作半徑1個(gè)單位、高度2.668個(gè)單位的圓筒狀龍骨了。

>>> theta = np.linspace(0, 2*np.pi, cols)
>>> x = r * np.cos(theta)
>>> y = r * np.sin(theta)
>>> z = np.linspace(0, h, rows)
>>> xs = np.tile(x, (rows,1))
>>> ys = np.tile(y, (rows,1))
>>> zs = z.repeat(cols).reshape((rows,cols))

這里的xs、ys、zs就是圓筒狀龍骨上各個(gè)點(diǎn)的x坐標(biāo)、y坐標(biāo)、z坐標(biāo)。下面的代碼,每隔10個(gè)點(diǎn)抽取1個(gè)點(diǎn),用mesh的方法畫出龍骨形狀。當(dāng)然,也可以畫出全部的點(diǎn),那樣頂點(diǎn)就會(huì)連成一片。

>>> plt.mesh(xs[::10,::10], ys[::10,::10], zs[::10,::10], mode='FLBL')
>>> plt.show()

用3D的方式畫出來(lái)的龍骨,效果如下。

給龍骨貼上花燈紙

有了龍骨,接下來(lái)就可以把花燈紙貼在龍骨上了。繼續(xù)操作之前,記得先把剛才彈出的3D龍骨窗口關(guān)閉。

>>> plt.mesh(xs, ys, zs, im)
>>> plt.show()

不過(guò),你會(huì)立刻發(fā)現(xiàn),花燈紙上下方向貼反了。沒(méi)關(guān)系,我們可以像下面這樣反轉(zhuǎn)方向。

>>> plt.mesh(xs, ys, zs, im[::-1])
>>> plt.show()

怎么樣,是不是有一點(diǎn)走馬燈的雛形了呢?

制作旋轉(zhuǎn)葉輪

走馬燈之所以能夠轉(zhuǎn)動(dòng),是因?yàn)槔锩嬗邢灎T加熱形成上升氣流,推動(dòng)頂部的葉輪旋轉(zhuǎn),從而帶動(dòng)花燈旋轉(zhuǎn)。當(dāng)然,這里的葉輪僅僅是個(gè)樣子,花燈旋轉(zhuǎn)依賴另外的機(jī)制實(shí)現(xiàn)。

>>> theta = np.linspace(0, 2*np.pi, 18, endpoint=False)
>>> x = r * np.cos(theta)
>>> y = r * np.sin(theta)
>>> x[2::3] = x[1::3]
>>> x[1::3] = 0
>>> y[2::3] = y[1::3]
>>> y[1::3] = 0
>>> z = np.ones(18) * h * 0.9
>>> vs = np.stack((x,y,z), axis=1)
>>> plt.mesh(xs, ys, zs, im[::-1])
>>> plt.surface(vs, color='#C03000', method='T', mode='FCBC', alpha=0.8)
>>> plt.show()

葉輪設(shè)計(jì)有6片,用三角形模擬,顏色深紅,透明度0.8,整體效果略顯粗糙了一點(diǎn)。

加上照明燈和提系

照明燈用一個(gè)白色的圓球表示,提系則是紅色的一條直線,兼做照明燈的電源線。

>>> plt.mesh(xs, ys, zs, im[::-1])
>>> plt.surface(vs, color='#C03000', method='T', mode='FCBC', alpha=0.8)
>>> plt.sphere((0,0,h*0.4), 0.4, '#FFFFFF', slices=60, mode='FCBC')
>>> plt.plot((0,0), (0,0), (0.4*h, 1.5*h), width=3.0, style='solid', cmap='hsv', caxis='z')

讓花燈轉(zhuǎn)起來(lái)

花燈旋轉(zhuǎn)的實(shí)現(xiàn)非常簡(jiǎn)單,只需要給show方法一個(gè)rotation參數(shù)就可以。

plt.show(rotation='h-')

最終的花燈效果如下。

3.完整代碼

# -*- coding: utf-8 -*-

import numpy as np
from PIL import Image
import wxgl.wxplot as plt

im = np.array(Image.open('res/paper.png'))/255
rows, cols, deep = im.shape

r, h = 1, 2*np.pi*rows/cols
theta = np.linspace(0, 2*np.pi, cols)
x = r*np.cos(theta)
y = r*np.sin(theta)
z = np.linspace(0, h, rows)
xs = np.tile(x, (rows,1))
ys = np.tile(y, (rows,1))
zs = z.repeat(cols).reshape((rows,cols))

theta = np.linspace(0, 2*np.pi, 18, endpoint=False)
x = r*np.cos(theta)
y = r*np.sin(theta)
x[2::3] = x[1::3]
x[1::3] = 0
y[2::3] = y[1::3]
y[1::3] = 0
z = np.ones(18) * h * 0.9
vs = np.stack((x,y,z), axis=1)

plt.mesh(xs, ys, zs, im[::-1])
plt.surface(vs, color='#C03000', method='T', mode='FCBC', alpha=0.8)
plt.sphere((0,0,h*0.4), 0.4, '#FFFFFF', slices=60, mode='FCBC')
plt.plot((0,0), (0,0), (0.4*h, 1.5*h), width=3.0, style='solid', cmap='hsv', caxis='z')
plt.show(rotation='h-')

到此這篇關(guān)于使用Python制作一盞 3D 花燈喜迎元宵佳節(jié)的文章就介紹到這了,更多相關(guān)Python制作 3D 花燈內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • python接入GoogleAuth的實(shí)現(xiàn)

    python接入GoogleAuth的實(shí)現(xiàn)

    經(jīng)常會(huì)用到GoogleAuth作為二次驗(yàn)證碼,本文主要介紹了python接入GoogleAuth的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-08-08
  • Python3 socket同步通信簡(jiǎn)單示例

    Python3 socket同步通信簡(jiǎn)單示例

    這篇文章主要介紹了Python3 socket同步通信功能,結(jié)合簡(jiǎn)單實(shí)例形式分析了Python socket同步通信客戶端與服務(wù)器端實(shí)現(xiàn)技巧,需要的朋友可以參考下
    2017-06-06
  • Pandas數(shù)據(jù)結(jié)構(gòu)之Series的使用

    Pandas數(shù)據(jù)結(jié)構(gòu)之Series的使用

    本文主要介紹了Pandas數(shù)據(jù)結(jié)構(gòu)之Series的使用,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-03-03
  • Python中八大圖像特效算法的示例詳解

    Python中八大圖像特效算法的示例詳解

    圖像特效處理是基于圖像像素?cái)?shù)據(jù)特征,將原圖像進(jìn)行一定步驟的計(jì)算——例如像素作差、灰度變換、顏色通道融合等,從而達(dá)到期望的效果。本文將為大家介紹八種常用的圖像特效算法,需要的可以參考一下
    2022-03-03
  • Anaconda和ipython環(huán)境適配的實(shí)現(xiàn)

    Anaconda和ipython環(huán)境適配的實(shí)現(xiàn)

    這篇文章主要介紹了Anaconda和ipython環(huán)境適配的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-04-04
  • tensorflow 獲取變量&打印權(quán)值的實(shí)例講解

    tensorflow 獲取變量&打印權(quán)值的實(shí)例講解

    今天小編就為大家分享一篇tensorflow 獲取變量&打印權(quán)值的實(shí)例講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-06-06
  • Python任務(wù)調(diào)度模塊APScheduler使用

    Python任務(wù)調(diào)度模塊APScheduler使用

    這篇文章主要介紹了Python任務(wù)調(diào)度模塊APScheduler使用,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-04-04
  • pycharm2022.1最新永久激活碼破解補(bǔ)丁一鍵安裝教程免費(fèi)分享(2022持續(xù)更新)

    pycharm2022.1最新永久激活碼破解補(bǔ)丁一鍵安裝教程免費(fèi)分享(2022持續(xù)更新)

    更新到Pycharm 2022.2.x版,pycharm2022.2最新可用永久激活碼分享(持續(xù)更新),pycharm激活補(bǔ)丁一鍵安裝簡(jiǎn)單方便,無(wú)需手動(dòng)修改文件,兼容蘋果MAC,linux,Windows系統(tǒng)
    2022-07-07
  • python如何生成任意n階的三對(duì)角矩陣

    python如何生成任意n階的三對(duì)角矩陣

    這篇文章主要介紹了python如何生成任意n階的三對(duì)角矩陣,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • python字符串string的內(nèi)置方法實(shí)例詳解

    python字符串string的內(nèi)置方法實(shí)例詳解

    這篇文章主要介紹了python字符串string的內(nèi)置方法,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2018-05-05

最新評(píng)論