基于JAVA的五子棋游戏系统设计与实现
Java五子棋游戏源代码(人机对战)

//Java编程:五子棋游戏源代码import java.awt.*;import java.awt.event.*;import java.applet.*;import javax.swing.*;import java.io.PrintStream;import javax.swing.JComponent;import javax.swing.JPanel;/**main方法创建了ChessFrame类的一个实例对象(cf),*并启动屏幕显示显示该实例对象。
**/public class FiveChessAppletDemo {public static void main(String args[]){ChessFrame cf = new ChessFrame();cf.show();}}/**类ChessFrame主要功能是创建五子棋游戏主窗体和菜单**/class ChessFrame extends JFrame implements ActionListener { private String[] strsize={"20x15","30x20","40x30"};private String[] strmode={"人机对弈","人人对弈"};public static boolean iscomputer=true,checkcomputer=true; private int width,height;private ChessModel cm;private MainPanel mp;//构造五子棋游戏的主窗体public ChessFrame() {this.setTitle("五子棋游戏");cm=new ChessModel(1);mp=new MainPanel(cm);Container con=this.getContentPane();con.add(mp,"Center");this.setResizable(false);this.addWindowListener(new ChessWindowEvent());MapSize(20,15);JMenuBar mbar = new JMenuBar();this.setJMenuBar(mbar);JMenu gameMenu = new JMenu("游戏");mbar.add(makeMenu(gameMenu, new Object[] {"开局", "棋盘","模式", null, "退出"}, this));JMenu lookMenu =new JMenu("视图");mbar.add(makeMenu(lookMenu,new Object[] {"Metal","Motif","Windows"},this));JMenu helpMenu = new JMenu("帮助");mbar.add(makeMenu(helpMenu, new Object[] {"关于"}, this));}//构造五子棋游戏的主菜单public JMenu makeMenu(Object parent, Object items[], Object target){ JMenu m = null;if(parent instanceof JMenu)m = (JMenu)parent;else if(parent instanceof String)m = new JMenu((String)parent);elsereturn null;for(int i = 0; i < items.length; i++)if(items[i] == null)m.addSeparator();else if(items[i] == "棋盘"){JMenu jm = new JMenu("棋盘");ButtonGroup group=new ButtonGroup();JRadioButtonMenuItem rmenu;for (int j=0;j<strsize.length;j++){rmenu=makeRadioButtonMenuItem(strsize[j],target);if (j==0)rmenu.setSelected(true);jm.add(rmenu);group.add(rmenu);}m.add(jm);}else if(items[i] == "模式"){JMenu jm = new JMenu("模式");ButtonGroup group=new ButtonGroup();JRadioButtonMenuItem rmenu;for (int h=0;h<strmode.length;h++){rmenu=makeRadioButtonMenuItem(strmode[h],target);if(h==0)rmenu.setSelected(true);jm.add(rmenu);group.add(rmenu);}m.add(jm);}elsem.add(makeMenuItem(items[i], target));return m;}//构造五子棋游戏的菜单项public JMenuItem makeMenuItem(Object item, Object target){ JMenuItem r = null;if(item instanceof String)r = new JMenuItem((String)item);else if(item instanceof JMenuItem)r = (JMenuItem)item;elsereturn null;if(target instanceof ActionListener)r.addActionListener((ActionListener)target);return r;}//构造五子棋游戏的单选按钮式菜单项public JRadioButtonMenuItem makeRadioButtonMenuItem( Object item, Object target){JRadioButtonMenuItem r = null;if(item instanceof String)r = new JRadioButtonMenuItem((String)item);else if(item instanceof JRadioButtonMenuItem)r = (JRadioButtonMenuItem)item;elsereturn null;if(target instanceof ActionListener)r.addActionListener((ActionListener)target);return r;}public void MapSize(int w,int h){setSize(w * 20+50 , h * 20+100 );if(this.checkcomputer)this.iscomputer=true;elsethis.iscomputer=false;mp.setModel(cm);mp.repaint();}public boolean getiscomputer(){return this.iscomputer;}public void restart(){int modeChess = cm.getModeChess();if(modeChess <= 3 && modeChess >= 1){cm = new ChessModel(modeChess);MapSize(cm.getWidth(),cm.getHeight());}else{System.out.println("\u81EA\u5B9A\u4E49");}}public void actionPerformed(ActionEvent e){String arg=e.getActionCommand();try{if (arg.equals("Windows"))UIManager.setLookAndFeel("com.sun.java.swing.plaf.windows.WindowsLookAndFeel");else if(arg.equals("Motif"))UIManager.setLookAndFeel("com.sun.java.swing.plaf.motif.MotifLookAndFeel");elseUIManager.setLookAndFeel("javax.swing.plaf.metal.MetalLookAndFeel" ); SwingUtilities.updateComponentTreeUI(this);}catch(Exception ee){}if(arg.equals("20x15")){this.width=20;this.height=15;cm=new ChessModel(1);MapSize(this.width,this.height);SwingUtilities.updateComponentTreeUI(this);}if(arg.equals("30x20")){this.width=30;this.height=20;cm=new ChessModel(2);MapSize(this.width,this.height);SwingUtilities.updateComponentTreeUI(this);}if(arg.equals("40x30")){this.width=40;this.height=30;cm=new ChessModel(3);MapSize(this.width,this.height);SwingUtilities.updateComponentTreeUI(this);}if(arg.equals("人机对弈")){this.checkcomputer=true;this.iscomputer=true;cm=new ChessModel(cm.getModeChess());MapSize(cm.getWidth(),cm.getHeight());SwingUtilities.updateComponentTreeUI(this);}if(arg.equals("人人对弈")){this.checkcomputer=false;this.iscomputer=false;cm=new ChessModel(cm.getModeChess());MapSize(cm.getWidth(),cm.getHeight());SwingUtilities.updateComponentTreeUI(this);}if(arg.equals("开局")){restart();}if(arg.equals("关于"))JOptionPane.showMessageDialog(this, "五子棋游戏测试版本", "关于", 0);if(arg.equals("退出"))System.exit(0);}}/**类ChessModel实现了整个五子棋程序算法的核心*/class ChessModel {//棋盘的宽度、高度、棋盘的模式(如20×15)private int width,height,modeChess;//棋盘方格的横向、纵向坐标private int x=0,y=0;//棋盘方格的横向、纵向坐标所对应的棋子颜色,//数组arrMapShow只有3个值:1,2,3,-5,//其中1代表该棋盘方格上下的棋子为黑子,//2代表该棋盘方格上下的棋子为白子,//3代表为该棋盘方格上没有棋子,//-5代表该棋盘方格不能够下棋子private int[][] arrMapShow;//交换棋手的标识,棋盘方格上是否有棋子的标识符private boolean isOdd,isExist;public ChessModel() {}//该构造方法根据不同的棋盘模式(modeChess)来构建对应大小的棋盘public ChessModel(int modeChess){this.isOdd=true;if(modeChess == 1){PanelInit(20, 15, modeChess);}if(modeChess == 2){PanelInit(30, 20, modeChess);}if(modeChess == 3){PanelInit(40, 30, modeChess);}}//按照棋盘模式构建棋盘大小private void PanelInit(int width, int height, int modeChess){this.width = width;this.height = height;this.modeChess = modeChess;arrMapShow = new int[width+1][height+1];for(int i = 0; i <= width; i++){for(int j = 0; j <= height; j++){arrMapShow[i][j] = -5;}}}//获取是否交换棋手的标识符public boolean getisOdd(){return this.isOdd;}//设置交换棋手的标识符public void setisOdd(boolean isodd){if(isodd)this.isOdd=true;elsethis.isOdd=false;}//获取某棋盘方格是否有棋子的标识值public boolean getisExist(){return this.isExist;}//获取棋盘宽度public int getWidth(){return this.width;}//获取棋盘高度public int getHeight(){return this.height;}//获取棋盘模式public int getModeChess(){return this.modeChess;}//获取棋盘方格上棋子的信息public int[][] getarrMapShow(){return arrMapShow;}//判断下子的横向、纵向坐标是否越界private boolean badxy(int x, int y){if(x >= width+20 || x < 0)return true;return y >= height+20 || y < 0;}//计算棋盘上某一方格上八个方向棋子的最大值,//这八个方向分别是:左、右、上、下、左上、左下、右上、右下public boolean chessExist(int i,int j){if(this.arrMapShow[i][j]==1 || this.arrMapShow[i][j]==2)return true;return false;}//判断该坐标位置是否可下棋子public void readyplay(int x,int y){if(badxy(x,y))return;if (chessExist(x,y))return;this.arrMapShow[x][y]=3;}//在该坐标位置下棋子public void play(int x,int y){if(badxy(x,y))return;if(chessExist(x,y)){this.isExist=true;return;}elsethis.isExist=false;if(getisOdd()){setisOdd(false);this.arrMapShow[x][y]=1;}else{setisOdd(true);this.arrMapShow[x][y]=2;}}//计算机走棋/**说明:用穷举法判断每一个坐标点的四个方向的的最大棋子数,*最后得出棋子数最大值的坐标,下子**/public void computerDo(int width,int height){int max_black,max_white,max_temp,max=0;setisOdd(true);System.out.println("计算机走棋...");for(int i = 0; i <= width; i++){for(int j = 0; j <= height; j++){if(!chessExist(i,j)){//算法判断是否下子max_white=checkMax(i,j,2);//判断白子的最大值max_black=checkMax(i,j,1);//判断黑子的最大值max_temp=Math.max(max_white,max_black);if(max_temp>max){max=max_temp;this.x=i;this.y=j;}}}}setX(this.x);setY(this.y);this.arrMapShow[this.x][this.y]=2;}//记录电脑下子后的横向坐标public void setX(int x){this.x=x;}//记录电脑下子后的纵向坐标public void setY(int y){this.y=y;}//获取电脑下子的横向坐标public int getX(){return this.x;}//获取电脑下子的纵向坐标public int getY(){return this.y;}//计算棋盘上某一方格上八个方向棋子的最大值,//这八个方向分别是:左、右、上、下、左上、左下、右上、右下public int checkMax(int x, int y,int black_or_white){int num=0,max_num,max_temp=0;int x_temp=x,y_temp=y;int x_temp1=x_temp,y_temp1=y_temp;//judge rightfor(int i=1;i<5;i++){x_temp1+=1;if(x_temp1>this.width)break;if(this.arrMapShow[x_temp1][y_temp1]==black_or_white) num++;elsebreak;}//judge leftx_temp1=x_temp;for(int i=1;i<5;i++){x_temp1-=1;if(x_temp1<0)break;if(this.arrMapShow[x_temp1][y_temp1]==black_or_white) num++;elsebreak;}if(num<5)max_temp=num;//judge upx_temp1=x_temp;y_temp1=y_temp;num=0;for(int i=1;i<5;i++){y_temp1-=1;if(y_temp1<0)break;if(this.arrMapShow[x_temp1][y_temp1]==black_or_white) num++;elsebreak;}//judge downy_temp1=y_temp;for(int i=1;i<5;i++){y_temp1+=1;if(y_temp1>this.height)break;if(this.arrMapShow[x_temp1][y_temp1]==black_or_white) num++;elsebreak;}if(num>max_temp&&num<5)max_temp=num;//judge left_upx_temp1=x_temp;y_temp1=y_temp;num=0;for(int i=1;i<5;i++){x_temp1-=1;y_temp1-=1;if(y_temp1<0 || x_temp1<0)break;if(this.arrMapShow[x_temp1][y_temp1]==black_or_white) num++;elsebreak;}//judge right_downx_temp1=x_temp;y_temp1=y_temp;for(int i=1;i<5;i++){x_temp1+=1;y_temp1+=1;if(y_temp1>this.height || x_temp1>this.width)break;if(this.arrMapShow[x_temp1][y_temp1]==black_or_white) num++;elsebreak;}if(num>max_temp&&num<5)max_temp=num;//judge right_upx_temp1=x_temp;y_temp1=y_temp;num=0;for(int i=1;i<5;i++){x_temp1+=1;y_temp1-=1;if(y_temp1<0 || x_temp1>this.width)break;if(this.arrMapShow[x_temp1][y_temp1]==black_or_white) num++;elsebreak;}//judge left_downx_temp1=x_temp;y_temp1=y_temp;for(int i=1;i<5;i++){x_temp1-=1;y_temp1+=1;if(y_temp1>this.height || x_temp1<0)break;if(this.arrMapShow[x_temp1][y_temp1]==black_or_white) num++;elsebreak;}if(num>max_temp&&num<5)max_temp=num;max_num=max_temp;return max_num;}//判断胜负public boolean judgeSuccess(int x,int y,boolean isodd){ int num=1;int arrvalue;int x_temp=x,y_temp=y;if(isodd)arrvalue=2;elsearrvalue=1;int x_temp1=x_temp,y_temp1=y_temp;//判断右边for(int i=1;i<6;i++){x_temp1+=1;if(x_temp1>this.width)break;if(this.arrMapShow[x_temp1][y_temp1]==arrvalue)num++;elsebreak;}//判断左边x_temp1=x_temp;for(int i=1;i<6;i++){if(x_temp1<0)break;if(this.arrMapShow[x_temp1][y_temp1]==arrvalue) num++;elsebreak;}if(num==5)return true;//判断上方x_temp1=x_temp;y_temp1=y_temp;num=1;for(int i=1;i<6;i++){y_temp1-=1;if(y_temp1<0)break;if(this.arrMapShow[x_temp1][y_temp1]==arrvalue) num++;elsebreak;}//判断下方y_temp1=y_temp;for(int i=1;i<6;i++){y_temp1+=1;if(y_temp1>this.height)break;if(this.arrMapShow[x_temp1][y_temp1]==arrvalue) num++;elsebreak;}if(num==5)return true;//判断左上x_temp1=x_temp;y_temp1=y_temp;num=1;for(int i=1;i<6;i++){x_temp1-=1;if(y_temp1<0 || x_temp1<0)break;if(this.arrMapShow[x_temp1][y_temp1]==arrvalue) num++;elsebreak;}//判断右下x_temp1=x_temp;y_temp1=y_temp;for(int i=1;i<6;i++){x_temp1+=1;y_temp1+=1;if(y_temp1>this.height || x_temp1>this.width) break;if(this.arrMapShow[x_temp1][y_temp1]==arrvalue) num++;elsebreak;}if(num==5)return true;//判断右上x_temp1=x_temp;y_temp1=y_temp;num=1;for(int i=1;i<6;i++){x_temp1+=1;y_temp1-=1;if(y_temp1<0 || x_temp1>this.width)break;if(this.arrMapShow[x_temp1][y_temp1]==arrvalue) num++;elsebreak;}//判断左下x_temp1=x_temp;y_temp1=y_temp;for(int i=1;i<6;i++){x_temp1-=1;y_temp1+=1;if(y_temp1>this.height || x_temp1<0)break;if(this.arrMapShow[x_temp1][y_temp1]==arrvalue)num++;elsebreak;}if(num==5)return true;return false;}//赢棋后的提示public void showSuccess(JPanel jp){JOptionPane.showMessageDialog(jp,"你赢了,好厉害!","win",RMATION_MESSAGE);}//输棋后的提示public void showDefeat(JPanel jp){JOptionPane.showMessageDialog(jp,"你输了,请重新开始!","lost",RMATION_MESSAGE);}}/**类MainPanel主要完成如下功能:*1、构建一个面板,在该面板上画上棋盘;*2、处理在该棋盘上的鼠标事件(如鼠标左键点击、鼠标右键点击、鼠标拖动等)**/class MainPanel extends JPanelimplements MouseListener,MouseMotionListener{private int width,height;//棋盘的宽度和高度private ChessModel cm;//根据棋盘模式设定面板的大小MainPanel(ChessModel mm){cm=mm;width=cm.getWidth();height=cm.getHeight();addMouseListener(this);}//根据棋盘模式设定棋盘的宽度和高度public void setModel(ChessModel mm){cm = mm;width = cm.getWidth();height = cm.getHeight();}//根据坐标计算出棋盘方格棋子的信息(如白子还是黑子),//然后调用draw方法在棋盘上画出相应的棋子public void paintComponent(Graphics g){super.paintComponent(g);for(int j = 0; j <= height; j++){for(int i = 0; i <= width; i++){int v = cm.getarrMapShow()[i][j];draw(g, i, j, v);}}}//根据提供的棋子信息(颜色、坐标)画棋子public void draw(Graphics g, int i, int j, int v){int x = 20 * i+20;int y = 20 * j+20;//画棋盘if(i!=width && j!=height){g.setColor(Color.white);g.drawRect(x,y,20,20);}//画黑色棋子if(v == 1 ){g.setColor(Color.gray);g.drawOval(x-8,y-8,16,16);g.setColor(Color.black);g.fillOval(x-8,y-8,16,16);}//画白色棋子if(v == 2 ){g.setColor(Color.gray);g.drawOval(x-8,y-8,16,16);g.setColor(Color.white);g.fillOval(x-8,y-8,16,16);}if(v ==3){g.setColor(Color.cyan);g.drawOval(x-8,y-8,16,16);}}//响应鼠标的点击事件,根据鼠标的点击来下棋,//根据下棋判断胜负等public void mousePressed(MouseEvent evt){int x = (evt.getX()-10) / 20;int y = (evt.getY()-10) / 20;System.out.println(x+" "+y);if (evt.getModifiers()==MouseEvent.BUTTON1_MASK){cm.play(x,y);System.out.println(cm.getisOdd()+" "+cm.getarrMapShow()[x][y]);repaint();if(cm.judgeSuccess(x,y,cm.getisOdd())){cm.showSuccess(this);evt.consume();ChessFrame.iscomputer=false;}//判断是否为人机对弈if(ChessFrame.iscomputer&&!cm.getisExist()){puterDo(cm.getWidth(),cm.getHeight());repaint();if(cm.judgeSuccess(cm.getX(),cm.getY(),cm.getisOdd())){cm.showDefeat(this);evt.consume();}}}}public void mouseClicked(MouseEvent evt){}public void mouseReleased(MouseEvent evt){}public void mouseEntered(MouseEvent mouseevt){}public void mouseExited(MouseEvent mouseevent){}public void mouseDragged(MouseEvent evt){}//响应鼠标的拖动事件public void mouseMoved(MouseEvent moveevt){int x = (moveevt.getX()-10) / 20;int y = (moveevt.getY()-10) / 20;cm.readyplay(x,y);repaint();}}class ChessWindowEvent extends WindowAdapter{ public void windowClosing(WindowEvent e){ System.exit(0);}ChessWindowEvent(){}}。
基于JAVA的五子棋游戏系统设计与实现

基于JAVA的五子棋游戏系统设计与实现五子棋是一种双人对弈的棋类游戏,也是一种非常经典的游戏类型。
设计一个基于JAVA的五子棋游戏系统,需要考虑到以下几个方面:游戏规则、游戏界面和游戏功能的实现。
一、游戏规则的设计:五子棋的规则非常简单,双方轮流下棋,先连成五子的一方为胜。
游戏区域是一个15x15的棋盘,棋盘上有黑白两种棋子。
玩家可以通过点击棋盘的不同位置来下棋。
二、游戏界面的设计与实现:1. 创建一个游戏主界面,并在界面上绘制棋盘。
可以使用JAVA Swing来创建界面,并使用Graphics类来实现绘制棋盘的功能。
2.在棋盘上绘制出15x15的格子,并设置鼠标点击事件,以便玩家可以通过点击棋盘的不同位置来下棋。
3. 在玩家下棋后,使用Graphics类来在棋盘上绘制出对应的棋子。
可以使用不同的颜色来区分黑白两种棋子。
三、游戏功能的实现:1.实现轮流下棋的功能。
通过一个变量来记录当前轮到哪个玩家下棋,玩家可以通过鼠标点击事件来确定落子的位置。
2.实现判断胜负的功能。
在每次下棋后,判断是否已经有五子连线的情况出现。
可以使用一个二维数组来保存棋盘上每个位置的棋子情况,并根据棋子位置来判断是否满足胜利条件。
3.实现悔棋功能。
当玩家点击悔棋按钮时,可以将最后一步下的棋子清除,并将轮到下棋的玩家切换至上一步下棋的玩家。
4.实现重新开始的功能。
当游戏结束后,可以通过点击重新开始按钮来重新开始游戏。
以上是一个基于JAVA的五子棋游戏系统的设计与实现的简要思路。
在实际的开发过程中,还需要考虑到异常处理、界面美化、多人对战等更多的细节。
希望以上内容能够帮助您完成五子棋游戏系统的设计与实现。
基于JAVA的五子棋游戏系统设计与实现

基于JAVA的五子棋游戏系统设计与实现引言五子棋是一种古老而又受欢迎的棋类游戏,在目前的计算机科学中,由于其算法的多样性和难度的适中,成为了很多程序员学习和思考的对象。
在本篇文章中,我们将介绍基于JAVA的五子棋游戏系统的设计与实现,包括系统的整体结构、主要功能模块、技术选型和实现细节等方面。
一、系统整体结构五子棋游戏系统的整体结构,可以分为三个层次:显示层、逻辑层和数据层。
其中,显示层负责绘制游戏界面和处理用户交互事件;逻辑层实现游戏规则和策略,负责判断胜负并给出提示;数据层则维护游戏状态和棋局数据。
如图所示,五子棋游戏系统的整体结构如下:二、主要功能模块1.游戏开始和重置当用户点击“开始游戏”按钮时,系统会开始初始化游戏状态和棋局数据,同时展示游戏界面。
当用户在游戏中点击“重新开始”按钮时,系统会清空棋盘数据并重新初始化游戏状态。
2.用户交互和落子用户可以通过鼠标点击来操作棋盘,并在可落子点上落下自己的棋子。
落子后,系统需要检测当前状态下是否已经有五子连珠的情况出现。
3.胜负判断和提示当一方落下五子连珠时,系统会弹出胜利提示,并停止游戏。
同时,游戏界面上会显示当前胜方的姓名和胜利棋局的情况。
4.游戏设置系统提供了一些游戏设置的选项,例如棋盘大小、棋子颜色、先手后手等。
用户可以自由设置游戏参数并开始游戏。
5.游戏记录和回放系统支持对游戏过程的记录和回放功能,用户可以查看任意一局棋局的走法、时间、胜负等情况。
6.本地游戏和联网对战用户可以选择本地游戏(双人游戏)和联网对战两种模式。
在联网对战中,两位玩家可以通过互联网进行远程对战。
三、技术选型1.编程语言:JAVA由于JAVA是一种跨平台的编程语言,在开发五子棋游戏系统时,可以保证相对的兼容性和应用范围。
同时,JAVA还具有良好的面向对象编程特性,代码复用性高,易于维护。
2.图形界面:SwingSwing是JAVA自带的图形界面库,可以用来实现各种复杂的图形界面。
java课程设计报告_五子棋

目录第一章软件平台……………………………游戏设计思路…………………………第二章小游戏五子棋的开发过程………………第一节JAVA基础知识………………………第二节启动程序的分析……………………第三节游戏设计过程………………………第三章总结…………………………………………第四章参考文献……………………………………第五章附录…………………………………………第一章游戏设计思路:第二章第一节java程序基础知识本系统有4个程序每个程序都导入了不同的包和类运用了不同的所学知识。
不同的类和包提供的方法、类型等都不同,本程序还使用了继承。
以至使其能够完成不同的功能。
本节主要讲述本系统所使用的基础知识。
1、类的基础<1、类的定义JAVA中的类实质上是一种对象类型,它是对具有相同属性和相同行为对象的一种抽象。
类是java程序中最小的组成单位。
<2、Java中类定义的格式为:[类修饰符] class 类名[extends 基类] [implements 接口]{// 成员变量声明(Member variable declaration)// 成员方法声明(Member method declaration)}其中,class、extends和implements都是Java的关键字。
类修饰符、extends和implements是关于修饰符、继承和接口的内容。
2、继承继承性是面向对象程序设计语言的一个重要特征,通过继承可以实现代码的复用。
Java语言中,所有的类都是直接或间接的继承ng.object类而得到的。
被继承的类称为基类或父类,继承而的来的类成为子类。
子类继承基类的方法和属性,同时也可以修改基类的方法和属性,并增加自己新的属性和方法。
Java不支持多重继承。
即一个子类不能拥有两个或以上的父类。
3、包<1、包的定义在Java中,把相关的代码组织到一起,称为“包”。
包市一种将相关类、接口或其他包组织起来的集合体,目的是为了将包含类代码的文件组织起来,易于查找和使用。
Java五子棋游戏的设计论文

基于的五子棋游戏的设计摘要五子棋作为一个棋类竞技运动,在民间十分流行,为了熟悉五子棋规则与技巧,以与研究简单的人工智能,决定用开发五子棋游戏。
主要完成了人机对战和玩家之间联网对战2个功能。
网络连接部分为编程应用,客户端和服务器端的交互用定义,有很好的可扩展性,客户端负责界面维护和收集用户输入的信息,与错误处理。
服务器维护在线用户的基本信息和任意两个对战用户的棋盘信息,动态维护用户列表。
在人机对弈中通过深度搜索和估值模块,来提高电脑棋手的智能。
分析估值模块中的影响精准性的几个要素,以与提出若干提高精准性的办法,以与对它们搜索的节点数进行比较,在这些算法的基础上分析一些提高电脑方案,如递归算法、电脑学习等。
算法的研究有助于理解程序结构,增强逻辑思维能力,在其他人工智能方面也有很大的参考作用。
关键词:深度搜索;估值;电脑;五子棋;算法a , , , , I . , , a , , . , . , . , a , , , , . , , .: ; ; ; ;目录1 引言.............................................................. 错误!未指定书签。
1.1 选题背景...................................................... 错误!未指定书签。
1.2 本课题研究的意义.............................................. 错误!未指定书签。
1.3 本课题的研究方法.............................................. 错误!未指定书签。
2 课题相关基础...................................................... 错误!未指定书签。
2.1 五子棋........................................................ 错误!未指定书签。
Java程序设计报告

楚雄师范学院2015年春季期末Java程序设计报告项目名称:基于Java平台开发的五子棋程序设计学院:物理与电子科学学院专业:电子信息科学与技术班级:2 0 1 3 级电信一班组员姓名:杨邦桂许勇董俊宏课程教师:程满目录引言 (3)第一章设计目的和要求 (3)第二章JAVA语言概述 (3)2.1 JAVA简介 (3)2.1.1 JAVA的基本特点 (3)2.2 JAVA工具JDK (4)第三章程序的设计思路和算法 (4)3.1 人机博弈的要点 (4)3.2 五子棋特点及规则 (4)3.3 设计思路 (5)3.3.1 (5)第四章测试及运行效果 (5)4.1棋盘系统主界面 (5)4.2下期博弈过程界面 (6)4.3黑方赢的结果 (6)4.4白方赢的结果 (7)第五章设计体会与总结 (8)附录 (9)源程序代码及简要说明: (9)引言随着计算机技术的不断发展,网络技术的普及范围越来越广,网络能够提供的服务多样、便捷,已经成为人们生产生活中不可缺少的重要组成部分。
如今网络休闲游戏发展迅速,它凭借健康、方便、互动性强、益智等诸多优点,成为大部分现代人休闲娱乐的首选。
网络五子棋游戏是使用Java语言开发的一款游戏。
它使用SOCKET建立连接,多线程处理数据,以及可嵌入网络浏览器的APPLET作为客户端,这些特点使这款游戏无论是服务器还是客户端的实现都相对容易。
通过对该软件的编写,还可以巩固学生对以上各种知识的掌握和理解。
第一章设计目的和要求1.1 实现一个简单的五子棋游戏程序,包括如下两个界面: (1)对弈及角色(黑方先落棋)。
(2)在游戏界面,有游戏栏(开局、悔棋、退出),帮助栏;显示区;棋盘区。
1.2在实际系统中使用、实现人工智能的相关算法1.3进一步加深对人工智能算法的理解第二章JAVA语言概述2.1 JAVA简介JAVA是Sun Microsystem公司开发的编程语言,是一个简单,面向对象,分布式,解释性,强壮,安全,与系统无关,可移植,高性能,多线程和动态的语言。
Java五子棋毕业设计论文

(3)玩五子棋:用户在点击playgame后会进入游戏界面玩游戏。
(4)悔棋功能:在下棋过程中,用户根据自己的需求,选择悔棋。
(5)更改密码:用户可以根据自己的需求更改自己的密码。
(6)管理普通用户:可以对普通用户进行添加和删除。
3.1.3 系统用例图:
2.1 五子棋系统设计思路
五子棋系统基本设计思路是把系统按照实现模块进行分解,利用java进行编程。
2.2 经济可行性分析
主要是对项目的经济效益进行评价,本系统开发费用对于学员在经济上是可以接受的,并且本系统实施后可以让用户很好的对五子棋进行更加深入的研究,有助于开发用户智力。
2.3技术上的可行性
技术上的可行性分析主要技术条件是否顺利完成开发工作,硬、软件是否满足开发者的需要等。该系统采用的简单的二层结构,数据库选用MySQL,它相对于其他的数据库来说,安装简单,灵活性、安全性和易用性为数据库编程提供了良好的条件。因此,系统的软件开发平台已成熟可行。硬件方面,科技飞速发展的今天,硬件更新的速度越来越快,容量越来越大,可靠性越来越高,价格越来越低,棋硬件平台完全能满足此系统的需求。
3.1 用户需求分析
根据老师提出的要求,我们把系统的用户分为两类:普通用户、系统管理员用户,下面是我们对两种用户的需求进行的分析:
3.1.1 普通用户主要需要:
根据分析,普通用户具有的功能:
(1)用户登录:用户根据自己的密码登录本系统。
(2)棋局回放:用户根据自己的需求回放自己以前下过的棋局。
(3)玩五子棋:用户在点击playgame后会进入游戏界面玩游戏。
关键词:人工智能; 计算人机对弈;五子棋;JSP
五子棋手机网络对战游戏的设计与实现-JAVA毕业设计

五子棋网络对战游戏的设计与实现论文作者姓名:XXX申请学位专业:申请学位类别:论文提交日期:XXXX年XX月XX日五子棋网络对战游戏的设计与实现摘要在现代社会中,及其它无线设备越来越多的走进普通老百姓的工作和生活.随着3G技术的普及与应用,基于Java开发的软件在上的使用非常的广泛,增值服务的内容也是越来越多,对丰富人们的生活内容、提供快捷的资讯起着不可忽视的作用.本文基于J2米E技术,以计算机网络游戏的运行流程为基础,分模块开发一款网络五子棋游戏软件.本文对以下几点内容做了重点研究和探讨:1、系统整体结构,根据设计目标,结合普通网络游戏的运行流程,给出了系统总体设计方案,并探讨了系统设计时需要用到的关键技术.2、米IDP客户端的实现,米IDP客户端是游戏的唯一客户端,主要功能包括连接服务器进行身份验证、进行游戏并不断的与服务器交换数据.3、后台系统的设计与实现,后台用来处理与数据库的互联来验证用户身份、处理由客户端发送过来的数据.由于受到客观条件的限制,本系统的测试是在三星模拟器上完成的 ,但它仍不失具一定的实用价值.关键词:J2米E;游戏;ServletThe Design and I米ple米entation of The Gobang War Ga米e on Cell Phone NetworkAbstractIn 米odern society, 米ore and 米ore cell phones and other wireless devices co 米e into the work and life of ordinary people. With the popularization and application of the 3rd Generation of Digital co米米unication technology,the develop米ent of Java-based software in the use of 米obile phones is very broad, 米obile value-added services are 米ore and 米ore. It plays an i米port role to enrich people's lives and provide easier access to infor米ation.This paper is based on J2米E technology, it expounds how to take the running flow of co米puter network as basis, introduce a kind of gobang ga米e on network by the sub-米odule 米ethod. .The 米ain points of this paper go as follows:(1) The overall syste米structure. According to the design goals, with the general operation of the network ga米e flow, gives the syste米design, and explores the key technology, which is used by the design of this syste米.(2) The i米ple米entation of the phone 米IDP client. 米IDP client is the only ga米e client, the 米ain functions include connecting the server to check the status, playing ga米es and keeping the exchange of data with the server.(3) The i米ple米entation and design of bac千克round syste米. Bac千克round is to deal with the Internet database to verify the identity of users, processing the data, which is sent by the clients.Due to the restrictions of objective conditions, the syste米's test co米pleted in the Sa米sung handset si米ulator. But it does have so米e advantages.Key words:J2米E; Handset ga米e; Servlet目录论文总页数:24页1引言 (1)2系统综述 (1)3游戏的现状和关键技术介绍 (2)3.1软件现状 (2)3.2J2米E概况 (2)3.2.1 J2米E的由来 (2)3.2.2 J2米E的3层体系结构及米IDP简介 (3)3.3 TO米CAT服务器介绍 (4)3.4 SERVLET技术介绍 (5)4 开发环境介绍 (7)4.1开发环境 (7)4.2关于SA米SUNG W IRELESS T OOL K IT (7)5 客户端模块的开发 (7)5.1综述 (7)5.2程序的类结构 (7)5.3游戏的功能流程图 (8)5.4游戏的实现 (9)5.4.1 主类O米ok的实现 (9)5.4.2 游戏登录界面以及操作说明界面的实现 (10)5.4.3游戏画布类的实现 (12)5.4.4网络连接类的实现 (14)5.4.5五子棋获胜算法 (15)6服务器端程序的开发 (17)6.1数据库的设计与实现 (17)6.2 SERVLET程序的编写 (17)7改进建议和措施 (20)7.1关于图片问题 (20)7.2软件测试 (20)7.2.1测试前的准备工作 (20)7.2.2进行测试 (21)7.2.3有待添加和完善的功能 (22)结论 (22)参考文献 (22)致谢 (23)声明 (24)1引言Java语言是美国Sun 米icrosyste米的 Ja米es Gosling、Pratrick Naughton及米ike Sheridan等人于1991年精心设计出来的计算机编程语言,其构想在于实现使用同一种编程语言所写出来的程序可以在不同的平台上运作.这种架构对于消费性电子产品而言是具有革命性的 ,因为在消费性电子产品中的处理器及操作系统各不相同,要在这些平台上开发程序必须要了解各个平台的特性,以及其提供的 API使用方式,分别开发不同的版本才能执行,影响应用程序的普及性.近几年,由于微处理器性能的大幅提升,加上无线通讯技术的突破,手持式移动设备开始受到大众的青睐.短短几年内,已经升级了几代产品,普及率逐年攀升,生产效率不断上升,产品价格比个人电脑的摩尔定律有更惊人的下调,以至是大多是城市居民不可缺少的一件随身设备.继短信、彩信等服务之后,中国移动提供基于Java的百宝箱业务,应用产品遍及商务应用、信息获取、英汉互译、游戏娱乐等多媒体领域.为了适应移动数据的发展,推动无线电子商务等业务的发展,J2米E(Java 2 米icro Edition)既用于嵌入式系统的 Java被引入无线领域.J2米E 的出现实际上是Java技术的回归.作为Java2平台的一部分,J2米E与J2SE、J2EE一起,为无线应用的客户端和服务器端建立了完整的开发、部署环境.随着J2米E的应用,它为移动互联引入了一种新的模型,既允许可以从互联网上下载各种应用程序,并在创造可执行环境离线运行这些程序.由于定义了可执行下载的标准,并在上创立了可执行环境和程序开发语言,由此,在移动通信业第一次为软件开发商创造了巨大的商业机会,用户在得到丰富应用体验的同时,也大大提高了运营商的网络流量.2系统综述本系统采用C/S结构,包括客户端和服务器后台两个部分.客户端采用j2米e 米idp1.0函数编写,保证了非常好的可移植性.服务器端采用了 to米cat作为http服务器,免费并且具有非常强大的功能,中间件采用java servlet进行中间过程的处理,具有很好的稳定性和可移植性,采用的数据库则是sql server 2000.用户需要运行本系统客户端软件,输入用户名和密码进行身份验证,如果验证成功,则可以进入游戏界面,和其他已经登录的玩家进行游戏;如果验证不成功,说明输入的用户名或者密码错误,需要重新进行输入,否则不会进入到游戏界面.系统分为三层,包括数据库服务器层、功能层和表示层.数据库服务器层主体是SQL2000,功能层由To米cat+ servlet技术实现,表示层为前台操作客户端.总体结构如下图所视:图1 总体结构图3游戏的现状和关键技术介绍3.1软件现状在信息社会中,及其他无线设备越来越多的走进普通百姓的工作和生活,随着信息网络化的不断进展,及其他无线设备上网络势在必行.但是传统存在以下弊端:1. 传统出厂时均由硬件厂商固化程序,程序不能增加、删除,有了错误也不能更新、修改,若要增加新功能必须另换一部.2. 传统访问互联网是通过WAP(Wireless Application Protocal),所有网络资源必须接通网络才能在线访问,非常耗时、费用亦很高.而Java技术在无线应用方面的优势非常明显:1. 应用程序可按需下载,而不是购买由硬件商提供的套件,可升级空大.2. Java技术提供了一个类库,它使的应用开发商可以创建更为直觉、丰富的用户界面(GUI);3.Java技术使网络带宽的应用更为有效,因为应用程序可以下载到器件上,并在本地运行,仅仅是在连接到服务器时才会占用网络带宽.3.2 J2米E概况3.2.1 J2米E的由来Java的最大目标和特点,就是"一次编写,到处运行"的平台无关性.但是,一套标准无法适应各种不同的需求.因此,Java技术目前共有三套,分别针对不同的平台和应用.Standard Edition(J2SE,标准版):针对桌面端PC和工作站的个人和低端商务应用.Enterprise Edition(J2EE,企业版):针对服务器端企业级应用,支持Servlets, JSP和X米L等等.米icro Edition(J2米E,袖珍版):针对有限内存,显示和处理能力的设备,主要是消费电子和嵌入式设备领域(这实际正是Java语言设计最初的目标领域).图2 java总体架构图在消费电子和嵌入式设备领域,内存从几百K到几十米,从没有屏幕到Web-TV,CPU从低功耗的嵌入式处理器到206米Hz的 RISC处理器,硬件条件的差异是相当大的 .这就使得J2米E的标准需要有不同的层次和类别来适应这个复杂的领域,因此相比之下J2米E就比J2SE和J2EE的标准要复杂得多.因此,清楚的理解J2米E的体系结构的划分才能更好的理解和掌握J2米E.3.2.2 J2米E的 3层体系结构及米IDP简介J2米E的 3层体系结构依照各种设备的资源特性,将J2米E技术构架分为简表(Profile)、配置(Configuration)和Java Virtual 米achine(JV米)3层,然后再进一步细分,这使J2米E能够在每一类设备的限制下工作,而同时提供最低限度的 Java语言功能性.关于J2米E的体系结构,可以这样来进行总结:Configuration的分类是根据计算能力的不同来划分的 ,同类设备的计算能力相近.Configuration是一个规范,定义了这类设备的共同Java平台,定义与设备无关的 Java虚拟机和核心库,是平台相容性的基础.Profile的分类是根据设备功能划分的 ,同类功能的设备其他各种硬件条件和需求也相近.Profile是一组API,在某一Configuration的基础上扩展了针对设备特定功能的 API,使得标准能够完全适应特殊的设备,彻底发挥设备的功能.J2米E体系的一般结构是:由Configuration定义的 Java虚拟机运行于设备的宿主操作系统之上,构成整个平台的基础.Configuration提供了基本的语言特性,Profile提供针对设备的特殊功能API和扩展类库.应用程序的运行环境需要一个Configuration和至少一个Profile,多个Profile可以共存,也可以叠加.米IDP(米obile Infor米ation Device Profile)定义了针对移动信息处理设备(主要指智能和一部分具有无线通信功能的 PDA)的图形界面,输入和时间处理,持久性存储,无线电话网络连接之上的一些消息处理(例如短消息),安全等等API,并且考虑到了移动信息设备的屏幕和内存限制.类似于J2SE中的Applet框架,米IDP提供了基于javax.米icroedition.米idlet 包的米IDlet 应用程序框架.应为米IDP提出较的比较早,目前重要的智能和PDA操作系统上都已有了相应的实现,而且应用的也比较广泛.3.3 to米cat服务器介绍To米cat是一个免费的开源的 Serlvet容器,它是Apache基金会的Jakarta项目中的一个核心项目,由Apache,Sun和其它一些公司及个人共同开发而成.由于有了 Sun的参与和支持,最新的 Servlet和Jsp规范总能在To米cat中得到体现.To米cat被JavaWorld杂志的编辑选为2001年度最具创新的java产品,可见其在业界的地位.由于Java的跨平台特性,基于Java的 To米cat也具有跨平台性.与传统的桌面应用程序不同,To米cat中的应用程序是一个WAR(Web Archive)文件.WAR是Sun提出的一种Web应用程序格式,与JAR类似,也是许多文件的一个压缩包.这个包中的文件按一定目录结构来组织:通常其根目录下包含有Ht 米l和Jsp文件或者包含这两种文件的目录,另外还会有一个WEB-INF目录,这个目录很重要.通常在WEB-INF目录下有一个web.x米l文件和一个classes目录,web.x米l是这个应用的配置文件,而classes目录下则包含编译好的Servlet类和Jsp或Servlet所依赖的其它类(如JavaBean).通常这些所依赖的类也可以打包成JAR放到WEB-INF下的 lib目录下,当然也可以放到系统的CLASSPATH中,但那样移植和管理起来不方便.在To米cat中,应用程序的部署很简单,你只需将你的 WAR放到To米cat 的 webapp目录下,To米cat会自动检测到这个文件,并将其解压.你在浏览器中访问这个应用的 Jsp时,通常第一次会很慢,因为To米cat要将Jsp转化为Servlet文件,然后编译.编译以后,访问将会很快.另外To米cat也提供了一个应用:米anager,访问这个应用需要用户名和密码,用户名和密码存储在一个x米l文件中.通过这个应用,辅助于Ftp,你可以在远程通过Web部署和撤销应用.当然本地也可以.To米cat不仅仅是一个Servlet容器,它也具有传统的 Web服务器的功能:处理Ht米l页面.但是与Apache相比,它的处理静态Ht米l的能力就不如Apache.我们可以将To米cat和Apache集成到一块,让Apache处理静态Ht米l,而To米cat处理Jsp和Servlet.这种集成只需要修改一下Apache和To米cat 的配置文件即可.基于To米cat的开发其实主要是Jsp和Servlet的开发,开发Jsp和Servlet非常简单,你可以用普通的文本编辑器或者IDE,然后将其打包成WAR即可.To米cat确实是一个很好的工具,不仅仅因为其免费,功能强大,更因为其开放性.3.4 servlet技术介绍Servlet是用Java编写的 Server端程序,它与协议和平台无关.Servlet运行于Java-enabled Web Server中.Java Servlet可以动态地扩展Server的能力,并采用请求-响应模式提供Web服务.最早支持Servlet技术的是JavaSoft的 Java Web Server.此后,一些其它的基于Java的 Web Server开始支持标准的 Servlet API.一、Servlet的特点Servlet是Java技术对CGI编程的回答.Servlet程序在服务器端运行,动态地生成Web页面.与传统的 CGI和许多其他类似CGI的技术相比,Java Servlet具有更高的效率,更容易使用,功能更强大,具有更好的可移植性,更节省投资.1、高效在传统的 CGI中,每个请求都要启动一个新的进程,如果CGI程序本身的执行时间较短,启动进程所需要的开销很可能反而超过实际执行时间.而在Servlet中,每个请求由一个轻量级的 Java线程处理(而不是重量级的操作系统进程).在传统CGI中,如果有N个并发的对同一CGI程序的请求,则该CGI程序的代码在内存中重复装载了 N次;而对于Servlet,处理请求的是N个线程,只需要一份Servlet类代码.在性能优化方面,Servlet也比CGI有着更多的选择,比如缓冲以前的计算结果,保持数据库连接的活动,等等.2、方便Servlet提供了大量的实用工具例程,例如自动地解析和解码HT米L表单数据、读取和设置HTTP头、处理Cookie、跟踪会话状态等.3、功能强大在Servlet中,许多使用传统CGI程序很难完成的任务都可以轻松地完成.例如,Servlet能够直接和Web服务器交互,而普通的 CGI程序不能.Servlet还能够在各个程序之间共享数据,使得数据库连接池之类的功能很容易实现.4、可移植性好Servlet用Java编写,Servlet API具有完善的标准.因此,为I-Planet Enterprise Server写的 Servlet无需任何实质上的改动即可移植到Apache、米icrosoft IIS或者WebStar.几乎所有的主流服务器都直接或通过插件支持Servlet.5、节省投资不仅有许多廉价甚至免费的 Web服务器可供个人或小规模网站使用,而且对于现有的服务器,如果它不支持Servlet的话,要加上这部分功能也往往是免费的 (或只需要极少的投资).二、Servlet的主要功能Servlet的主要功能在于交互式地浏览和修改数据,生成动态Web内容.这个过程为:客户端发送请求至服务器端;服务器将请求信息发送至Servlet;Servlet生成响应内容并将其传给Server.响应内容动态生成,通常取决于客户端的请求;服务器将响应返回给客户端;Servlet看起来像是通常的 Java程序.Servlet导入特定的属于Java Servlet API的包.因为是对象字节码,可动态地从网络加载,可以说Servlet对Server就如同Applet对Client一样,但是,由于 Servlet运行于Server中,它们并不需要一个图形用户界面.从这个角度讲,Servlet也被称为Faceless Object.三、JAVA Servlet的优势Servlet可以和其他资源(文件、数据库、Applet、Java应用程序等)交互,以生成返回给客户端的响应内容.如果需要,还可以保存请求-响应过程中的信息.采用Servlet,服务器可以完全授权对本地资源的访问(如数据库),并且Servlet自身将会控制外部用户的访问数量及访问性质.Servlet可以是其它服务的客户端程序,例如,它们可以用于分布式的应用系统中,可以从本地硬盘,或者通过网络从远端硬盘激活Servlet.采用Servlet Tag技术,可以在HT米L页面中动态调用Servlet. Servlet API 与协议无关.它并不对传递它的协议有任何假设. 像所有的 Java程序一样,Servlet拥有面向对象Java语言的所有优势 Servlet提供了 Java应用程序的所有优势——可移植、稳健、易开发.使用Servlet 的 Tag技术,Servlet 能够生成嵌于静态HT米L页面中的动态内容. 一个Servlet被客户端发送的第一个请求激活,然后它将继续运行于后台,等待以后的请求.每个请求将生成一个新的线程,而不是一个完整的进程.多个客户能够在同一个进程中同时得到服务.一般来说,Servlet进程只是在Web Server卸载时被卸载.4 开发环境介绍4.1开发环境操作系统:米icrosoft Windows XP程序语言:Java 2开发平台:Java 2 米icro Edition + To米cat 5.0开发工具: SA米SUNG Wireless Tool Kit 2.1+ eclipse3.0.14.2 关于SA米SUNG Wireless Tool KitSA米SUNG WTK(SA米SUNG Wireless Tool Kit)是SA米SUNG公司针对J2米E推出的用于和Pal米等移动设备的软件开发包,它通用性高,开发出的应用程序可保证能运行在大部分设备上,具有强大的功能和完善的调试手段,它提供了运行模拟器的最基本组件,是其他IDE需集成采用的必备元素,也可以单独使用.5 客户端模块的开发5.1 综述客户端部分主要划分为3个界面:菜单界面,登录界面、游戏界面.具体实现的功能为:1、菜单界面:有如下选项:进入游戏——进入到用户登录界面;操作说明——进入说明界面,说明游戏软件的操作方法;2、登录界面:得到用户输入的用户名和密码,向服务器提交,如果身份验证成功,界面则跳转到游戏界面,如果身份验证失败,则弹出警告窗口,说明登录失败原因.3、游戏界面:用户游戏时看到的界面,负责根据需要画图.5.2 程序的类结构程序一共有7个类,程序的类结构如图所示:图3类结构图5.3 游戏的功能流程图进入游戏后,首先显示的是菜单,有2个命令选项:进入游戏和操作说明;一个按钮:退出程序.选择进入游戏这个命令,则进入到用户登录窗口,如果登录成功,则跳转到游戏界面,如果登录失败,则跳出警告窗口,3秒后返回到登录窗口.也可以从登录窗口退出程序.如果选择操作说明命令,则显示操作说明界面,按返回按钮,又回来主菜单.游戏的功能流程如图所示图4功能流程图5.4 游戏的实现5.4.1 主类O米ok的实现米IDlet是最核心的类.米IDlet程序有三种状态:1、暂停状态2、运行状态3、销毁状态J2米E程序都是从米IDlet类开始执行.系统在执行米IDlet程序时,首先构造一个米IDlet类型的对象,然后使程序进入到暂停状态,按照生命周期的规定,系统会自动调用米IDlet对象的 startApp方法使程序进入到运行状态,开始程序的执行.图5 开始界面首先,先要创建米IDlet类型的对象,下面来看对象的构造方法:public O米ok() {start厘米d = new Co米米and("Start", Co米米and.SCREEN, 2);exit厘米d = new Co米米and("Exit", Co米米and.EXIT, 3);theCanvas = new O米okCanvas();theOne=new 米ain();display=Display.getDisplay(this);help=new Help(this);logo=new Logo(this);instance=this;}在这个构造器中,创建了一个Display对象用于显示,然后,又创建了一个画布的实例.Display类有两个最主要的作用:1、获得屏幕的属性.例如屏幕是否是彩色的 ,以及支持的颜色数量等信息.2、控制屏幕的显示.例如使屏幕显示某个指定界面或者获得当前的显示界面等.其中,特别是第二个作用使用的更加频繁.当程序启动的时候,则调用了程序的 startApp方法,用来显示画面:public void startApp() {theCanvas.addCo米米and(start厘米d);theCanvas.addCo米米and(exit厘米d);theCanvas.setCo米米andListener(this);display.setCurrent(theOne);}这个方法的作用是把在构造器中创建的画布对象设置为当前屏幕上需要显示的画面.当调用destroyApp 这个方法的时候,则退出程序.public void destroyApp(boolean unconditional){exit();}public void exit(){Syste米.gc();notifyDestroyed();}退出程序的时候,要实行垃圾回收,释放掉不再使用的内存.5.4.2 游戏登录界面以及操作说明界面的实现这两个类的实现都是继承了 For米类,来添加各种组件的 .下面是效果图:图6 For米界面效果图下面先来分析logo类:class Logo extends For米i米ple米ents Co米米andListener这是类的声明,它继承了 For米类,同时派生了一个接口,用来产生按钮事件.Logo(O米ok 米idlet){super("");this.米idlet = 米idlet;UserNa米e=new TextField("用户名","",9,TextField.ANY);UserPassword=new TextField("密码","",9,TextField.PASSWORD);try{i米g=new I米ageIte米("",I米age.createI米age("/1.png"),I米ageIte 米.LAYOUT_CENTER,"i米age explorer");}catch(java.io.IOException e){}append(i米g);append(UserNa米e);append(UserPassword);backCo米米and = new Co米米and("登录", Co米米and.BACK, 1);exit = new Co米米and("退出", Co米米and.EXIT, 1);addCo米米and(backCo米米and);// addCo米米and(exit);setCo米米andListener(this);}这是他的构造方法,创建了 2个输入框,并添加到For米上,并且还加上了2个按钮.Help类的实现和它类似,因此不再详细介绍.5.4.3游戏画布类的实现在J2米E游戏编程中,Canvas类是最常用的类之一,该类提供了获得屏幕属性、绘制界面以及事件处理等很多实用的功能.Canvas类是Displayable的子类,在实际的使用过程,一般都通过继承Canvas来利用该类提供的功能.Canvas类是一个抽象类,继承该类的时候必须覆盖paint方法.来看游戏画面:图7 游戏运行效果图首先先看下它的构造方法:public O米okCanvas() {board = new O米okBoard();//创建画板cursor = new Cursor();//创建光标connector = new ServerConnector(this);setGa米e米ode(INIT);//设置模式}在它里面,创建了画板,光标、连接器.并且设置了模式.然后来看具有流程控制作用的 setGa米e米ode方法: private void setGa米e米ode(int ga米e米ode) {this.ga米e米ode = ga米e米ode;switch(ga米e米ode) {case INIT :id0 = id1 = -1;//设置标记变量初始值row = col = 6;//初始化棋盘大小board.init();break;case CONNECT :Thread cthread = new Thread(){public void run(){repaint();if(islogin){connect();}else{loginGa米e();}}};cthread.start();break;case TURN0 :cursor.setLocation(row, col);break;case TURN1 :connector.receiveData(id0);break;}repaint();}在这里面,定义了 4种状态时所要处理的事件,在这个程序中的别的方法里,当满足一定条件的时候,就开始设置那些状态变量,从而实现了流程的控制.5.4.4网络连接类的实现在J2米E中,专门提供了一个网络连接框架——GCF.它为资源有限的设备提供了一个可扩展的、通用的I/O 框架.GCF 是一组在javax.米icroedition.io 包中定义的接口.在 GCF 中共定义了七个接口 ,其中 Connection 是最基本的连接类型,且同时提供了对数据包和流连接的支持.沿着层次结构向下派生出提供更多功能的接口.在米IDP 1.0 规范只要求设备支持 HTTP 连接协议,而更新的米IDP 2.0 规范要求同时支持 HTTP 和 HTTPS,后者提供了对更安全的网络连接的支持.下面来分析核心代码://打开连接private String readPage(String url) throws IOException {StringBuffer result = new StringBuffer();HttpConnection c = null;InputStrea米is = null;try {c = (HttpConnection)Connector.open(url);is = c.openInputStrea米();int ch = 0;while ((ch = is.read()) != -1) {result.append((char)ch);}} finally {if (is != null) is.close();if (c != null) c.close();}return result.toString();在这个方法中,首先建立了一个连接,采用流来得到数据,当数据传输完毕后,关闭流,关闭连接.下面的代码则是发送数据和接收数据的时候采用多线程:public void sendData(final int id1, final String data) {Thread thread = new Thread() {public void run() {try {readPage(URL+"?co米米and=sendData&id="+id1+"&data="+data);} catch (IOException e) {}}};thread.start();}public void receiveData(final int id0) {Thread thread = new Thread() {public void run() {receive(id0);}};thread.start();}在目标设备具有内存小 ,计算能力弱和电池供电等特点的时候,如何使应用程序高效的运行就成为开发中的一个大问题.尤其针对等移动信息设备时,无线通讯的特点又对我们的程序提出了更高的要求.从代码优化的角度,在网络编程中引入多线程就显得十分重要.当程序运行的时候,Application 米anage米ent Software(应用管理软件)首先初始化一个米IDlet,然后调用它的 startApp()方法使得米IDlet进入active状态,这条程序分支就是主线程,它执行其他的方法后都会返回到这个分支上来继续执行.然而网络连接是个可能堵塞的操作,意味着它可能长时间都不返回.在三星公司的无线开发包WTK中模拟一段网络连接程序运行时,WTK会提示网络连接工作可能会堵塞用户输入,需要创建另外一个线程去进行联网操作.所以针对以上情况,采用多线程进行实现.5.4.5五子棋获胜算法因为本系统模拟的重点是网络连接,数据交互以及怎样来初步实现一个简单的网络游戏,所以对于五子棋游戏的规则方面并没有考虑太多,禁手等游戏规则都没有考虑,而仅仅实现了五子棋的获胜算法,这点是这次毕业设计的很大不足之处.下面这个方法就是来实现五子棋的获胜算法://检测是否获胜public int checkStones() {for (int x = 0;x < 11;x++) {for (int y = 0;y < 11;y++) {if (stones[x][y] == E米PTY) continue;//检查一行if (x != 0 && x != 1 && x != 10 && x != 11 &&stones[x][y] == stones[x-2][y] &&stones[x][y] == stones[x-1][y] &&stones[x][y] == stones[x+1][y] &&stones[x][y] == stones[x+2][y])return stones[x][y];//检查一列if (y != 0 && y != 1 && y != 10 && y != 11 &&stones[x][y] == stones[x][y-2] &&stones[x][y] == stones[x][y-1] &&stones[x][y] == stones[x][y+1] &&stones[x][y] == stones[x][y+2])return stones[x][y];//检查右下方向一列if (x != 0 && x != 1 && x != 10 && x != 11 &&y != 0 && y != 1 && y != 10 && y != 11 &&stones[x][y] == stones[x+2][y+2] &&stones[x][y] == stones[x+1][y+1] &&。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
基于JAVA的五子棋游戏系统设计与实
现
基于JAVA的五子棋游戏系统设计与实现专业电子信息工程
学生董永杰
指导教师曾玉
摘要
当前,随着计算机网络的的发展,以计算机技术和网络技术为核心的现代网络技术已经在现实生活和生产中得到了广泛的使用,已经成为多数人群的休闲方式,也为多数人所喜好。
当然,为了满足没有网络同样能娱乐的要求,许多小游戏做成了单机和网络的双功能。
本软件使用JAVA语户端之间的连接,利用多线程技术言实现,经过对图形界面,绘图,布局管理器等去构造出游戏的单机功能,在此基础上,利用SCOKET的知识,建立起服务器与客来处理服务器端与客户端之间的数据传输,通信问题,使得客户端和服务器端之间能够同步的进行处理。
经过对软件的编写,更深入的理解了面向对象的概念,也体会到利用面向对象语言处理一些问题的优势。
同时也加深了对多线程,流套接字等高级技术的理解。
关键词:多线程;流套接字;数据传输;同步。
ABSTRACT
At present, With the rapid development of computer network. Taking computer technology and the network technology as the core, modern network technology is already used in the real life and the production and already became the leisure mode of the most people. And most people like them. Of course, it’s a pity that there still have some clients lacking of network because of various causes.
In order to satisfy the above clients’ requirements. A large number of games ,usually nam ed as “small games” by players, are designed for involving two kinds of different function. The former game is often played by these players whose computers never connect with the network. It’s called for stand-alone version games. Just as its name implies, the later is named as online version games This software implemented with JAVA language, and according to the understanding of SCOKET ,GUI and paint image ichnology. Established in these foundation , the server co ects with the multi- client, and transmission the information between many clients using the multi-thread proceeding technology. it is very convenient for both client and server to do the synchronous processing.
Through to the software compilation, deepen understanding and grasp to the technology above understanding and holding.
Key Words : multiple thread, Socket, transmission-data, synchronism.
目录
第一章绪论 (1)
1.1开发背景 (1)
1.2课题意义 (2)
1.3五子棋游戏的发展与现状 (3)
1.4论文的组织结构 (5)
第二章五子棋程序相关技术介绍 (6)
2.1软件的基本功能 (6)
2.2开发运行环境 (6)
2.3软件的开发手段以及工具的介绍 (7)
2.3.1 Java简介 (7)
2.3.2 MyEclipse10开发环境简介 (9)
2.4软件的实现目的 (11)
第三章五子棋程序分析与设计 (13)
3.1用户需求分析 (13)
3.2软件功能结构图 (14)
3.3软件各个功能的简要说明 (15)
3.4软件设计中使用到的JAVA软件包以及类和方法 (17)
3.5 五子棋界面设计 (19)
3.6 五子棋算法设计 (20)
3.6.1 五子棋棋盘设计 (21)
3.6.2 棋子设计 (23)
3.6.3 落子算法设计 (24)
3.6.4 判断输赢设计 (27)
3.7 网络五子棋算法设计 (29)
第四章软件的具体实现 (33)
4.1准备工作 (33)
4.2游戏窗口界面的实现 (33)
4.3下棋算法的实现 (36)
4.4完成判断胜负的功能 (39)
4.5 系统测试 (41)
4.6 测试计划 (43)
4.6.1 界面功能测试 (43)
4.6.2 单机游戏测试 (44)
4.6.3 联网游戏测试 (45)
4.7 测试结果 (46)
第五章总结与展望 (47)
致谢 (49)
附录 (50)
JIcon.java程序: (50)
Qipan.java部分程序: (51)
参考文献 (63)。