设为首页 收藏本站
查看: 3340|回复: 0

[经验分享] python开发_tkinter_图形随鼠标移动

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2015-4-25 06:16:34 | 显示全部楼层 |阅读模式
  做这个东西的时候,灵感源自于一个js效果:
  两个眼睛随鼠标移动而移动
  运行效果:
DSC0000.png
  ===============================================
  代码部分:
  ===============================================



  1 from tkinter import *
  2
  3 #1.获取到小圆当前的圆心坐标(x1, y1)
  4 #2.获取到小圆移动的圆心坐标(x2, y2)
  5 #3.把小圆从坐标(x1, y1)移动到坐标(x2, y2)
  6
  7 __author__ = {'name' : 'Hongten',
  8               'mail' : 'hongtenzone@foxmail.com',
  9               'blog' : 'http://www.iyunv.com/',
10               'QQ': '648719819',
11               'created' : '2013-09-20'}
12
13 class Eay(Frame):
14     
15     def createWidgets(self):
16         ## The playing field
17         self.draw = Canvas(self, width=500, height=500)
18
19         #鼠标位置
20         self.mouse_x = 450
21         self.mouse_y = 250
22         
23         #圆心坐标(x,y)
24         self.oval_zero_x = 250
25         self.oval_zero_y = 250
26         #外面大圆半径
27         self.oval_r = 100
28         
29         #里面小圆半径
30         self.oval_R = 30
31
32         self.oval_r1 = self.oval_r - self.oval_R + 0.5
33         self.oval_r2 = self.oval_r - self.oval_R - 0.5
34
35
36         #小圆
37         self.letter_ball_x1 = 250
38         self.letter_ball_y1 = 250
39                 
40         # The ball 外面大圆
41         self.ball = self.draw.create_oval((self.oval_zero_x - self.oval_r),
42                                           (self.oval_zero_y - self.oval_r),
43                                           (self.oval_zero_x + self.oval_r),
44                                           (self.oval_zero_y + self.oval_r),
45                                           fill="white")
46
47         self.ball = self.draw.create_oval((self.oval_zero_x - self.oval_r1),
48                                           (self.oval_zero_y - self.oval_r1),
49                                           (self.oval_zero_x + self.oval_r1),
50                                           (self.oval_zero_y + self.oval_r1),
51                                           fill="blue")
52
53         self.ball = self.draw.create_oval((self.oval_zero_x - self.oval_r2),
54                                           (self.oval_zero_y - self.oval_r2),
55                                           (self.oval_zero_x + self.oval_r2),
56                                           (self.oval_zero_y + self.oval_r2),
57                                           fill="white")
58         
59         #里面小圆
60         self.ball_over = self.draw.create_oval((self.oval_zero_x - self.oval_R),
61                                                (self.oval_zero_y - self.oval_R),
62                                                (self.oval_zero_x + self.oval_R),
63                                                (self.oval_zero_y + self.oval_R),
64                                                fill="red")
65
66         self.draw.pack(side=LEFT)
67
68     def mouseMove(self, event):
69         self.mouse_x = event.x
70         self.mouse_y = event.y
71
72         if SHOW_LOG:
73             print('#' * 50)
74             print('鼠标的坐标为:({}, {})'.format(self.mouse_x, self.mouse_y))
75             print('小圆当前坐标为:({}, {})'.format(self.letter_ball_x1, self.letter_ball_y1))
76         '''获取到小圆移动的圆心坐标(x2, y2)'''
77         ax_x = abs(self.mouse_x - self.oval_zero_x)
78         ax_y = abs(self.mouse_y - self.oval_zero_y)
79         if SHOW_LOG:
80             print('坐标A(oval_zero_x, oval_zero_y)到坐标X(mouse_x, mouse_y)的距离为AX')
81             print('AX中ax_x = {}, ax_y = {}'.format(ax_x, ax_y))
82         ax_len = ((ax_x ** 2) + (ax_y ** 2))**0.5
83         if SHOW_LOG:
84             print('AX的长度为:{}'.format(ax_len))
85            
86         #如果鼠标坐标在(ax_len > |r-R|)
87         if ax_len > abs(self.oval_r - self.oval_R):
88             ac_len = abs(self.oval_r - self.oval_R)
89             if SHOW_LOG:
90                 print('AC的产度为:{}'.format(ac_len))
91         
92             if int(self.mouse_x - self.oval_zero_x) != 0:
93                 if int(self.mouse_y - self.oval_zero_y) != 0:
94                     #求直线斜率  y = kx + b
95                     k = (self.mouse_y - self.oval_zero_y)/(self.mouse_x - self.oval_zero_x)
96                     if SHOW_LOG:
97                         print('鼠标到大圆圆心的直线的斜率为:{}'.format(k))
98                     b = self.mouse_y - (k * self.mouse_x)
99                     ###################################################
100                 
101                     #小圆移动后的坐标
102                     #这里有三个条件:
103                     #    1.小圆的圆心坐标(x1, y1)在直线AC上(y = kx + b)
104                     #    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
105                     #    3.if self.mousex_x > 0:
106                     #          x1 > 0
107                     #这是一个二元二次方程,方程的解有两组,不过通过鼠标的位置self.mouse_x(self.mouse_y)可以判断圆心坐标x1(y1)
108                     letter_ball_x2 = ((ac_len * (abs(self.mouse_x - self.oval_zero_x)))/ax_len) + self.letter_ball_x1
109                     letter_ball_y2 = (letter_ball_x2 * k) + b
110                     if SHOW_LOG:
111                         print('小圆当前坐标为:({}, {})'.format(self.letter_ball_x1, self.letter_ball_y1))
112                         print('小圆移动后坐标为:({}, {})'.format(letter_ball_x2, letter_ball_y2))
113
114                     #把小圆从坐标(x1, y1)移动到坐标(x2, y2)
115                     self.moved_x2 = letter_ball_x2 - self.letter_ball_x1
116                     self.moved_y2 = letter_ball_y2 - self.letter_ball_y1
117                     if SHOW_LOG:
118                         print('需要移动的距离是:({}, {})'.format(int(self.moved_x2), int(self.moved_y2)))
119                     self.draw.move(self.ball_over, int(self.moved_x2), int(self.moved_y2))
120                     self.letter_ball_x1 = letter_ball_x2
121                     self.letter_ball_y1 = letter_ball_y2
122                 else:
123                     print('鼠标在X轴上')
124             else:
125                 print('鼠标在Y轴上')
126         else:
127             if SHOW_LOG:
128                 print('小圆的移动后的坐标就是鼠标坐标')
129             #小圆移动后的坐标
130             letter_ball_x2 = self.mouse_x
131             letter_ball_y2 = self.mouse_y
132             if SHOW_LOG:
133                 print('小圆移动后坐标为:({}, {})'.format(letter_ball_x2, letter_ball_y2))
134
135             #把小圆从坐标(x1, y1)移动到坐标(x2, y2)
136             self.moved_x2 = letter_ball_x2 - self.letter_ball_x1
137             self.moved_y2 = letter_ball_y2 - self.letter_ball_y1
138             if SHOW_LOG:
139                 print('需要移动的距离是:({}, {})'.format(int(self.moved_x2), int(self.moved_y2)))
140             self.draw.move(self.ball_over, int(self.moved_x2), int(self.moved_y2))
141             self.letter_ball_x1 = letter_ball_x2
142             self.letter_ball_y1 = letter_ball_y2
143     
144     def move_ball(self, *args):
145         #当鼠标在窗口中按下左键拖动的时候执行
146         #Widget.bind(self.draw, "", self.mouseMove)
147         #当鼠标在大圆内移动的时候执行
148         self.draw.tag_bind(self.ball, "", self.mouseMove)
149
150     def __init__(self, master=None):
151         global letter_ball_x2
152         letter_ball_x2 = 0
153         global letter_ball_y2
154         letter_ball_y2 = 0
155         global SHOW_LOG
156         SHOW_LOG = True
157         
158         Frame.__init__(self, master)
159         Pack.config(self)
160         self.createWidgets()
161         self.after(10, self.move_ball)
162
163 game = Eay()
164
165 game.mainloop()
  

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-60323-1-1.html 上篇帖子: Windows下 Python 安装包的配置 下篇帖子: Selenium RC For Python:教程1
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表