• 在学习python面向对象编程的时候,心血来潮,决定写一个时钟模型来玩玩,所以就有了现在这个小玩意,不过python这个东西确实是挺好玩的
  • 方法;运用python的tkinter库开发图形化时钟程序
    •   时钟启动时以系统的时间为当前的时间
    •   时钟有时针、分针和秒针
    •   表盘可以切换为程序绘制的或基于图片的样式
  • 对象分析
    •   指针:

      • 坐标集(针头坐标和针头坐标)
      • 当前位置坐标(绘制各种针的当前位置)
      • 颜色,粗细,当前指针的图形ID(把前一个id删除),画布对象
      • 当前指针的上级指针,上下级指针的行走关系(分针走一格,秒针走多少格),行走一格,
      • 设置起始位置,绘制指针,删除指针
    •   基本表盘
      • 所有刻度线起讫点坐标(绘制每一个刻度线)
      • 画布引用
      • 绘制刻度线,删除刻度线
    •   图像表盘
      • 刻度图

        • 图像名称
        • 绘制id,绘制删除指定图像文件
      • 装饰图
        • 图像名称
        • 绘制ID,删除绘制指定图像文件
    • 钟表
      • 三种类型的指针
      • 表盘
      • 切换表盘的按钮
      • 设置图形表盘图像
      • 切换表盘(按钮)
  • d代码实现
    •   

      1. #coding=gbk
      2. # -*- encoding:utf-8 -*-
      3.  
      4. import time,datetime
      5. import math
      6. import itertools
      7. import tkinter
      8. import threading
      9.  
      10. def get_clock_step(base_pntr,long_pntr):
      11. pos = []
      12. for i in range(60):
      13. pos.append((base_pntr[0]+long_pntr*math.cos(i*math.pi/30),
      14. base_pntr[0]+long_pntr*math.sin(i*math.pi/30)))
      15. return pos[45:] + pos[:45]
      16.  
      17. def gen_i_pos(c_pntr,long_pntr):
      18. for i,p in enumerate(get_clock_step(c_pntr,long_pntr)):
      19. yield i,p
      20.  
      21. class Pointer:
      22.  
      23. def __init__(self,c_pntr,long_pntr,cvns,scale=None,super_pntr=None,width=1,fill='black'):
      24. # 参数说明:
      25. # c_pntr: 表盘的中心坐标;
      26. # long_pntr: 表针长;
      27. # cvns: 画布引用;
      28. # scale: 指针行走比例;
      29. # super_pntr: 上级指针;
      30. # width: 指针粗细;
      31. # fill: 指针颜色;
      32. self.pos_iter = itertools.cycle(gen_i_pos(c_pntr,long_pntr))
      33. self.scale = scale
      34. self.cvns = cvns
      35. self.crrnt_pos = self.pos_iter.__next__()[1]
      36. self.c_pntr = c_pntr
      37. self.super_pntr = super_pntr
      38. self.id_pntr = None
      39. self.width = width
      40. self.fill = fill
      41.  
      42. def draw(self):
      43. self.id_pntr = cvns.create_line(self.c_pntr,self.crrnt_pos,width=self.width,fill=self.fill)
      44.  
      45. def walk_step(self):
      46. self.delete()
      47. self.draw()
      48. i,self.crrnt_pos = self.pos_iter.__next__()
      49. if self.super_pntr and self.scale and (i + 1) % self.scale == 0:
      50. self.super_pntr.walk_step()
      51.  
      52. def delete(self):
      53. if self.id_pntr:
      54. self.cvns.delete(self.id_pntr)
      55.  
      56. def set_start(self,steps):
      57. for i in range(steps-1):
      58. self.pos_iter.__next__()
      59. self.crrnt_pos = self.pos_iter.__next__()[1]
      60.  
      61. class PlateImg:
      62.  
      63. def __init__(self,c_pntr,clock_r,cvns,img):
      64. self.cvns = cvns
      65. self.clock_r = clock_r
      66. self.c_pntr = c_pntr
      67. self.img = img
      68. self.pid = None
      69. self.draw()
      70.  
      71. def draw(self):
      72. self.im = tkinter.PhotoImage(file=self.img)
      73. self.pid = self.cvns.create_image(self.c_pntr,image = self.im)
      74.  
      75. def delete(self):
      76. if self.pid:
      77. self.cvns.delete(self.pid)
      78.  
      79. def set_img(self,img):
      80. self.img = img
      81. self.delete()
      82. self.draw()
      83.  
      84. class InImg(PlateImg):
      85. def draw(self):
      86. x = self.c_pntr[0]
      87. y = self.c_pntr[0] + self.clock_r / 5
      88. self.im = tkinter.PhotoImage(file=self.img)
      89. self.pid = self.cvns.create_image(x,y,image = self.im)
      90.  
      91. class CustomPlate:
      92. def __init__(self,c_pntr,clock_r,cvns,imgp='platex.gif',imgi='flowersx.gif'):
      93. self.pi = PlateImg(c_pntr,clock_r,cvns,imgp)
      94. self.ii = InImg(c_pntr,clock_r,cvns,imgi)
      95.  
      96. def set_img(self,imgp,imgi):
      97. self.pi.set_img(imgp)
      98. self.ii.set_img(imgi)
      99.  
      100. def delete(self):
      101. self.pi.delete()
      102. self.ii.delete()
      103.  
      104. class Plate:
      105.  
      106. def __init__(self,c_pntr,clock_r,cvns,long=10):
      107. self.pos_a = get_clock_step(c_pntr,clock_r - long)
      108. self.pos_b = get_clock_step(c_pntr,clock_r)
      109. self.cvns = cvns
      110. self.plates = []
      111. self.draw()
      112.  
      113. def draw(self):
      114. for i,p in enumerate(zip(self.pos_a,self.pos_b)):
      115. width = 5 if (i + 1) % 5 == 0 else 3
      116. pid = self.cvns.create_line(*p,width=width)
      117. self.plates.append(pid)
      118.  
      119. def delete(self):
      120. if self.plates:
      121. for item in self.plates:
      122. self.cvns.delete(item)
      123.  
      124. class MyClock:
      125.  
      126. def __init__(self,base_pntr,clock_r,cvns):
      127. self.c_pntr = base_pntr
      128. self.clock_r = clock_r
      129. self.cvns = cvns
      130. self.plate = Plate(base_pntr,clock_r,self.cvns)
      131. h,m,s = self.start_time()
      132. self.h_pntr = Pointer(base_pntr,3 * clock_r // 5,self.cvns,width=5,fill='blue')
      133. self.m_pntr = Pointer(base_pntr,4 * clock_r // 5,self.cvns,12,super_pntr=self.h_pntr,width=3,fill='green')
      134. self.h_pntr.set_start(h * 5)
      135. self.m_pntr.set_start(m)
      136. self.h_pntr.walk_step()
      137. self.m_pntr.walk_step()
      138. self.s_pntr = Pointer(base_pntr,clock_r-5,self.cvns,60,super_pntr=self.m_pntr,fill='red')
      139. self.s_pntr.set_start(s)
      140.  
      141. def chg_plate(self):
      142. self.plate.delete()
      143. if isinstance(self.plate,CustomPlate):
      144. self.plate = Plate(self.c_pntr,self.clock_r,self.cvns)
      145. else:
      146. self.plate = CustomPlate(self.c_pntr,self.clock_r,self.cvns)
      147. self.h_pntr.delete()
      148. self.h_pntr.draw()
      149. self.m_pntr.delete()
      150. self.m_pntr.draw()
      151.  
      152. def set_img(self,imgp,imgi):
      153. if not isinstance(self.plate,CustomPlate):
      154. self.chg_plate()
      155. self.plate.set_img(imgp,imgi)
      156.  
      157. def walk_step(self):
      158. self.s_pntr.walk_step()
      159.  
      160. def start_time(self):
      161. crrnt_time = datetime.datetime.now()
      162. hour = crrnt_time.hour
      163. minute = crrnt_time.minute
      164. second = crrnt_time.second
      165. return hour,minute,second
      166.  
      167. class MyButton:
      168. def __init__(self,root,clock):
      169. self.clock = clock
      170. button = tkinter.Button(root,text = '改变表盘',command = self.chg_plate)
      171. button.pack()
      172.  
      173. def chg_plate(self):
      174. self.clock.chg_plate()
      175.  
      176. class MyTk(tkinter.Tk):
      177. def quit(self):
      178. StartClock.looping = False
      179. self.quit()
      180.  
      181. class StartClock:
      182. looping = True
      183. def __init__(self,mc,root):
      184. self.mc = mc
      185. self.root = root
      186.  
      187. def start_clock(self):
      188. while StartClock.looping:
      189. self.mc.walk_step()
      190. self.root.update()
      191. time.sleep(0.05)
      192.  
      193. if __name__ == '__main__':
      194. root = MyTk()
      195. cvns = tkinter.Canvas(root,width=400,height=400,bg='white')
      196. cvns.pack()
      197. mc = MyClock((200,200),200,cvns)
      198. bt = MyButton(root,mc)
      199. t = threading.Thread(target=StartClock(mc,root).start_clock)
      200. t.setDaemon(True)
      201. t.start()
      202. root.resizable(False, False)
      203. root.mainloop()
    • 刚刚学习,谢谢指出错误!

Python--面向对象编程--时钟实例开发的更多相关文章

  1. python面向对象编程设计与开发

    一.什么是面向对象的程序设计 1.何为数据结构? 数据结构是指相互之间存在一种或多种特定关系的数据元素的集合,如列表.字典. 2.何为编程? 编程是指程序员用特定的语法+数据结构+算法,组成的代码,告 ...

  2. Python面向对象编程——继承与派生

    Python面向对象编程--继承与派生 一.初始继承 1.什么是继承 继承指的是类与类之间的关系,是一种什么"是"什么的关系,继承的功能之一就是用来解决代码重用问题. 继承是一种创 ...

  3. python 面向对象编程学习

    1. 问题:将所有代码放入一个py文件:无法维护 方案:如果将代码才分放到多个py文件,好处: 1. 同一个名字的变量互相不影响 2.易于维护 3.引用模块: import module 2.包:解决 ...

  4. python 面向对象编程(一)

    一.如何定义一个类 在进行python面向对象编程之前,先来了解几个术语:类,类对象,实例对象,属性,函数和方法. 类是对现实世界中一些事物的封装,定义一个类可以采用下面的方式来定义: class c ...

  5. Python面向对象编程指南

    Python面向对象编程指南(高清版)PDF 百度网盘 链接:https://pan.baidu.com/s/1SbD4gum4yGcUruH9icTPCQ 提取码:fzk5 复制这段内容后打开百度网 ...

  6. python面向对象编程进阶

    python面向对象编程进阶 一.isinstance(obj,cls)和issubclass(sub,super) isinstance(obj,cls)检查是否obj是否是类 cls 的对象 1 ...

  7. Python面向对象编程(下)

    本文主要通过几个实例介绍Python面向对象编程中的封装.继承.多态三大特性. 封装性 我们还是继续来看下上文中的例子,使用Student类创建一个对象,并修改对象的属性.代码如下: #-*- cod ...

  8. Python 面向对象编程——访问限制

    <无访问限制的对象> 在Class内部,可以有属性和方法,而外部代码可以通过直接调用实例变量的方法来操作数据,这样,就隐藏了内部的复杂逻辑.但是,从前面Student类的定义来看(见:Py ...

  9. Python 面向对象编程基础

    Python 面向对象编程基础 虽然Pthon是解释性语言,但是Pthon可以进行面向对象开发,小到 脚本程序,大到3D游戏,Python都可以做到. 一类: 语法: class 类名: 类属性,方法 ...

随机推荐

  1. CF Round 542 Div1.

    B. Wrong Answer 构造一个长度为 2000 的数组,满足最大“子段和 $\times$ 子段长度”比最大子段和刚好大 k sol: 一个比较好的构造方法: 令数组总和为 $S$,然后构造 ...

  2. 数据处理之pandas库

    1. Series对象 由于series对象很简单,跟数组类似,但多了一些额外的功能,偷个懒,用思维导图表示 2. DaraFrame对象 DataFrame将Series的使用场景由一维扩展到多维, ...

  3. 解决count distinct多个字段的方法

    Distinct的作用是用于从指定集合中消除重复的元组,经常和count搭档工作,语法如下 COUNT( { [ ALL | DISTINCT ] expression ] | * } ) 这时,可能 ...

  4. sleep(0)作用

    假设现在是 2008-4-7 12:00:00.000,如果我调用一下 Thread.Sleep(1000) ,在 2008-4-7 12:00:01.000 的时候,这个线程会 不会被唤醒?某人的代 ...

  5. 使用HibernateTemplate手写源生SQL的【增删改查】 操作

    使用 HibernateTemplate 进行持久化操作 执行的时候不报错,但数据库的持久化操作没有一点作用,问了好多人,说没有声明事务和提交事务, 用的是别人搭的的架构,事务已经有了,自动提交事务的 ...

  6. 蓝桥杯 Beaver's Calculator

    问题描述 从万能词典来的聪明的海狸已经使我们惊讶了一次.他开发了一种新的计算器,他将此命名为"Beaver's Calculator 1.0".它非常特别,并且被计划使用在各种各样 ...

  7. JAVA 正则表达式 Regex

    //正则表达式,去掉空格.换行.制表位 public static void replaceBlank(){ Pattern p = Pattern.compile("\\s*|\t|\r| ...

  8. OpenWrt添加启动脚本

    1.在 /etc/init.d 目录下建立文件 vi silabs #!/bin/sh /etc/rc.common # Copyright (C) 2006 OpenWrt.org START=93 ...

  9. (转)Dynamic Web project转成Maven项目

    本文转载自:http://my.oschina.net/twosnail/blog/369125 1.新建Dynamic Web Project 1.File -> New -> Othe ...

  10. springboot或者jetty等启动服务器后,如何去停止这个服务

    首先在win7下找到运行,但是win7的运行不像XP那么好找,win7运行的位置在:开始→所有程序→附件→运行.   然后在对话框中,输入cmd(大小写均可).   然后是如何查看80端口的方法,一般 ...