做这个东西的时候,灵感源自于一个js效果:

两个眼睛随鼠标移动而移动

运行效果:

===============================================

代码部分:

===============================================

 from tkinter import *

 #1.获取到小圆当前的圆心坐标(x1, y1)
#2.获取到小圆移动的圆心坐标(x2, y2)
#3.把小圆从坐标(x1, y1)移动到坐标(x2, y2) __author__ = {'name' : 'Hongten',
'mail' : 'hongtenzone@foxmail.com',
'blog' : 'http://www.cnblogs.com/',
'QQ': '',
'created' : '2013-09-20'} class Eay(Frame): def createWidgets(self):
## The playing field
self.draw = Canvas(self, width=500, height=500) #鼠标位置
self.mouse_x = 450
self.mouse_y = 250 #圆心坐标(x,y)
self.oval_zero_x = 250
self.oval_zero_y = 250
#外面大圆半径
self.oval_r = 100 #里面小圆半径
self.oval_R = 30 self.oval_r1 = self.oval_r - self.oval_R + 0.5
self.oval_r2 = self.oval_r - self.oval_R - 0.5 #小圆
self.letter_ball_x1 = 250
self.letter_ball_y1 = 250 # The ball 外面大圆
self.ball = self.draw.create_oval((self.oval_zero_x - self.oval_r),
(self.oval_zero_y - self.oval_r),
(self.oval_zero_x + self.oval_r),
(self.oval_zero_y + self.oval_r),
fill="white") self.ball = self.draw.create_oval((self.oval_zero_x - self.oval_r1),
(self.oval_zero_y - self.oval_r1),
(self.oval_zero_x + self.oval_r1),
(self.oval_zero_y + self.oval_r1),
fill="blue") self.ball = self.draw.create_oval((self.oval_zero_x - self.oval_r2),
(self.oval_zero_y - self.oval_r2),
(self.oval_zero_x + self.oval_r2),
(self.oval_zero_y + self.oval_r2),
fill="white") #里面小圆
self.ball_over = self.draw.create_oval((self.oval_zero_x - self.oval_R),
(self.oval_zero_y - self.oval_R),
(self.oval_zero_x + self.oval_R),
(self.oval_zero_y + self.oval_R),
fill="red") self.draw.pack(side=LEFT) def mouseMove(self, event):
self.mouse_x = event.x
self.mouse_y = event.y if SHOW_LOG:
print('#' * 50)
print('鼠标的坐标为:({}, {})'.format(self.mouse_x, self.mouse_y))
print('小圆当前坐标为:({}, {})'.format(self.letter_ball_x1, self.letter_ball_y1))
'''获取到小圆移动的圆心坐标(x2, y2)'''
ax_x = abs(self.mouse_x - self.oval_zero_x)
ax_y = abs(self.mouse_y - self.oval_zero_y)
if SHOW_LOG:
print('坐标A(oval_zero_x, oval_zero_y)到坐标X(mouse_x, mouse_y)的距离为AX')
print('AX中ax_x = {}, ax_y = {}'.format(ax_x, ax_y))
ax_len = ((ax_x ** 2) + (ax_y ** 2))**0.5
if SHOW_LOG:
print('AX的长度为:{}'.format(ax_len)) #如果鼠标坐标在(ax_len > |r-R|)
if ax_len > abs(self.oval_r - self.oval_R):
ac_len = abs(self.oval_r - self.oval_R)
if SHOW_LOG:
print('AC的产度为:{}'.format(ac_len)) if int(self.mouse_x - self.oval_zero_x) != 0:
if int(self.mouse_y - self.oval_zero_y) != 0:
#求直线斜率 y = kx + b
k = (self.mouse_y - self.oval_zero_y)/(self.mouse_x - self.oval_zero_x)
if SHOW_LOG:
print('鼠标到大圆圆心的直线的斜率为:{}'.format(k))
b = self.mouse_y - (k * self.mouse_x)
################################################### #小圆移动后的坐标
#这里有三个条件:
# 1.小圆的圆心坐标(x1, y1)在直线AC上(y = kx + b)
# 2.(r-R)^2 = x1^2 + y1^2 由1,2可以得到 => (r-R)^2 = x1^2 + 2*x1*k*b + b^2 => x1有两个值,通过3判断x1的符号,从而求出y1
# 3.if self.mousex_x > 0:
# x1 > 0
#这是一个二元二次方程,方程的解有两组,不过通过鼠标的位置self.mouse_x(self.mouse_y)可以判断圆心坐标x1(y1)
letter_ball_x2 = ((ac_len * (abs(self.mouse_x - self.oval_zero_x)))/ax_len) + self.letter_ball_x1
letter_ball_y2 = (letter_ball_x2 * k) + b
if SHOW_LOG:
print('小圆当前坐标为:({}, {})'.format(self.letter_ball_x1, self.letter_ball_y1))
print('小圆移动后坐标为:({}, {})'.format(letter_ball_x2, letter_ball_y2)) #把小圆从坐标(x1, y1)移动到坐标(x2, y2)
self.moved_x2 = letter_ball_x2 - self.letter_ball_x1
self.moved_y2 = letter_ball_y2 - self.letter_ball_y1
if SHOW_LOG:
print('需要移动的距离是:({}, {})'.format(int(self.moved_x2), int(self.moved_y2)))
self.draw.move(self.ball_over, int(self.moved_x2), int(self.moved_y2))
self.letter_ball_x1 = letter_ball_x2
self.letter_ball_y1 = letter_ball_y2
else:
print('鼠标在X轴上')
else:
print('鼠标在Y轴上')
else:
if SHOW_LOG:
print('小圆的移动后的坐标就是鼠标坐标')
#小圆移动后的坐标
letter_ball_x2 = self.mouse_x
letter_ball_y2 = self.mouse_y
if SHOW_LOG:
print('小圆移动后坐标为:({}, {})'.format(letter_ball_x2, letter_ball_y2)) #把小圆从坐标(x1, y1)移动到坐标(x2, y2)
self.moved_x2 = letter_ball_x2 - self.letter_ball_x1
self.moved_y2 = letter_ball_y2 - self.letter_ball_y1
if SHOW_LOG:
print('需要移动的距离是:({}, {})'.format(int(self.moved_x2), int(self.moved_y2)))
self.draw.move(self.ball_over, int(self.moved_x2), int(self.moved_y2))
self.letter_ball_x1 = letter_ball_x2
self.letter_ball_y1 = letter_ball_y2 def move_ball(self, *args):
#当鼠标在窗口中按下左键拖动的时候执行
#Widget.bind(self.draw, "<B1-Motion>", self.mouseMove)
#当鼠标在大圆内移动的时候执行
self.draw.tag_bind(self.ball, "<Any-Enter>", self.mouseMove) def __init__(self, master=None):
global letter_ball_x2
letter_ball_x2 = 0
global letter_ball_y2
letter_ball_y2 = 0
global SHOW_LOG
SHOW_LOG = True Frame.__init__(self, master)
Pack.config(self)
self.createWidgets()
self.after(10, self.move_ball) game = Eay() game.mainloop()

