您好,登錄后才能下訂單哦!
這篇“Python如何實現繪制3D地球旋轉效果”文章的知識點大部分人都不太理解,所以小編給大家總結了以下內容,內容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“Python如何實現繪制3D地球旋轉效果”文章吧。
想畫一個轉動的地球,那么首先要有一個球,或者說要有一個球面,用參數方程可以表示為
x=rcos?cosθ
y=rcos?sinθ
z=rsin?
然后要有一個地球,或者說要有一個地圖,用來作為貼圖,映射到球面上。
import numpy as np import matplotlib.pyplot as plt path = "earth2.jpg" img = plt.imread(path) h, w, c = img.shape ys, xs = np.indices([h, w]) th = xs/w*np.pi*2 phi = np.pi/2 - ys/h*np.pi x = np.cos(phi)*np.cos(th) y = np.cos(phi)*np.sin(th) z = np.sin(phi) cs = [tuple(c/255) for c in img.reshape(-1,3)] ax = plt.subplot(projection='3d') ax.scatter(x, y, z, marker='.', c=cs) plt.axis('off') plt.show()
其中scatter
畫的是散點圖,c=cs
為顏色映射參數,所以溫馨提示,選取的地球圖片不宜過大,否則點太多會讓電腦爆掉。
最后得到的效果如下
三維空間中的旋轉矩陣如下表所示,具體講解可參考這兩篇博客:旋轉坐標軸????旋轉正方體
有了旋轉矩陣,接下來就是讓地球轉起來。
import numpy as np import matplotlib.pyplot as plt from matplotlib import animation cos = lambda th : np.cos(np.deg2rad(th)) sin = lambda th : np.sin(np.deg2rad(th)) Rz = lambda th : np.array([ [cos(th) , -sin(th), 0], [sin(th), cos(th), 0], [0 , 0, 1]]) xyz = np.array([x,y,z]).reshape(3,-1) fig = plt.figure(figsize=(5,5)) ax = fig.add_subplot(projection='3d') ax.grid() lines = ax.scatter(x, y, z, marker='.', c=cs) def animate(n): # 按照xyz順序旋轉 axis = [2,1,0] shape = xyz.shape lines._offsets3d = Rz(n)@xyz return lines, ani = animation.FuncAnimation(fig, animate, range(0, 360, 2), interval=25, blit=True) #plt.show() ani.save("zyx.gif")
效果如下
以上就是關于“Python如何實現繪制3D地球旋轉效果”這篇文章的內容,相信大家都有了一定的了解,希望小編分享的內容對大家有幫助,若想了解更多相關的知識內容,請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。