按钮

作者: 匿隱 | 来源:发表于2019-02-13 15:49 被阅读0次

import pygame
from color import Color
from random import randint

···
class Button:
def init(self, x, y, width, height, text='', background_color=Color.red, text_color=Color.white):
self.x = x
self.y = y
self.width = width
self.height = height
self.text = text
self.background_color = background_color
self.text_color = text_color
self.font_size = 30

def show(self, window):
    pygame.draw.rect(window, self.background_color, (self.x, self.y, self.width, self.height))
    font = pygame.font.SysFont('Times', self.font_size)
    text = font.render(self.text, True, self.text_color)
    w, h = text.get_size()
    x = self.width / 2 - w / 2 + self.x
    y = self.height / 2 - h / 2 + self.y
    window.blit(text, (x, y))

def is_cliecked(self, pos):
    x, y = pos
    return  (self.x <= x <= self.x + self.width) and (self.y <= y <= self.y + self.height)

def main():
pygame.init()
window = pygame.display.set_mode((400, 600))
pygame.display.set_caption('事件')
window.fill(Color.white)

# add_btn(window)
add_btn = Button(100, 100, 100, 50, 'del')
add_btn.show(window)

btn2 = Button(100, 250, 100, 60, 'Score', background_color=Color.yellow, text_color=Color.black)
btn2.show(window)

pygame.display.flip()
is_move = False
while True:
    for event in pygame.event.get():
        if event.type == pygame.QUIT:
            exit()
        elif event.type == pygame.MOUSEBUTTONDOWN:
            mx, my = event.pos
            if add_btn.is_cliecked(event.pos):
                print('删除!')
                continue
            if btn2.is_cliecked(event.pos):
                # print('hello')
                btn2.text = str(randint(0, 100))
                btn2.show(window)
                pygame.display.update()
                continue

···

相关文章

  • 2019-04-12 按钮组(3)

    基本按钮组 按钮 1 按钮 2 按钮 3 按钮工具栏 按钮 1 按钮 2 按钮 3 按钮 4 ...

  • macOS人机界面准则四—控件和拓展功能

    * 按钮 复选框、折叠控件、渐变按钮、帮助按钮、图像按钮、弹出按钮、下拉按钮、操作按钮、单选按钮、范围按钮、切换按...

  • 按钮,按钮

    他不知道自己是如何变成这样的。 或者说意识到。 用他自己的话来说,就是没有人性——尽管与他接触的任何人都绝不可能接...

  • JQuery mobile

    JQuery mobile 编写页面的参数: 所有的按钮 普通按钮 行内按钮 组合按钮: 后退按钮 更多用于按钮的...

  • 平面设计课堂:按钮如何设计更能吸引人

    按钮的不同分类如下: * 动作按钮 * 常用按钮样式 * 按钮的颜色和形状 * 按钮状态和反馈 * 标签按钮 * ...

  • 自定义Vue2.0组件

    Button 按钮 常用的操作按钮。 基础用法 基础的按钮用法。 禁用状态 按钮禁用状态 带图标的按钮 让按钮不仅...

  • B端设计组件:按钮

    一、按钮类型 依据按钮呈现的视觉重量差异,我们可以通过改变样式将按钮分为主按钮、次按钮、虚线按钮、文字按钮、图标按...

  • 第四天

    1、Form:包裹标签,action:# Input:文本框,单选按钮,多选按钮。提交的按钮,按钮,重置的按钮。 ...

  • 2019-04-24 vue css实现按钮淡入淡出效果

    具体场景:点击添加显示删除按钮,此时删除按钮淡入;点击删除按钮,删除按钮淡出 注意:在点击添加按钮,删除按钮淡入时...

  • jquery事件的常用方法

    单击按钮 ,按钮消失 双击按钮,按钮消失 鼠标放上去,按钮消失 鼠标离开,按钮消失 2.绑定事件和解除绑定事 3....

网友评论

      本文标题:按钮

      本文链接:https://www.haomeiwen.com/subject/bvhljqtx.html