========================================================

More reading,and english is important.

I'm Hongten

大哥哥大姐姐,觉得有用打赏点哦!多多少少没关系,一分也是对我的支持和鼓励。谢谢。
Hongten博客排名在100名以内。粉丝过千。
Hongten出品,必是精品。

E | hongtenzone@foxmail.com  B | http://www.cnblogs.com/hongten

========================================================

python开发_tkinter_图形随鼠标移动的更多相关文章

  1. python开发_tkinter_小球完全弹性碰撞游戏

    python开发_tkinter_小球完全弹性碰撞游戏   完成这个小球的完全弹性碰撞游戏灵感来自于: 下面是我花了一周下班时间所编写的一个小球完全弹性碰撞游戏: 游戏初始化状态: 最下面的游标和修改 ...

  2. python开发_tkinter_获取文本框内容_给文本框添加键盘输入事件

    在之前的blog中有提到python的tkinter中的菜单操作 python开发_tkinter_窗口控件_自己制作的Python IDEL_博主推荐 python开发_tkinter_窗口控件_自 ...

  3. python开发_tkinter_获取单选菜单值

    在之前的blog中有提到python的tkinter中的菜单操作 python开发_tkinter_窗口控件_自己制作的Python IDEL_博主推荐 python开发_tkinter_窗口控件_自 ...

  4. python开发_tkinter_多级子菜单

    在之前的blog中有提到python的tkinter中的菜单操作 python开发_tkinter_窗口控件_自己制作的Python IDEL_博主推荐 python开发_tkinter_窗口控件_自 ...

  5. python开发_tkinter_单选菜单_不可用菜单操作

    在之前的blog中有提到python的tkinter中的菜单操作 python开发_tkinter_窗口控件_自己制作的Python IDEL_博主推荐 python开发_tkinter_窗口控件_自 ...

  6. python开发_tkinter_复选菜单

    在之前的blog中有提到python的tkinter中的菜单操作 python开发_tkinter_窗口控件_自己制作的Python IDEL_博主推荐 python开发_tkinter_窗口控件_自 ...

  7. python开发_tkinter_菜单选项中英文切换_菜单选项不可用操作_博主推荐

    我使用的python版本为:3.3.2 如果你对python中tkinter模块的菜单操作不是很了解,你可以看看: python开发_tkinter_窗口控件_自己制作的Python IDEL_博主推 ...

  8. python开发_tkinter_窗口控件_自己制作的Python IDEL_博主推荐(二)

    在上一篇blog:python开发_tkinter_窗口控件_自己制作的Python IDEL_博主推荐 中介绍了python中的tkinter的一些东西,你可能对tkinter有一定的了解了.这篇b ...

  9. python开发_tkinter_小球完全弹性碰撞游戏_源码下载

    完成这个小球的完全弹性碰撞游戏灵感来自于: 下面是我花了一周下班时间所编写的一个小球完全弹性碰撞游戏: 游戏初始化状态: 最下面的游标和修改小球的移动速度 ====================== ...

