Python tkinter实现的图片移动碰撞动画效果【附源码下载】

Python tkinter实现的图片移动碰撞动画效果【附源码下载】,第1张

概述本文实例讲述了Pythontkinter实现的图片移动碰撞动画效果。分享给大家供大家参考,具体如下:

本文实例讲述了Python tkinter实现的图片移动碰撞动画效果。分享给大家供大家参考,具体如下:

先来看看运行效果:

具体代码如下:

#!/usr/bin/python# -*- Coding: utf-8 -*-import timetry: from tkinter import *except importError: #Python 2.x PythonVersion = 2 from Tkinter import * from tkFont import Font from ttk import * from tkMessageBox import * import tkfileDialogelse: #Python 3.x PythonVersion = 3 from tkinter.Font import Font from tkinter.ttk import * from tkinter.messageBox import *# 配置# 要打开的图像image1 = "open.gif"# 初始坐标x0 = 50.0y0 = 50.0# 列表将包含所有的x和y坐标.到目前为止,他们只包含初始坐标x = [x0]y = [y0]# 每次移动的速度或距离vx = 1.0# x 速度vy = 0.5# y 速度# 边界,这里要考虑到图片的大小,要预留一半的长和宽x_min = 46.0y_min = 46.0x_max = 754.0y_max = 554.0# 图片间隔时间,要动画效果,此处设为每秒40帧sleep_time = 0.025# 运行步数range_min = 1range_max = 2000# 创建500次的x和y坐标for t in range(range_min,range_max): # 新坐标等于旧坐标加每次移动的距离 new_x = x[t - 1] + vx new_y = y[t - 1] + vy # 如果已经越过边界,反转方向 if new_x >= x_max or new_x <= x_min:  vx = vx * -1.0 if new_y >= y_max or new_y <= y_min:  vy = vy * -1.0 # 添加新的值到列表 x.append(new_x) y.append(new_y)# 开始使用tk绘图root = Tk()root.Title("编程小技巧 tkinter动画测试") #在这里修改窗口的标题canvas = Canvas(wIDth=800,height=600,bg='white')canvas.pack()photo1 = PhotoImage(file=image1)wIDth1 = photo1.wIDth()height1 = photo1.height()image_x = (wIDth1) / 2.0image_y = (height1) / 2.0# 每次的移动for t in range(range_min,range_max): canvas.create_image(x[t],y[t],image=photo1,tag="pic") canvas.update() # 暂停0.05妙,然后删除图像 time.sleep(sleep_time) canvas.delete("pic")root.mainloop()

附:完整实例代码点击此处本站下载

注:tkinter只能识别gif格式图片,将jpg或png格式图片后缀名简单改成gif是不能识别的!

更多关于Python相关内容感兴趣的读者可查看本站专题:《Python数据结构与算法教程》、《Python函数使用技巧总结》、《Python字符串 *** 作技巧汇总》、《Python入门与进阶经典教程》及《Python文件与目录 *** 作技巧汇总》

希望本文所述对大家Python程序设计有所帮助。

总结

以上是内存溢出为你收集整理的Python tkinter实现的图片移动碰撞动画效果【附源码下载】全部内容,希望文章能够帮你解决Python tkinter实现的图片移动碰撞动画效果【附源码下载】所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1200814.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-04
下一篇 2022-06-04

发表评论

登录后才能评论

评论列表(0条)

保存