部分代码:

 public void run(){
while (true){
//单击棋子第一下开始闪烁
if (chessManClick){
play[Man].setVisible(false); //时间控制
try{
tmain.sleep();
}
catch(Exception e){
} play[Man].setVisible(true);
} //闪烁当前提示信息 以免用户看不见
else {
text.setVisible(false);
//时间控制
try{
tmain.sleep();
}
catch(Exception e){
} text.setVisible(true);
} try{
tmain.sleep();
}
catch (Exception e){
}
}
} //单击棋子方法
public void mouseClicked(MouseEvent me){
System.out.println("Mouse"); //当前坐标
int Ex=,Ey=; //启动线程
if (tmain == null){
tmain = new Thread(this);
tmain.start();
} //单击棋盘(移动棋子)
if (me.getSource().equals(image)){
//该红棋走棋的时候
if (chessPlayClick == && play[Man].getName().charAt() == ''){
Ex = play[Man].getX();
Ey = play[Man].getY();
//移动卒、兵
if (Man > && Man < ){
rule.armsRule(Man,play[Man],me);
} //移动炮
else if (Man > && Man < ){
rule.cannonRule(play[Man],play,me);
} //移动车
else if (Man >= && Man < ){
rule.cannonRule(play[Man],play,me);
} //移动马
else if (Man > && Man < ){
rule.horseRule(play[Man],play,me);
} //移动相、象
else if (Man > && Man < ){
rule.elephantRule(Man,play[Man],play,me);
} //移动仕、士
else if (Man > && Man < ){
rule.chapRule(Man,play[Man],play,me);
} //移动将、帅
else if (Man == || Man == ){
rule.willRule(Man,play[Man],play,me);
} //是否走棋错误(是否在原地没有动)
if (Ex == play[Man].getX() && Ey == play[Man].getY()){
text.setText(" 红棋走棋");
chessPlayClick=;
} else {
text.setText(" 黑棋走棋");
chessPlayClick=;
} }//if //该黑棋走棋的时候
else if (chessPlayClick == && play[Man].getName().charAt() == ''){
Ex = play[Man].getX();
Ey = play[Man].getY(); //移动卒、兵
if (Man > && Man < ){
rule.armsRule(Man,play[Man],me);
} //移动炮
else if (Man > && Man < ){
rule.cannonRule(play[Man],play,me);
} //移动车
else if (Man >= && Man < ){
rule.cannonRule(play[Man],play,me);
} //移动马
else if (Man > && Man < ){
rule.horseRule(play[Man],play,me);
} //移动相、象
else if (Man > && Man < ){
rule.elephantRule(Man,play[Man],play,me);
} //移动仕、士
else if (Man > && Man < ){
rule.chapRule(Man,play[Man],play,me);
} //移动将、帅
else if (Man == || Man == ){
rule.willRule(Man,play[Man],play,me);
} //是否走棋错误(是否在原地没有动)
if (Ex == play[Man].getX() && Ey == play[Man].getY()){
text.setText(" 黑棋走棋");
chessPlayClick=;
} else {
text.setText(" 红棋走棋");
chessPlayClick=;
} }//else if //当前没有操作(停止闪烁)
chessManClick=false; }//if //单击棋子
else{
//第一次单击棋子(闪烁棋子)
if (!chessManClick){
for (int i=;i<;i++){
//被单击的棋子
if (me.getSource().equals(play[i])){
//告诉线程让该棋子闪烁
Man=i;
//开始闪烁
chessManClick=true;
break;
}
}//for
}//if //第二次单击棋子(吃棋子)
else if (chessManClick){
//当前没有操作(停止闪烁)
chessManClick=false; for (i=;i<;i++){
//找到被吃的棋子
if (me.getSource().equals(play[i])){
//该红棋吃棋的时候
if (chessPlayClick == && play[Man].getName().charAt() == ''){
Ex = play[Man].getX();
Ey = play[Man].getY(); //卒、兵吃规则
if (Man > && Man < ){
rule.armsRule(play[Man],play[i]);
} //炮吃规则
else if (Man > && Man < ){
rule.cannonRule(,play[Man],play[i],play,me);
} //车吃规则
else if (Man >= && Man < ){
rule.cannonRule(,play[Man],play[i],play,me);
} //马吃规则
else if (Man > && Man < ){
rule.horseRule(play[Man],play[i],play,me);
} //相、象吃规则
else if (Man > && Man < ){
rule.elephantRule(play[Man],play[i],play);
} //士、仕吃棋规则
else if (Man > && Man < ){
rule.chapRule(Man,play[Man],play[i],play);
} //将、帅吃棋规则
else if (Man == || Man == ){
rule.willRule(Man,play[Man],play[i],play);
play[Man].setVisible(true);
} //是否走棋错误(是否在原地没有动)
if (Ex == play[Man].getX() && Ey == play[Man].getY()){
text.setText(" 红棋走棋");
chessPlayClick=;
break;
} else{
text.setText(" 黑棋走棋");
chessPlayClick=;
break;
} }//if //该黑棋吃棋的时候
else if (chessPlayClick == && play[Man].getName().charAt() == ''){
Ex = play[Man].getX();
Ey = play[Man].getY(); //卒吃规则
if (Man > && Man < ){
rule.armsRule(play[Man],play[i]);
} //炮吃规则
else if (Man > && Man < ){
rule.cannonRule(,play[Man],play[i],play,me);
} //车吃规则
else if (Man >= && Man < ){
rule.cannonRule(,play[Man],play[i],play,me);
} //马吃规则
else if (Man > && Man < ){
rule.horseRule(play[Man],play[i],play,me);
} //相、象吃规则
else if (Man > && Man < ){
rule.elephantRule(play[Man],play[i],play);
} //士、仕吃棋规则
else if (Man > && Man < ){
rule.chapRule(Man,play[Man],play[i],play);
} //将、帅吃棋规则
else if (Man == || Man == ){
rule.willRule(Man,play[Man],play[i],play);
play[Man].setVisible(true);
} //是否走棋错误(是否在原地没有动)
if (Ex == play[Man].getX() && Ey == play[Man].getY()){
text.setText(" 黑棋走棋");
chessPlayClick=;
break;
} else {
text.setText(" 红棋走棋");
chessPlayClick=;
break;
} }//else if }//if }//for //是否胜利
if (!play[].isVisible()){
JOptionPane.showConfirmDialog(
this,"黑棋胜利","玩家一胜利",
JOptionPane.DEFAULT_OPTION,JOptionPane.WARNING_MESSAGE);
//双方都不可以在走棋了
chessPlayClick=;
text.setText(" 黑棋胜利"); }//if else if (!play[].isVisible()){
JOptionPane.showConfirmDialog(
this,"红棋胜利","玩家二胜利",
JOptionPane.DEFAULT_OPTION,JOptionPane.WARNING_MESSAGE);
chessPlayClick=;
text.setText(" 红棋胜利");
}//else if }//else }//else }

作业七:团队项目——Alpha版本冲刺阶段-10的更多相关文章

  1. 作业七:团队项目——Alpha版本冲刺阶段

      本次作业为期三周时间,要求各组结合所选项目并阅读教材<构建之法>第六章内容,完成项目的Alpha版本.本阶段的主要内容如下:(20分) 1. 每天组织一次站立会议,讨论每个成员的昨天进 ...

  2. 作业七:团队项目——Alpha版本冲刺阶段002

    今日进展:我们终于安装好了软件,今天开始进行作业设计. 今日安排:今天开始我们要开始我们的框架的设计.

  3. 作业七:团队项目——Alpha版本冲刺阶段-13

    对项目最后进行了完善. 代码如下: public void chapRule(int Man ,JLabel play,JLabel playTake,JLabel playQ[]){ //当前状态 ...

  4. 作业七:团队项目——Alpha版本冲刺阶段010

    今日安排:组内成员讨论 今日进程:组内成员讨论结束,并有明确的解决办法,每个人准备实践

  5. 作业七:团队项目——Alpha版本冲刺阶段009

    今日安排:组内成员讨论 今日进度:组内成员讨论分工细节以及可能遇到的问题,并提出解决方案

  6. 作业七:团队项目——Alpha版本冲刺阶段008

    今日进度:组内成员讨论 今日安排:组内成员分工

  7. 作业七:团队项目——Alpha版本冲刺阶段007

    今日进展:完善游戏主体代码. 今日安排:让游戏能运行起来.

  8. 作业七:团队项目——Alpha版本冲刺阶段006

    今日进展:完成主体代码. 今日安排:对程序主体进行编写.

  9. 作业七:团队项目——Alpha版本冲刺阶段005

    今日进展:编写代码. 今日安排:完成开始部分代码.

随机推荐

  1. 异步I/O操作

    今天在看boost库的时候注意到异步I/O操作时,缓冲区有效性问题. 如何实现异步操作:以异步读操作为例async_read(buffer, handler): void handler() {} v ...

  2. 数据库执行sql报错Got a packet bigger than 'max_allowed_packet' bytes及重启mysql

    准备在mysql上使用数据库A,但mysql5经过重装后,上面的数据库已丢失,只得通过之前备份的A.sql重新生成数据库A. 1.执行sql报错 在执行A.sql的过程中,出现如下错误:Got a p ...

  3. 浅谈php设计模式(1)---工厂模式

    一.接口继承直接调用 先看看这样一段代码: <?php interface db{ function conn(); } class dbmysql implements db { public ...

  4. SEO和SEM的区别

    SEO是属于SEM的一部分,SEO和SEM最主要的是最终目标的不同: SEO主要是为了关键词的排名.网站的流量.网站的结构.搜索引擎中页面收录的数据. SEM是通过SEO技术基础上扩展为搜索引擎中所带 ...

  5. [16]APUE:套接字

    [a] socket / socketpair #include <sys/socket.h> int socket(int domain, int type, int protocol) ...

  6. Oracle优化的方法

    想做到数据库优化的高手,不是花几周,几个月就能达到的,这并不是因为数据库优化有多高深,而是因为要做好优化一方面需要有非常好的技术功底,对操作系统.存储硬件网络.数据库原理等方面有比较扎实的基础知识,另 ...

  7. linux下搭建nagios

    配置环境:1)CentOS 6.5 作为监控主机,IP:10.0.0.30(根据自己公司需要改变) 2)客户机: windows server  2008R2 , windows 7, windows ...

  8. Linux echo, sort, sed 等一些命令总结

    linux echo, sort, sed是初学linux shell script 的一些常用的命令.基本上来说,如果能够掌握了这些命令,我们就能写出一些不错的linux脚本.以下是我遇到的以下常用 ...

  9. hdu 1142(DFS+dijkstra)

    #include<iostream> #include<cstdio> #include<cmath> #include<map> #include&l ...

  10. hdu 5976 Detachment

    Detachment Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total ...