1、什么是GUI

在这里插入图片描述
在这里插入图片描述


2、常用的GUI框架

在这里插入图片描述
在这里插入图片描述
官方网址:https://www.wxpython.org

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述


3、安装wxPython

步骤:
1、cmd窗口,执行命令:pip install -U wxpython
在这里插入图片描述
解决问题,执行一条命令:

pip install -i https://pypi.doubanio.com/simple/ --trusted-host pypi.doubanio.com wxpython

在这里插入图片描述
执行一条命令:

python -m pip install  --upgrade pip

在这里插入图片描述
安装ok


接下来,在复制一行代码:

import wx; a=wx.App(); wx.Frame(None, title="Hello World").Show(); a.MainLoop()

在这里插入图片描述
打开:Python-shell
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述


4、创建一个wx.app的子类

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
具体代码实现:

# -*- coding:utf-8 -*-
import wx 			# 导入wxPython
class App(wx.App):
    # 初始化方法
    def OnInit(self):
        frame = wx.Frame(parent=None, title='Hello wyPython') # 创建窗口
        frame.Show() # 显示窗口
        return True  # 返回值

if __name__ == '__main__':
    app = App()     # 创建App类的实例
    app.MainLoop()  # 调用App类的MainLoop()主循环方法

运行程序后,调出效果图:
在这里插入图片描述


5、直接使用wx.App

具体代码实现:

# -*- coding:utf-8 -*-
import wx            # 导入wxPython
app   = wx.App()     # 初始化wx.App类
frame = wx.Frame(None,title='Hello wyPython')  # 定义了一个顶级窗口
frame.Show()         # 显示窗口
app.MainLoop()       # 调用wx.App类的MainLoop()主循环方法

运行程序后,调出效果图:

若已经存在的窗口就可以直接创建:
在这里插入图片描述


6、使用wx.Frame框架

在这里插入图片描述
具体代码实现:

# -*- coding:utf-8 -*-
import wx   # 导入wxPython
class MyFrame(wx.Frame):
    def __init__(self,parent,id):
        wx.Frame.__init__(self,parent,id, title="创建Frame",pos=(100, 100), size=(300, 300))

if __name__ == '__main__':
    app = wx.App()  	                    # 初始化应用
    frame = MyFrame(parent=None,id=-1)  # 实例MyFrame类,并传递参数
    frame.Show()                        # 显示窗口
    app.MainLoop()                      # 调用MainLoop()主循环方法

运行程序后,调出效果图:
在这里插入图片描述
在这里插入图片描述


7、常用控件

在这里插入图片描述
具体代码实现:

# -*- coding:utf-8 -*-
import wx
class MyFrame(wx.Frame):
    def __init__(self,parent,id):
        wx.Frame.__init__(self, parent, id, title = "创建StaticText类",
                           pos=(100, 100), size=(600, 400))
        panel = wx.Panel(self) # 创建画板
        # 创建标题,并设置字体
        title = wx.StaticText(panel, label='Python之禅——Tim Peters',pos=(100,20))
        font  = wx.Font(16, wx.DEFAULT, wx.FONTSTYLE_NORMAL, wx.NORMAL)
        title.SetFont(font)
        # 创建文本
        wx.StaticText(panel, label='优美胜于丑陋',pos=(50,50))
        wx.StaticText(panel, label='明了胜于晦涩',pos=(50,70))
        wx.StaticText(panel, label='简洁胜于复杂',pos=(50,90))
        wx.StaticText(panel, label='复杂胜于凌乱',pos=(50,110))
        wx.StaticText(panel, label='扁平胜于嵌套',pos=(50,130))
        wx.StaticText(panel, label='间隔胜于紧凑',pos=(50,150))
        wx.StaticText(panel, label='可读性很重要',pos=(50,170))
        wx.StaticText(panel, label='即便假借特例的实用性之名,也不可违背这些规则',pos=(50,190))
        wx.StaticText(panel, label='不要包容所有错误,除非你确定需要这样做',pos=(50,210))
        wx.StaticText(panel, label='当存在多种可能,不要尝试去猜测',pos=(50,230))
        wx.StaticText(panel, label='而是尽量找一种,最好是唯一一种明显的解决方案',pos=(50,250))
        wx.StaticText(panel, label='虽然这并不容易,因为你不是 Python 之父',pos=(50,270))
        wx.StaticText(panel, label='做也许好过不做,但不假思索就动手还不如不做',pos=(50,290))
        wx.StaticText(panel, label='如果你无法向人描述你的方案,那肯定不是一个好方案;反之亦然',pos=(50,310))
        wx.StaticText(panel, label='命名空间是一种绝妙的理念,我们应当多加利用',pos=(50,330))

