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

  1. 老师请问我的代码错在哪里呢?怎么没能显示随机的5个坦克?


  2. """
    v1.08
        1.新增敌方坦克
        2.将敌方坦克展示到窗口中
    """
    import pygame,time,random
    _display = pygame.display
    COLOR_BLACK = pygame.Color(0, 0, 0)
    COLOR_RED = pygame.Color(255, 0, 0)
    version = 'v1.08'
    class MainGame():
        #游戏主窗口
        window = None
        SCREEN_HEIGHT = 500
        SCREEN_WIDTH = 800
        #创建我方坦克
        TANK_P1 = None
        # 存储所以敌方坦克
        EnemyTank_List=[]
        #要创建的坦克数量
        EnemyTank_count=5
        def __init__(self):
            pass
        #开始游戏方法
        def startGame(self):
            _display.init()
            #创建窗口加载窗口(借鉴官方文档)
            MainGame.window = _display.set_mode([MainGame.SCREEN_WIDTH,MainGame.SCREEN_HEIGHT])
            #创建我方坦克
            MainGame.TANK_P1 = Tank(400,300)
            #创建敌方坦克
            self.creatEnemyTank()
            #设置一下游戏标题
            _display.set_caption("坦克大战"+version)
            #让窗口持续刷新操作
            while True:
                #给窗口完成一个填充颜色
                MainGame.window.fill(COLOR_BLACK)
                #在循环中持续完成事件的获取
                self.getEvent()
                #将绘制文字得到的小画布,粘贴到窗口中
                MainGame.window.blit(self.getTextSurface("剩余敌方坦克%d辆"%5),(5,5))
                #将我方坦克加入到窗口中
                MainGame.TANK_P1.displayTank()
                #循环展示敌方坦克
                self.biltEnemyTank()
                #根据坦克的开关状态调用坦克的持续移动
                if MainGame.TANK_P1 and not MainGame.TANK_P1.stop :
                    MainGame.TANK_P1.move()
                time.sleep(0.02)
                #窗口的刷新
                _display.update()
        #创建敌方坦克
        def creatEnemyTank(self):
    
            top=100
            speed=random.randint(3,6)
            for i in range(MainGame.EnemyTank_count):
                left = random.randint(1, 7)
                eTank=EnemyTank(left*100,top,speed)
                MainGame.EnemyTank_List.append(eTank)
    
        #将坦克加入到窗口中
        def biltEnemyTank(self):
            for eTank in MainGame.EnemyTank_List:
                eTank.displayTank()
        #获取程序期间所有事件(鼠标事件,键盘事件)
        def getEvent(self):
            #1.获取所有事件
            eventList = pygame.event.get()
            #2.对事件进行判断处理(1、点击关闭按钮  2、按下键盘上的某个按键)
            for event in eventList:
                #判断event.type 是否QUIT,如果是退出的话,直接调用程序结束方法
                if event.type == pygame.QUIT:
                    self.endGame()
                #判断事件类型是否为按键按下,如果是,继续判断按键是哪一个按键,来进行对应的处理
                if event.type == pygame.KEYDOWN:
                    #具体是哪一个按键的处理
                    if event.key == pygame.K_LEFT:
                        print("坦克向左调头,移动")
                        #修改坦克方向
                        MainGame.TANK_P1.direction="L"
                        MainGame.TANK_P1.stop = False
                    elif event.key == pygame.K_RIGHT:
                        print("坦克向右调头,移动")
                        # 修改坦克方向
                        MainGame.TANK_P1.direction = "R"
                        MainGame.TANK_P1.stop = False
                    elif event.key == pygame.K_UP:
                        print("坦克向上调头,移动")
                        # 修改坦克方向
                        MainGame.TANK_P1.direction = "U"
                        MainGame.TANK_P1.stop = False
                    elif event.key == pygame.K_DOWN:
                        print("坦克向下掉头,移动")
                        # 修改坦克方向
                        MainGame.TANK_P1.direction = "D"
                        MainGame.TANK_P1.stop = False
                    elif event.key == pygame.K_SPACE:
                        print("发射子弹")
                if event.type == pygame.KEYUP:
                    if event.key ==pygame.K_LEFT or event.key == pygame.K_RIGHT or event.key ==pygame.K_DOWN or event.key == pygame.K_UP :
                        MainGame.TANK_P1.stop = True
    
    
                    #结束游戏方法
        #左上角文字绘制的功能
        def getTextSurface(self,text):
            # 初始化字体模块
            pygame.font.init()
            #查看系统支持的所有字体
            # fontList = pygame.font.get_fonts()
            # print(fontList)
            # 选中一个合适的字体
            font = pygame.font.SysFont('kaiti',18)
            # 使用对应的字符完成相关内容的绘制
            textSurface = font.render(text,True,COLOR_RED)
            return textSurface
        def endGame(self):
            print("谢谢使用")
            #结束python解释器
            exit()
    class Tank():
        def __init__(self,left,top):
            self.images = {
                'U':pygame.image.load('img/p1tankU.gif'),
                'D':pygame.image.load('img/p1tankD.gif'),
                'L':pygame.image.load('img/p1tankL.gif'),
                'R':pygame.image.load('img/p1tankR.gif')
            }
            self.direction = 'U'
            self.image = self.images[self.direction]
            #坦克所在的区域  Rect->
            self.rect = self.image.get_rect()
            #指定坦克初始化位置 分别距x,y轴的位置
            self.rect.left = left
            self.rect.top = top
            #坦克速度设定
            self.speed=5
            #新增属性,坦克的移动开关
            self.stop=True
        #坦克的移动方法
        def move(self):
            if self.direction == "L":
                if self.rect.left > 0:
                    self.rect.left -= self.speed
            elif self.direction =="R":
                if self.rect.left + self.rect.height < MainGame.SCREEN_WIDTH:
                    self.rect.left += self.speed
            elif self.direction =="U":
                if self.rect.top > 0:
                    self.rect.top -= self.speed
            elif self.direction == "D":
                if self.rect.top + self.rect.height <MainGame.SCREEN_HEIGHT:
                    self.rect.top += self.speed
        #射击方法
        def shot(self):
            pass
        #展示坦克(将坦克这个surface绘制到窗口中  blit())
        def displayTank(self):
            #1.重新设置坦克的图片
            self.image = self.images[self.direction]
            #2.将坦克加入到窗口中
            MainGame.window.blit(self.image,self.rect)
    
    class MyTank(Tank):
        def __init__(self):
            pass
    class EnemyTank(Tank):
        def __init__(self,left,top,speed):
            self.images = {
                'U': pygame.image.load('img/enemy1U.gif'),
                'D': pygame.image.load('img/enemy1D.gif'),
                'L': pygame.image.load('img/enemy1L.gif'),
                'R': pygame.image.load('img/enemy1R.gif')
            }
            self.direction = self.randDirection()
            self.image = self.images[self.direction]
            # 坦克所在的区域  Rect->
            self.rect = self.image.get_rect()
            # 指定坦克初始化位置 分别距x,y轴的位置
            self.rect.left = left
            self.rect.top = top
            # 坦克速度设定
            self.speed = speed
            # 新增属性,坦克的移动开关
            self.stop = True
        def randDirection(self):
            num=random.randint(1,4)
            if num == "1":
                return "U"
            elif num == "2":
                return "D"
            elif num == "3":
                return "L"
            elif num == "4":
                return "R"
    
    
    
    class Bullet():
        def __init__(self):
            pass
        #子弹的移动方法
        def move(self):
            pass
        #展示子弹的方法
        def displayBullet(self):
            pass
    class Explode():
        def __init__(self):
            pass
        #展示爆炸效果
        def diplayExplode(self):
            pass
    class Wall():
        def __init__(self):
            pass
        #展示墙壁的方法
        def displayWall(self):
            pass
    class Music():
        def __init__(self):
            pass
        #开始播放音乐
        def play(self):
            pass
    MainGame().startGame()

