做这个东西的时候,灵感源自于一个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. 已知可生成0~4的rand5(),实现生成0~6的rand7()

    若已知生成0~6的rand7(),求生成0~4的rand5(),则一个方法就是不断生成0~7的数,直到这个数满足0~4就返回. int rand5(){ int res; do{ res = rand ...

  2. socket系统调用

    SYSCALL_DEFINE3(socket, int, family, int, type, int, protocol) { int retval; struct socket *sock; in ...

  3. Django模型和ORM

    一.ORM ORM介绍 ORM概念 对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术. 简单的说,ORM是 ...

  4. RobotFramework安装扩展库包autoitlibrary(四)

    Robot Framework扩展库包 http://robotframework.org/#libraries 一,自动化测试PC端程序 1,  安装pywin32(autoitlibrary使用需 ...

  5. JavaScript 简单吗

    英文:Aurélien Hervé  译文:众成翻译/msmailcode 这里有一些 Javascript初学者应该知道的技巧和陷阱.如果你已经是专家了,顺便温习一下. Javascript也只不过 ...

  6. vue+vuex+axios+echarts画一个动态更新的中国地图

    一. 生成项目及安装插件 # 安装vue-cli npm install vue-cli -g # 初始化项目 vue init webpack china-map # 切到目录下 cd china- ...

  7. Java Http接口加签、验签操作方法

    1.业务背景 最近接触了一些电商业务,发现在处理电商业务接口时,比如淘宝.支付类接口,接口双方为了确保数据参数在传输过程中未经过篡改,都需要对接口数据进行加签,然后在接口服务器端对接口参数进行验签,确 ...

  8. ZooKeeper常见问题

    转载自原文:zookeeper(二)常见问题汇总 一.为什么zookeeper要部署基数台服务器? 所谓的zookeeper容错是指,当宕掉几个zookeeper服务器之后,剩下的个数必须大于宕掉的个 ...

  9. Linux学习笔记:ctrl+z、ctrl+c、ctrl+d的区别

    ctrl+c和ctrl+z都是中断命令,但是他们的作用却不一样.    1.ctrl+c是强制中断程序的执行,进程已经终止.   2.ctrl+z的是将任务中止(暂停的意思),但是此任务并没有结束,他 ...

  10. django 建立一个简单的应用

    本人的用的版本是python 2.7.3和django 1.10.5,Windows10系统 1.首先通过命令建立项目和app 找到django的安装路径,我的路径是:C:\Python27\Lib\ ...