Python -- GUI图形界面编程—GUI编程实例 博主也在持续学习中[ 持续更新中!!! 欢迎白嫖 ]

 本文继上篇文章http://t.csdnimg.cn/mJlmW继续介绍GUI的图形界面编程(相关视频是哔站上的应该搜这个题目就能找到),文章还是很基础的,目前博主处于有一点基础的状态。

        文章的主要介绍了依旧非常重要的结构tinkter库、常见的三种布局管理器:Grid布局管理器、pack布局管理器、Place布局管理器;还有相关的小练习。依旧是很多代码部分是重复的,因为框架是固定的,跟着敲两遍就记住了,还是要动手。

感谢大佬持续支持!!既然路过就是缘分,点个赞吧!!

目录

12. Grid布局管理器详解

13. 计算器软件页面设计

14. pack布局管理器实现钢琴软件界面设计

15. Place布局管理器_绝对位置和相对位置

16. 扑克游戏界面设计_增加事件操作(练习place)

代码表示:

目录:


布局管理器简介:

tkinter提供了三种管理器:pack(组件的垂直或水平)、grid(表格布局【行和列 单元格】)、place(位置管理器,通过控制像素)

在Python中,特别是在使用图形用户界面(GUI)库如Tkinter、PyQt、PySide或Kivy时,布局管理器(Layout Managers)扮演着至关重要的角色。它们负责控制GUI组件(如按钮、文本框、标签等)的大小和位置,以确保用户界面在不同平台和屏幕尺寸上都能以一致且美观的方式呈现。

下面我将以Tkinter为例,详细解释几种常见的布局管理器,因为Tkinter是Python标准库的一部分,易于学习和使用。

### 1. Pack布局管理器

Pack布局管理器是最简单的布局管理器之一,它按照添加组件的顺序自动调整组件的位置和大小。默认情况下,它会将组件添加到容器的顶部,但你可以通过配置来改变方向(如`side=LEFT`、`side=RIGHT`等)。

```python
import tkinter as tk

root = tk.Tk()

button1 = tk.Button(root, text="Button 1")
button1.pack(side=tk.LEFT, padx=20, pady=20)

button2 = tk.Button(root, text="Button 2")
button2.pack(side=tk.RIGHT, padx=20, pady=20)

root.mainloop()
```

### 2. Grid布局管理器

Grid布局管理器将容器划分为一个二维的网格,你可以指定组件应该占据哪个网格位置(行和列)。Grid布局管理器非常适合需要表格或矩阵布局的场景。

```python
import tkinter as tk

root = tk.Tk()

label = tk.Label(root, text="Label")
label.grid(row=0, column=0, sticky=tk.W)

entry = tk.Entry(root)
entry.grid(row=0, column=1)

button = tk.Button(root, text="Submit")
button.grid(row=1, column=0, columnspan=2, sticky=tk.EW)

root.mainloop()
```

### 3. Place布局管理器

Place布局管理器提供了最大的灵活性,允许你通过指定组件的绝对位置(x和y坐标)和大小(宽度和高度)来放置组件。然而,这种灵活性也意味着你需要手动处理不同屏幕尺寸和分辨率的适配问题。

```python
import tkinter as tk

root = tk.Tk()

button1 = tk.Button(root, text="Button 1")
button1.place(x=50, y=50, width=100, height=50)

button2 = tk.Button(root, text="Button 2")
button2.place(x=160, y=50, width=100, height=50)

root.mainloop()
```

### 总结

- **Pack**:适合简单的垂直或水平布局。
- **Grid**:适合需要表格或矩阵布局的场景。
- **Place**:提供最大的灵活性,但需要手动处理不同屏幕尺寸的适配。

12. Grid布局管理器详解

代码表示:

import tkinter as tk
from tkinter import messagebox
​
class Application(tk.Frame):
    def __init__(self,master = None):
        super().__init__(master)
        self.master = master
        self.pack()
        self.createWidgets()
​
    def createWidgets(self):
        """通过grid布局实现登录页面"""
        self.label01 = tk.Label(self,text='用户名')
        self.label01.grid(row=0,column=0)
        self.entry01 = tk.Entry(self)
        self.entry01.grid(row=0,column=1)
        tk.Label(self,text='用户名为手机号').grid(row=0,column=2)
​
        tk.Label(self,text='密码').grid(row=1,column=0)
        tk.Entry(self,show='*').grid(row=1,column=1)
​
        tk.Button(self,text='登录').grid(row=2,column=1,sticky=tk.EW)
        tk.Button(self,text='取消').grid(row=2,column=2,sticky=tk.E)