Python 全系列/第二阶段:Python 深入与提高/游戏开发-坦克大战 2268楼

'''
06新增功能:
加载我方坦克
'''

import pygame
_display = pygame.display
COLOR_BLACK = pygame.Color(0,0,0)
COLOR_RED = pygame.Color(255,0,0)
version = 'v1.06'
class MainGame():
    #游戏主窗口
    window = None
    SCREEN_HEIGHT = 500
    SCREEN_WIDTH = 800
    #创建我方坦克
    TANK_P1 = None
    def __init__(self):
        pass
    #开始游戏
    def startGame(self):
        _display.init()
        #创建窗口加载窗口
        MainGame.window = pygame.display.set_mode([MainGame.SCREEN_WIDTH,MainGame.SCREEN_HEIGHT])
        #创建我方坦克
        MainGame.TANK_P1 = Tank(400,300)
    #设置游戏标题
        _display.set_caption("坦克大战"+version)
        #让窗口持续刷新操作
        while True:
            #给窗口填充颜色
            MainGame.window.fill(COLOR_BLACK)
            #在循环中持续完成事件的获取
            self.getEvent()
            #将绘制文字得到的小画布 粘贴到窗口中
            MainGame.window.blit(self.getTextSurface("剩余敌方坦克%d辆"%5),(5,5))
            #将我方坦克加入到窗口中
            MainGame.TANK_P1.displayTank()
            #窗口刷新
            _display.update()
    #获取程序期间所有事件(鼠标事件,键盘事件)
    def getEvent(self):
        #获取所有事件
        eventList = pygame.event.get()
        #对事件进行判断处理(1 点击关闭按钮 2 按下键盘上的某个按键)
        for event in eventList:
            #判断event.type是否OUIT,如果是退出 直接调用程序结束方法
            if event.type == pygame.QUIT:
                self.endGame()
            #判断事件类型是否为按键按下,如果是 继续判断按键是哪一个按键,进行对应的处理
            if event.type == pygame.KEYDOWN:
                #具体是哪一个按键的处理
                if event.key == pygame.K_LEFT:
                    print("坦克向左调头,移动")
                elif event.key == pygame.K_RIGHT:
                    print("坦克向右调头,移动")
                elif event.key == pygame.K_UP:
                    print("坦克向上调头,移动")
                elif event.key == pygame.K_DOWN:
                    print("坦克向下调头,移动")
                elif event.key == pygame.K_SPACE:
                    print("发射子弹")
    #左上角文字绘制的功能
    def getTextSurface(self,text):
        #字体初始化
        pygame.font.init()
        #查看系统所支持的所有字体
        #fontList = pygame.font.get_fonts()
        #print(fontList)
        #选择一个合适的字体
        font = pygame.font.SysFont('kaiti',18)
        #使用对应的字体完成相关内容的绘制
        textSurface = font.render(text,True,COLOR_RED)
        return textSurface

    #结束游戏
    def endGame(self):
        print("谢谢使用")
        #结束python解释器
        exit()
