Python OpenGL绘制一场烟花盛会

目录
  • 1. 安装WxGL
  • 2. 快速体验
  • 3. 编写自己的着色器
  • 4. 绽放的烟花

忙碌了一年,今天终于放假了。原本打算好好休息一下,没成想只过了半天就觉得有点无聊。看家人和朋友们都在忙年,那我就用OpenGL导演一场烟花盛会,献给即将到来的新年吧。

一说到OpenGL,很多人都会觉得复杂,其实不然。只要掌握了几个基本的概念,借助于工具软件,任何人都可以很轻松地上手。在制作烟花之前,我先介绍一下WxGL这个三维数据快速可视化工具。

1. 安装WxGL

WxGL是一个基于PyOpenGL的三维数据可视化库,以wx为显示后端,提供Matplotlib风格的交互式应用方式。WxGL也可以和wxPython无缝结合,在wx的窗体上绘制三维模型。使用pip命令即可快速安装WxGL及其所依赖的其他模块。

pip install wxgl

2. 快速体验

下面这几行代码,绘制了一个中心在坐标原点半径为1的纯色圆球。忽略模块名的话,这些代码和Matplotlib的风格是完全一致的。

>>> import wxgl.wxplot as plt
>>> plt.uvsphere((0,0,0), 1, color='cyan')
>>> plt.title('快速体验:$x^2+y^2=1$')
>>> plt.show()

生成一个地球模型是如此简单。

>>> plt.uvsphere((0,0,0), 1, texture='res/earth.jpg', xflip=True, yflip=False)
>>> plt.show()

让地球自转,更是易如反掌。

>>> plt.uvsphere((0,0,0), 1,
    texture='res/earth.jpg',
    xflip=True,
    yflip=False,
    transform = lambda tn,gms,tms : ((0, 1, 0, (0.01*tms)%360),)
)
>>> plt.show()

勾选“屏幕录制”,点击“播放”按钮,即可保存为gif文件或mp4/avi格式的视频文件。

这是代码中用的的地球纹理图片,可以直接下载使用。

3. 编写自己的着色器

WxGL不仅提供了线段、散点、曲面、三维等值面等一系列绘图函数,还支持用户定制着色器程序,以实现更复杂的功能。下面这个例子,用粒子技术模拟了烟花升空的过程。

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

import numpy as np
import wxgl
import wxgl.wxplot as plt

def rise(n, pos, h, v, a, cycle):
    """烟花升空模型

    n       - 粒子数量
    pos     - 初始位置
    h       - 上升行程
    v       - 初始速度
    a       - 上升加速度
    cycle   - 循环周期
    """

    vshader_src = """
        #version 330 core
        in vec4 a_Position;
        in vec4 a_Color;
        in float a_Delay; // 粒子发射延迟时间(s)
        uniform float u_Ts; // 持续时间(s)
        uniform float u_V; // 初始速度
        uniform float u_A; // 上升加速度
        uniform mat4 u_MVPMatrix;
        out vec4 v_Color;
        out float v_Ts;
        void main() {
            float t = u_Ts - a_Delay;
            if (t < 0) t = 0;

            float s = u_V * t + 0.5 * u_A * t * t;
            gl_Position = u_MVPMatrix * vec4(a_Position.x, a_Position.y+s, a_Position.z, a_Position.w);
            gl_PointSize = 1;
            v_Color = a_Color;
            v_Ts = u_Ts;
        }
    """

    fshader_src = """
        #version 330 core
        in vec4 v_Color;
        uniform float u_Tmax;
        in float v_Ts;
        void main() {
            if(v_Ts > u_Tmax) discard;

            vec2 temp = gl_PointCoord - vec2(0.5);
            float f = dot(temp, temp);
            if(f > 0.25) discard;

            gl_FragColor = vec4(v_Color.rgb, 1);
        }
    """

    vs = np.array(pos) + (np.random.random((n,3)) - 0.5) * h/100
    color = np.tile(np.array((1.0,1.0,0.8)), (n,1))
    delay = np.float32(np.absolute(np.random.randn(n))) / 10
    tmax = (pow(v*v+2*a*h, 0.5)-v)/a + delay.max()

    m = wxgl.Model(wxgl.POINTS, vshader_src, fshader_src, sprite=True)
    m.set_vertex('a_Position', vs)
    m.set_color('a_Color', color)
    m.set_argument('a_Delay', delay)
    m.set_argument('u_Ts', lambda tn,gms,tms:(tms/1000)%cycle)
    m.set_argument('u_V', v)
    m.set_argument('u_A', a)
    m.set_argument('u_Tmax', tmax)
    m.set_mvp_matrix('u_MVPMatrix') # 设置模型矩阵、视点矩阵和投影矩阵

    return m