​
​
if __name__ == '__main__':
    root = tk.Tk()      #创建根窗口对象
    root.geometry('400x200+200+200')
    app = Application(master=root)
    root.mainloop()         #事件循环

13. 计算器软件页面设计

# P13
from tkinter import *
from tkinter import messagebox
​
class Application(Frame):
    def __init__(self,master=None):
        super().__init__(master)
        self.master = master
        self.pack()
        self.createWidgets()
​
    def createWidgets(self):
        btnText = [['MC','M+','M-','MR'],
                   ['C','±','/','×'],
                   [7,8,9,'-'],
                   [4,5,6,'+'],
                   [1,2,3,'='],
                   [0,'.']]
​
        Entry(self).grid(row=0,column=0,columnspan=4,pady=10)       #跨列 外边框为10
​
        for rindex,r in enumerate(btnText):
            for cindex,c in enumerate(r):
                if c == '=':
                    Button(self,text=c,width=2)\
                    .grid(row=rindex+1,column=cindex,rowspan=2,sticky=NSEW)
                elif c == 0:
                    Button(self, text=c, width=2) \
                        .grid(row=rindex + 1, column=cindex, columnspan=2, sticky=NSEW)
                elif c == '.':
                    Button(self, text=c, width=2) \
                        .grid(row=rindex + 1, column=cindex+1, sticky=NSEW)
                else:
                    Button(self, text=c, width=2) \
                        .grid(row=rindex+1, column=cindex, sticky=NSEW)     #因为有一行是Entry,所以是rindex+1
​
​
if __name__ == '__main__':
    # 创建根窗口对象
    root = Tk()
    root.geometry('450x250-200+200')
    app = Application(master=root)
    root.mainloop()     #事件循环

14. pack布局管理器实现钢琴软件界面设计

对于一下了解看看就行,pack()只适用于简单的排布垂直水平情况

代码表示:

# P14
from tkinter import *
​
root=Tk()
root.geometry('700x220')
​
# Frame是一个矩形区域,就是用来方式其他子组件的容器
f1 = Frame(root);f1.pack()
f2 = Frame(root);f2.pack()
​
btnText= ('流行风','复古风','摇滚风','R&B','欧美风','中国风')
​
for txt in btnText:
    Button(f1,text=txt,).pack(side='left',padx='10')
​
for i in range(1,10):
    Label(f2,width=5,height=10,borderwidth=1,relief='solid',
           bg='black' if i%2==0 else'white').pack(side='left',padx=2)
root.mainloop()

15. Place布局管理器_绝对位置和相对位置

place布局管理器可以通过坐标精确控制组件的位置,适用于一些布局更加灵活的场景。

代码表示:

from tkinter import *
​
root = Tk()
root.geometry('600x300')
root.title('place布局管理')
root['bg'] = 'white'
​
f1 = Frame(root,width=200,height=200,bg='green')
f1.place(x=30,y=30)
​
Button(root,text='zmr').place(relx=0.2,x=100,y=20,relwidth=0.2,relheight=0.5)       #x方向上相对于父元素0.2+100
Button(f1,text='加油!').place(relx=0.6,rely=0.7)
Button(f1,text='相信自己,哦~~~~').place(relx=0.5,rely=0.2)
root.mainloop()

16. 扑克游戏界面设计_增加事件操作(练习place)

代码表示:
P16
from tkinter import *
from tkinter import messagebox
​
class Application(Frame):
    def __init__(self,master = None):
        super().__init__(master)
        self.master = master
        self.pack()
        self.createWidgets()
​
    def createWidgets(self):
        """通过place布局管理器实现扑克牌位置控制"""
        self.photos = [PhotoImage(file='img/img_'+str(i)+'.png') for i in range(7)]
        self.imges = [Label(self.master,image=self.photos[i]) for i in range(7)]
​
        for i in range(7):
            self.imges[i].place(x=10+i*60,y=50)
​
        # 为所有的Lable添加事件处理
        self.imges[0].bind_class('Label','<Button-1>',self.chupai)
​
    def chupai(self,event):
        print(event.widget.winfo_geometry())
        print(event.widget.winfo_y())
​
        if event.widget.winfo_y() == 50:
            event.widget.place(y=30)
        else:
            event.widget.place(y=50)
​
if __name__ == '__main__':
    root = Tk()      #创建根窗口对象
    root.geometry('750x600+200+200')
    app = Application(master=root)
    root.mainloop()         #事件循环
项目列表:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值