지난번 만든 주사위 게임이 너무 밋밋하다는 의견이 있었습니다.
그래서 에니메이션 효과를 좀 넣었습니다.
포토스케이프 X를 사용하면 gif 파일을 만들 수 있습니다.
여러 그림을 가지고 마치 움직이는 것 처럼 보이게 할 수 있다는 얘기죠.
프레임 속도를 적당히 조절하고 반복횟수는 3회로 해서 6개의 파일을 만들고, 끝나는 그림은 주사위 1에서 6까지 설정합니다.
파일이름은 dice1.gif ~ dice6.gif 로 정했습니다.
qt designer의 ui이도 조금 수정 했습니다.
MainWindow를 좀 더 크게 만들고 label은 2개를 나란히 배치하였습니다.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
|
from PyQt5.QtWidgets import *
from PyQt5 import uic
import sys
from PyQt5.QtGui import QMovie
import random
dice = 'dice.ui'
class MyWindow(QMainWindow):
def __init__(self):
QMainWindow.__init__(self, None)
uic.loadUi(dice, self)
self.pushButton.clicked.connect(self.pushButtonClicked)
def movedice(self):
r = random.randrange(1,7)
ra = random.randrange(1,7)
self.movie = QMovie(f'dice{r}.gif')
self.lbl_result.setMovie(self.movie)
self.movie.start()
self.moviea = QMovie(f'dice{ra}.gif')
self.lbl_resulta.setMovie(self.moviea)
self.moviea.start()
def pushButtonClicked(self):
self.movedice()
if __name__ == '__main__':
app = QApplication(sys.argv)
win = MyWindow()
win.show()
app.exec_()
|
cs |
전체적인 코드는 위와 같습니다.
qt designer에서 label에 gif를 나타나게 하려면, QMovie 라는 클래스가 필요합니다.
각 레이블(label)에 보여지는 gif 파일을 따로 적용해서 pushbutton을 클릭하면 각각의 레이블에 gif가 표시 됩니다.
전체적인 코드는 이전 포스트와 유사하니 필요하시면 이전 포스트를 참고하시기 바랍니다.
코드를 실행하면 아래의 영상과 같이 구동됩니다.
728x90
반응형
'파이썬(Python) > 파이썬 기초' 카테고리의 다른 글
파이썬 Pandas - 시각화를 위한 한글 폰트 설정 (0) | 2021.04.17 |
---|---|
파이썬으로 가위바위보 게임 만들기 (0) | 2021.01.04 |
파이썬으로 주사위 게임 만들기 3 (qt designer 연결해서 완료하기) (0) | 2021.01.01 |
파이썬으로 주사위 게임 만들기 2(qt designer를 이용하여 시각화 하기) (0) | 2020.12.30 |
파이썬(Python) - 파일 복사, 삭제하기(os, shutil 모듈) (1) | 2020.12.29 |
댓글