vs = np.array([
    [-1.5,2,1], [-1.5,0,1], [1.5,2,1], [1.5,0,1],
    [-1.5,2,-1], [-1.5,0,-1], [1.5,2,-1], [1.5,0,-1]])
vs = vs[[0,1,2,3,0,2,1,3,4,5,6,7,4,6,5,7,0,4,1,5,2,6,3,7]]
m = rise(n=500, pos=(0,0,0), h=1.5, v=2, a=-1.2, cycle=5)

plt.figure(zoom=0.7, elev=10)
plt.line(vs, color=(0,1,1), method='isolate') # 六面体线框,表示烟花燃放的空间
plt.model(m)
plt.show()

4. 绽放的烟花

只要理解了烟花升空的代码,很容易写出烟花在空中爆炸的着色器程序。下面的代码除了烟花升空的着色器,还提供了两种烟花爆炸的着色器,其中用到了一个纹理图片,可直接下载下面这张图使用。

如果将上面的纹理图片替换成文字,就可以在烟花爆炸的瞬间显示出文字了。WxGL提供了一个文本转PIL图形对象的函数,可以直接作为纹理使用。

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

import numpy as np
import wxgl
import wxgl.wxplot as plt

def rise(n, pos, h, v, a, cycle):
    """烟花升空模型

    n       - 粒子数量
    pos     - 初始位置
    h       - 上升行程
    v       - 初始速度
    a       - 上升加速度
    cycle   - 循环周期
    """

    vshader_src = """
        #version 330 core
        in vec4 a_Position;
        in vec4 a_Color;
        in float a_Delay; // 粒子发射延迟时间(s)
        uniform float u_Ts; // 持续时间(s)
        uniform float u_V; // 初始速度
        uniform float u_A; // 上升加速度
        uniform mat4 u_MVPMatrix;
        out vec4 v_Color;
        out float v_Ts;
        void main() {
            float t = u_Ts - a_Delay;
            if (t < 0) t = 0;

            float s = u_V * t + 0.5 * u_A * t * t;
            gl_Position = u_MVPMatrix * vec4(a_Position.x, a_Position.y+s, a_Position.z, a_Position.w);
            gl_PointSize = 1;
            v_Color = a_Color;
            v_Ts = u_Ts;
        }
    """

    fshader_src = """
        #version 330 core
        in vec4 v_Color;
        uniform float u_Tmax;
        in float v_Ts;
        void main() {
            if(v_Ts > u_Tmax) discard;

            vec2 temp = gl_PointCoord - vec2(0.5);
            float f = dot(temp, temp);
            if(f > 0.25) discard;

            gl_FragColor = vec4(v_Color.rgb, 1);
        }
    """

    vs = np.array(pos) + (np.random.random((n,3)) - 0.5) * h/100
    color = np.tile(np.array((1.0,1.0,0.8)), (n,1))
    delay = np.float32(np.absolute(np.random.randn(n))) / 10
    tmax = (pow(v*v+2*a*h, 0.5)-v)/a + delay.max()

    m = wxgl.Model(wxgl.POINTS, vshader_src, fshader_src, sprite=True)
    m.set_vertex('a_Position', vs)
    m.set_color('a_Color', color)
    m.set_argument('a_Delay', delay)
    m.set_argument('u_Ts', lambda tn,gms,tms:(tms/1000)%cycle)
    m.set_argument('u_V', v)
    m.set_argument('u_A', a)
    m.set_argument('u_Tmax', tmax)
    m.set_mvp_matrix('u_MVPMatrix') # 设置模型矩阵、视点矩阵和投影矩阵

    return m, tmax

