JAVA程序设计(12.3)---- 监听器0基础应用:五子棋
1.制作五子棋游戏软件
由于老师已经基本做完了。重做的时候快了非常多……可是还是感觉思维非常混乱…… 哪边先哪边后,哪个方法在哪边好之类的问题 太纠结了……
先是窗体 内部类:鼠标适配器 窗体的构造器 画图
package com.lovo.homework2; import java.awt.Color;
import java.awt.Graphics;
import java.awt.Image;
import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent;
import java.awt.image.BufferedImage; import javax.swing.JFrame;
import javax.swing.JOptionPane; /**
* 类 : 我的五子棋窗体
*
* @author Abe
*/
public class MyFrameRenju extends JFrame {
private MyboardRenju board = new MyboardRenju();
private boolean isBlack = true;
private Image offImage = new BufferedImage(800, 800,
BufferedImage.TYPE_INT_RGB);// 双缓冲
private boolean isGameOver = false; /**
* 内部类:鼠标适配器
*
* @author Abe
*/
public class MyMouseAdapter extends MouseAdapter {
@Override
public void mousePressed(MouseEvent e) { // 重写点击鼠标的方法
if (!isGameOver) {
int x = e.getX();
int y = e.getY();
if (x > 25 && x < 775 && y > 25 && y < 775) {
int i = (x - 25) / 50;
int j = (y - 25) / 50;
if (board.move(i, j, isBlack)) {
repaint();
if (board.win(i, j, isBlack)) {
JOptionPane.showMessageDialog(null,
isBlack ? "黑方胜! " : "白方胜");
isGameOver = true;
}
isBlack = !isBlack;
}
}
}
}
} /**
* 构造器
*/
public MyFrameRenju() {
this.setTitle("五子棋");
this.setSize(800, 800);
this.setResizable(false);
this.setDefaultCloseOperation(EXIT_ON_CLOSE);
this.setLocationRelativeTo(null);
this.setLayout(null);
this.getContentPane().setBackground(new Color(180, 125, 12)); MyMouseAdapter l = new MyMouseAdapter();
this.addMouseListener(l); } /**
* 重写方法画出全部 newG均为双缓冲 去掉闪屏须要
*/
@Override
public void paint(Graphics g) {
Graphics newG = offImage.getGraphics();
super.paint(newG);
board.draw(newG);
g.drawImage(offImage, 0, 0, 800, 800, null);
} public static void main(String[] args) {
new MyFrameRenju().setVisible(true);
}
}
然后是位置面板,绘制棋子。走棋。推断胜负
package com.lovo.homework2; import java.awt.BasicStroke;
import java.awt.Color;
import java.awt.Graphics;
import java.awt.Graphics2D;
import java.awt.Shape;
import java.awt.Stroke; import javax.xml.bind.annotation.adapters.CollapsedStringAdapter; /**
* 类 : 五子棋棋盘
*
* @author Abe
*
*/
public class MyboardRenju {
private int[][] p = new int[15][15]; // 给每一个交点赋值 public void draw(Graphics g) {
g.setColor(Color.BLACK);
Graphics2D g2d = (Graphics2D) g; // 强转g为2D型 赋值给g2d
g2d.setStroke(new BasicStroke(5));
g.drawRect(50, 50, 700, 700);
g2d.setStroke(new BasicStroke(1));
g.fillOval(392, 392, 16, 16); // 画天元 星
g.fillOval(195, 195, 10, 10);
g.fillOval(195, 595, 10, 10);
g.fillOval(595, 195, 10, 10);
g.fillOval(595, 595, 10, 10); for (int i = 0; i < 750; i += 50) { // 画横纵坐标线
g.drawLine(50, 100 + i, 750, 100 + i);
g.drawLine(100 + i, 50, 100 + i, 750);
}
for (int i = 0; i < p.length; i++) { // 画出棋盘上的棋子
for (int j = 0; j < p.length; j++) {
if (p[i][j] != 0) {
g.setColor(p[i][j] == 1 ? Color.black : Color.WHITE);
g.fillOval(25 + i * 50, 25 + j * 50, 50, 50);
}
}
}
} /**
* 走棋
*/
public boolean move(int i, int j, boolean isBlack) {
if (p[i][j] == 0) {
p[i][j] = isBlack ? 1 : 2;
return true;
}
return false;
} /**
* 方法:推断胜负
*/
public boolean win(int i, int j, boolean isBlack) {
int currentColor = isBlack ? 1 : 2;
if (countH(i, j, currentColor) >= 5 || countV(i, j, currentColor) >= 5
|| countX1(i, j, currentColor) >= 5
|| countX2(i, j, currentColor) >= 5) {
return true;
}
return false;
} private int countH(int i, int j, int currentColor) {
int counter = 1;
int tempi = i;
while (--tempi >= 0 && p[tempi][j] == currentColor) {
counter++;
}
tempi = i;
while (++tempi <= p.length && p[tempi][j] == currentColor) {
counter++;
}
return counter;
} private int countV(int i, int j, int currentColor) {
int counter = 1;
int tempj = j;
while (--tempj >= 0 && p[i][tempj] == currentColor) {
counter++;
}
tempj = j;
while (++tempj <= p.length && p[i][tempj] == currentColor) {
counter++;
}
return counter;
} private int countX1(int i, int j, int currentColor) {
int counter = 1;
int tempi = i;
int tempj = j;
while (--tempj >= 0 && --tempi >= 0 && p[tempi][tempj] == currentColor) {
counter++;
}
tempi = i;
tempj = j;
while (++tempj <= p.length && ++tempi <= p.length
&& p[tempi][tempj] == currentColor) {
counter++;
}
return counter;
} private int countX2(int i, int j, int currentColor) {
int counter = 1;
int tempi = i;
int tempj = j;
while (--tempj >= 0 && ++tempi >= 0 && p[tempi][tempj] == currentColor) {
counter++;
}
tempi = i;
tempj = j;
while (++tempj <= p.length && --tempi <= p.length
&& p[tempi][tempj] == currentColor) {
counter++;
}
return counter;
}
}
JAVA程序设计(12.3)---- 监听器0基础应用:五子棋的更多相关文章
- JAVA程序设计(11)-----面对对象0基础设计 麻将 创建麻将牌 然后洗牌 发牌~ 恩 就这样
zzzzZZZZ 1.開始还想贴图的 实在太懒了-- 这是一张麻将 package com.lovo; import java.awt.Graphics; import java.awt.Image; ...
- Java 入门课程视频实战-0基础 上线了,猜拳游戏,ATM实战,欢迎围观
Java 入门课程视频实战-0基础 已经上传完了.欢迎小伙伴们过来围观 直接进入: http://edu.csdn.net/course/detail/196 课程文件夹例如以下: 1 初识Java ...
- 《Java程序设计》第三章-基础语法
20145221<Java程序设计>第三章-基础语法 总结 教材学习内容总结 类型.变量与运算符 类型 Java可区分为基本类型(Primitive Type)和类类型(Class Typ ...
- Java程序设计的DOS命令基础
Java程序设计的DOS命令基础 用户使用操作系统和软件有两种方式:命令行界面(Command Line Interface,CLI)和图形界面(Graphical User Interface,GU ...
- 20155304 2016-2017-2 《Java程序设计》第三周学习总结
20155304 2016-2017-2 <Java程序设计>第三周学习总结 教材学习内容总结 第四章 类与对象 定义: 对象(Object):存在的具体实体,具有明确的状态和行为. 类( ...
- 20145221 《Java程序设计》第二周学习总结
20145221 <Java程序设计>第二周学习总结 教材学习内容总结 第二周内容已在假期完成,详见博客: <Java程序设计>第三章-基础语法 代码调试中的问题和解决过程 第 ...
- 【转】WF4.0 (基础篇)
转自:http://www.cnblogs.com/foundation/category/215023.html 作者:WXWinter —— 兰竹菊梅★春夏秋冬☆ —— wxwinter@16 ...
- 20145219 《Java程序设计》实验四 Android开发基础设计实验报告
20145219 <Java程序设计>实验四 Android开发基础设计实验报告 实验内容 安装Andriod Studio并配置软件 使用Andriod Studio软件实现Hello ...
- 201521123082 《Java程序设计》第12周学习总结
201521123082 <Java程序设计>第12周学习总结 标签(空格分隔): java 1. 本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结多流与文件相关内容. An ...
随机推荐
- mysql 审核引擎 goInception 的基本使用
官网地址 github.com 安装 git clone https://github.com/hanchuanchuan/goInception.git cd goInception 修改配置 开启 ...
- 常见slave 延迟原因以及解决方法
一 序言在运维线上M-M 架构的MySQL数据库时,接收的比较多关于主备延时的报警: 点击(此处)折叠或打开 check_ins_slave_lag (err_cnt:1)critical-slav ...
- arrive 和reach 的区别
例如:He arrived yesterday. 没宾语的话就用arrive了reach作抵达讲时是及物动词,后面要宾语的 分清arrive和reach的区别arrive是不及物动词,后面不能直接加地 ...
- 脑阔疼的双层SQLserver游标
本来简单的双层游标没啥的,内层游标需要读取的是视图的内容,一直报“当前命令发生了严重错误.应放弃任何可能产生的结果.”的错误.无可奈何尝试先将视图的数据放到表变量中,之后再用游标遍历表变量. 简直很怀 ...
- ACdream 1135 MST
MST Time Limit: 2000/1000MS (Java/Others) Memory Limit: 128000/64000KB (Java/Others) Problem Descrip ...
- python3--__call__拦截调用
__call__拦截调用 当实例调用时,使用__call__方法.不,这不是循环定义:如果定义了,Python就会为实例应用函数调用表达式运行__call__方法.这样可以让类实例的外观和用法类似于函 ...
- shell的until循环
until 循环执行一系列命令直至条件为 true 时停止.until 循环与 while 循环在处理方式上刚好相反.一般while循环优于until循环,但在某些时候,也只是极少数情况下,until ...
- TheBrain8破解方式
破解文件下载地址:http://rghost.net/51736270 mac破解方式: 我用的MAC 装的8007版本的,今天竟然提示要升级专业版本了.补救方法是,先打开TB,把之前手贱输入的云服务 ...
- HackerRank# Candies
原题地址 LeetCode上也有这道题,直接扫一遍就行了,连数组都不用开,感觉像是蕴含了某种动归的思想在里面,要不怎么是个动归题呢 代码: #include <cmath> #includ ...
- Bzoj1083 1083: [SCOI2005]繁忙的都市【MST】
大水题,真不知道出题者是怎么把这么水的题出的这么长的TAT 其实这题在于考语文水平,一共三个要求,前两个要求意思就是要选出的道路是树形的,最后一个要求就是要权值最小,于是整个题意说白了就是求一棵MST ...