您当前的位置:首页 > IT编程 > python
| C语言 | Java | VB | VC | python | Android | TensorFlow | C++ | oracle | 学术与代码 | cnn卷积神经网络 | gnn | 图像修复 | Keras | 数据集 | Neo4j | 自然语言处理 | 深度学习 | 医学CAD | 医学影像 | 超参数 | pointnet | pytorch | 异常检测 | Transformers | 情感分类 | 知识图谱 |

自学教程:Python绘制3D立体花朵示例详解

51自学网 2022-02-21 10:46:46
  python
这篇教程Python绘制3D立体花朵示例详解写得很实用,希望能帮到您。

动态展示

这是一个动态图哦

导读

兄弟们可以收藏一下哦!情人节可以送出去,肥学找了几朵python写的花给封装好送给大家。不是多炫酷但是有足够的用心哦。别忘了点赞呀我也就不细说了,来吧展示!

源码和详解

荷花

def lotus():    fig = plt.figure(figsize=(10,7),facecolor='black',clear=True)    ax = fig.gca(projection='3d')    [x, t] = np.meshgrid(np.array(range(25))/24.0, np.arange(0, 575.5, 0.5)/575 * 17 * np.pi-2*np.pi)    p = (np.pi/2)*np.exp(-t/(8*np.pi))    u = 1-(1-np.mod(3.6*t, 2*np.pi)/np.pi)**4/2    y = 2*(x**2-x)**2*np.sin(p)    r = u*(x*np.sin(p)+y*np.cos(p))    surf = ax.plot_surface(r*np.cos(t), r*np.sin(t), u*(x*np.cos(p)-y*np.sin(p)), rstride=1, cstride=1, cmap=cm.gist_rainbow_r,                           linewidth=0, antialiased=True)

效果图

玫瑰花

def rose_flower():    fig = plt.figure(figsize=(10,7),facecolor='black',clear=True)    ax = fig.gca(projection='3d')    # 将相位向后移动了6*pi    [x, t] = np.meshgrid(np.array(range(25)) / 24.0, np.arange(0, 575.5, 0.5) / 575 * 20 * np.pi + 4*np.pi)    p = (np.pi / 2) * np.exp(-t / (8 * np.pi))    # 添加边缘扰动    change = np.sin(15*t)/150    # 将t的参数减少,使花瓣的角度变大    u = 1 - (1 - np.mod(3.3 * t, 2 * np.pi) / np.pi) ** 4 / 2 + change    y = 2 * (x ** 2 - x) ** 2 * np.sin(p)    r = u * (x * np.sin(p) + y * np.cos(p))    h = u * (x * np.cos(p) - y * np.sin(p))    c= cm.get_cmap('Reds')    surf = ax.plot_surface(r * np.cos(t), r * np.sin(t), h, rstride=1, cstride=1,                           cmap= c, linewidth=0, antialiased=True)

效果图

桃花

def peach_blossom():    fig = plt.figure(figsize=(10,7),facecolor='black',clear=True)    ax = fig.gca(projection='3d')    [x, t] = np.meshgrid(np.array(range(25)) / 24.0, np.arange(0, 575.5, 0.5) / 575 * 6 * np.pi - 4*np.pi)    p = (np.pi / 2) * np.exp(-t / (8 * np.pi))    change = np.sin(10*t)/20    u = 1 - (1 - np.mod(5.2 * t, 2 * np.pi) / np.pi) ** 4 / 2 + change    y = 2 * (x ** 2 - x) ** 2 * np.sin(p)    r = u * (x * np.sin(p) + y * np.cos(p)) * 1.5    h = u * (x * np.cos(p) - y * np.sin(p))    c= cm.get_cmap('spring_r')    surf = ax.plot_surface(r * np.cos(t), r * np.sin(t), h, rstride=1, cstride=1,                           cmap= c, linewidth=0, antialiased=True)

效果图

月季

def monthly_rose():    fig = plt.figure(figsize=(10,7),facecolor='black',clear=True)    ax = fig.gca(projection='3d')    [x, t] = np.meshgrid(np.array(range(25)) / 24.0, np.arange(0, 575.5, 0.5) / 575 * 30 * np.pi - 4 * np.pi)    p = (np.pi / 2) * np.exp(-t / (8 * np.pi))    change = np.sin(20 * t) / 50    u = 1 - (1 - np.mod(3.3 * t, 2 * np.pi) / np.pi) ** 4 / 2 + change    y = 2 * (x ** 2 - x) ** 2 * np.sin(p)    r = u * (x * np.sin(p) + y * np.cos(p)) * 1.5    h = u * (x * np.cos(p) - y * np.sin(p))    c = cm.get_cmap('magma')    surf = ax.plot_surface(r * np.cos(t), r * np.sin(t), h, rstride=1, cstride=1,                           cmap=c, linewidth=0, antialiased=True)

效果图

到此这篇关于Python绘制3D立体花朵示例详解的文章就介绍到这了,更多相关Python 绘制3D立体花朵内容请搜索51zixue.net以前的文章或继续浏览下面的相关文章希望大家以后多多支持51zixue.net!


pandas如何优雅的列转行及行转列详解
Python利用 matplotlib 绘制直方图
万事OK自学网:51自学网_软件自学网_CAD自学网自学excel、自学PS、自学CAD、自学C语言、自学css3实例,是一个通过网络自主学习工作技能的自学平台,网友喜欢的软件自学网站。