if __name__ == '__main__':
    app = wx.App()                      # 初始化应用
    frame = MyFrame(parent=None,id=-1)  # 实例MyFrame类,并传递参数   
    frame.Show()                        # 显示窗口
    app.MainLoop()                      # 调用主循环方法

运行程序后,调出效果图:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
具体代码实现:

# -*- coding:utf-8 -*-
import wx
class MyFrame(wx.Frame):
    def __init__(self,parent,id):
        wx.Frame.__init__(self, parent,id, title="创建TextCtrl类",size=(400, 300))
        #创建面板
        panel = wx.Panel(self)
        # 创建文本和输入框
        self.title = wx.StaticText(panel ,label="请输入用户名和密码",pos=(140,20))
        self.label_user = wx.StaticText(panel,label="用户名:",pos=(50,50) )
        self.text_user = wx.TextCtrl(panel,pos=(100,50),size=(235,25),style=wx.TE_LEFT)
        self.label_pwd = wx.StaticText(panel,pos=(50,90),label="密   码:")
        self.text_password = wx.TextCtrl(panel,pos=(100,90),size=(235,25),style=wx.TE_PASSWORD)

if __name__ == '__main__':        
    app = wx.App()                      # 初始化应用
    frame = MyFrame(parent=None,id=-1)  # 实例MyFrame类,并传递参数
    frame.Show()                        # 显示窗口
    app.MainLoop()                      # 调用主循环方法

运行程序后,调出效果图:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
具体代码实现:

# -*- coding:utf-8 -*-
import wx
class MyFrame(wx.Frame):
    def __init__(self,parent,id):
        wx.Frame.__init__(self, parent,id, title="创建TextCtrl类",size=(400, 300))
        #创建面板
        panel = wx.Panel(self)
        # 创建文本和密码输入框
        self.title = wx.StaticText(panel ,label="请输入用户名和密码",pos=(140,20))
        self.label_user = wx.StaticText(panel,label="用户名:",pos=(50,50) )
        self.text_user = wx.TextCtrl(panel,pos=(100,50),size=(235,25),style=wx.TE_LEFT)
        self.label_pwd = wx.StaticText(panel,pos=(50,90),label="密   码:")
        self.text_password = wx.TextCtrl(panel,pos=(100,90),size=(235,25),style=wx.TE_PASSWORD)
        #创建“确定”和“取消”按钮
        self.bt_confirm = wx.Button(panel,label='确定',pos=(105,130))
        self.bt_cancel  = wx.Button(panel,label='取消',pos=(195,130))

if __name__ == '__main__':
    app = wx.App()                      # 初始化
    frame = MyFrame(parent=None,id=-1)  # 实例MyFrame类,并传递参数
    frame.Show()                        # 显示窗口
    app.MainLoop()                      # 调用主循环方法

运行程序后,调出效果图:

在这里插入图片描述


8、BoxSizer布局

Sizer布局
在这里插入图片描述
什么是BoxSizer
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
具体代码实现:

# -*- coding:utf-8 -*-
import wx
class MyFrame(wx.Frame):
    def __init__(self, parent, id):
        wx.Frame.__init__(self, parent, id, '用户登录', size = (400, 300))
        #创建面板
        panel = wx.Panel(self)
        self.title = wx.StaticText(panel ,label="请输入用户名和密码")
        #添加容器,容器中控件按纵向排列
        vsizer = wx.BoxSizer(wx.VERTICAL)
        vsizer.Add(self.title,proportion=0,flag=wx.BOTTOM|wx.TOP|wx.ALIGN_CENTER, border = 15 )
        panel.SetSizer(vsizer)
if __name__ == '__main__':
    app = wx.App()                      # 初始化
    frame = MyFrame(parent=None,id=-1)  # 实例MyFrame类,并传递参数
    frame.Show()                        # 显示窗口
    app.MainLoop()                      # 调用主循环方法

