许可优化
许可优化
产品
产品
解决方案
解决方案
服务支持
服务支持
关于
关于
软件库
当前位置:服务支持 >  软件文章 >  Fluent鱼儿游动弹射动图:Python代码保存为GIF动画

Fluent鱼儿游动弹射动图:Python代码保存为GIF动画

阅读数 2
点赞 0
article_banner
# -*- coding: utf-8 -*-
"""
Created on Fri Nov 11 18:41:30 2022
fluent鱼儿游动,保存为gif动图
@author: in
"""

import matplotlib
matplotlib.use('Agg') # 只绘图保存,不显示图片,一定要加在import后面
import numpy as np
import matplotlib.pyplot as plt
import imageio
import pandas as pd
from matplotlib.pyplot import MultipleLocator#从pyplot导入MultipleLocator类,这个类用于设置刻度间隔


path = r'https://www.gofarlic.com\20221112fish\move\coordinate.xlsx'
data = pd.DataFrame(pd.read_excel(path))
output_path = r'https://www.gofarlic.com\20221112fish\move\test.gif'#保存gif的路径及名字
print(data.index)#获取行的索引名称
print(data.columns)#获取列的索引名称
x = data['x'].values.tolist()#获取列名为姓名这一列的内容
t = data['t'].values.tolist()#获取列名为姓名这一列的内容
b = data['b'].values.tolist()#获取列名为姓名这一列的内容
m = data['m'].values.tolist()



time = 1.8
step = 0.04
image_list = []
pig = 0
zdfd = 1
def fish(x,t,dt,zdfd):
    k = 2*3.1415926/0.95
    w = 2*3.1415926*1
    return zf*(0.02-0.08*x+0.16*x*x)*((np.sin(k*x-w*t))-(np.sin(k*x-w*(t-dt))))
for td in np.arange(0.01,time,step):
    pig = pig+1
    ty = []
    my = []
    by = []
    for xp in range(0,len(x)):
        dy = fish(x[xp],td,step,zdfd)
        t[xp] = t[xp]+dy
        m[xp] = m[xp]+dy
        b[xp] = b[xp]+dy
    plt.plot(x, t)
    plt.plot(x, b)
    plt.plot(x, m)
    '''设置数据在四周的坐标显示'''
    plt.tick_params(top=True,bottom=True,left=True,right=True)
    plt.tick_params(labeltop=True,labelleft=True,labelright=True,labelbottom=True)
    plt.grid( color = 'black',linestyle='-.',linewidth = 1)#设置网格线
    plt.ylim(-0.3,0.3)#设置y轴的最大值和最小值
#    plt.xlim(-0.5,11)#设置x轴的最大值和最小值
    
#    '''设置x,y轴的间隔'''
#    x_major_locator=MultipleLocator(0.1)
#    #把x轴的刻度间隔设置为,并存在变量里
#    y_major_locator=MultipleLocator(0.05)
#    #把y轴的刻度间隔设置为,并存在变量里
#    ax=plt.gca()
#    #ax为两条坐标轴的实例
#    ax.xaxis.set_major_locator(x_major_locator)
#    #把x轴的主刻度设置为0.1
#    ax.yaxis.set_major_locator(y_major_locator)
#    #把y轴的主刻度设置为0.05

    plt.savefig('temp.png')
    img = cv2.imread('temp.png')
    image_list.append(imageio.imread('temp.png'))
    plt.pause(0.1)
    plt.close()
imageio.mimsave(output_path, image_list, 'GIF', duration=0.35)

excel的链接:https://download. csdn .net/download/weixin_43245453/86996059
在这里插入图片描述
免责声明:本文系网络转载或改编,未找到原创作者,版权归原作者所有。如涉及版权,请联系删


相关文章
技术文档
QR Code
微信扫一扫,欢迎咨询~
customer

online

联系我们
武汉格发信息技术有限公司
湖北省武汉市经开区科技园西路6号103孵化器
电话:155-2731-8020 座机:027-59821821
邮件:tanzw@gofarlic.com
Copyright © 2023 Gofarsoft Co.,Ltd. 保留所有权利
遇到许可问题?该如何解决!?
评估许可证实际采购量? 
不清楚软件许可证使用数据? 
收到软件厂商律师函!?  
想要少购买点许可证,节省费用? 
收到软件厂商侵权通告!?  
有正版license,但许可证不够用,需要新购? 
联系方式 board-phone 155-2731-8020
close1
预留信息,一起解决您的问题
* 姓名:
* 手机:

* 公司名称:

姓名不为空

姓名不为空

姓名不为空
手机不正确

手机不正确

手机不正确
公司不为空

公司不为空

公司不为空