• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com专业计算机教程网站
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure
您的位置:首页 > 网页设计 >html5 > Tkinter教程之Canvas篇(3)

Tkinter教程之Canvas篇(3)

作者:匿名 字体:[增加 减小] 来源:互联网 时间:2018-12-03

本文主要包含Tkinter,Canvas等相关知识,匿名希望在学习及工作中可以帮助到您
'''Tkinter教程之Canvas篇(3)'''


'''16.移动item'''


# -*- coding: cp936 -*-


# move指定x,y在偏移量


from Tkinter import *


root = Tk()


# 创建一个Canvas,设置其背景色为白色


cv = Canvas(root,bg = 'white')

# 创建两个同样的rectangle,比较移动前后的不同


rt1 = cv.create_rectangle(
10,10,110,110,
tags = ('r1','r2','r3'))
cv.create_rectangle(
10,10,110,110,
tags = ('r1','r2','r3'))


# 移动rt1


cv.move(rt1,20,-10)
cv.pack()
root.mainloop()


# move可以指定x,y在相对偏移量,可以为负值


'''17.删除item'''


# -*- coding: cp936 -*-


# delete删除给定的item


from Tkinter import *
root = Tk()
cv = Canvas(root,bg = 'white')


# 创建两个rectangle


rt1 = cv.create_rectangle(
10,10,110,110,
tags = ('r1','r2','r3'))
r2 = cv.create_rectangle(
20,20,110,110,
tags = ('s1','s2','s3'))

# 使用id删除rt1


cv.delete(rt1)


# 使用tag删除r2

cv.delete('s1')
cv.pack()
root.mainloop()


# 两种方法删除item(id/tag)


'''18.缩放item'''


# -*- coding: cp936 -*-


# scale缩放item,计算公式:(coords - offset)*scale + offset


from Tkinter import *
root = Tk()
cv = Canvas(root,bg = 'white')

# 创建两个rectangle


rt1 = cv.create_rectangle(
10,10,110,110,
tags = ('r1','r2','r3'))


# 将y坐标放大为原来的2位,x坐标值不变


cv.scale(rt1,0,0,1,2)
cv.pack()
root.mainloop()


# scale的参数为(self,xoffset,yoffset,xscale,yscale)


'''19.绑定item与event'''


# -*- coding: cp936 -*-


# 使用tag_bind来绑定item与事件

from Tkinter import *
root = Tk()


# 创建一个Canvas,设置其背景色为白色


cv = Canvas(root,bg = 'white')

# 创建三个rectangle


rt1 = cv.create_rectangle(
10,10,110,110,
width = 8,
tags = ('r1','r2','r3'))
def printRect(event):
print 'rectangle'


# 绑定item与事件


cv.tag_bind('r1','<Button-1>',printRect)
cv.pack()
root.mainloop()


# 只有点击到矩形的边框时才会触发事件


'''20.添加绑定事件'''


# -*- coding: cp936 -*-


# 使用tag_bind来绑定item与事件,与参考上测试结果不一致。


from Tkinter import *
root = Tk()


# 创建一个Canvas,设置其背景色为白色


cv = Canvas(root,bg = 'white')




# 创建三个rectangle


rt1 = cv.create_rectangle(
10,10,110,110,
width = 8,
tags = ('r1','r2','r3'))
def printRect(event):
print 'rectangle'
def printLine(event):
print 'line'


# 绑定item与左键事件


cv.tag_bind('r1','<Button-1>',printRect)

# 绑定item与右键事件


cv.tag_bind('r1','<Button-3>',printLine)
cv.pack()
root.mainloop()

# 只有点击到矩形的边框时才会触发事件,不使用add参数,默认就是向这个item添加一个处理函数,它不会替换原来的事件函数,例子结果:既响应左键又响应右键


'''21.绑定新的item与现有的tags'''


# -*- coding: cp936 -*-


# 使用tag_bind来绑定item与事件,测试结果与参考上的说法不一致


from Tkinter import *
root = Tk()


# 创建一个Canvas,设置其背景色为白色


cv = Canvas(root,bg = 'white')


# 创建三个rectangle


rt1 = cv.create_rectangle(
10,10,110,110,
width = 8,
tags = ('r1','r2','r3'))
def printRect(event):
print 'rectangle'
def printLine(event):
print 'line'


# 绑定item与左键事件


cv.tag_bind('r1','<Button-1>',printRect)


# 绑定item与右键事件


cv.tag_bind('r1','<Button-3>',printLine)


# 创建一个line,并将其tags设置为'r1'


cv.create_line(10,200,100,200,width = 5,tags = 'r1')
cv.pack()
root.mainloop()


# 将事件与tag('r1')绑定后,创建新的item并指定已绑定事件的tag,新创建的item同样也与事件绑定,这个与参考上的说法也不一致

以上就是Tkinter教程之Canvas篇(3)的内容,更多相关内容请关注微课江湖()!

您可能想查找下面的文章:

  • Tkinter教程之Canvas篇(4)
  • Tkinter教程之Canvas篇(3)
  • Tkinter教程之Canvas篇(2)

相关文章

  • 2018-12-03H5怎样做出图片拖拽上传预览组件
  • 2018-12-03HTML5 本地存储和内容按需加载的思路和方法_html5教程技巧
  • 2018-12-03解析HTML5 geolocation的实例教程
  • 2018-12-03详解HTML5中的拖放事件(Drag 和 drop)
  • 2018-12-03H5实现上传本地图片并能够预览的功能代码
  • 2018-12-03HTML5幻灯片系统:H5Slides
  • 2018-12-03网络视频直播系统开发需要用到哪方面的知识?
  • 2017-08-06HTML5中div、article、section的区别及使用介绍
  • 2018-12-03ECharts-基于HTML5 Canvas的JavaScript图表库图文详解
  • 2018-12-03html5 worker 实例(二) 图片变换效果_html5教程技巧

文章分类

  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure

最近更新的内容

    • HTML5新特性之跨文档消息传输详解
    • HTML5实战与剖析之媒体元素(2、媒体元素的属性)
    • HTML5实践-使用CSS3 Media Queries实现响应式设计的代码分享
    • 三个不常见的 HTML5 实用新特性简介
    • HTML5+CSS3实现机器猫
    • HTML5晃动DeviceMotionEvent事件
    • HTML5边玩边学(八)-砖块贴图点阵字
    • 谈一谈HTML5本地存储技术_html5教程技巧
    • HTML5断点续上传的示例代码分享
    • html5使用canvas绘制文字特效_html5教程技巧

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有