做这个项目记录的一些笔记。 说明:翻金币项目是一款经典的益智类游戏,我们需要将金币都翻成同色,才视为胜利。首先,开始、选关、游戏、胜利界面如下:data:image/s3,"s3://crabby-images/1c49e/1c49e47a54d89ca59a3f41d0d3684e2ebdab17af" alt="在这里插入图片描述" 游戏的代码和软件资源请点击自取[资源在此](提取码:7758,制作不易,希望点个赞,非常感谢)
1、创建项目
- 创建QT widgets Application,项目名任意,选择基类QMainWindow,类名MainScene,代表主场景。(注意项目所在路径千万不要出现中文,否则可能会出现点击运行,没有窗口弹出的情况)
- 选择MinGW作为编译器
2、导入资源实现退出
(1)导入资源
- 将资源文件复制到当前项目下
- 右击项目名—添加新文件—QT—QT Resource File—文件名为res
- 添加前缀(/res)—添加文件(把所有文件都添加进去)
- 点击小锤子按钮,将资源文件导入
(2)实现退出
- 打开ui界面,删除工具栏和状态栏
- 编辑界面左上角的菜单名称:开始—退出
- 在mainscene.cpp文件中输入10-13行所示的代码:
#include "mainscene.h"
#include "ui_mainscene.h"
MainScene::MainScene(QWidget *parent)
: QMainWindow(parent)
, ui(new Ui::MainScene)
{
ui->setupUi(this);
connect(ui->actionQuit,&QAction::triggered,[=](){
this->close();
});
this->setFixedSize(320,588);
}
MainScene::~MainScene()
{
delete ui;
}
3、主场景的搭建
前3步的代码如下:
this->setFixedSize(320,588);
this->setWindowTitle("翻金币主场景");
this->setWindowIcon(QIcon(":/res/Coin0001.png"));
添加背景需要重写绘图事件,其主要代码和效果如下:
void mainscene::paintEvent(QPaintEvent *)
{
QPainter painter(this);
QPixmap pix;
pix.load(":/res/PlayLevelSceneBg.png");
painter.drawPixmap(0,0,this->width(),this->height(),pix);
pix.load(":/res/Title.png");
pix = pix.scaled(pix.width()*0.5,pix.height()*0.5);
painter.drawPixmap(10,30,pix);
}
data:image/s3,"s3://crabby-images/57d05/57d05643ffef9afbe5966ace2e9dee276d352be2" alt="在这里插入图片描述"
4、开始按钮封装
- (1)新建一个名为MyPushButton的C++ Class,继承于QObject(创建完毕后在代码中改成QPushButton)
- (2)在mypushbutton.h中重新写了一种构造方式,代码如下
#ifndef MYPUSHBUTTON_H
#define MYPUSHBUTTON_H
#include <QPushButton>
class MyPushButton : public QPushButton
{
Q_OBJECT
public:
MyPushButton(QString normalImg,QString pressImg=" ");
QString normalPath;
QString pressPath;
signals:
public slots:
};
#endif
- (3)mypushbutton.cpp中实现,代码如下:
#include "mypushbutton.h"
#include <QDebug>
MyPushButton::MyPushButton(QString normalImg,QString pressImg)
{
this->normalPath = normalImg;
this->pressPath = pressImg;
QPixmap pix;
bool ret = pix.load(this->normalPath);
if(!ret)
{
QString str = QString("图片加载失败,失败的路径是: %1").arg(this->normalPath);
qDebug()<<str;
}
this->setFixedSize(pix.width(),pix.height());
this->setStyleSheet("QPushButton{border:0px;}");
this->setIcon(pix);
this->setIconSize(QSize(pix.width(),pix.height()));
}
- 在mainscene.cpp中,显示了开始按钮,效果如下
data:image/s3,"s3://crabby-images/7d133/7d13334e4e42e51c46111778fa674f184f7cbad6" alt="在这里插入图片描述"
5、开始按钮跳跃效果实现
- 在MyPushButton中封装zoom1和zoom2函数实现跳跃
- (1)在mypushbutton.h中添加了下图3所示的代码
data:image/s3,"s3://crabby-images/881cf/881cfb83a229a494946fac75a3046ffa4d93ce0d" alt="在这里插入图片描述"
- (2)在mypushbutton.cpp中添加了下图4所示的代码,值得注意的是,在创建动画这一行代码中,动画的方式别打错字,否则可能出现以下报错
QPropertyAnimation: you're trying to animate a non-existing property grometry of your QObject ,导致点击按钮没反应。
data:image/s3,"s3://crabby-images/e00d9/e00d9a84e80105a307fe5945b1b6313fbb584257" alt="在这里插入图片描述"
void MyPushButton::zoom1()
{
QPropertyAnimation * animation = new QPropertyAnimation(this,"geometry");
animation->setDuration(200);
animation->setStartValue(QRect(this->x(),this->y(),this->width(),this->height()));
animation->setEndValue(QRect(this->x(),this->y()+10,this->width(),this->height()));
animation->setEasingCurve(QEasingCurve::OutBounce);
animation->start(QAbstractAnimation::DeleteWhenStopped);
}
void MyPushButton::zoom2()
{
QPropertyAnimation * animation = new QPropertyAnimation(this,"geometry");
animation->setDuration(200);
animation->setStartValue(QRect(this->x(),this->y()+10,this->width(),this->height()));
animation->setEndValue(QRect(this->x(),this->y(),this->width(),this->height()));
animation->setEasingCurve(QEasingCurve::OutBounce);
animation->start(QAbstractAnimation::DeleteWhenStopped);
}
- (3)在mainscene中调用这两个函数进行测试
data:image/s3,"s3://crabby-images/03d30/03d3075a3f81ae743c701ebc2fbf2b4bd5fe4063" alt="在这里插入图片描述"
6、选择关卡场景的基本配置
- (1)创建ChooseLevelScene 选择关卡场景
- (2)在主场景中维护了第二个场景的指针
- (3)在主场景的cpp中去创建第二个场景,并且点击开始按钮进行跳转(有一个延时进入)
在chooselevelscene.cpp中用代码编写出了菜单栏,并且编写了背景的绘图事件 data:image/s3,"s3://crabby-images/e8435/e8435efe9678d2dcbb5d8f8750ccce6a0bff998d" alt="在这里插入图片描述"
7、返回按钮的创建
(1)在选关场景中创建返回按钮,重写按钮的鼠标按下和鼠标释放事件。具体效果为:当鼠标按下的时候显示另外一张图片,当鼠标松开时恢复出原来的效果。 data:image/s3,"s3://crabby-images/a002a/a002a63a955920b8c41f981d5ab820cbf85a8e4f" alt="在这里插入图片描述"
(2)在自定义的mypushbutton.h中重写了鼠标按下和鼠标释放事件data:image/s3,"s3://crabby-images/ea0f9/ea0f91a3e52fdbac1b67f318febb40ad82c1dc5b" alt="在这里插入图片描述"
(3)在mypushbutton.cpp中实现了鼠标按下和鼠标释放事件data:image/s3,"s3://crabby-images/c82a8/c82a88595106567e1ee5de1b07cf58c5cf7624c2" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/71b28/71b28003b04d14add16f2c127aa51bc939ecff5d" alt="在这里插入图片描述"
8、返回按钮的功能实现
功能描述:点击返回按钮时,能够回到主场景。 实现手段:利用信号和槽。 (1)选择关卡场景的.h中定义了返回按钮的信号data:image/s3,"s3://crabby-images/0924e/0924e21cfeccb1d7455549104abbbfcdda3c18d3" alt="在这里插入图片描述"
(2)选择关卡场景的.cpp文件中实现了返回按钮的信号 data:image/s3,"s3://crabby-images/0c515/0c515d5b71c34368777b02322969fe66d8d22337" alt="在这里插入图片描述"
在主场景的.cpp文件中,监听了返回按钮的信号。data:image/s3,"s3://crabby-images/9d694/9d6946d058cfbc324379176053ff6ff1f0098bce" alt="在这里插入图片描述"
9、创建选择关卡的小按钮
由于是按钮,故直接可通过自己编写的mypushbutton类来创建。 因此,在选择关卡chooselevelscene.cpp中直接加入以下代码即可:
for(int i = 0 ;i <20;i++)
{
MyPushButton * menuBtn = new MyPushButton(":/res/LevelIcon.png","");
menuBtn->setParent(this);
menuBtn->move(25+(i%4)*70,130+(i/4)*70);
connect(menuBtn,&MyPushButton::clicked,[=](){
qDebug()<<"您选择的是第"<<i+1<<"关";
});
}
效果演示如下: data:image/s3,"s3://crabby-images/27f2f/27f2f4c0b5f3f91db7d62e9efd6777c71849e2db" alt="在这里插入图片描述"
核心代码说明: menuBtn->move(25+(i%4)*70,130+(i/4)*70);
可以看到上图,关卡按钮是4行5列的。
- 当i为0、1、2、3时,25+(i%4)*70所得到的值分别为:25 95 165 235,对应按钮的横坐标;
- 当i为0、4、8、12、16时,130+(i/4)*70所得到的值对应按钮的纵坐标。
10、显示关卡按钮上面的数字实现
在按钮上显示关卡数字。 实现思路1: 按钮底层本身封装了一个函数—setText,可以在按钮上直接显示内容。 具体代码: menuBtn->setText(QString::number(i+1)); //因为setText要的是字符串,而QString::number表示将int型数据转化成字符串型。 具体效果如下:会发现该方法无法得到理想的效果,因为原先的按钮是矩形的,我们将其改为了圆形,因此文本也无法对应。
data:image/s3,"s3://crabby-images/ac2a9/ac2a9c688527b4cfd42148a5c388533a9a3747e8" alt="在这里插入图片描述"
实现思路2: 利用QLabel标签。 具体代码如下:
QLabel * label = new QLabel;
label->setParent(this);
label->move(25+(i%4)*70,130+(i/4)*70);
label->setFixedSize(menuBtn->width(),menuBtn->height());
label->setText(QString::number(i+1));
label->setAlignment(Qt::AlignHCenter|Qt::AlignVCenter);
label->setAttribute(Qt::WA_TransparentForMouseEvents);
data:image/s3,"s3://crabby-images/80e84/80e8463f9574716e2498426b0e31fc7df2e2cfc4" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/94405/94405cd282a76780b50a497c1d62ea33f027f7be" alt="在这里插入图片描述"
11、翻金币场景的创建及基本搭建
(1)创建翻金币场景:创建PlayScene.h和PlayScene.cpp文件(父类为QMainWindow) (2)在选择关卡场景chooselevelscene.h中维护 第三个场景的指针。data:image/s3,"s3://crabby-images/f943b/f943b82860d5dad55f43de183214dd976e9c8e9a" alt="在这里插入图片描述"
(3)当用户点击选关按钮,创建第三个场景。data:image/s3,"s3://crabby-images/0cc02/0cc023783fd8ae240e92ae2156ba0822655d7892" alt="在这里插入图片描述"
(4)游戏场景的基本搭建 即绘图事件,在playscene.h和playscene.cpp中的代码分别为: data:image/s3,"s3://crabby-images/fa2c8/fa2c82a183838ac74baae0502b4179371333c41d" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/83c30/83c30859a47868e48fb4a4c399dfc72c14053e2b" alt="在这里插入图片描述"
12、翻金币场景的返回按钮实现
(1)创建返回按钮。 (2)点击时发送自定义信号。 (3)在选关场景(第2场景)中监听翻金币游戏场景的信号,并作响应。
- 在playscene.h中设置了一个返回按钮的信号
- 在playscene.cpp中实现了信号的发射
- 在ChooseLevelScene.cpp中监听了游戏场景发送回的信号(特别要注意监听信号的代码所在的范围,这种bug极难发现)
- 具体新增代码如下图所示
data:image/s3,"s3://crabby-images/71548/715489aad1361245ec93d1cd16c3b250aa546e78" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/43942/4394295653cadd8f3f4ae4641d5ad21cd3342098" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/f68bc/f68bce156618afc67a3992d2db7d0243e6af71a0" alt="在这里插入图片描述"
13、当前关卡号功能实现
在playscene.cpp文件中添加了如下代码,这个过程和第十章的内容差不多,只不过新增了两种技巧: 1: QString str = QString(“Level:%1”).arg(this->levelIndex); //arg的作用是拼接 2:QFont font(“华文新魏”,20); //设置标签的字体属性 label->setFont(font); 3: //设置标签的大小和位置 label->setGeometry(QRect(30,this->height()-50,this->width(),50)); data:image/s3,"s3://crabby-images/1d0eb/1d0ebfdba0dde5b2a37e373b37e2ac08aa05a23d" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/92914/92914ab094b507eb9c59ebcf217acde5933734e1" alt="在这里插入图片描述"
14、金币背景图加载
(1)在playscene.cpp中新增了如下代码,注意,在新增代码中用到了两层for循环,这是为了在游戏规则处理时更加方便的选择硬币上下左右的关系。data:image/s3,"s3://crabby-images/339ae/339ae7c3f6a11453abfa2422f8821f3afdb20212" alt="在这里插入图片描述"
效果如图28所示:data:image/s3,"s3://crabby-images/bd23d/bd23d95ddadf3cda77108462aa5e104ca5b6b09d" alt="在这里插入图片描述"
15、金币类创建
我们知道,金币是本游戏的核心对象,并且在游戏中可以利用二维数组进行维护,拥有支持点击,翻转特效等特殊性,因此不妨将金币单独封装到一个类中,完成金币所需的所有功能。 (1)创建一个MyCoin类,父类为QWidget,创建成功以后,将其构造函数的定义与实现删除,并将其父类改成QPushButton(头文件和继承都要改) (2)MyCoin.h中的代码 data:image/s3,"s3://crabby-images/f5a8b/f5a8b81014503545b4bc57dd39d4832feea542ba" alt="在这里插入图片描述"
(3)MyCoin.cpp中的代码
data:image/s3,"s3://crabby-images/aeafc/aeafcaef6b0691118cfffec7ccb3afc2e16f8dde" alt="在这里插入图片描述"
(4)playscene.cpp中的代码 data:image/s3,"s3://crabby-images/a5b6c/a5b6cafba9cefe24eb6ccf66376cf85fb4415549" alt="在这里插入图片描述"
16、初始化关卡
首先将dataconfig.cpp和dataconfig.h文件导入项目中。 以dataconfig.h为例,该类只有一个成员,表示关卡号对应的金币规则
#ifndef DATACONFIG_H
#define DATACONFIG_H
#include <QObject>
#include <QMap>
#include <QVector>
class dataConfig : public QObject
{
Q_OBJECT
public:
explicit dataConfig(QObject *parent = 0);
public:
QMap<int, QVector< QVector<int> > >mData;
signals:
public slots:
};
#endif
下面给出了1-3关的dataconfig.cpp文件中的代码,其中1为金币,2为银币。
#include "dataconfig.h"
#include <QDebug>
dataConfig::dataConfig(QObject *parent) : QObject(parent)
{
int array1[4][4] = {{1, 1, 1, 1},
{1, 1, 0, 1},
{1, 0, 0, 0},
{1, 1, 0, 1} } ;
QVector< QVector<int>> v;
for(int i = 0 ; i < 4;i++)
{
QVector<int>v1;
for(int j = 0 ; j < 4;j++)
{
v1.push_back(array1[i][j]);
}
v.push_back(v1);
}
mData.insert(1,v);
int array2[4][4] = { {1, 0, 1, 1},
{0, 0, 1, 1},
{1, 1, 0, 0},
{1, 1, 0, 1}} ;
v.clear();
for(int i = 0 ; i < 4;i++)
{
QVector<int>v1;
for(int j = 0 ; j < 4;j++)
{
v1.push_back(array2[i][j]);
}
v.push_back(v1);
}
mData.insert(2,v);
int array3[4][4] = { {0, 0, 0, 0},
{0, 1, 1, 0},
{0, 1, 1, 0},
{0, 0, 0, 0}} ;
v.clear();
for(int i = 0 ; i < 4;i++)
{
QVector<int>v1;
for(int j = 0 ; j < 4;j++)
{
v1.push_back(array3[i][j]);
}
v.push_back(v1);
}
mData.insert(3,v);
然后分别在playscene.h和playscene.cpp中新增了以下代码,有用于给每个关卡的金币、银币进行图案排版:data:image/s3,"s3://crabby-images/b0ec6/b0ec619733dbd2c311d1d61339ee88da497b7dd0" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/3fcc7/3fcc78683b82afacb9933c87ecb5f2a3140e6b76" alt="在这里插入图片描述"
效果图如下,最后一关是全银币的。data:image/s3,"s3://crabby-images/d4b30/d4b30ff19cf66839be7a2f27d96754449739972f" alt="在这里插入图片描述"
17、翻转银币的功能实现(核心:切图)
(1)如下图所示,为了方便翻转硬币,在金币类中,拓展了属性posX、posY和flag。这三个属性分别代表了,该金币在二维数组中的x坐标,y坐标以及当前的正反标志(也就是是金币还是银币)
int posX;
int posY;
bool flag;
data:image/s3,"s3://crabby-images/c856e/c856e67330c519c47225daa77df1af0690bc0738" alt="在这里插入图片描述"
(2)关卡的初始化完成后,就应该点击金币,进行翻转的效果了,那么首先在MyCoin类中创建出该方法。 在MyCoin.h中声明:
void changeFlage();
QTimer *timer1;
QTimer *timer2;
int min = 1;
int max = 8;
data:image/s3,"s3://crabby-images/a6e34/a6e34e8abb6cc823eb994cb6c56e60a7d5ab96db" alt="在这里插入图片描述"
(3)在MyCoin.cpp中实现:data:image/s3,"s3://crabby-images/b67bc/b67bce17d6aaffb25af8f654ac14afc4aaba97eb" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/acd24/acd242886ed0d5a51dcc8f582b9b72e67f0328fa" alt="在这里插入图片描述"
(4)在playscene.cpp中新增的测试代码如下data:image/s3,"s3://crabby-images/fdfa4/fdfa4f6d077d6b4b82c9cfddaeaeadc1cc904464" alt="在这里插入图片描述"
18、快速点击导致的翻转效果不完整
问题说明,当鼠标快速点击金币时,会出现金币翻银币,银币翻金币,然后又是银币翻金币。说白了就是金币翻银币的动作还没做,银币翻金币的动作就开始了。 解决方法,要将整个动作做完才能执行下一个动作(要做一些限制)。 加一个标志如isAnimation,用于表示当前金币是否做完了动画,默认为false,即做完了。 实现过程,在MyCoin.h中加入
bool isAnimation = false;
实现过程,在MyCoin.cpp中加入 data:image/s3,"s3://crabby-images/9ecf5/9ecf5b322391c5ab662c439375f5fcfe1491befa" alt="在这里插入图片描述"
19、翻转周围硬币
说明:点击硬币时,还需要将当前硬币周围上下左右4个硬币也进行延时翻转,代码写到监听硬币下。 此外,翻转硬币时还要注意,最左侧、右侧、上侧、下侧的几个位置的规则是不一样的。 (1)在playscene.h中,新增了如下代码: data:image/s3,"s3://crabby-images/14e55/14e554f9c5e1aef756311cff8bb01e717ba1791a" alt="在这里插入图片描述"
(2)在playscene.cpp中,新增了如下代码: data:image/s3,"s3://crabby-images/08238/0823807cdfd68b37ad894e6b7d61d07269cb6b7e" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/3b6f9/3b6f9729b26d6032514b3aafafbc522ecbb26cde" alt="在这里插入图片描述"
20、游戏胜利的检测以及禁用硬币点击
(1)检测游戏胜利 在playscene.h中新增以下代码: data:image/s3,"s3://crabby-images/ce2e9/ce2e98db033d553ea8c2be51cbebac8ca13a9b20" alt="在这里插入图片描述"
在playscene.cpp中新增以下代码: data:image/s3,"s3://crabby-images/61b7a/61b7a4485c24186ed0b8ab805cfa9c6df810e186" alt="在这里插入图片描述"
(2)禁用硬币翻转 在mycoin.h中新增以下代码 data:image/s3,"s3://crabby-images/9ffa8/9ffa845b7037a7e33b8f036ca98386e525e2b04a" alt="在这里插入图片描述"
在mycoin.cpp中新增以下代码 data:image/s3,"s3://crabby-images/2bd27/2bd273d3de23fa179d9ca46eb96b4633b6b22e77" alt="在这里插入图片描述"
21、游戏胜利后手速过快导致的bug
描述: 当手速过快时可能会出现下一步所示的bug,明明点击一步就赢了,但是在0.3s内又点了另外一个硬币,就会出现下图所示的情况。 原因: 这是因为周围的硬币是在0.3s后才翻转的,胜利检测也是如此,但是这时候玩家又点击了下一张个硬币,就会出现当前的bug。 data:image/s3,"s3://crabby-images/206a9/206a9e9906658fee4e999dfcdc840d088fc4d2a6" alt="在这里插入图片描述"
解决方法: 在playscene.cpp中加入以下代码data:image/s3,"s3://crabby-images/fe2ef/fe2efb144d92bb20027c126e59c0284c700e0b56" alt="在这里插入图片描述"
22、胜利图片显示
(1)在playscene.cpp的构造函数中准备好胜利图片 data:image/s3,"s3://crabby-images/1ca82/1ca82b1a7a4f643f405fa65036e5f17d9a01febf" alt="在这里插入图片描述"
(2)当游戏胜利后,将图片以动画的效果显示出来 data:image/s3,"s3://crabby-images/584e2/584e2908688b5c08f8276f9950b3787dceebb17a" alt="在这里插入图片描述"
23、音效的添加
(1)添加音效要用到#include < QSound > 头文件,在这之前需要在.pro文件中添加multimedia模块,如下图所示: data:image/s3,"s3://crabby-images/4287f/4287ffd167dcbcaf79f8f00c27b988b7b198d400" alt="在这里插入图片描述"
(2)分别在三个场景中添加音效
- mainscene.cpp中添加开始音效
data:image/s3,"s3://crabby-images/dca01/dca01cec5d4bf2cb638c2530dea468396f95ae3c" alt="在这里插入图片描述"
- 在chooselevelscene.cpp中添加选择关卡和返回音效
data:image/s3,"s3://crabby-images/19225/19225994cc21d91f751d82af36f9c9938897aa2c" alt="在这里插入图片描述"
- 在playscene.cpp中添加翻转金币、返回和游戏胜利音效
data:image/s3,"s3://crabby-images/6a5c4/6a5c42df0328b7bf47814dc71b947740a91a9ed7" alt="在这里插入图片描述"
24、bug解决—场景位置统一
该游戏有三个场景,但是如果在不同场景下去移动位置,之后点击返回按钮,这三个场景的位置会不在一起,因此最好固定三个场景的位置。 (1)开始场景和选关场景的解决data:image/s3,"s3://crabby-images/4cb1e/4cb1e5fb4ec6a74927e651de921af8a950806e9b" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/41d6c/41d6cb0e055f5177bb533807e1b8dc5f22eb9eec" alt="在这里插入图片描述"
25、游戏辅助玩法介绍
(1)存档功能 (2)倒计时功能 (3)提示功能 (4)逐关解锁功能
26、项目打包发布
(1)首先将项目从debug模式改成release模式,点击左下方的电脑图标。data:image/s3,"s3://crabby-images/e412d/e412d8a59aff9ebbeff99d9b5c1d542405890241" alt="在这里插入图片描述"
(2)点击运行 (3)之后就可以在资源路径下找到release文件夹,找到相应的exe文件data:image/s3,"s3://crabby-images/ec0ff/ec0ff5c281d026dec5f2e60844798d4211c26975" alt="在这里插入图片描述"
双击运行,会发现有错误提示(如图60所示),这是因为没有配置环境变量,需要图61的方法加入环境变量。但是如果我们想让其他人也玩这个游戏,那岂不是得让别人也安装QT,也配置环境变量。(当然不是)data:image/s3,"s3://crabby-images/a4227/a4227e3a07be639dbab4ee868fcc3b1ca7bc28f2" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/be0bc/be0bcd1e276bb8212149114e985379aff31eb03a" alt="在这里插入图片描述"
那么如何真正的打包发布呢? 首先在开始菜单中找到MinnGW软件,然后再看看自己的安装路径下有没有w开头的exe文程序,如图63所示,有的话说明具备打包发布的功能。data:image/s3,"s3://crabby-images/6ad63/6ad631593b1024df71cad0769f374e0e16feacac" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/ad4e4/ad4e45c25ffbf2e8f6adeaa05eaa251d9870ffba" alt="在这里插入图片描述"
将刚release生成的CoinFlip.exe单独放在一个文件夹,哪里都行。我放在了桌面的111文件夹中 data:image/s3,"s3://crabby-images/1f5c0/1f5c098537d7a3b954fecc8bd3de8d46582df1da" alt="在这里插入图片描述"
双击启动开始菜单中的MinnGW软件,然后输入以下代码:
//windeployqt 加 刚刚release出来的exe软件全部路径名称(我放在桌面了)
windeployqt C:\Users\Lenovo\Desktop\111\CoinFlip.exe
data:image/s3,"s3://crabby-images/6b40e/6b40e5725f39ef6f3b5f41e3722c1ac0acd998b4" alt="在这里插入图片描述"
执行完毕后就能看到,文件夹中多出了许多文件,并且这时候点击运行发现也能正常玩了,如果要发给别人,需要将这里面的所有文件一起发过去。 data:image/s3,"s3://crabby-images/533a0/533a02b12fd2825b6403c878c091479bb8439e02" alt="在这里插入图片描述"
最后优化:可以看到上述游戏要发给别人玩会发现附带了许多配置文件,很冗余的感觉,但是像在应用商店里面下载的游戏都是给出一个安装包,然后选择路径一步一步安装,最后不想玩了还可以卸载。那么QT能不能做到呢?当然能,但是这就需要第三方工具。 nisedit2.0.3.exe和nsis-3.05-setup.exe 有需要的小伙伴可以自行去了解一下这两款软件。
总算是写完了,可以看到制作一个这么小的小游戏也没有想象中的那么简单,一个人要弄的话也要弄好久。麻雀虽小,五脏俱全。 能看到这也不容易,希望你也有所收获,最后,如果觉得本文对你有所帮助的话,希望能点赞收藏,您的鼓励是对我最大的支持!
|