运行程序后,弹出效果图:
在这里插入图片描述


9、事件处理

在这里插入图片描述
绑定事件
在这里插入图片描述
在这里插入图片描述
具体代码实现:

# -*- coding:utf-8 -*-
import wx

class MyFrame(wx.Frame):
    def __init__(self, parent, id):
        wx.Frame.__init__(self, parent, id, '用户登录', size=(400, 300))
        # 创建面板
        panel = wx.Panel(self)

        # 创建“确定”和“取消”按钮,并绑定事件
        self.bt_confirm = wx.Button(panel, label='确定')
        self.bt_confirm.Bind(wx.EVT_BUTTON, self.OnclickSubmit)
        self.bt_cancel = wx.Button(panel, label='取消')
        self.bt_cancel.Bind(wx.EVT_BUTTON, self.OnclickCancel)
        # 创建文本,左对齐
        self.title = wx.StaticText(panel, label="请输入用户名和密码")
        self.label_user = wx.StaticText(panel, label="用户名:")
        self.text_user = wx.TextCtrl(panel, style=wx.TE_LEFT)
        self.label_pwd = wx.StaticText(panel, label="密   码:")
        self.text_password = wx.TextCtrl(panel, style=wx.TE_PASSWORD)
        # 添加容器,容器中控件横向排列
        hsizer_user = wx.BoxSizer(wx.HORIZONTAL)
        hsizer_user.Add(self.label_user, proportion=0, flag=wx.ALL, border=5)
        hsizer_user.Add(self.text_user, proportion=1, flag=wx.ALL, border=5)
        hsizer_pwd = wx.BoxSizer(wx.HORIZONTAL)
        hsizer_pwd.Add(self.label_pwd, proportion=0, flag=wx.ALL, border=5)
        hsizer_pwd.Add(self.text_password, proportion=1, flag=wx.ALL, border=5)
        hsizer_button = wx.BoxSizer(wx.HORIZONTAL)
        hsizer_button.Add(self.bt_confirm, proportion=0, flag=wx.ALIGN_CENTER, border=5)
        hsizer_button.Add(self.bt_cancel, proportion=0, flag=wx.ALIGN_CENTER, border=5)
        # 添加容器,容器中控件纵向排列
        vsizer_all = wx.BoxSizer(wx.VERTICAL)
        vsizer_all.Add(self.title, proportion=0, flag=wx.BOTTOM | wx.TOP | wx.ALIGN_CENTER,
                        border=15)
        vsizer_all.Add(hsizer_user, proportion=0, flag=wx.EXPAND | wx.LEFT | wx.RIGHT, border=45)
        vsizer_all.Add(hsizer_pwd, proportion=0, flag=wx.EXPAND | wx.LEFT | wx.RIGHT, border=45)
        vsizer_all.Add(hsizer_button, proportion=0, flag=wx.ALIGN_CENTER | wx.TOP, border=15)
        panel.SetSizer(vsizer_all)
    def OnclickSubmit(self,event):
        """ 单击确定按钮,执行方法 """
        message = ""
        username = self.text_user.GetValue()     # 获取输入的用户名
        password = self.text_password.GetValue() # 获取输入的密码
        if username == "" or password == "" :    # 判断用户名或密码是否为空
            message = '用户名或密码不能为空'
        elif username =='mr' and password =='mrsoft': # 用户名和密码正确
            message = '登录成功'
        else:
            message = '用户名和密码不匹配'            # 用户名或密码错误
        wx.MessageBox(message)                        # 弹出提示框

    def OnclickCancel(self,event):
        """ 单击取消按钮,执行方法 """
        self.text_user.SetValue("")     # 清空输入的用户名
        self.text_password.SetValue("") # 清空输入的密码


if __name__ == '__main__':
    app = wx.App()                      # 初始化
    frame = MyFrame(parent=None,id=-1)  # 实例化MyFrame类,并传递参数
    frame.Show()                        # 显示窗口
    app.MainLoop()                      # 调用主循环方法

运行程序后,弹出效果图:
在这里插入图片描述

Logo

CSDN联合极客时间,共同打造面向开发者的精品内容学习社区,助力成长!

更多推荐