def bomb_1(n, pos, start, a, cycle):
    """烟花爆炸模型

    n       - 粒子数量
    pos     - 位置
    start   - 时间
    a       - 下降加速度
    cycle   - 循环周期
    """

    vshader_src = """
        #version 330 core
        in vec4 a_Position;
        in vec3 a_Data;
        uniform float u_Ts;
        uniform float u_Start;
        uniform float u_A;
        uniform mat4 u_MVPMatrix;
        out vec4 v_Color;
        out float v_Ts;
        void main() {
            float t = u_Ts - u_Start;
            if (t < 0) t = 0;

            float lat = radians((a_Data.x - 0.5) * 90);
            float lon = radians(a_Data.y * 360);
            float r = (a_Data.z * 0.3 + 0.7) * 0.3 * t * (1 + 0.3 * a_Position.z);
            float y = r * sin(lat) + a_Position.y - 0.5*u_A*t*t;
            float xz = r * cos(lat);
            float x = xz * cos(lon) + a_Position.x;
            float z = xz * sin(lon) + a_Position.z;

            gl_Position = u_MVPMatrix * vec4(x,y,z,a_Position.w);
            gl_PointSize = 3 * t;
            v_Ts = t;

            int i = gl_VertexID % 6;
            if (i == 0) v_Color = vec4(1,0,0,1);
            else if (i == 1) v_Color = vec4(0,1,0,1);
            else if (i == 2) v_Color = vec4(0,0,1,1);
            else if (i == 3) v_Color = vec4(1,1,0,1);
            else if (i == 4) v_Color = vec4(0,1,1,1);
            else v_Color = vec4(1,0,1,1);
        }
    """

    fshader_src = """
        #version 330 core
        in vec4 v_Color;
        in float v_Ts;
        void main() {
            if(v_Ts <= 0 || v_Ts > 2) discard;

            vec2 temp = gl_PointCoord - vec2(0.5);
            float f = dot(temp, temp);
            if(f > 0.25)  discard;

            //float alpha = v_Color.a * exp(1-30*f) * (4-v_Ts*v_Ts)/2;
            float alpha = v_Color.a * (1-4*f) * (4-v_Ts*v_Ts)/2;
            gl_FragColor = vec4(v_Color.rgb, alpha);
        }
    """

    vs = np.tile(np.array(pos), (n,1))
    data = np.float32(np.random.random((n,3)))

    m = wxgl.Model(wxgl.POINTS, vshader_src, fshader_src, sprite=True, opacity=False)
    m.set_vertex('a_Position', vs)
    m.set_argument('a_Data', data)
    m.set_argument('u_Start', start)
    m.set_argument('u_A', a)
    m.set_argument('u_Ts', lambda tn,gms,tms:(tms/1000)%cycle)
    m.set_mvp_matrix('u_MVPMatrix') # 设置模型矩阵、视点矩阵和投影矩阵

    return m

def bomb_2(pos, start, texture, a, size, cycle):
    """烟花爆炸模型

    pos     - 位置
    start   - 时间
    texture - 纹理
    a       - 下降加速度
    cycle   - 循环周期
    """

    vshader_src = """
        #version 330 core
        in vec4 a_Position;
        uniform float u_Ts;
        uniform float u_Start;
        uniform float u_A;
        uniform float u_Size;
        uniform mat4 u_MVPMatrix;
        out float v_Ts;
        void main() {
            float t = u_Ts - u_Start;
            if (t < 0) t = 0;

            if (t < 2) gl_PointSize = t * u_Size/2 * (1 + 0.3 * a_Position.z);
            else gl_PointSize = u_Size * (1 + 0.3 * a_Position.z);

            gl_Position = u_MVPMatrix * vec4(a_Position.x, a_Position.y-0.5*u_A*t*t, a_Position.z, a_Position.w);
            v_Ts = t;
        }
    """

    fshader_src = """
        #version 330 core
        uniform sampler2D u_Fireworks;
        in float v_Ts;
        void main() {
            if(v_Ts <= 0 || v_Ts > 2) discard;

            vec4 color = texture2D(u_Fireworks, gl_PointCoord);
            gl_FragColor = vec4(color.rgb, color.a*(4-v_Ts*v_Ts)/2);
        }
    """

    vs = np.array(pos).reshape(-1,3)

    m = wxgl.Model(wxgl.POINTS, vshader_src, fshader_src, sprite=True)
    m.set_vertex('a_Position', vs)
    m.set_argument('u_A', a)
    m.set_argument('u_Size',size)
    m.set_argument('u_Start', start)
    m.set_argument('u_Ts', lambda tn,gms,tms:(tms/1000)%cycle)
    m.add_texture('u_Fireworks', texture, wxgl.TEXTURE_2D, yflip=False)
    m.set_mvp_matrix('u_MVPMatrix') # 设置模型矩阵、视点矩阵和投影矩阵

    return m

