?? chesspad.java
字號:
package com.fivechess.chessface;
import java.awt.*;
import java.awt.event.*;
import java.io.*;
import java.net.*;
/**
* @author wufenghanren
* 顯示棋盤的Panel。此Panel實現了鼠標監聽器
*/
public class chessPad extends Panel implements MouseListener {
public int chessPoint_x = -1, chessPoint_y = -1, chessColor = 1;
int chessBlack_x[] = new int[200];//黑子的x坐標
int chessBlack_y[] = new int[200];//黑子的y坐標
int chessWhite_x[] = new int[200];//白子的x坐標
int chessWhite_y[] = new int[200];//白子的y坐標
int chessBlackCount = 0, chessWhiteCount = 0;
int chessBlackWin = 0, chessWhiteWin = 0;
public boolean isMouseEnabled = false, isWin = false, isInGame = false;
public Label statusLabel = new Label("客戶端狀態");
public TextField statusText = new TextField("請先連接服務器");//顯示客戶端狀態的文本框
public Socket chessSocket;
DataInputStream inData;
DataOutputStream outData;
public String chessSelfName = null;//己方的名字
public String chessPeerName = null;//對方的名字
public String host = null;
public int port = 4331;
public chessThread chessthread = new chessThread(this);
/**
* 棋盤Panel的構造函數
*/
public chessPad() {
setSize(440, 440);
setLayout(null);
setBackground(new Color(204, 204, 204));
addMouseListener(this);
add(statusLabel);
statusLabel.setBounds(30, 5, 70, 24);
add(statusText);
statusText.setBounds(100, 5, 300, 24);
statusText.setEditable(false);
}
/**
* 和服務器通信的函數
*/
public boolean connectServer(String ServerIP, int ServerPort)
throws Exception {
try {
//利用參數創建一個Socket的實例來完成和服務器之間的信息交換
chessSocket = new Socket(ServerIP, ServerPort);
inData = new DataInputStream(chessSocket.getInputStream());
outData = new DataOutputStream(chessSocket.getOutputStream());
chessthread.start();
return true;
} catch (IOException ex) {
statusText.setText("chessPad:connectServer:無法連接 \n");
}
return false;
}
/**
* 一方獲勝時的對棋局的處理
*/
public void chessVictory(int chessColorWin) {
//清除所有的棋子
this.removeAll();
//將保存所有黑棋和白棋的位置坐標的數組清空,為西一盤棋做準備。
for (int i = 0; i <= chessBlackCount; i++) {
chessBlack_x[i] = 0;
chessBlack_y[i] = 0;
}
for (int i = 0; i <= chessWhiteCount; i++) {
chessWhite_x[i] = 0;
chessWhite_y[i] = 0;
}
chessBlackCount = 0;
chessWhiteCount = 0;
add(statusText);
statusText.setBounds(40, 5, 360, 24);
//如果黑棋獲勝,計算雙方獲勝盤數,將雙方的戰績比在狀態文本框顯示出來。
if (chessColorWin == 1) {
chessBlackWin++;
statusText.setText("黑棋勝,黑:白為" + chessBlackWin + ":" + chessWhiteWin
+ ",重新開局,等待白棋下子...");
}
//白棋獲勝,同上。
else if (chessColorWin == -1) {
chessWhiteWin++;
statusText.setText("白棋勝,黑:白為" + chessBlackWin + ":" + chessWhiteWin
+ ",重新開局,等待黑棋下子...");
}
}
/**
* 將各個棋子的坐標保存在數組里
*/
public void getLocation(int a, int b, int color) {
if (color == 1) {
chessBlack_x[chessBlackCount] = a * 20;
chessBlack_y[chessBlackCount] = b * 20;
chessBlackCount++;
} else if (color == -1) {
chessWhite_x[chessWhiteCount] = a * 20;
chessWhite_y[chessWhiteCount] = b * 20;
chessWhiteCount++;
}
}
/**
* 依據五子棋的行棋規則判斷某方獲勝
*/
public boolean checkWin(int a, int b, int checkColor) {
int step = 1, chessLink = 1, chessLinkTest = 1, chessCompare = 0;
if (checkColor == 1) {
chessLink = 1;
for (step = 1; step <= 4; step++) {
for (chessCompare = 0; chessCompare <= chessBlackCount; chessCompare++) {
if (((a + step) * 20 == chessBlack_x[chessCompare])
&& ((b * 20) == chessBlack_y[chessCompare])) {
chessLink = chessLink + 1;
if (chessLink == 5) {
return (true);
}
}
}
if (chessLink == (chessLinkTest + 1))
chessLinkTest++;
else
break;
}
for (step = 1; step <= 4; step++) {
for (chessCompare = 0; chessCompare <= chessBlackCount; chessCompare++) {
if (((a - step) * 20 == chessBlack_x[chessCompare])
&& (b * 20 == chessBlack_y[chessCompare])) {
chessLink++;
if (chessLink == 5) {
return (true);
}
}
}
if (chessLink == (chessLinkTest + 1))
chessLinkTest++;
else
break;
}
chessLink = 1;
chessLinkTest = 1;
for (step = 1; step <= 4; step++) {
for (chessCompare = 0; chessCompare <= chessBlackCount; chessCompare++) {
if ((a * 20 == chessBlack_x[chessCompare])
&& ((b + step) * 20 == chessBlack_y[chessCompare])) {
chessLink++;
if (chessLink == 5) {
return (true);
}
}
}
if (chessLink == (chessLinkTest + 1))
chessLinkTest++;
else
break;
}
for (step = 1; step <= 4; step++) {
for (chessCompare = 0; chessCompare <= chessBlackCount; chessCompare++) {
if ((a * 20 == chessBlack_x[chessCompare])
&& ((b - step) * 20 == chessBlack_y[chessCompare])) {
chessLink++;
if (chessLink == 5) {
return (true);
}
}
}
if (chessLink == (chessLinkTest + 1))
chessLinkTest++;
else
break;
}
chessLink = 1;
chessLinkTest = 1;
for (step = 1; step <= 4; step++) {
for (chessCompare = 0; chessCompare <= chessBlackCount; chessCompare++) {
if (((a - step) * 20 == chessBlack_x[chessCompare])
&& ((b + step) * 20 == chessBlack_y[chessCompare])) {
chessLink++;
if (chessLink == 5) {
return (true);
}
}
}
if (chessLink == (chessLinkTest + 1))
chessLinkTest++;
else
break;
}
for (step = 1; step <= 4; step++) {
for (chessCompare = 0; chessCompare <= chessBlackCount; chessCompare++) {
if (((a + step) * 20 == chessBlack_x[chessCompare])
&& ((b - step) * 20 == chessBlack_y[chessCompare])) {
chessLink++;
if (chessLink == 5) {
return (true);
}
}
}
if (chessLink == (chessLinkTest + 1))
chessLinkTest++;
else
break;
}
chessLink = 1;
chessLinkTest = 1;
for (step = 1; step <= 4; step++) {
for (chessCompare = 0; chessCompare <= chessBlackCount; chessCompare++) {
if (((a + step) * 20 == chessBlack_x[chessCompare])
&& ((b + step) * 20 == chessBlack_y[chessCompare])) {
chessLink++;
if (chessLink == 5) {
return (true);
}
}
}
if (chessLink == (chessLinkTest + 1))
chessLinkTest++;
else
break;
}
for (step = 1; step <= 4; step++) {
for (chessCompare = 0; chessCompare <= chessBlackCount; chessCompare++) {
if (((a - step) * 20 == chessBlack_x[chessCompare])
&& ((b - step) * 20 == chessBlack_y[chessCompare])) {
chessLink++;
if (chessLink == 5) {
return (true);
}
}
}
if (chessLink == (chessLinkTest + 1))
chessLinkTest++;
else
break;
}
} else if (checkColor == -1) {
chessLink = 1;
for (step = 1; step <= 4; step++) {
for (chessCompare = 0; chessCompare <= chessWhiteCount; chessCompare++) {
if (((a + step) * 20 == chessWhite_x[chessCompare])
&& (b * 20 == chessWhite_y[chessCompare])) {
chessLink++;
if (chessLink == 5) {
return (true);
}
}
}
if (chessLink == (chessLinkTest + 1))
chessLinkTest++;
else
break;
}
for (step = 1; step <= 4; step++) {
for (chessCompare = 0; chessCompare <= chessWhiteCount; chessCompare++) {
if (((a - step) * 20 == chessWhite_x[chessCompare])
&& (b * 20 == chessWhite_y[chessCompare])) {
chessLink++;
if (chessLink == 5) {
return (true);
}
}
}
if (chessLink == (chessLinkTest + 1))
chessLinkTest++;
else
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -