专栏首页灰小猿技术社区Python实战之tkinter库画图,用canver画布教你画卡通人物!

Python实战之tkinter库画图,用canver画布教你画卡通人物!

我们知道Python之所以强大,很大一方面都是因为它具有很多强大的第三方库。

而且Python很突出的一方面就是代码用户交互界面的实现,这一点在Python上也被称作GUI编程。

与此同时,Python的GUI编程最常用的库就是tkinter,它包含了很多Python交互界面编程所需要的函数。

最近就有一个客户需求在GUI界面实现卡通人物的点击动作,那么今天我就来和大家分享一个在tkinter库中使用画布绘制会动的哆啦A梦的一个骚操作。

tkinter库画图基本思路

在使用Python的tkinter库进行界面绘图时,必须要用到的就是设置Canvas画布,熟悉tkinter库的小伙伴应该都知道这个函数。

在设置好画布之后,就是我们的程序员大画家施展才艺的时候了,在这里呢大灰狼给小伙伴一个小小的建议,就是在进行Canvas绘画之前呢。

可以先根据画布的位置设置一个x、y轴的坐标中心,这样做的目的呢就是在使用代码作图的时候,方便根据坐标参数进行图形界面的布局设置,设置坐标轴的具体代码如下:

画虚线

   line1 = w.create_line(0,200,400,200,fill="black",dash=(4,4))    #设置横向坐标线

    line2 = w.create_line(200,0,200,400,fill="black",dash=(4,4))    #设置纵向坐标线

设置好坐标轴之后就是开始哆啦A梦的大作了。

其实使用编程语言进行图形的绘制,大多数都是使用规则或不规则的图形组装拼接而成的

它就好像我们小时候玩积木一样,我们要做的就是将不同的积木(代码绘制的图形)拼装成我们想要的图形就可以了。

因此图形的绘制问题,最主要的就是什么形状的图形在哪里放置的问题了。

那么下面大灰狼就来和大家分享一下哆啦A梦的卡通图怎么画:

定义画原始人物的函数

def bt1_age():

```python
 #画虚线

    line1 = w.create_line(0,200,400,200,fill="black",dash=(4,4))    #设置横向坐标线

    line2 = w.create_line(200,0,200,400,fill="black",dash=(4,4))    #设置纵向坐标线

    #画圆脸

    w.create_oval((125,70,275,220),fill = 'blue')

    #画圆脸

    w.create_oval((140,100,260,220),fill = 'white')

    #画椭圆

    w.create_oval((200,80,230,120),fill = 'white')

    #画椭圆

    w.create_oval((170,80,200,120),fill = 'white')

    #画椭圆眼睛

    w.create_oval((203,92,215,108),fill = 'black')

    #画椭圆眼睛

    w.create_oval((185,92,197,108),fill = 'black')

    #画椭圆眼睛

    w.create_oval((206,95,212,105),fill = 'white')

    #画椭圆眼睛

    w.create_oval((188,95,194,105),fill = 'white')

    #画圆鼻子

    w.create_oval((193,115,207,130),fill = 'red')

    #嘴

    w.create_arc((140,60,260,180),style = 'arc',start = 240,extent = 60)#画弧线

    w.create_line(200,130,200,180,fill="black")#竖线

    #胡须

    w.create_line(215,150,245,150,fill="black")#横线

    w.create_line(155,150,185,150,fill="black")#横线

    w.create_line(158,127,185,137,fill="black")

    w.create_line(215,137,242,127,fill="black")

    w.create_line(158,170,185,163,fill="black")

    w.create_line(215,163,242,168,fill="black")

    #身体

    w.create_rectangle(150,200,250,285,fill="blue")     #身体正前方

    w.create_arc((160,190,240,270),style = 'chord',start = 135,extent = 270,fill = 'white')#画弧线

    w.create_line((150,200,250,200),fill="red",width = 10,capstyle = 'round')#圆滑轮廓线

    w.create_arc((185,270,215,300),style = 'chord',start = 0,extent = 180,fill = 'white')#画弧线

    w.create_line(185,285,215,285,fill="white")

    #画脚

    #画椭圆

    w.create_oval((140,275,190,295),fill = 'white')     #左脚

    w.create_oval((210,275,260,295),fill = 'white')     #右脚

    #画手

    w.create_polygon([150,205,150,235,120,250,120,235],outline="black",fill="blue")#手臂多边形

    w.create_polygon([250,205,250,235,280,250,280,235],outline="black",fill="blue")

    w.create_oval((110,230,135,255),fill = 'white')     #左圆形手掌

    w.create_oval((265,230,290,255),fill = 'white')     #右圆形手掌

    #画铃铛

    w.create_oval((190,200,210,220),fill = 'yellow')    #铃铛中心圆

    w.create_line((191,210,209,210),fill="black",width = 5,capstyle = 'round')#圆滑轮廓线

    w.create_line((192,210,208,210),fill="yellow",width = 3,capstyle = 'round')#圆滑轮廓线

    w.create_oval((198,213,202,217),fill = 'red')   #中心小红点

    w.create_line(200,218,200,220,fill="black")

    #画口袋

    w.create_arc((170,200,230,260),style = 'chord',start = 180,extent = 180,fill = 'white')#画弧线

以上这些呢就是定义哆啦A梦函数的基本操作了,那么接下来就是让哆啦A梦实现各种工作。

其实卡通人物每一个动作的实现其实是一幅全新的图画,通过多个这样图画函数,在点击触发某个动作的按钮时,调用该函数的图画即可。

那么接下来大灰狼来和大家分享几个有趣的动作变化。

点击眨眼

点击眨眼的函数大部分与定义哆啦A梦的函数相同,既然是眨眼的动作,那么最大的区别就是在眼睛上了,

因此在定义了眨眼函数之后,只需要眼部代码换成下方的闭眼代码就可以了, 闭眼动作代码

#闭左眼
    w.create_line((185, 100, 195, 105), fill='black')   #闭左眼
    w.create_line((185, 105, 195, 105), fill='black')   #闭左眼
    w.create_line((185, 110, 195, 105), fill='black')   #闭左眼

    #闭右眼
    w.create_line((205, 105, 215, 100), fill='black')   #闭右眼
    w.create_line((205, 105, 215, 105), fill='black')   #闭右眼
    w.create_line((205, 105, 215, 110), fill='black')   #闭右眼

运动四肢

运动四肢的函数相对较复杂,因为需要实现手臂和双腿的同时运动,因此需要修改手臂代码和哆啦A梦的身体部分,具体的实现代码如下: 修改参数实现四肢运动

  w.create_rectangle(150,200,250,285,fill="blue")     #身体正前方

    w.create_arc((160,190,240,270),style = 'chord',start = 135,extent = 270,fill = 'white')#画弧线

    w.create_line((150,200,250,200),fill="red",width = 10,capstyle = 'round')#圆滑轮廓线

    w.create_arc((170,270,230,300),style = 'chord',start = 0,extent = 180,fill = 'white', outline = 'white')#画弧线使双腿张开

    w.create_line(185,285,215,285,fill="white")

    #画脚

    #画椭圆

    w.create_oval((130,275,170,295),fill = 'white')

    w.create_oval((230,275,270,295),fill = 'white')

下面部分是修改实现手臂运动的代码修改: 修改参数实现四肢运动

 w.create_rectangle(150,200,250,285,fill="blue")     #身体正前方

    w.create_arc((160,190,240,270),style = 'chord',start = 135,extent = 270,fill = 'white')#画弧线

    w.create_line((150,200,250,200),fill="red",width = 10,capstyle = 'round')#圆滑轮廓线

    w.create_arc((170,270,230,300),style = 'chord',start = 0,extent = 180,fill = 'white', outline = 'white')#画弧线使双腿张开

    w.create_line(185,285,215,285,fill="white")

    #画脚

    #画椭圆

    w.create_oval((130,275,170,295),fill = 'white')

    w.create_oval((230,275,270,295),fill = 'white')

色彩变化

看过哆啦A梦的小伙伴应该都知道哆啦A梦还有一个妹妹----一只黄色的哆啦A梦。

那么我们只需要修改部分代码就可以实现哆啦A梦的色彩变化了,在这里我们只需要将在进行绘制时所有的调用‘blue’的代码换成调用‘yellow’色彩即可,同样我们也可以根据自己的爱好绘制其他不同的色彩。

这样我们的哆啦A梦以及实现的各种不同的动作变化的函数就已经定义完成了,总结一下就是在画布定义不同的图形函数,根据需要依次调用函数即可!

完整的代码可以在https://download.csdn.net/download/weixin_44985880/12367814下载, * 或者关注微信公众号“灰狼洞主”回复 ‘哆啦A梦’即可获取GUI编程的哆啦A梦完整代码!*

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • Python搭建脚本环境,配置path环境变量设置超详细步骤

    大多数刚开始学习编程的小伙伴都需要一个从学习程序到运行调试的过程,而其中所编写的程序大部分都是在固定的开发环境下所运行的,

    灰小猿
  • Java文本框内文字显示不同颜色、字号等属性【函数调用一键实现】

    最近在做聊天室相关项目的开发的时候,需要对文本框中的字体进行区别显示,但是由于JTextArea文本框属于纯文本形式的,无法对其中的文本进行不同格式的显示,所以...

    灰小猿
  • C#索引器的实现、索引器和属性的异同对比,这些技能你get到了嘛?

    最近在用C#做开发的时候要用到索引函数,所以今天就在这里和小伙伴记录一下C#中索引器的实现。

    灰小猿
  • Linux下2号进程的kthreadd--Linux进程的管理与调度(七)

    内核初始化rest_init函数中,由进程 0 (swapper 进程)创建了两个process

    233333
  • Salesforce Distributed Marketing赋能每个人数字营销能力

    上一篇文章介绍了Salesforce Marketing Cloud的最新更新功能,其中一个功能是Distributed Marketing quick sen...

    臭豆腐
  • javascript和jquary的ajax请求

    ajax全称 Asynchronous JavaScript and XML(异步的JavaScript和XML)。不是一门新技术,是html,css,js,或...

    微醺
  • Go - 函数

    新亮
  • 「r」dplyr 里的 join 与 base 里的 merge 存在差异

    今天在使用连接操作时发现:虽然都是合并操作函数,dplyr 包里的 *_join() 和基础包里面的 merge() 存在差异,不同的数据结构,结果也会存在偏差...

    王诗翔呀
  • 美团外卖Flutter动态化实践

    动态化是 Flutter 无法避开的话题。本文从 Flutter 的特点讲起, 阐述了美团外卖团队在整个 Flutter 动态化上探索的心路历程,还有设计理念、...

    美团技术团队
  • php常见的判断函数

    一、文件、目录 1、is_file();//文件是否存在 2、is_dir();//目录是否存在 二、函数、类、接口 1、function_exists();/...

    joshua317

扫码关注云+社区

领取腾讯云代金券