会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 132359个问题
Python 全系列/第二阶段:Python 深入与提高/游戏开发-坦克大战 830楼
Python 全系列/第二阶段:Python 深入与提高/文件处理 832楼

"""开发画图软件的菜单"""

from tkinter.colorchooser import *
from tkinter import *

# 窗口的宽度和高度
win_width = 900
win_height = 450


class Application(Frame):

    def __init__(self, master=None):
        super().__init__(master)
        self.master = master
        self.bgcolor = "#000000"
        self.x = 0
        self.y = 0
        self.fgcolor = "#ff0000"
        self.lastDraw = 0  # 表示最后绘制的图形的id
        self.startDrawFlag = False
        self.pack()
        self.createWidget()

    def createWidget(self):
        # 创建绘图区
        self.drawpad = Canvas(root, width=win_width, height=win_height * 0.9, bg=self.bgcolor)
        self.drawpad.pack()

        # 创建按钮
        btn_start = Button(root, text="开始", name="start")
        btn_start.pack(side="left", padx="10")
        btn_pen = Button(root, text="笔画", name="pen")
        btn_pen.pack(side="left", padx="10")
        btn_rect = Button(root, text="矩形", name="rect")
        btn_rect.pack(side="left", padx="10")
        btn_clear = Button(root, text="清屏", name="clear")
        btn_clear.pack(side="left", padx="10")
        btn_erasor = Button(root, text="橡皮擦", name="erasor")
        btn_erasor.pack(side="left", padx="10")
        btn_line = Button(root, text="直线", name="line")
        btn_line.pack(side="left", padx="10")
        btn_lineArrow = Button(root, text="箭头直线", name="lineArrow")
        btn_lineArrow.pack(side="left", padx="10")
        btn_color = Button(root, text="颜色", name="color")
        btn_color.pack(side="left", padx="10")

        # 事件处理
        btn_pen.bind_class("<ButtonRelease-1>", self.eventManager)
        self.drawpad.bind("<ButtonRelease-1>", self.stopDraw)

        # 增加颜色切换快捷键处理
        root.bind("<KeyPress-r>", self.kuaijiejian)
        root.bind("<KeyPress-g>", self.kuaijiejian)
        root.bind("<KeyPress-y>", self.kuaijiejian)

    def eventManager(self, event):
        name = event.widget.winfo_name()
        print(name)
        if name == "line":
            self.drawpad.bind("<B1-Motion>", self.myline)
        elif name == "lineArrow":
            self.drawpad.bind("<B1-Motion>", self.mylineArrow)

        elif name == "rect":
            self.drawpad.bind("<B1-Motion>", self.myRect)

        elif name == "pen":
            self.drawpad.bind("<B1-Motion>", self.myPen)

        elif name == "erasor":
            self.drawpad.bind("<B1-Motion>", self.myErasor)

        elif name == "clear":
            self.drawpad.delete("all")

        elif name == "color":
            c = askcolor(color=self.fgcolor, title="选择笔画颜色")
            self.fgcolor = c[1]

    def stopDraw(self, event):
        self.startDrawFlag = False
        self.lastDraw = 0

    def startDraw(self, event):
        self.drawpad.delete(self.lastDraw)

        if not self.startDrawFlag:
            self.startDrawFlag = True
            self.x = event.x
            self.y = event.y

    def myline(self, event):
        self.startDraw(event)
        self.lastDraw = self.drawpad.create_line(self.x, self.y, event.x, event.y, fill=self.fgcolor)

    def mylineArrow(self, event):
        self.startDraw(event)
        self.lastDraw = self.drawpad.create_line(self.x, self.y, event.x, event.y, arrow=LAST, fill=self.fgcolor)

    def myRect(self, event):
        self.startDraw(event)
        self.lastDraw = self.drawpad.create_rectangle(self.x, self.y, event.x, event.y, outline=self.fgcolor)

    def myPen(self, event):
        self.startDraw(event)
        self.drawpad.create_line(self.x, self.y, event.x, event.y, fill=self.fgcolor)
        self.x = event.x
        self.y = event.y

    def myErasor(self, event):
        self.startDraw(event)
        self.drawpad.create_rectangle(event.x-4, event.y-4, event.x+4, event.y+4, fill=self.bgcolor)
        self.x = event.x
        self.y = event.y

    def kuaijiejian(self, event):
        if event.char == "r":
            self.fgcolor = "#ff0000"
        elif event.char == "g":
            self.fgcolor = "#00ff00"
        elif event.char == "y":
            self.fgcolor = "#ffff00"


