java课程设计报告书
图一,数字按钮功能模块
图二,三个功能按钮模块
图三,数据记录模块
图四,鼠标操作模块
2.2部分模块流程图:
3代码设计
packagemybase.programe;
/*
* lianliankan总体算法思路:由两个确定的按钮。若这两个按钮的数字相等,就开始找它们相连的路经。这个找路经
*分3种情况:(从下面的这三种情况,我们可以知道,需要三个检测,这三个检测分别检测一条直路经。这样就会有
<3>.重列按钮(帮助)的功能:游戏过程中,遇到困难难以寻找下一符合要求的一对数字,可按左下按钮重置重新排列 方可继续游戏。
<4>.退出按钮:击左下方的 “退出游戏”按钮,即可结束游戏。
1.2本系统涉及的知识点:
循环,javaGUI组件,函数,数组,分支等
2.功能设计
2.1算法设计
本系统需要实现的功能要求:
intgrid[][] =newint[8][7];
staticbooleanpressInformation=false;//判断是否有按钮被选中
intx0= 0,y0= 0,x= 0,y= 0,fristMsg= 0,secondMsg= 0,validateLV;//游戏按钮的位置坐标
inti,j,k,n;//消除方法控制
JLabelfractionLable=newJLabel("0");//实例化分数标签,并初始化为“0”
JButtonfirstButton,secondButton;//分别记录两次被选中的按钮
//储存游戏按钮位置(这里其实只要6行,5列。但是我们用了8行,7列。是等于在这个面板按钮的周围还围
//了一层是0的按钮,这样就可以实现靠近面板边缘的两个按钮可以消去)
《Java程序设计》课程设计报告
2015—2016学年第二学期
设计题目:《数字连பைடு நூலகம்看》
学生:黄杰
学 号:2
专业班级:软件工程1402
指导教师:国权
2016 年 7 月 2日
1.JAVA程序设计书3
1.1《简易连连看》3
1.1.1具体要求3
1.2本系统设计的知识点3
2.功能设计3
2.1算法设计3
2.2部分模块流程图4
*三条路经。若这三条路经上都是空按钮,那么就刚好是三种直线(两个转弯点)把两个按钮连接起来了)
* 1.相邻
*
* 2.若不相邻的先在第一个按钮的同行找一个空按钮。1).找到后看第二个按钮横向到这个空按钮
*所在的列是否有按钮。2).没有的话再看第一个按钮到与它同行的那个空按钮之间是否有按钮。3).没有的话,再从
for(intcols= 0;cols< 6;cols++) {
JFramemainFrame;//主面板
ContainerthisContainer;
JPanelcenterPanel,southPanel,northPanel;//子面板
JButtondiamondsButton[][] =newJButton[6][5];//游戏按钮数组
JButtonexitButton,resetButton,newlyButton;//退出,重列,重新开始按钮
3.代码设计5
4.界面及运行效果,测试工具与测试效果14
5.设计总结16
5.1.程序调试情况:16
5.2.本人在程序设计中感想:16
6.致16
主要参考文献16
:
1.1Java程序课程设计任务书
1.1《简易连连看游戏》
本程序基本实现了小游戏连连看的功能,玩家找出游戏中2个相同图案的方块,如果它们之间的连接线不多于3根直线,则将其连接起来,就可以成功将图案相同的方块消除,否则不会消失,当游戏中已没有满足条件的图案时,点击重列,可重新排序,游戏结束会跳出所得分数,该游戏的特点是与自己竞争,超过自己之前所创纪录。
publicvoidinit()
{
mainFrame=newJFrame("JKJ连连看");//实例化
thisContainer=mainFrame.getContentPane();//将thisContainer放入mainFrame的容窗口中
thisContainer.setLayout(newBorderLayout());//为thisContainer创建Borderlayout布局管理器
*那个空按钮横向到与第二个按钮同列看是否有按钮。没有的话路经就通了,可以消了。
*
*若以上三步都失败,说明这两个按钮不可以消去。
*/
importjavax.swing.*;
importjava.awt.*;
importjava.awt.event.*;
publicclassLianLianKanimplementsActionListener {
1.1.1具体要求(包括技术要求等):
<1>.该游戏界面为方格类型,由纵6横7的直线平行垂直交叉组成,分别是6行5列方块拼接,共有30格小方块。方块上随机分布一些数字,数字的要至少两两相同,位置随机打乱。
<2>.当将相同数字的方块连接,但要满足只能至少单边无阻碍呈直线趋势连接,否则无效,若连接一对成功就消失于界面,继续游戏,直到游戏结束,并能返回所得分数。
*与第一个按钮同行的那个空按钮竖向到与第二个按钮的同行看是否有按钮。没有的话路经就通了,可以消了.
*
* 3.若2失败后,再在第一个按钮的同列找一个空按钮。1).找到后看第二个按钮竖向到这个空按钮所在的行是否有按钮。
* 2).没有的话,再看第一个按钮到与它同列的那个空按钮之间是否有按钮。3).没有的话,再从与第一个按钮同列的
thisContainer.add(southPanel,"South");
thisContainer.add(northPanel,"North");
centerPanel.setLayout(newGridLayout(6, 5));//为centerPanel面板设置网格式布局管理器(6行5列)的容纳组建的网格
centerPanel=newJPanel();//实例化
southPanel=newJPanel();//实例化
northPanel=newJPanel();//实例化
thisContainer.add(centerPanel,"Center");//以下三行是为thisContainer容器添加不同方位的新的面板组件