服务器之家

服务器之家 > 正文

Python库学习Tkinter制作GUI个性签名设计软件

时间:2022-01-11 00:39     来源/作者:朱小五是凹凸君呀

人生苦短,快学Python!

上一周发了一篇文章《Python Tkinter图形工具使用方法及实例解析》,很多小伙伴都希望能多出点教程,今天就来了。

Python库学习Tkinter制作GUI个性签名设计软件

 

Tkinter简介

由于Tkinter是Python自带的标准库,我们想要使用它的时候,只需直接导入即可。

from tkinter import *

Tkinter支持的组件有:

Python库学习Tkinter制作GUI个性签名设计软件

对于简单的图形界面 Tkinter 还是能应付自如,不过相对于PyQt5做出的界面不够美观,相对于Pysimplegui则显得代码太笨重。这两个库埋个坑,后面开一篇单独介绍。

今天的整体思路就是:先选择一个在线签名网站,找到接口模拟请求,然后将生成的签名图片下载到本地,最后显示在 Tkinter 生成的 GUI 窗口上。

 

获取个性签名图

在制作个性签名软件前,第一件事是先找到一个合适的网站,获取他们的接口。

为啥说要找合适的网站呢?

某搜索引擎 一搜"签名设计",那真的是花里胡哨啊,我的审美被一顿冲击。“乱花丛中”找了一圈,才挑到一个稍微正常一点的网站。

Python库学习Tkinter制作GUI个性签名设计软件

网站地址:http://www.yishuzi.com/b/13.htm

F12开发者模式,选择 Network。手动将配色调整为#000000黑色,背景调整为#FFFFFF白色,随便输入一个名字,点击生成。

非常轻松,就可以找到该网站生成签名发送的请求。如下所示:

Python库学习Tkinter制作GUI个性签名设计软件

废话不多说,直接上Python!

通过requests.post()请求该网址,并导入参数。

其中最重要的参数有两个: id对应的是带生成名字,id1对应的是艺术字体。

import requests
from urllib.request import urlretrieve
url = "http://www.yishuzi.com/b/re13.php"
d = requests.post(url, data={"id": "测试签名", "zhenbi": "20191123",
                             "id1": "904", "id2": "#FFFFFF", 
                             "id4": "#000000", "id6": "#000000"})
d.content.decode("utf-8")

可以看到,post()返回的是带有链接的字符串。

Python库学习Tkinter制作GUI个性签名设计软件

轻松就可以从返回的字符串中,提取到生成的增长的个性签名图片。然后用urlretrieve()下载图片到本地,最后将其封装为自定义函数。

def create_sign(word):
    url = "http://www.yishuzi.com/b/re13.php"
    d = requests.post(url, data={"id": word, "zhenbi": "20191123",
                                 "id1": "904", "id2": "#FFFFFF", "id4": "#000000", "id6": "#000000"})
    myurl = d.content.decode("utf-8").split(""")[1]
    urlretrieve(myurl, word + ".png")

后续在设计软件GUI界面时,直接调用这个函数,就可以直接生成个性签名了。

 

设计软件GUI界面

下载签名图片函数create_sign()已经创建好,工作实际就完成了一半。

剩下就是我们设计软件界面了,不妨先简单画个草图。

Python库学习Tkinter制作GUI个性签名设计软件

这里主要要用到:Label(标签控件)、Entry(输入控件)、 Button(按钮控件)、Frame(框架控件)以及选择字体时,需要用到的Combobox(下拉列表框)。

前面的控件都介绍过,具体看这一篇8000字,Tkinter详细使用教程!,这里只重点讲一下下拉列表框

 

下拉列表框

Python 窗体(Tkinter)下拉列表框Combobox。它是在Tkinter模块下的ttk模块的一个部件,产生的效果是一个下拉列表框,它是GUI当中的一个装饰(widget)。当用户点击下拉列表获取值的时候是从列表当中选取的,那么就会产生一个名为<<ComboboxSelected>>的虚拟事件。

其常见的几个参数有:

语法 作用
cv = tk.stringVar() 绑定变量
com = ttk.Combobox(root, textvariable=cv) 创建下拉框
com.pack() 放置下拉框
com[“value”] = (‘文本",文本") 设置下拉数据
com.current(索引) 设置默认值
demo = com.get() 变量接受值
com.bind("<>", 函数名) 下拉数据点击调用函数

简单用一个小例子帮助大家理解。

import tkinter
from tkinter import ttk
root = tkinter.Tk()
root.geometry("400x200") 
xVariable = tkinter.StringVar()   #创建变量
com = ttk.Combobox(root, textvariable=xVariable)  #创建下拉菜单
com.pack()     #将下拉菜单绑定到窗体
com["value"] = ("选项1", "选项2", "选项3", "选项4")
com.current(0)   #设定下拉菜单的默认值
root.mainloop()

运行后,效果如下所示。

Python库学习Tkinter制作GUI个性签名设计软件

这样我们再通过com.get(),就可以获取下拉框中,最后选择的值了。

 

设计界面

剩下的界面设计就简单多了,只需要将Label(标签控件)、Entry(输入控件)、 Button(按钮控件)、Frame(框架控件)、Combobox(下拉列表框)排列一下。

回想一下前面画的草图,开整!

Python库学习Tkinter制作GUI个性签名设计软件

规定窗口大小为600x400,再设置窗口的基本属性。

所有组件都采用place几何方法,将组件的大小及布局,进行合理的规划。同时,Button组件也都与其对应的功能函数create_sign(word),进行了链接。

部分代码如下所示,完整代码见文末。

root = Tk()
root.title("签名设计 by:快学Python")
root.geometry("600x400")
bg_image = PhotoImage(file = "background.png")
bg_label = Label(root, image = bg_image)
bg_label.place(relwidth = 1, relheight = 1)
frame = Frame(root, bg = "#edcc79", bd = 5)
frame.place(relx = 0.5, rely = 0.1, relwidth = 0.75, relheight = 0.1,anchor = "n")
font_label = Label(frame, text = "输入签名:", font = ("微软雅黑", 16), fg ="black")
font_label.place(relwidth = 0.25, relheight = 1)
name_entry = Entry(frame, font = ("微软雅黑", 16))

最终成品,展示一下。

Python库学习Tkinter制作GUI个性签名设计软件

输入名字,点击生成,一气呵成!不同风格,一键转换!

这样,我们就又完成了一个Tkinter实战小案例。

以上就是Python库学习Tkinter制作GUI个性签名设计软件的详细内容,更多关于Python库Tkinter制作GUI应用的资料请关注服务器之家其它相关文章!

原文链接:https://blog.csdn.net/zhuxiao5/article/details/120443687

相关文章

热门资讯

蜘蛛侠3英雄无归3正片免费播放 蜘蛛侠3在线观看免费高清完整
蜘蛛侠3英雄无归3正片免费播放 蜘蛛侠3在线观看免费高清完整 2021-08-24
yue是什么意思 网络流行语yue了是什么梗
yue是什么意思 网络流行语yue了是什么梗 2020-10-11
背刺什么意思 网络词语背刺是什么梗
背刺什么意思 网络词语背刺是什么梗 2020-05-22
2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全
2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全 2019-12-26
2021年耽改剧名单 2021要播出的59部耽改剧列表
2021年耽改剧名单 2021要播出的59部耽改剧列表 2021-03-05
返回顶部