class Tank():
    def __init__(self,left,top):
        self.images = {
            'U':pygame.image.load('img/p1tankU.gif'),
            'D':pygame.image.load('img/p1tankD.gif'),
            'L':pygame.image.load('img/p1tankL.gif'),
            'R':pygame.image.load('img/p1tankR.gif')
        }
        self.direction = 'U'
        self.images = self.images[self.direction]
        #坦克所在的区域
        self.rect = self.images.get_rect()
        #指定坦克初始化位置 分别距x,y轴的位置
        self.rect.left = left
        self.rect.top = top
    #坦克移动
    def move(self):
        pass
    #射击
    def shot(self):
        pass
    #展示坦克(将坦克这个surface绘制到窗口中  blit())
    def displayTank(self):
        #1.重新设置坦克的图片
        self.image = self.images[self.direction]
        #2.将坦克加入到窗口中
        MainGame.window.blit(self.image,self.rect)
class MyTank(Tank):
    def __init__(self):
        pass
class EnemyTank(Tank):
    def __init__(self):
        pass
class Bullet():
    def __init__(self):
        pass
    #子弹移动方法
    def move(self):
        pass
    #展示子弹的方法
    def displayBullet(self):
        pass
class Explode():
    def __init__(self):
        pass
    #展示爆炸效果
    def displayExplode(self):
        pass
class Wall():
    def __init__(self):
        pass
    #展示墙壁
    def displayWall(self):
        pass
class Music():
    def __init__(self):
        pass
    #开始播放音乐
    def play(self):
        pass
MainGame().startGame()

image.png这几处报错怎么回事啊

Python 全系列/第二阶段:Python 深入与提高/游戏开发-坦克大战 2269楼
Python 全系列/第二阶段:Python 深入与提高/GUI编程(隐藏) 2270楼
Python 全系列/第二阶段:Python 深入与提高/游戏开发-坦克大战 2273楼

"""测试Text多行文本框组件的基本用法,使用面向对象的方式"""