if __name__ == '__main__':
    vs = np.array([[-1.5,2,1], [-1.5,0,1], [1.5,2,1], [1.5,0,1], [-1.5,2,-1], [-1.5,0,-1], [1.5,2,-1], [1.5,0,-1]])
    vs = vs[[0,1,2,3,0,2,1,3,4,5,6,7,4,6,5,7,0,4,1,5,2,6,3,7]]

    plt.figure(zoom=0.5, elev=10)
    plt.line(vs, color=(0,1,1,0), method='isolate') # 六面体线框,表示烟花燃放的空间

    # ------------------------------
    h, v, a, cycle = 1.7, 2.2, -1.2, 4
    for i, ch in enumerate('新春快乐'):
        x = -1.5 + i
        m1, start = rise(n=300, pos=(x,0,1), h=h, v=v, a=a, cycle=cycle)
        m2 = bomb_1(200, (x,h,1), start, a=0.1, cycle=cycle)
        m3 = bomb_2((x,h,1), start, wxgl.text2image(ch, 96, (1,0,0)), a=0.1, size=100, cycle=cycle)
        plt.model(m1)
        plt.model(m2)
        plt.model(m3)

    # -------------------------------
    for i in range(20):
        x, z = (np.random.random()-0.5)*4, (np.random.random()-0.5)*2
        h, v, a = 1.5+(np.random.random()-0.5)*0.4, 2.2, -1.2
        cycle = np.random.randint(4, 7)
        m1, start = rise(n=300, pos=(x,0,z), h=h, v=v, a=a, cycle=cycle)
        m2 = bomb_1(200, (x,h,z), start, a=0.1, cycle=cycle)
        plt.model(m1)
        plt.model(m2)

    # -------------------------------
    for i in range(20):
        x, z = (np.random.random()-0.5)*4, (np.random.random()-0.5)*2
        h, v, a = 1.5+(np.random.random()-0.5)*0.4, 2.3, -1.2
        cycle = np.random.randint(4, 7)
        m1, start = rise(n=300, pos=(x,0,z), h=h, v=v, a=a, cycle=cycle)
        m2 = bomb_2((x,h,z), start, 'res/fw.png', a=0.1, size=300, cycle=cycle)
        plt.model(m1)
        plt.model(m2)

    plt.show()

最终的效果如下面的gif所示。