随机推荐

  1. REX系统了解1

    REX是高通开发出来的一个操作系统,起初它是为了在Inter 80186处理器上应用而开发的,到后来才转变成应用在ARM这种微处理器上.他历经了很多版本,代码也越来越多,功能也越来越完善.REX只用不 ...

  2. asterisk各种报错

    1.控制台打印出: Got SIP response "Temporarily Unavailable" back from 210.13.87.110:5060   造成原因:在 ...

  3. 读书笔记--C陷阱与缺陷(七)

    第七章 1.null指针并不指向任何对象,所以只用于赋值和比较运算,其他使用目的都是非法的. 误用null指针的后果是未定义的,根据编译器各异. 有的编译器对内存位置0只读,有的可读写. 书中给出了一 ...

  4. python随笔(二)

    range(2,10):不包括10 range(2,10,3):步长为3 range(10,2,-1):从10到2,步长-1.

  5. 利用sys.dm_db_index_physical_stats查看索引碎片等数据

    我们都知道,提高sql server的数据查询速度,最有效的方法,就是为表创建索引,而索引在对数据进行新增,删除,修改的时候,会产生索引碎片,索引碎片多了,就需要重新组织或重新生成索引,以达到索引的最 ...

  6. Kubernetes 概述和搭建(多节点)

    一.Kubernetes整体概述和架构 Kubernetes是什么 Kubernetes是一个轻便的和可扩展的开源平台,用于管理容器化应用和服务.通过Kubernetes能够进行应用的自动化部署和扩缩 ...

  7. MyBatis的动态插入语句(经常报‘无效的列类型’)

    最近在工作中经常遇到一个情况:通过mybatis的标签执行插入语句,当表中字段比较多的时候,需要全部插入,而有时候的需求是只插入其中几个字段,但是会报错. 原来的语句,必须把所有字段都Set值. &l ...

  8. 宝塔Linux常用命令

    https://www.bt.cn/bbs/thread-1186-1-1.html 2017年3月8日发布全新架构的宝塔Linux 面板3.1Beta版,到现在的5.2.0正式版,历经100多天打磨 ...

  9. Nginx 虚拟主机 VirtualHost 配置

    Nginx 是一个轻量级高性能的 Web 服务器, 并发处理能力强, 对资源消耗小, 无论是静态服务器还是小网站, Nginx 表现更加出色, 作为 Apache 的补充和替代使用率越来越高. 我在& ...

  10. 为django的python manage.py加自定义命令

    计划在开发软件的过程中, 每次可以自己加入测试数据,这样就可以每次作全新的测试了. 将这个初始化django modules数据命令,将在manage.py里是最合适的. 下面我们就来实现吧. 参考文 ...