from tkinter import *
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')
        self.w1.pack()

        self.w1.insert(1.0, '123456789\n987654321')
        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(side='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')

    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):
        self.photo=PhotoImage(file='imgs/logo.gif')
        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 testTag(self):
        self.w1.delete(1.0, END)
        self.w1.insert(INSERT, 'good good study day day up\n百战程序员\n北京尚学堂\n百度一下你就知道')
        self.w1.tag_add('good', 1.0, 1.9)
        self.w1.tag_config('good', background='yellow', foreground='red')

        self.w1.tag_add('百度', 4.0, 4.2)
        self.w1.tag_config('百度', underline=True)
        self.w1.tag_bind('百度', '<Button-1>', self.webshow)

    def webshow(self, event):
        webbrowser.open('http://www.baidu.com')


if __name__ == '__main__':
    root = Tk()
    root.geometry("450x300+200+300")
    app = Application(master=root)
    root.mainloop()

老师我的运行之后,五个button在下面,没有在顶部是什么原因呢?

image.png

Python 全系列/第二阶段:Python 深入与提高/GUI编程(隐藏) 2274楼
Python 全系列/第二阶段:Python 深入与提高/异常机制 2276楼

# 导入模块
from tkinter import *
from tkinter.colorchooser import *
from tkinter.filedialog import *




#
class Application(Frame):           # 父系Frame-可以包含其他小部件并具有3D边框的框架小部件

    def __init__(self,master=None):
        super().__init__(master)
        self.master = master
        self.textpad = None
        self.pack()
        self.createWidget()         # 定义主菜单方法
        self.contextMenu = None     # contextMenu 上下文菜单对象

    def createWidget(self):
    # 创建主菜单栏
        menubar = Menu(root)

        #menuedit = Menu(menubar2, tearoff=1)  # 菜单栏    添加菜单编辑器
        #menubar2.add_cascade(label="编辑", menu=menuedit)  # cascade=串联,add_cascade语句添加层次菜单项

        # menuedit添加子菜单项目
        #menuedit.add_command(label="剪切")
        #menuedit.add_command(label="复制")
        #menuedit.add_command(label="粘贴")

    #创建子菜单
        menuFile = Menu(menubar)
        menuEdit = Menu(menubar)
        menueHelp = Menu(menubar)

        menubar.add_cascade(label="文件F",menu=menuFile)
        menubar.add_cascade(label="编辑E", menu=menuEdit)
        menubar.add_cascade(label="帮助H", menu=menueHelp)

        # 添加子菜单项目
        menuFile.add_command(label="新建",accelerator="ctel+n",command=self.test)
        menuFile.add_command(label="打开", accelerator="ctel+o", command=self.test)
        menuFile.add_command(label="保存", accelerator="ctel+s", command=self.test)
        menuFile.add_command(label="退出", accelerator="ctel+q", command=self.test)

       # 将主菜单添加到跟主窗口
        root["menu"]=menubar

        # 定义文字编辑区
        self.textpad = Text(root,width=500,height=100)
        self.textpad.pack()


        root.bind("<Button-3>", self.text)


        self.contextMenu = Menu(root)  # 菜单2=菜单栏(root)
        self.contextMenu.add_command(label="颜色", command=self.openAskColor)  # 菜单添加项目颜色,并关联事件=openAskcolor



    # test(event)窗口实时监测方法;
    def text(self, event):
        self.contextMenu.post(event.x_root, event.y_root)


    # 定义一个方法用来调出背景色
    def openAskColor(self):
        s1 = askcolor(color="red", title="选择背景色")
        self.textpad.config(bg=s1[1])

    def test():
        pass

        menubar2 = Menu(root)  # 菜单2=菜单栏(root)







# 创建菜单






   # w1 = Text(root, width=500, height=300)
   # w1.bind("<Button-3>", test)


if __name__ == '__main__':
    root =Tk()
    root.geometry("450x300+200+300")
    root.title("百战程序员的简易记事本")
    app = Application(master=root)


    root.mainloop()

运行报错,请指导:

C:\Users\Administrator\AppData\Local\Programs\Python\Python38\python.exe "H:/python DM/MYPY_0204_GUI/notebook.py"

Exception in Tkinter callback

Traceback (most recent call last):

  File "C:\Users\Administrator\AppData\Local\Programs\Python\Python38\lib\tkinter\__init__.py", line 1883, in __call__

    return self.func(*args)

  File "H:/python DM/MYPY_0204_GUI/notebook.py", line 66, in text

    self.contextMenu.post(event.x_root, event.y_root)

AttributeError: 'NoneType' object has no attribute 'post'


Process finished with exit code 0

需要怎么改?怎么就错了?

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

课程分类

百战程序员微信公众号

百战程序员微信小程序

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