到此这篇关于Python OpenGL绘制一场烟花盛会的文章就介绍到这了,更多相关Python OpenGL烟花内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • 利用Python绘制虎年烟花秀

    目录 一.演示效果 二.python代码 三.前端代码 一.演示效果 b站:虎年烟花演示 二.python代码 import pygame from math import * from pygame.locals import * import random class firew:          def __init__(self, pos, color, light, size, move):         self.pos = list(pos)         self.colo

  • python代码实现烟花实例

    实现代码如下: # -*- coding: utf-8 -*- import math, random,time import threading import tkinter as tk import re #import uuid Fireworks=[] maxFireworks=8 height,width=600,600 class firework(object): def __init__(self,color,speed,width,height): #uid=uuid.uuid

  • Python Pygame实现可控制的烟花游戏

    目录 实现效果描述 效果 代码地址 解析 main.py core.py fireworks.py 写在最后 自控烟花升空 实现效果描述效果代码地址解析main.pycore.pyfireworks.py 写在最后 实现效果描述 这大过年的不弄点有意思的怎么行呢?可以考虑用编程实现一个烟花升空-爆炸-绚丽地效果.随机的烟花也玩习惯了,这次我们用pygame实现用户鼠标点击屏幕实现放烟花并在指定高度绽放~ 效果 鼠标点击时,烟花点会从屏幕底部正中心发射至鼠标点击点处并绽放出随机的颜色,烟花颗粒符合

  • 利用Python Pygame放个烟花

    uu们,有多久没放烟花了?今年你所在的地方允许放烟花么?既然我们不能线下放,那么我们就在线上放个够吧,先上最后效果图 老规矩,先导包,导入pygame,Python Pygame 是一款专门为开发和设计 2D 电子游戏而生的软件包,它支 Windows.Linux.Mac OS 等操作系统,具有良好的跨平台性. import pygame from random import randint, uniform, choice import math Pygame 绘制烟花的基本原理 1.发射阶段

  • python烟花效果的代码实例

    天天敲代码的朋友,有没有想过代码也可以变得很酷炫又浪漫?今天就教大家用Python模拟出绽放的烟花,工作之余也可以随时让程序为自己放一场烟花秀. 这个有趣的小项目并不复杂,只需一点可视化技巧,100余行Python代码和程序库Tkinter,最后我们就能达到下面这个效果: 学完本教程后,你也能做出这样的烟花秀. 整体概念梳理 我们的整个理念比较简单. 如上图示,我们这里通过让画面上一个粒子分裂为X数量的粒子来模拟爆炸效果.粒子会发生"膨胀",意思是它们会以恒速移动且相互之间的角度相等.

  • 利用Python写一场新年烟花秀

    目录 1.导库 2.烟花颜色 3.定义烟花类 4.燃放烟花 5.启动 我们用到的 Python 模块包括:tkinter.PIL.time.random.math,如果第三方模块没有装的话,pip install 一下即可,下面看一下代码实现. 1.导库 import tkinter as tk from PIL import Image, ImageTk from time import time, sleep from random import choice, uniform, randi

  • Python Pygame制作雪夜烟花景

    目录 运行截图 实现过程 核心代码 基础架子 下雪的过程 雪落到地上堆起来的过程 实现烟花的过程 完整代码 运行截图 运行效果: 什么?你说你看不清烟花?那我换一种颜色,请点开看. 实现过程 准备工作 使用语言和框架:python.pygame. 安装pygame: pip install -i https://pypi.tuna.tsinghua.edu.cn/simple/ --trusted-host pypi.tuna.tsinghua.edu.cn pygame 你需要知道的基础知识

  • Python新年炫酷烟花秀代码

    先介绍下 Pygame 绘制烟花的基本原理,烟花从发射到绽放一共分为三个阶段: 1,发射阶段:在这一阶段烟花的形状是线性向上,通过设定一组大小不同.颜色不同的点来模拟“向上发射” 的运动运动,运动过程中 5个点被赋予不同大小的加速度,随着时间推移,后面的点会赶上前面的点,最终所有点会汇聚在一起,处于 绽放准备阶段: 2,烟花绽放:烟花绽放这个阶段,是由一个点分散多个点向不同方向发散,并且每个点的移动轨迹可需要被记录,目的是为了追踪整个绽放轨迹. 3,烟花凋零,此阶段负责描绘绽放后烟花的效果,绽放

  • Python OpenGL绘制一场烟花盛会

    目录 1. 安装WxGL 2. 快速体验 3. 编写自己的着色器 4. 绽放的烟花 忙碌了一年,今天终于放假了.原本打算好好休息一下,没成想只过了半天就觉得有点无聊.看家人和朋友们都在忙年,那我就用OpenGL导演一场烟花盛会,献给即将到来的新年吧. 一说到OpenGL,很多人都会觉得复杂,其实不然.只要掌握了几个基本的概念,借助于工具软件,任何人都可以很轻松地上手.在制作烟花之前,我先介绍一下WxGL这个三维数据快速可视化工具. 1. 安装WxGL WxGL是一个基于PyOpenGL的三维数据

  • 通过Python OpenGL的point sprite技术绘制雪花

    看冬奥才知道,阿勒泰不但是中国的“雪都”,还是“人类滑雪起源地”.这个说法是否成立,姑且不论,阿勒泰的雪的确很漂亮.冬奥会有一个宣传片,就是借用一朵阿勒泰雪花的视角来讲述冬奥会的故事,既有历史的厚重,又有艺术的浪漫,极具视觉冲击感. 那么问题来了:如何用OpenGL绘制雪花呢?通常,点精灵(point sprite)技术被用于描述大量粒子在屏幕上的运动,自然也可以用于绘制雪花.点精灵可以理解为贴了纹理图片的点——仅用一个vertex就可以把一个2D纹理图片绘制到屏幕的任何位置. 在OpenGL中

  • 浅谈Python pygame绘制机制

    pygame绘制机制简介 屏幕控制 pygame.display • 用来控制Pygame游戏的屏幕 • Pygame有且只有一个屏幕 • 屏幕左上角坐标为(0,0) • 以像素为单位 屏幕控制需求 • 游戏全屏 • 游戏屏幕大小可调节 • 游戏屏幕无边框 • 更改游戏标题栏内容 • 更改游戏图标 • -- 屏幕控制的重要函数 OpenGL和硬件加速 OpenGL被设计成独立于硬件,独立于窗口系统,在运行各种操作系统的各种计算机上都可用,并能在网络环境下以客户/服务器模式工作,是专业图形处理.科

  • Python+OpenGL制作一个元宵花灯

    目录 1.准备 2.快速体验 3.模型动画 4.子图布局 5.颜色映射 6.走马灯 又是一年元宵节,作为程序员的你,打算怎么过呢?如果昨天情人节的红包发得手软又心疼,不妨静下心来,了解一下三维数据可视化,顺便做一盏花灯送给女朋友,也许比红包更能讨她欢心呢. 1.准备 三维数据快速可视化工具,我喜欢用WxGL.这是一个基于PyOpenGL的三维数据可视化库,提供类似Matplotlib风格的3D绘图函数.如果熟悉NumPy和Matplotlib的话,只需要几分钟时间就可以学会使用WxGL的交互式绘

  • Python OpenGL基本配置方式

    目录 OpenGL基本配置方式 pip 安装 PyOpenGL 测试代码 Python+OpenGL库理解及代码应用 1.读取off文件 OpenGL基本配置方式 参考:http://pyopengl.sourceforge.net pip 安装 PyOpenGL pip install PyOpenGL PyOpenGL_accelerate 测试代码 from OpenGL.GL import * from OpenGL.GLU import * from OpenGL.GLUT impor

  • 利用JavaScript实现绘制2023新年烟花的示例代码

    目录 前言 烟花效果展示 使用教程 查看源码 HTML代码 CSS代码 JavaScript 新年祝福 前言 大家过年好!新春佳节,在这个充满喜悦的日子里,愿新年的钟声带给你一份希望和期待,我相信,时空的距离不能阻隔你我,我的祝福永远在你身边. 祝愿朋友,财源滚滚,吉祥高照,鸿运当头,幸福环绕,万事顺心,笑口常开. 在这喜庆的日子里,我给大家分享一个烟花代码,代码下载在使用教程部分,希望大家都能开开心心过大年! 烟花效果展示 烟花样式可以自定义选择,背景音乐选择十分真实的仿烟花声.当你把代码打包

  • Android开发之OpenGL绘制2D图形的方法分析

    本文实例讲述了Android开发之OpenGL绘制2D图形的方法.分享给大家供大家参考,具体如下: Android为OpenGL ES支持提供了GLSurviceView组建,这个组建用于显示3D图形.GLSurviceView本身并不提供绘制3的图形的功能,而是由GLSurfaceView.Renderer来完成了SurviceView中3D图形的绘制. 归纳起来,在android中使用OpenGL ES需要3个步骤. 1. 创建GLSurviceView组件,使用Activity来显示GLS

  • matplotlib在python上绘制3D散点图实例详解

    大家可以先参考官方演示文档: 效果图: ''' ============== 3D scatterplot ============== Demonstration of a basic scatterplot in 3D. ''' from mpl_toolkits.mplot3d import Axes3D import matplotlib.pyplot as plt import numpy as np def randrange(n, vmin, vmax): ''' Helper f

  • Python图形绘制操作之正弦曲线实现方法分析

    本文实例讲述了Python图形绘制操作之正弦曲线实现方法.分享给大家供大家参考,具体如下: 要画正弦曲线先设定一下x的取值范围,从0到2π.要用到numpy模块. numpy.pi 表示π numpy.arange( 0 , 2π ,0.01)  从0到2π,以0.01步进. 令 x=numpy.arange( 0, 2*numpy.pi, 0.01) y=numpy.sin(x) 画图要用到matplotlib.pyplot模块中plot方法. plot(x,y) pyplot.plot.sh

  • python+matplotlib绘制简单的海豚(顶点和节点的操作)

    海豚 本文例子主要展示了如何使用补丁.路径和转换类绘制和操作给定的顶点和节点的形状. 测试可用. import matplotlib.cm as cm import matplotlib.pyplot as plt from matplotlib.patches import Circle, PathPatch from matplotlib.path import Path from matplotlib.transforms import Affine2D import numpy as n

随机推荐