无限翻方块折纸教程,凭方块后部分图片猜整个图片内容的游戏怎么制作的,可以给详细步骤吗

我的世界:看图猜方块,你能看出这图片分别都用到了什么方块吗?
我的世界:看图猜方块,你能看出这图片分别都用到了什么方块吗?
依旧是用Qubicle Voxel Editor编辑和MagicaVoxel渲染;最近看到MagicaVoxel的更新预告了,貌似可以支持更大的场景了,若是可以大话以后将会变得更加的好玩(题外话)。今天做的是火影忍者里面的小李子,这三个模型在我的世界里所用到的方块,你能找出几种?或者猜猜看,诶 嘿嘿,估计够呛的。不过如果换做是你做的话,会用哪些方块呢?
本文仅代表作者观点,不代表百度立场。系作者授权百家号发表,未经许可不得转载。
百家号 最近更新:
简介: 总有好玩的游戏不是吗?游戏生活---小圡逗~
作者最新文章这个教程介绍方块游戏类的使用。教程共分三个部分。第一部分是简介,让你用最简单的办法实现自
己的方块游戏。第二部分是功能展示,这里通过一个例子对这个类的所有功能进行了演示。第三部分是游戏分析,通过对接口函数的展示和对整个游戏设计流程的分
析,帮助你更好的理解源码。
需要说明的是:我们下面使用的编程环境是基于Qt 4.6的Qt
Creator 1.3.0 Windows版本。这个类包含的四个文件myitem.cpp, myitem.h ,gamearea.cpp
,gamearea.h 会和本教程打包在一起,你也可以到网上下载。
下载地址可以到我的博客
进行查看。
基于这个类我已经写了一个范例游戏
:俄罗斯方块劳拉版
可以到csdn下
或到qt论坛下载:
第一部分:简介
Creator中已经有了俄罗斯方块的例子,大家可以在帮助中搜索Tetrix进行查看。其内容如下:
但是对于初学者,这个例子并不是那么容易就能看
懂。所以我结合这个例子和网上的一些资料,写了一个比较简单的方块游戏类。希望能帮助初学者更好的理解这个例子和写出自己的方块游戏。
这里已经对所有的功能函数进行了整理,最简单的,你只需要定义一个对象就能让这个游戏运行起来。
写最简单的游戏
1. 新建Empty Qt4 Project,我们这里命名为myTetrix
向工程里添加新的普通文本文件,命名为main.cpp 。
3. 将myitem.cpp, myitem.h,
gamearea.cpp, gamearea.h四个文件复制到工程文件夹下。
4. 将上面四个文件加入到工程中。
将main.cpp的内容更改如下:
#include &gamearea.cpp&
int main(int argc,char* argv[])
QApplication app(argc,argv);
GameArea box(500);
box.show();
return app.exec();
6.然后运行程序。效
果如下图。
当游戏结束时会弹出提示框,确定后游戏将重新开
如下图所示。
7.可以看到,用这个类建立方块游戏是这么的简
单。我们只是在主函数里新建了一个该类的对象,其中的参数为方块下移的速度,单位是毫秒,上面的500即0.5秒。
何向工程中添加文件)
在工程文件夹上点右键,弹出的菜单中Add
New表示添加新文件,Add Existing Files表示添加工程文件夹中已有的文件。
二部分:功能展示
要想实现更强大的功能,我
们就需要应用控制窗体,而让这个游戏区域只作为它的一个部件。为了更好的控制游戏,我们也需要自己建立定时器,而不再应用该类自带的定时器了。
核心功能:
(一)建立工程。
1.首先建立工程Qt4 Gui Application,这里命名为Tetris,选用
Base class
2.然后将myitem.cpp, myitem.h ,gamearea.cpp,
gamearea.h四个文件复制到工程文件夹下并添加到工程中。
3.在widget.h中添加#include
&gamearea.h&的头文件包含。并在下面的private中声明一个游戏类对象GameArea *gameA
widget.cpp的构造函数里添加语句。
Widget::Widget(QWidget *parent) :
QWidget(parent),
ui(new Ui::Widget)
ui-&setupUi(this);
this-&resize(800,500);
this-&gameArea = new GameArea(this);
这里重新设定了主窗
口大小,并在主窗口上新建了一个游戏区域对象。
5.这时运行程序效果如下。
可以看到,因为使用了另一个构造函数,没有使用
该类自带的定时器,所以只是显示了游戏区域,游戏并没有运行。
(二)添加定时器和开始按钮,让游戏可以运行。
1.在widget.h里的private中添加定时器对象和分数变量的声明。
在public中添加显示分数函数的声明。
void doScore(int);
加槽函数的声明。
private slots:
void timer_upDate();
widget.cpp文件中的构造函数里添加下面的语句:
this-&timer = new QTimer(this);
connect(this-&timer,SIGNAL(timeout()),this,SLOT(timer_upDate()));
定义了定时器并进行了信号和槽函数的关联,初始化分数为0;
3.然后在下面定义两个
void Widget::timer_upDate() //定时器溢出处理
this-&gameArea-&moveOneStep();
//先移动一步,这时并没有显示出来
if(this-&gameArea-&isMoveEnd())
//如果无法移动,到底了或结束了
if(this-&gameArea-&isGame_Over())
//如果是结束了
this-&timer-&stop(); //停止计时
QMessageBox::warning(this,tr(&warning&),tr(&Game
Over!&),QMessageBox::Yes);
//弹出对话框
this-&score =0;
//清空分数
this-&gameArea-&init_Game(); //重新开始游戏
this-&gameArea-&gameStart();
this-&timer-&start(500);
else //如果是移动到底了
this-&gameArea-&nextItem(); //出现下一个图形
num = this-&gameArea-&getFullRowNum(); //获得已满的行数
this-&doScore(num);
//显示分数
this-&gameArea-&gameStart(); //继续游戏
else //如果没有到底
this-&gameArea-&do_MoveNext();
//显示方块下移一步后的界面
void Widget::doScore(int
num) //显示分数
score += num*100;
this-&ui-&label_2-&setText(tr(&%1&).arg(score));
4.在设计器中向主窗口上添加两个标签label和label_2,其中label写上&你的分数是:&,label_2
写上&0&;然后再添加一个开始按钮。添加完后效果如下。
5.然后右击&开始游戏&按钮,选择其单击事件
的槽函数。更改如下。
void Widget::on_pushButton_clicked() //开始按钮
this-&gameArea-&init_Game(); //第一次进入游戏时进行的初始化
this-&gameArea-&gameStart();
//开始游戏
this-&timer-&start(500); //开启定时器
this-&gameArea-&setFocus();
//让游戏区域获得焦点,这样才能响应键盘
6.现在游戏已经可以正常进行了。运行效果如下。
(三)添加暂停和重新开始按钮,完成基本
的控制功能。
1.在主窗口上添加&暂停游戏&和&重新开始&两个按钮。在&暂停游戏&按钮的属性中将checkable选中。
如下图所示。
2.分别进入两个按钮的单击事件槽函数。修改如
void Widget::on_pushButton_2_clicked() //暂停按钮
if(this-&ui-&pushButton_2-&isChecked())
this-&timer-&stop();
this-&ui-&pushButton_2-&setText(tr(&
取消暂停&));
this-&timer-&start(500);
this-&ui-&pushButton_2-&setText(tr(&暂停游戏&));
this-&gameArea-&setFocus();
void Widget::on_pushButton_3_clicked() //重新开始
this-&timer-&stop();
this-&on_pushButton_clicked();
3.在main.cpp中添加语句,让程序中可以使用中文。
添加#include 的
头文件包含。
在main()函数里添加
QTextCodec::setCodecForTr(QTextCodec::codecForLocale());语句。
运行效果如下。
高级功能的应用
(一)改变颜色和给方块添加图片。
添加&更改颜色&按钮和&方块贴图&按钮。如下图。
2.更改其单击事件槽函数。如下。
Widget::on_pushButton_4_clicked() //改变颜色
this-&gameArea-&setGameAreaColor(QColor(255,255,0,qrand()%255));
//更改游戏区域背景颜色
this-&gameArea-&setBoxBrushColor(QColor(0,255,0,qrand()%255));
//更改小方块背景颜色
this-&gameArea-&setBoxPenColor(QColor(0,0,0,qrand()%255));
//更改小方块边框颜色
this-&gameArea-&draw_gameArea();
更新游戏区域
this-&gameArea-&setFocus();
Widget::on_pushButton_5_clicked() //方块贴图
this-&gameArea-&set_draw_box_picture(true);
//确认使用方块背景图片
this-&gameArea-&setBoxPicture(&box.gif&);
//添加方块背景图片
this-&gameArea-&draw_gameArea();
更新显示区域
this-&gameArea-&setFocus();
点击&改变背景&按钮后,游戏区域背景,方块的填充颜色和边框颜色都改变了。
点击&方块贴图&按钮。注意,只有方块颜色的透
明度不是255时,才能看见贴图。所以,如果开始游戏后直接按&方块贴图&按钮,是不能显示出背景图片的,我们需要先改变颜色。
(二)是否显示背景网格和下一个要出现的
1.添加&网格显示&按钮和&方块提示&按钮。并将它们属性中的checkable选中。界面如下。
2.修改它们的单击事件槽函数。
Widget::on_pushButton_6_clicked() //网格显示
if(this-&ui-&pushButton_6-&isChecked())
this-&gameArea-&setDrawGrid(false);
this-&gameArea-&setDrawGrid(true);
this-&gameArea-&draw_gameArea();
this-&gameArea-&setFocus();
Widget::on_pushButton_7_clicked() //方块提示
if(this-&ui-&pushButton_7-&isChecked())
this-&gameArea-&setDrawNextItem(false);
this-&gameArea-&setDrawNextItem(true);
this-&gameArea-&draw_gameArea();
this-&gameArea-&setFocus();
3.运行效果如下。
(三)添加方块移动的声音。
1.添加&打开声音&按钮,并将其属性中的checkable选中。
2.修改其单击事件槽函数。
Widget::on_pushButton_8_clicked() //声音开关
if(this-&ui-&pushButton_8-&isChecked())
this-&gameArea-&setPlaySound_itemChange(&changeItem.wav&,true);
this-&gameArea-&setPlaySound_moveDown(&moveDown.wav&,true);
this-&gameArea-&setPlaySound_moveLeft(&moveLeft.wav&,true);
this-&gameArea-&setPlaySound_moveRight(&moveLeft.wav&,true);
this-&ui-&pushButton_8-&setText(tr(&关闭声音&));
this-&gameArea-&setPlaySound(false);
//关闭音乐
this-&ui-&pushButton_8-&setText(tr(&打开声音&));
this-&gameArea-&setFocus();
需要的声音文件放到工程文件夹下的debug文件夹下。注意:只能是wav格式的。然后运行程序,测试一下效果。
(四)添加向下
按键移动步数设置。
1.添加&是否坠落&按钮,并将其属性中的checkable选中。
2.更改其单击事件槽函数。
Widget::on_pushButton_9_clicked() //是否坠落
if(this-&ui-&pushButton_9-&isChecked())
this-&gameArea-&setKey_Down_Move_oneStep(true);
//按一下向下方向键,下移一步
this-&gameArea-&setKey_Down_Move_oneStep(false);
//按一下向下方向键,移动到底
this-&gameArea-&setFocus();
3.运行程序,测试一下效果。
(五)自己添加方块。
1.添加&添加方
2.修改其单击事件槽函数。
Widget::on_pushButton_10_clicked() //添加方块
this-&gameArea-&init_Game();
//清空游戏区域
this-&gameArea-&setbox(10,4);
this-&gameArea-&setbox(10,5);
this-&gameArea-&setbox(10,6);
//在第10行第4,5,6列添加三个方块
this-&gameArea-&gameStart();
//重新开始游戏
this-&gameArea-&draw_gameArea();
this-&gameArea-&setFocus();
3.运行程序,效果如下。
(六)设置旋转游戏区。
1.添加&旋转游戏&按钮。
2.修改其单击事件槽函数。
Widget::on_pushButton_11_clicked() //旋转游戏
this-&gameArea-&setRotate(true);
//开启旋转
this-&gameArea-&setGameAreaPixOrigin(100,200);
//设置游戏区域新的坐标原点
this-&gameArea-&setGameAreaPix(-100,-200);
//设置游戏区域的位置
this-&gameArea-&setRotateAngle(qrand()%360);
//旋转度数
this-&gameArea-&draw_gameArea();
this-&gameArea-&setFocus();
3.运行程序,效果如下。
分:游戏分析
可被外部调用的功能函数的
GameArea(QWidget *parent = 0); //不带定时器的构造函数
GameArea(int
speed,QWidget *parent = 0); //带定时器的构造函数
//以下是核心功能控制函数
init_gameArea(int X,int Y,int frame_width,int frame_height,int
width,int height,int boxStep,int start_x,int start_y);
moveOneStep();
bool isMoveEnd();
bool isGame_Over();
void init_Game();
void gameStart();
nextItem();
int getFullRowNum();
void do_MoveNext();
void draw_gameArea();
//以下是设置颜色函数
setGameAreaColor(QColor color=Qt::white);
setBoxBrushColor(QColor color=Qt::green);
setBoxPenColor(QColor color=Qt::black);
set_draw_box_picture(bool Bool=false);
setBoxPicture(QString fileName);
//以下是设置声音函数
setPlaySound_moveLeft(QString fileName,bool Bool=false);
setPlaySound_moveRight(QString fileName,bool Bool=false);
setPlaySound_moveDown(QString fileName,bool Bool=false);
setPlaySound_itemChange(QString fileName,bool Bool=false);
setPlaySound(bool Bool=false);
//以下是设置游戏区域旋转函数
setRotate(bool Bool=false);
void setGameAreaPixOrigin(int x,int
void setGameAreaPix(int x,int y);
setRotateAngle(int angle);
//以下是其他功能函数
setKey_Down_Move_oneStep(bool Bool = false);
setDrawGrid(bool Bool = true);
void setDrawNextItem(bool Bool
void setbox(int row,int col);
(二)游戏流程分析。
这里共有四个文件myitem.cpp ,myitem.h, gamearea.cpp, gamearea.h
myitem.cpp, myitem.h是方块类的定义文件,它用来提供随机产生的方块。
gamearea.cpp,
gamearea.h是游戏区域类的定义文件,它实现了游戏的所有功能。
为了帮助大家更好的理解源码,我们这里描述一下游戏的实现流
游戏实现的核心方法是什么?
这里是利用了数组对整个游戏
区域进行存储。
游戏是怎么实现显示现在和已有的图形的?
这里利用了两个数组,方
块每移动一步,都对整个数组进行一次备份。
游戏是怎么判断方块已经重合的?
是先尝试让方块移动一步,判断其是否与其他图形重合,如果不重合就移动。如果重合了,就进行其他操作。
是怎么进行消行的?
这里是让已满的行和它上面的所有的行均等于其上面的一行。
到这里整篇教程就结束了。这个方块游戏类还有很多功能不太完善,为了使代码更容易理解,也舍去了一些功能,例如让
不同方块显示不同的颜色等。大家可以参考
自带的例程进行完善,也很希望大家对这个类的源码进行修改和完善。
最后,如果你喜欢我的写作风格,并且初学
Qt,可以在我的空间查看Qt Creator系列教程,希望能对你的入门有所帮助。
本文已收录于以下专栏:
相关文章推荐
中秋无聊,女朋友加班,自己一个宅在宿舍写了一
QT 创建经典的Hello Word程序,一步步创建QT程序。
近日在学习Python的一些基础知识,觉得还是很有趣的一个一门语言!就目前的学习的一些知识,编写了一些一个简单的石头剪刀布的游戏。主要是熟悉一些Python的一些控制语句。import random
最近一直在用Qt折腾一个简单的俄罗斯方块游戏,期间断断续续经过将近一个月的折腾,终于完成啦,挂在这里,供大家评阅,第一次做游戏,肯定会有很多的不足之处,希望大家指正。
其实做这个游戏主要是想学学多层...
问题1:之前用安装包下载的软件qt creator 无法在命令行打开
solution:apt-get重新安装一次 qt creator 问题2:因为源代码是在QT4上编译的 而我的工程是QT5...
这几天在学习QT编程,编写过一些基本的qt对话框和简单的界面,对于一些简单的qt库的应用,如button,text,还有layout等界面布局管理。本以为已经可以对qt已经初步掌握了,可是发现离开教程...
Qt版双人俄罗斯方块游戏
转载请标明出处:牟尼的专栏 http://blog.csdn.net/u
之前写过《VC版双人俄罗斯方块》,将其在Qt下又重写了一遍,核...
看见身边好多同学都有写博客的好习惯,受他们潜移默化的影响,决定从今天开始起自己也要开始写博客。一方面方便自己偶尔查询已经忘记的知识点,另一方面也有利于巩固自己的知识体系,加深对已做过项目的认识与理解。...
他的最新文章
讲师:李江龙
讲师:司徒正美
您举报文章:
举报原因:
原文地址:
原因补充:
(最多只允许输入30个字)}

我要回帖

更多关于 unity 方块翻滚 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信