实例介绍
【实例截图】
【核心代码】
* 检查棋盘中的五子棋是否连城五子
* @param xChange
* @param yChenge
* @param color
* @return
*/
public int checkCount(int xChange , int yChenge ,int color){
int count = 1;
int tempX = xChange;
int tempy = yChenge; //保存初始值
//全局变量x,y最初为鼠标点击的坐标,
//经下棋方法已经将x,y的范围变成0-15(遍历整个棋盘,寻找相同颜色的棋子)
while(x xChange >=0 && x xChange <15 && y yChenge >=0 && y yChenge < 15 && color == allChess[x xChange][y yChenge]){
ount ;
if(xChange != 0) xChange ;
if(yChenge != 0 ){
if(yChenge != 0){
if(yChenge > 0) {
yChenge ;
}else {
yChenge--;
}
}
}
}
xChange = tempX;
yChenge = tempy; // 恢复初始值
(x-xChange >=0 && x-xChange <15 && y-yChenge >=0 &&
y-yChenge <15 && color == allChess[x-xChange][y-yChenge]){
count ;
if(xChange != 0){
xChange ;
}
if(yChenge != 0){
if (yChenge > 0) {
yChenge ;
}else {
yChenge--;
}
}
}
count;
}
悔棋
(e.getX() >= 430 && e.getX() <= (430 55) && e.getY() >= 246 && e.getY() <= (246 20) 表示鼠标所点击的位置在这个范围表示悔棋。
先进行判断是否愿意悔棋,当确定实现悔棋时,即实现allChess[chessX[--countX]][chessY[--countY]]=0;这个功能,因为chessx[]和chessY[]用来记录你所下的步数,例如:你下到第11步时想要悔棋,这时将allChess[][]将其置0并消除第11步数字,表示没有下棋;这时轮到你下棋。
if(e.getX() >= 430 && e.getX() <= (430 55) && e.getY() >= 246 && e.getY() <= (246 20)){
int result = JOptionPane.showConfirmDialog(this,
(isblack == true ? "白方悔棋,黑方是否同意?" :"黑方悔棋,白方是否同意?"));
// result = 0为悔棋
if(result == 0){
allChess[chessX[--countX]][chessY[--countY]]=0;
if(isblack == true ){
isblack = false;
}else {
isblack = true;
}
this.repaint(); //重绘棋盘
}
标签: 五子棋
小贴士
感谢您为本站写下的评论,您的评论对其它用户来说具有重要的参考价值,所以请认真填写。
- 类似“顶”、“沙发”之类没有营养的文字,对勤劳贡献的楼主来说是令人沮丧的反馈信息。
- 相信您也不想看到一排文字/表情墙,所以请不要反馈意义不大的重复字符,也请尽量不要纯表情的回复。
- 提问之前请再仔细看一遍楼主的说明,或许是您遗漏了。
- 请勿到处挖坑绊人、招贴广告。既占空间让人厌烦,又没人会搭理,于人于己都无利。
关于好例子网
本站旨在为广大IT学习爱好者提供一个非营利性互相学习交流分享平台。本站所有资源都可以被免费获取学习研究。本站资源来自网友分享,对搜索内容的合法性不具有预见性、识别性、控制性,仅供学习研究,请务必在下载后24小时内给予删除,不得用于其他任何用途,否则后果自负。基于互联网的特殊性,平台无法对用户传输的作品、信息、内容的权属或合法性、安全性、合规性、真实性、科学性、完整权、有效性等进行实质审查;无论平台是否已进行审查,用户均应自行承担因其传输的作品、信息、内容而可能或已经产生的侵权或权属纠纷等法律责任。本站所有资源不代表本站的观点或立场,基于网友分享,根据中国法律《信息网络传播权保护条例》第二十二与二十三条之规定,若资源存在侵权或相关问题请联系本站客服人员,点此联系我们。关于更多版权及免责申明参见 版权及免责申明
网友评论
我要评论