1、 汉诺塔程序设计 一、总功能概述 (1) 设计Hannoi塔中有三个座,名字为A、B和C。初始状态是A座上有3个大小不等的盘子,这些盘子从座底到座顶按着大小顺序依次摆放在A座上。用户可以用鼠标来移动盘子、释放鼠标来放置该盘子; (2) 程序要求用户在移动盘子过程中,不允许把大盘子放置在小盘子的上面,用户最终要完成的是把A座上的全部盘子移动到B座或C座上; (3) 用户可以通过Hannoi塔界面提供的菜单来选择初级、中级、高级和自定义四个级别。初级级别A座上有3个大小不等盘子、中级级别A座上有四个大小不等盘子、高级级别
2、A座上有大小不等盘子、自定义级别A座用户可以任意输入盘子数目: (4) 用户可以通过单击Hannoi塔界面上提供的按钮,让程序自动完成把A座上的盘子全部移动到C座上; (5) 用户在移动盘子的过程中,可以随时单击Hannoi塔界面上提供的按钮,重新开始当前的级别; (6) 有计时功能,即显示用户完成移动盘子所花费的时间; (7) 用户可以设置最大和最小盘子的大小; 二、分功能模块概述 1.AutoMoveDisc模块: 声明盘子的数量,塔点,塔的名字,容器,文本框,以及用到的一些按钮,定义设置移动步骤的方法,定义操作演示的方法,最后声明AutoMoveDisc这个方法并且实
3、现AutoMoveDisc这个方法。 2. Disc模块: Disc类的主要功能是建立一个类disc,然后通过调用盘子的设置数量、获取数量以及点的设置数量、获取数量来实现这个程序的功能。 3. HandleMouse模块: HandleMouse类实现接口鼠标监视器和鼠标动作监视器处理鼠标事件,在此模块中,实现了对鼠标操作从而完成汉诺塔的游戏。在这个类中,构造了函数mousePressed点击鼠标键事件、mouseDragged拖动鼠标事件、mouseReleased放开鼠标键事件,并对其构造函数进行实现,接口并调用了mouseMoved移动鼠标事件、mouseEnter鼠标进入组件
4、事件、mouseExited鼠标离开组件事件、mouseClicked单击鼠标事件。 4. HannoiWindow模块: HannoiWindow类的主要工功能是实现程序的窗口化。用的是BordLayout布局,采用了菜单、按钮、面板等组件,菜单主要包括选择级别,盘子个数,设置大小等功能,它分别调用了塔的名字TowerName(A,B,C)、设置盘子的个数SetAmountOfDisc以及大小、这个游戏可以选择的级别menuGrade(初、中、高),按钮的功能包括重新开始(renew)和自动演示(autoButton)以及播放、暂停、演示、关闭等。 5. Tower模块 本模块是有关
5、Tower的程序,主要是塔的制作过程。 Tower类是javax.swing包中JPanel容器的一个子类,创建的对象tower是Hannoiwindow窗口的成员之一,被添加到HannoiWindow窗口的中心位置。 A、B、C座的实现方法:pointA,pointB,pointC都是TowerPoint型数组,三个数组的长度与盘子数目相同,分别用来表示Hannoi塔中三个座上的塔点。A座、B座和C座上的三个塔点分别由PointA,PointB,PointC中的单元来确定。每个座上的三个塔点都是从座顶依次对应数组的相应单元中的TowerPoint对象。 6. TowerPoint模块
6、 TowerPoint类实现对塔的设置和对盘子的属性的设置,通过构造函数setHaveDisc设置属性并带参数boolean进行判断,并对其进行实现,通过构造函数putDisc设置放置盘子的方法并对其进行实现,通过getDiscOnPoint定义获取盘子的方法,通过removeDisc定义移动盘子的方法。 三、UML类图 1. AutoMoveDisc UML类图 JDialog AutoMoveDisc +amountOfDisc:int +pointA,pointB,pointC:T
7、owerPoint +towername:char +i,number:int +AutoMoveDisc(Container con):void +setPointA(TowerPoint[] pointA):void + setPointB(TowerPoint[] pointB):void + setPointC(TowerPoint[] pointC):void +setTowerName(char name[]):void +setAmountOfDise(int n):void +actionPerformed(ActionEvent e) -serMove
8、Step(int amountOfDisc,char one,char two,char three):void -autoMoveDisc(char cStart,char cEnd):void Disc +Number:int +Point:TowerPoint Disc():无类型 +SetNumber(int n):void +getNumber():int +SetPoint(TowerPoint):void +getPoint():TowerPoint 2.Disc UML类图 3.HandleMo
9、use UML类图 HandleMouse pointA,pointB,pointC:TowerPoint[] startPoint,endPoint:TowerPoint leftX,leftY,x0,y0:int move,countTime:boolaen con:Container HandleMouse(Container con) +setPointA(TowerPoint[] pointA):void +setPointB(TowerPoint[] pointB):void +setPointC(TowerPoint[] pointC):vo
10、id +mousePressed(MouseEvent e):void +mouseMoved(MouseEvent e):void +mouseDragged(MouseEvent e):void +mouseReleased(MouseEvent e):void +mouseEnter(MouseEvent e):void +mouseExite(MouseEvent e):void +mouseClick(MouseEvent e):void 4. HannoiWindow UML类图 HannoiWindow
11、 +Amountofdisc:int +towerName:char[] +tower:Tower +Hannoiwindow:无类型 +actionPerformed(ActionEvent e):void +main(String args[]):void 5. Tower UML类图 Tower +amountOfDisc:int Disc:Disc[] +towerName:char[] +maxDiscWidth,minDiscWidth,discHeight:int +pointA,pointB,pointC:Tower[] handleMo
12、use:HandleMouse autoMoveDisc:AutoMoveDisc Tower(char[]):无类型 +setAmountOfDisc(int):void +setmaxDiscWidth(int):void +setminDiscWidth(int):void +setDiscHeight(int):void +putDiscOnTower():void +removeDisk():void +paintComponent(Graphics):void 6. TowerPoint UML类图 TowerPoint x,y:int have
13、Disc:boolean disc:Disc +TowerPoint(int x,int y) +isHaveDisc():boolean +setHaveDisc(boolean boo):void +getX():int +getY():int +equals(TowerPoint p):boolean +putDisc(Componet com,Container con):void +getDiscOnPoint():Disc +removeDisc(Componet com,Container con):void






