PyQt实例:设计按钮释放烟花。

我们考虑一件事情,如果让你来做GUI实现按钮后在屏幕喷射烟花并放音乐,你应该如何做?

  1. 需要一个UI窗口,一个代表button的icon图形,这个我可以用PS或者Sketch画出来。画的时候注意,一定要按照你想要的button 的比例构建。


    image.png
  2. 我们需要定义一个烟花发射的video,以及一段音乐。
    https://github.com/YuanzhengMa/notes_md/blob/main/fireworks.gif

  3. 然后需要对button绑定该动作就可以了。

绑定释放烟花,播放音乐在Qt中教slot function,按按钮这个的动作是用户发出的,叫做signal。

如下定义main窗口

# -*- coding: utf-8 -*-
# main.py


import argparse
import PIL.Image as Image
import PIL.ImageSequence as ImageSeq


# define hyper params
parser = argparse.ArgumentParser(description='Firework playing.')
parser.add_argument('--window_size', type=tuple, default=(300, 300), help='the size of the Main Window')

opt = parser.parse_args()

# designed the sub-class of Qt Window


class UiMainWindow(object):
    def __init__(self, options=None):
        self.opt = options
    # set up Ui in PyQt5 including windows, push button, radio buttons...

    def setupUi(self, MainWindow):
        MainWindow.setObjectName("MainWindow")
        MainWindow.resize(self.opt.window_size[0], self.opt.window_size[1])

        MainWindow.setWindowOpacity(1)
        screen = QtWidgets.QDesktopWidget().screenGeometry()
        self.width = screen.width()
        self.height = screen.height()


        # 创建一个按钮控件-submit selctions
        self.pushButton = QtWidgets.QPushButton(MainWindow)
        self.pushButton.setGeometry(QtCore.QRect(self.opt.window_size[0]//2-50, self.opt.window_size[1]//2, 100, 32))
        # 1.png是我定义的图标
        self.pushButton.setStyleSheet("QPushButton{border-image: url(1.png)}")
        self.pushButton.setObjectName("submitButton")
        # rename Ui
        self.retranslateUi(MainWindow)
        # bind to slots
        QtCore.QMetaObject.connectSlotsByName(MainWindow)
        # binding slot for submit button
        self.pushButton.clicked.connect(self.openImg_Music)

    def openImg_Music(self):
        # image show with new window
        import imshowWin
        # resize imgs,fireworks.gif是烟花
        temp = Image.open("fireworks.gif")
        temp = [frame.resize((self.width, self.height)) for frame in ImageSeq.Iterator(temp)]

        temp[0].save("fireworks2.gif", save_all=True, append_images=temp[1:])
        #  imageio.mimsave('fireworks2.gif',temp)
        self.imgWin = imshowWin.multiImgs(imgs='fireworks2.gif')
        self.imgWin.show()

    def retranslateUi(self, main_window):
        _translate = QtCore.QCoreApplication.translate
        main_window.setWindowTitle(_translate("MainWindow", "Fireworks"))
        self.pushButton.setText(_translate("MainWindow", " "))

# Main function
if __name__ == '__main__':
    import sys
    app = QtWidgets.QApplication(sys.argv)
    MainWindow = QtWidgets.QMainWindow()  # Create the normal window object
    ui = UiMainWindow(options=opt)  # 创建PyQt5设计的窗体对象
    ui.setupUi(MainWindow=MainWindow)  # 调用PyQt5窗体的方法对窗体对象进行初始化设置
    MainWindow.show()  # Show the designed window
    sys.exit(app.exec_())  # close the app and exit

import imshowWin是我自己定义的一个类,其内容如下:

定义一个multiImgs类,

# -*- coding: utf-8 -*-
# imshowWin.py

from PyQt5.QtWidgets import *
from PyQt5.QtGui import QPainter, QPixmap, QMovie
from PyQt5.QtCore import Qt, QRect, QCoreApplication, QMetaObject
import pygame


class multiImgs(QLabel):
    def __init__(self, parent=None, imgs=None):
        super(multiImgs, self).__init__(parent)

        self.setObjectName("Fireworks")
        self.setWindowFlag(Qt.FramelessWindowHint)
        screen = QDesktopWidget().screenGeometry()
        self.width = screen.width()
        self.height = screen.height()
        self.resize(self.width, self.height)
        self.label = QLabel(self)
        self.label.setGeometry(QRect(0, 0, self.width, self.height))
        self.label.setObjectName("label")
        # show gif
        self.gif = QMovie(imgs)
        self.label.setMovie(self.gif)
        self.gif.start()
        # Opacity button
        self.pushBtn = QPushButton(self)
        self.pushBtn.setGeometry(QRect(0, 0, self.width, self.height))
        op = QGraphicsOpacityEffect()
        op.setOpacity(0)
        self.pushBtn.setGraphicsEffect(op)
        #  play music,lonelyWaltz.mp3是我的音乐
        pygame.init()
        my_track = pygame.mixer.music.load(r"lonelyWaltz.mp3")
        pygame.mixer.music.play()

        # add slot for opacity button
        self.pushBtn.clicked.connect(self.close_all)
        # rename windows
        self.retranslateUi(self)
        # connect slots for signal
        QMetaObject.connectSlotsByName(self)

    def close_all(self):
        self.close()
        pygame.mixer.music.stop()

    def retranslateUi(self, Form):
        _translate = QCoreApplication.translate
        Form.setWindowTitle(_translate("Form", "Form"))

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,444评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,421评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,036评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,363评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,460评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,502评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,511评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,280评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,736评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,014评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,190评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,848评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,531评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,159评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,411评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,067评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,078评论 2 352

推荐阅读更多精彩内容