if __name__ == '__main__':
    root = Tk()
    root.geometry(str(win_width) + "x" + str(win_height) + "+200+300")
    root.title("画图软件项目")
    app = Application(master=root)
    root.mainloop()

老师,这代码能运行,但是,点击组件按钮画画,没反映,可能事件获取有问题,还是什么的?

Python 全系列/第二阶段:Python 深入与提高/GUI编程(隐藏) 833楼
Python 全系列/第二阶段:Python 深入与提高/文件处理 836楼

339a3d07e37790df0dadd52b3c27ada.png

老师,我这个怎么没有webChubby啊

Python 全系列/第二阶段:Python 深入与提高/模块 838楼
Python 全系列/第二阶段:Python 深入与提高/模块 839楼

from tkinter import *
# from tkinter import messagebox
import webbrowser
class Application(Frame):
    def __init__(self,master=None):
        super().__init__(master)   #super代表父类的定义,而不是父类的对象
        self.master=master
        self.pack()
        self.createWidget()

    def createWidget(self):
        self.w1=Text(root,width=40,height=12,bg="gray")
        # 宽度20个字母(10个汉字),高度一个行高
        self.w1.pack()
        self.w1.insert(1.0,"0123456789\nabcdefg")
        self.w1.insert(2.3,"锄禾日当午,汗滴禾下土。谁知盘中餐,粒粒皆辛苦\n")
        Button(self, text="重复插入文本",command=self.insertText).pack(side="left")
        Button(self, text="返回文本",command=self.returnText).pack(side="left")
        Button(self, text="添加图片",command=self.addImage).pack(side="left")
        Button(self, text="添加组件",command=self.addWidget).pack(sode="left")
        Button(self, text="通过tag精确控制文本",command=self.testTag).pack(side="left")

    def insertText(self):
        # Insert索引表示在光标处插入
        self.w1.insert(INSERT,"Gaoqi")
        #End索引号所以表示在最后插入
        self.w1.insert(END,"[sxt]")
        self.w1.insert(1.8, "gaoqi")

    def returnText(self):
        # Indexes(索引)是用来指向Text组件中文本的位置,Text的组件索引也是对应实际字符之间的位置
        # 核心:行号以1开始,列号以0开始
        print(self.w1.get(1.2,1.6))
        print("所有文本内容:\n"+self.w1.get(1.0,END))

    def addImage(self):
        # global photo
        self.photo=PhotoImage(file="imgs/logo1.png")
        self.w1.image_create(END,image=self.photo)

    def addWidget(self):
        b1=Button(self.w1,text="尚学堂")
        # 在text创建组件的命令
        self.w1.window_create(INSERT,window=b1)

    def textTag(self):
        self.w1.delete(1.0,END)
        self.w1.insert(INSERT,"good good good study,day day up\n北京尚学堂\n百战程序员\n希望2020年会心想事成")
        self.w1.tag_add("good", 1.0, 1.9)
        self.w1.tag_config("good", background="yellow", foreground="red")
        self.w1.tag_add("baidu",4.0,4.2)
        self.w1.tag_config("baidu",underline=True)
        self.w1.tag_bind("baidu","<Button-1>",self.webshow)
    def webshow(self,event):
        webbrowser.open("http://www.baidu.com")

if __name__ == "__main__":
    root = Tk()
    root.geometry("400x130+200+300")
    #root.title("一个经典的GUI程序类的测试")
    app=Application(master=root)
    root.mainloop()

Traceback (most recent call last):

  File "D:\AAAAAAAAApython\gui\my05.py", line 62, in <module>

    app=Application(master=root)

  File "D:\AAAAAAAAApython\gui\my05.py", line 10, in __init__

    self.createWidget()

  File "D:\AAAAAAAAApython\gui\my05.py", line 21, in createWidget

    Button(self, text="添加组件",command=self.addWidget).pack(sode="left")

  File "D:\lib\tkinter\__init__.py", line 2425, in pack_configure

    self.tk.call(

_tkinter.TclError: bad option "-sode": must be -after, -anchor, -before, -expand, -fill, -in, -ipadx, -ipady, -padx, -pady, or -side

老师我为什么报这么错啊

Python 全系列/第二阶段:Python 深入与提高/GUI编程(隐藏) 840楼

课程分类

百战程序员微信公众号

百战程序员微信小程序

©2014-2025百战汇智(北京)科技有限公司 All Rights Reserved 北京亦庄经济开发区科创十四街 赛蒂国际工业园
网站维护:百战汇智(北京)科技有限公司
京公网安备 11011402011233号    京ICP备18060230号-3    营业执照    经营许可证:京B2-20212637