java連連看程序代碼 連連看源代碼

用java語言編寫連連看游戲

我以前自己寫一個玩的。沒有把你要求的功能全部實現(xiàn),不過你看了后可以改一下就好了。參考一下吧,我給了注解:

創(chuàng)新互聯(lián)是一家集成都網(wǎng)站建設、成都做網(wǎng)站、網(wǎng)站頁面設計、網(wǎng)站優(yōu)化SEO優(yōu)化為一體的專業(yè)的建站公司,已為成都等多地近百家企業(yè)提供網(wǎng)站建設服務。追求良好的瀏覽體驗,以探求精品塑造與理念升華,設計最適合用戶的網(wǎng)站頁面。 合作只是第一步,服務才是根本,我們始終堅持講誠信,負責任的原則,為您進行細心、貼心、認真的服務,與眾多客戶在蓬勃發(fā)展的市場環(huán)境中,互促共生。

package mybase.programe;

/*

* lianliankan總體算法思路:由兩個確定的按鈕。若這兩個按鈕的數(shù)字相等,就開始找它們相連的路經(jīng)。這個找路經(jīng)

* 分3種情況:(從下面的這三種情況,我們可以知道,需要三個檢測,這三個檢測分別檢測一條直路經(jīng)。這樣就會有

* 三條路經(jīng)。若這三條路經(jīng)上都是空按鈕,那么就剛好是三種直線(兩個轉(zhuǎn)彎點)把兩個按鈕連接起來了)

* 1.相鄰

*

* 2. 若不相鄰的先在第一個按鈕的同行找一個空按鈕。1).找到后看第二個按鈕橫向到這個空按鈕

* 所在的列是否有按鈕。2).沒有的話再看第一個按鈕到與它同行的那個空按鈕之間是否有按鈕。3).沒有的話,再從

* 與第一個按鈕同行的那個空按鈕豎向到與第二個按鈕的同行看是否有按鈕。沒有的話路經(jīng)就通了,可以消了.

*

* 3.若2失敗后,再在第一個按鈕的同列找一個空按鈕。1).找到后看第二個按鈕豎向到這個空按鈕所在的行是否有按鈕。

* 2).沒有的話,再看第一個按鈕到與它同列的那個空按鈕之間是否有按鈕。3).沒有的話,再從與第一個按鈕同列的

* 那個空按鈕橫向到與第二個按鈕同列看是否有按鈕。沒有的話路經(jīng)就通了,可以消了。

*

* 若以上三步都失敗,說明這兩個按鈕不可以消去。

*/

import javax.swing.*;

import java.awt.*;

import java.awt.event.*;

public class LianLianKan implements ActionListener {

JFrame mainFrame; // 主面板

Container thisContainer;

JPanel centerPanel, southPanel, northPanel; // 子面板

JButton diamondsButton[][] = new JButton[6][5];// 游戲按鈕數(shù)組

JButton exitButton, resetButton, newlyButton; // 退出,重列,重新開始按鈕

JLabel fractionLable = new JLabel("0"); // 分數(shù)標簽

JButton firstButton, secondButton; // 分別記錄兩次被選中的按鈕

// 儲存游戲按鈕位置(這里其實只要6行,5列。但是我們用了8行,7列。是等于在這個面板按鈕的周圍還圍

//了一層是0的按鈕,這樣就可以實現(xiàn)靠近面板邊緣的兩個按鈕可以消去)

int grid[][] = new int[8][7];

static boolean pressInformation = false; // 判斷是否有按鈕被選中

int x0 = 0, y0 = 0, x = 0, y = 0, fristMsg = 0, secondMsg = 0, validateLV; // 游戲按鈕的位置坐標

int i, j, k, n;// 消除方法控制

public void init() {

mainFrame = new JFrame("JKJ連連看");

thisContainer = mainFrame.getContentPane();

thisContainer.setLayout(new BorderLayout());

centerPanel = new JPanel();

southPanel = new JPanel();

northPanel = new JPanel();

thisContainer.add(centerPanel, "Center");

thisContainer.add(southPanel, "South");

thisContainer.add(northPanel, "North");

centerPanel.setLayout(new GridLayout(6, 5));

for (int cols = 0; cols 6; cols++) {

for (int rows = 0; rows 5; rows++) {

diamondsButton[cols][rows] = new JButton(String

.valueOf(grid[cols + 1][rows + 1]));

diamondsButton[cols][rows].addActionListener(this);

centerPanel.add(diamondsButton[cols][rows]);

}

}

exitButton = new JButton("退出");

exitButton.addActionListener(this);

resetButton = new JButton("重列");

resetButton.addActionListener(this);

newlyButton = new JButton("再來一局");

newlyButton.addActionListener(this);

southPanel.add(exitButton);

southPanel.add(resetButton);

southPanel.add(newlyButton);

fractionLable.setText(String.valueOf(Integer.parseInt(fractionLable

.getText())));

northPanel.add(fractionLable);

mainFrame.setBounds(280, 100, 500, 450);

mainFrame.setVisible(true);

mainFrame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);

}

public void randomBuild() {

int randoms, cols, rows;

for (int twins = 1; twins = 15; twins++) {//一共15對button,30個

randoms = (int) (Math.random() * 25 + 1);//button上的數(shù)字

for (int alike = 1; alike = 2; alike++) {

cols = (int) (Math.random() * 6 + 1);

rows = (int) (Math.random() * 5 + 1);

while (grid[cols][rows] != 0) {//等于0說明這個空格有了button

cols = (int) (Math.random() * 6 + 1);

rows = (int) (Math.random() * 5 + 1);

}

this.grid[cols][rows] = randoms;

}

}

}

public void fraction() {

fractionLable.setText(String.valueOf(Integer.parseInt(fractionLable

.getText()) + 100));

}

public void reload() {

int save[] = new int[30];

int n = 0, cols, rows;

int grid[][] = new int[8][7];

for (int i = 0; i = 6; i++) {

for (int j = 0; j = 5; j++) {

if (this.grid[i][j] != 0) {

save[n] = this.grid[i][j];//記下每個button的數(shù)字

n++;//有幾個沒有消去的button

}

}

}

n = n - 1;

this.grid = grid;

while (n = 0) {//把沒有消去的button重新放一次

cols = (int) (Math.random() * 6 + 1);

rows = (int) (Math.random() * 5 + 1);

while (grid[cols][rows] != 0) {

cols = (int) (Math.random() * 6 + 1);

rows = (int) (Math.random() * 5 + 1);

}

this.grid[cols][rows] = save[n];

n--;

}

mainFrame.setVisible(false);

pressInformation = false; // 這里一定要將按鈕點擊信息歸為初始

init();

for (int i = 0; i 6; i++) {

for (int j = 0; j 5; j++) {

if (grid[i + 1][j + 1] == 0)

diamondsButton[i][j].setVisible(false);

}

}

}

public void estimateEven(int placeX, int placeY, JButton bz) {

if (pressInformation == false) {

x = placeX;

y = placeY;

secondMsg = grid[x][y];

secondButton = bz;

pressInformation = true;

} else {

x0 = x;

y0 = y;

fristMsg = secondMsg;

firstButton = secondButton;

x = placeX;

y = placeY;

secondMsg = grid[x][y];

secondButton = bz;

if (fristMsg == secondMsg secondButton != firstButton) {

xiao();

}

}

}

public void xiao() { // 相同的情況下能不能消去。仔細分析,不一條條注釋

if ((x0 == x (y0 == y + 1 || y0 == y - 1))

|| ((x0 == x + 1 || x0 == x - 1) (y0 == y))) { // 判斷是否相鄰

remove();

} else {

for (j = 0; j 7; j++) {

if (grid[x0][j] == 0) { // 判斷和第一個按鈕同行的哪個按鈕為空

//如果找到一個為空的,就按列值的三種情況比較第二個按鈕與空按鈕的位置

if (y j) {//第二個按鈕在空按鈕右邊

for (i = y - 1; i = j; i--) { //檢測從第二個按鈕橫向左邊到空格所在列為止是否全是空格

if (grid[x][i] != 0) {

k = 0;

break;//存在非空格的就退出,這一退出就不可能k==2了,所以就會到下而215行出同理的判斷列

} else {

k = 1;

} // K=1說明全是空格通過了第一次驗證,也就是從第二個按鈕橫向左邊到空格所在列為止全是空格

}

if (k == 1) {

linePassOne();//進入第二次驗證,也就是從第一個按鈕到它同行的空格之間的空格判斷

}

}

if (y j) { // 第二個按鈕在空按鈕左邊

for (i = y + 1; i = j; i++) {//檢測從第二個按鈕橫向右邊到空格所在列為止是否全是空格

if (grid[x][i] != 0) {

k = 0;

break;

} else {

k = 1;

}

}

if (k == 1) {

linePassOne();

}

}

if (y == j) {//第二個按鈕和空按鈕同列

linePassOne();

}

}

//第三次檢測,檢測確定為空的第j列的那個按鈕豎向到第二個按鈕,看是不是有按鈕

if (k == 2) {

if (x0 == x) {//第一,二按鈕在同行

remove();

}

if (x0 x) {//第一按鈕在第二按鈕下邊

for (n = x0; n = x - 1; n++) {//從空按鈕豎向到第二個按鈕所在行是否有按鈕

if (grid[n][j] != 0) {

k = 0;

break;

}

//沒有按鈕,說明這條路經(jīng)就通了

if (grid[n][j] == 0 n == x - 1) {

remove();

}

}

}

if (x0 x) {//第一按鈕在第二按鈕上邊

for (n = x0; n = x + 1; n--) {

if (grid[n][j] != 0) {

k = 0;

break;

}

if (grid[n][j] == 0 n == x + 1) {

remove();

}

}

}

}

}//-------------------------------------for

//當上面的檢測與第一個按鈕同行的空格按鈕失敗后(不能找到與第二個按鈕的相連路經(jīng)),下面就執(zhí)行

//檢測與第一個按鈕同列的空格按鈕

for (i = 0; i 8; i++) {

if (grid[i][y0] == 0) {// 判斷和第一個按鈕同列的哪個按鈕為空

if (x i) {//第二個按鈕在這個空按鈕的下面

for (j = x - 1; j = i; j--) {

if (grid[j][y] != 0) {

k = 0;

break;

} else {

k = 1;

}

}

if (k == 1) {

rowPassOne();

}

}

if (x i) {//第二個按鈕在這個空按鈕的上面

for (j = x + 1; j = i; j++) {

if (grid[j][y] != 0) {

k = 0;

break;

} else {

k = 1;

}

}

if (k == 1) {

rowPassOne();

}

}

if (x == i) {//第二個按鈕與這個空按鈕同行

rowPassOne();

}

}

if (k == 2) {

if (y0 == y) {//第二個按鈕與第一個按鈕同列

remove();

}

if (y0 y) {//第二個按鈕在第一個按鈕右邊

for (n = y0; n = y - 1; n++) {

if (grid[i][n] != 0) {

k = 0;

break;

}

if (grid[i][n] == 0 n == y - 1) {

remove();

}

}

}

if (y0 y) {//第二個按鈕在第一個按鈕左邊

for (n = y0; n = y + 1; n--) {

if (grid[i][n] != 0) {

k = 0;

break;

}

if (grid[i][n] == 0 n == y + 1) {

remove();

}

}

}

}

}//--------------------------------for

}//-------------else

}//------------xiao

public void linePassOne() {

if (y0 j) { // 第一按鈕同行空按鈕在左邊

for (i = y0 - 1; i = j; i--) { // 判斷第一按鈕同左側(cè)空按鈕之間有沒按鈕

if (grid[x0][i] != 0) {

k = 0;

break;

} else {

k = 2;

} // K=2說明通過了第二次驗證

}

}

if (y0 j) { // 第一按鈕同行空按鈕在右邊

for (i = y0 + 1; i = j; i++) {

if (grid[x0][i] != 0) {

k = 0;

break;

} else {

k = 2;

}

}

}

}

public void rowPassOne() {

if (x0 i) {//第一個按鈕在與它同列的那個空格按鈕下面

for (j = x0 - 1; j = i; j--) {

if (grid[j][y0] != 0) {

k = 0;

break;

} else {

k = 2;

}

}

}

if (x0 i) {//第一個按鈕在與它同列的那個空格按鈕上面

for (j = x0 + 1; j = i; j++) {

if (grid[j][y0] != 0) {

k = 0;

break;

} else {

k = 2;

}

}

}

}

public void remove() {

firstButton.setVisible(false);

secondButton.setVisible(false);

fraction();

pressInformation = false;

k = 0;

grid[x0][y0] = 0;

grid[x][y] = 0;

}

public void actionPerformed(ActionEvent e) {

if (e.getSource() == newlyButton) {

int grid[][] = new int[8][7];

this.grid = grid;

randomBuild();

mainFrame.setVisible(false);

pressInformation = false;

init();

}

if (e.getSource() == exitButton)

System.exit(0);

if (e.getSource() == resetButton)

reload();

for (int cols = 0; cols 6; cols++) {

for (int rows = 0; rows 5; rows++) {

if (e.getSource() == diamondsButton[cols][rows])

estimateEven(cols + 1, rows + 1, diamondsButton[cols][rows]);

}

}

}

public static void main(String[] args) {

LianLianKan llk = new LianLianKan();

llk.randomBuild();

llk.init();

}

}

java連連看里設置150秒倒計時,重行開始游戲時時間再次從150秒開始倒計時的代碼怎么寫,急?。。。。。?!

參考一下吧。

import?java.awt.FlowLayout;

import?java.awt.Font;

import?java.awt.event.ActionEvent;

import?java.awt.event.ActionListener;

import?javax.swing.JButton;

import?javax.swing.JFrame;

import?javax.swing.JLabel;

public?class?Program?{

static?int?seconds?=?150;

private?TimeThread?tt?=?null;

private?boolean?ttFlag?=?false;

private?void?init()?{

final?JLabel?tip?=?new?JLabel();

final?JButton?start?=?new?JButton("開始");

final?JButton?end?=?new?JButton("結(jié)束");

JFrame?f?=?new?JFrame();

f.setLayout(new?FlowLayout(5));

f.add(tip);

f.add(start);

f.add(end);

f.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);

f.setVisible(true);

f.setSize(300,?150);

f.setLocationRelativeTo(null);

start.addActionListener(new?ActionListener()?{

@Override

public?void?actionPerformed(ActionEvent?e)?{

start.setEnabled(false);

tip.setFont(new?Font("宋體",Font.BOLD,27));

ttFlag?=?true;

tt?=?new?TimeThread(tip);

tt.start();

}

});

end.addActionListener(new?ActionListener()?{

@Override

public?void?actionPerformed(ActionEvent?e)?{

start.setEnabled(true);

tip.setText("");

Program.seconds?=?150;

ttFlag?=?false;

}

});

}

/**

?*?@param?args

?*/

public?static?void?main(String[]?args)?{

new?Program().init();

}

class?TimeThread?extends?Thread?{

private?JLabel?tip;

TimeThread(JLabel?tip)?{

this.tip?=?tip;

}

@Override

public?void?run()?{

int?seconds?=?Program.seconds;

tip.setText(seconds+"");

while?(seconds--??0??ttFlag)?{

tip.setText(seconds+"");

try?{

Thread.sleep(1000);

}?catch?(InterruptedException?e)?{

e.printStackTrace();

}

}

}

};

}

連連看JAVA源代碼

加上。(初始化代碼樓主清洗本身選) 對應在這句話。別離grid[][]數(shù)組的行列即可,你只需定義25個不一樣的圖片;后面; 這句話是用來設置連連看的圖的.setIcon(icons[grid[cols + 1][rows + 1])])。 定義: diamondsButton[cols][rows] = new JButton(String .valueOf(grid[cols + 1][rows + 1])): ImageIcon icons[]= new ImageIcon[25]: diamondsButton[cols][rows].valueOf(grid[cols + 1][rows + 1]))diamondsButton[cols][rows] = new JButton(String 。它只用了數(shù)字; 然后把icons數(shù)組初始化對應每個圖片即可

連連看JAVA源代碼是什么?

importjavax.swing.*;\x0d\x0aimportjava.awt.*;\x0d\x0aimportjava.awt.event.*;\x0d\x0apublicclasslianliankanimplementsActionListener\x0d\x0a{\x0d\x0aJFramemainFrame;//主面板\x0d\x0aContainerthisContainer;\x0d\x0aJPanelcenterPanel,southPanel,northPanel;//子面板\x0d\x0aJButtondiamondsButton[][]=newJButton[6][5];//游戲按鈕數(shù)組\x0d\x0aJButtonexitButton,resetButton,newlyButton;//退出,重列,重新開始按鈕\x0d\x0aJLabelfractionLable=newJLabel("0");//分數(shù)標簽\x0d\x0aJButtonfirstButton,secondButton;//分別記錄兩次被選中的按鈕\x0d\x0aintgrid[][]=newint[8][7];//儲存游戲按鈕位置\x0d\x0astaticbooleanpressInformation=false;//判斷是否有按鈕被選中\(zhòng)x0d\x0aintx0=0,y0=0,x=0,y=0,fristMsg=0,secondMsg=0,validateLV;//游戲按鈕的位置坐標\x0d\x0ainti,j,k,n;//消除方法控制\x0d\x0apublicvoidinit(){\x0d\x0amainFrame=newJFrame("JKJ連連看");\x0d\x0athisContainer=mainFrame.getContentPane();\x0d\x0athisContainer.setLayout(newBorderLayout());\x0d\x0acenterPanel=newJPanel();\x0d\x0asouthPanel=newJPanel();\x0d\x0anorthPanel=newJPanel();\x0d\x0athisContainer.add(centerPanel,"Center");\x0d\x0athisContainer.add(southPanel,"South");\x0d\x0athisContainer.add(northPanel,"North");\x0d\x0acenterPanel.setLayout(newGridLayout(6,5));\x0d\x0afor(intcols=0;cols=0){\x0d\x0acols=(int)(Math.random()*6+1);\x0d\x0arows=(int)(Math.random()*5+1);\x0d\x0awhile(grid[cols][rows]!=0){\x0d\x0acols=(int)(Math.random()*6+1);\x0d\x0arows=(int)(Math.random()*5+1);\x0d\x0a}\x0d\x0athis.grid[cols][rows]=save[n];\x0d\x0an--;\x0d\x0a}\x0d\x0amainFrame.setVisible(false);\x0d\x0apressInformation=false;//這里一定要將按鈕點擊信息歸為初始\x0d\x0ainit();\x0d\x0afor(inti=0;ij){//如果第二個按鈕的Y坐標大于空按鈕的Y坐標說明第一按鈕在第二按鈕左邊\x0d\x0afor(i=y-1;i=j;i--){//判斷第二按鈕左側(cè)直到第一按鈕中間有沒有按鈕\x0d\x0aif(grid[x][i]!=0){\x0d\x0ak=0;\x0d\x0abreak;\x0d\x0a}\x0d\x0aelse//K=1說明通過了第一次驗證\x0d\x0a}\x0d\x0aif(k==1){\x0d\x0alinePassOne();\x0d\x0a}\x0d\x0a}\x0d\x0aif(yx){\x0d\x0afor(n=x0;n=x+1;n--){\x0d\x0aif(grid[n][j]!=0){\x0d\x0ak=0;\x0d\x0abreak;\x0d\x0a}\x0d\x0aif(grid[n][j]==0n==x+1){\x0d\x0aremove();\x0d\x0a}\x0d\x0a}\x0d\x0a}\x0d\x0a}\x0d\x0a}\x0d\x0afor(i=0;ii){\x0d\x0afor(j=x-1;j=i;j--){\x0d\x0aif(grid[j][y]!=0){\x0d\x0ak=0;\x0d\x0abreak;\x0d\x0a}\x0d\x0aelse\x0d\x0a}\x0d\x0aif(k==1){\x0d\x0arowPassOne();\x0d\x0a}\x0d\x0a}\x0d\x0aif(xy){\x0d\x0afor(n=y0;n=y+1;n--){\x0d\x0aif(grid[i][n]!=0){\x0d\x0ak=0;\x0d\x0abreak;\x0d\x0a}\x0d\x0aif(grid[i][n]==0n==y+1){\x0d\x0aremove();\x0d\x0a}\x0d\x0a}\x0d\x0a}\x0d\x0a}\x0d\x0a}\x0d\x0a}\x0d\x0a}\x0d\x0apublicvoidlinePassOne(){\x0d\x0aif(y0j){//第一按鈕同行空按鈕在左邊\x0d\x0afor(i=y0-1;i=j;i--){//判斷第一按鈕同左側(cè)空按鈕之間有沒按鈕\x0d\x0aif(grid[x0][i]!=0){\x0d\x0ak=0;\x0d\x0abreak;\x0d\x0a}\x0d\x0aelse//K=2說明通過了第二次驗證\x0d\x0a}\x0d\x0a}\x0d\x0aif(y0i){\x0d\x0afor(j=x0-1;j=i;j--){\x0d\x0aif(grid[j][y0]!=0){\x0d\x0ak=0;\x0d\x0abreak;\x0d\x0a}\x0d\x0aelse\x0d\x0a}\x0d\x0a}\x0d\x0aif(x0

回答于?2022-12-14

如何用JAVA 編寫一個連連看游戲全程設計

剛試了。。測試通過。。

importjavax.swing.*;

importjava.awt.*;

importjava.awt.event.*;

publicclass LianLianKan implements ActionListener {

JFrame mainFrame; // 主面板

Container thisContainer;

JPanel centerPanel, southPanel, northPanel; //子面板

JButton diamondsButton[][] = newJButton[6][5];// 游戲按鈕數(shù)組

JButton exitButton, resetButton, newlyButton;// 退出,重列,重新開始按鈕

JLabel fractionLable = newJLabel("0"); // 分數(shù)標簽

JButton firstButton, secondButton; // 分別記錄兩次被選中的按鈕

// 儲存游戲按鈕位置(這里其實只要6行,5列。但是我們用了8行,7列。是等于在這個面板按鈕的周圍還圍

//了一層是0的按鈕,這樣就可以實現(xiàn)靠近面板邊緣的兩個按鈕可以消去)

int grid[][] = new int[8][7];

static boolean pressInformation = false; // 判斷是否有按鈕被選中

int x0 = 0, y0 = 0, x = 0, y = 0, fristMsg =0, secondMsg = 0, validateLV; // 游戲按鈕的位置坐標

int i, j, k, n;// 消除方法控制

public void init() {

mainFrame = new JFrame("JKJ連連看");

thisContainer = mainFrame.getContentPane();

thisContainer.setLayout(new BorderLayout());

centerPanel = new JPanel();

southPanel = new JPanel();

northPanel = new JPanel();

thisContainer.add(centerPanel,"Center");

thisContainer.add(southPanel,"South");

thisContainer.add(northPanel,"North");

centerPanel.setLayout(new GridLayout(6, 5));

for (int cols = 0; cols 6; cols++) {

for (int rows = 0; rows 5; rows++) {

diamondsButton[cols][rows] = newJButton(String

.valueOf(grid[cols + 1][rows + 1]));

diamondsButton[cols][rows].addActionListener(this);

centerPanel.add(diamondsButton[cols][rows]);

}

}

exitButton = new JButton("退出");

exitButton.addActionListener(this);

resetButton = new JButton("重列");

resetButton.addActionListener(this);

newlyButton = new JButton("再來一局");

newlyButton.addActionListener(this);

southPanel.add(exitButton);

southPanel.add(resetButton);

southPanel.add(newlyButton);

fractionLable.setText(String.valueOf(Integer.parseInt(fractionLable

.getText())));

northPanel.add(fractionLable);

mainFrame.setBounds(280, 100, 500, 450);

mainFrame.setVisible(true);

mainFrame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);

}

public void randomBuild() {

int randoms, cols, rows;

for (int twins = 1; twins = 15; twins++){//一共15對button,30個

randoms = (int) (Math.random() * 25 +1);//button上的數(shù)字

for (int alike = 1; alike = 2; alike++){

cols = (int) (Math.random() * 6 + 1);

rows = (int) (Math.random() * 5 + 1);

while (grid[cols][rows] != 0) {//等于0說明這個空格有了button

cols = (int) (Math.random() * 6 + 1);

rows = (int) (Math.random() * 5 + 1);

}

this.grid[cols][rows] = randoms;

}

}

}

public void fraction() {

fractionLable.setText(String.valueOf(Integer.parseInt(fractionLable

.getText()) + 100));

}

public void reload() {

int save[] = new int[30];

int n = 0, cols, rows;

int grid[][] = new int[8][7];

for (int i = 0; i = 6; i++) {

for (int j = 0; j = 5; j++) {

if (this.grid[i][j] != 0) {

save[n] = this.grid[i][j];//記下每個button的數(shù)字

n++;//有幾個沒有消去的button

}

}

}

n = n - 1;

this.grid = grid;

while (n = 0) {//把沒有消去的button重新放一次

cols = (int) (Math.random() * 6 + 1);

rows = (int) (Math.random() * 5 + 1);

while (grid[cols][rows] != 0) {

cols = (int) (Math.random() * 6 + 1);

rows = (int) (Math.random() * 5 + 1);

}

this.grid[cols][rows] = save[n];

n--;

}

mainFrame.setVisible(false);

pressInformation = false; // 這里一定要將按鈕點擊信息歸為初始

init();

for (int i = 0; i 6; i++) {

for (int j = 0; j 5; j++) {

if (grid[i + 1][j + 1] == 0)

diamondsButton[i][j].setVisible(false);

}

}

}

public void estimateEven(int placeX, intplaceY, JButton bz) {

if (pressInformation == false) {

x = placeX;

y = placeY;

secondMsg = grid[x][y];

secondButton = bz;

pressInformation = true;

} else {

x0 = x;

y0 = y;

fristMsg = secondMsg;

firstButton = secondButton;

x = placeX;

y = placeY;

secondMsg = grid[x][y];

secondButton = bz;

if (fristMsg == secondMsg secondButton != firstButton) {

xiao();

}

}

}

public void xiao() { // 相同的情況下能不能消去。仔細分析,不一條條注釋

if ((x0 == x (y0 == y + 1 || y0 ==y - 1))

|| ((x0 == x + 1 || x0 == x - 1) (y0 == y))) { // 判斷是否相鄰

remove();

} else {

for (j = 0; j 7; j++) {

if (grid[x0][j] == 0) { // 判斷和第一個按鈕同行的哪個按鈕為空

//如果找到一個為空的,就按列值的三種情況比較第二個按鈕與空按鈕的位置

if (y j) {//第二個按鈕在空按鈕右邊

for (i = y - 1; i = j; i--) { //檢測從第二個按鈕橫向左邊到空格所在列為止是否全是空格

if (grid[x][i] != 0) {

k = 0;

break;//存在非空格的就退出,這一退出就不可能k==2了,所以就會到下而215行出同理的判斷列

} else {

k = 1;

} // K=1說明全是空格通過了第一次驗證,也就是從第二個按鈕橫向左邊到空格所在列為止全是空格

}

if (k == 1) {

linePassOne();//進入第二次驗證,也就是從第一個按鈕到它同行的空格之間的空格判斷

}

}

if (y j) { // 第二個按鈕在空按鈕左邊

for (i = y + 1; i = j; i++) {//檢測從第二個按鈕橫向右邊到空格所在列為止是否全是空格

if (grid[x][i] != 0) {

k = 0;

break;

} else {

k = 1;

}

}

if (k == 1) {

linePassOne();

}

}

if (y == j) {//第二個按鈕和空按鈕同列

linePassOne();

}

}

//第三次檢測,檢測確定為空的第j列的那個按鈕豎向到第二個按鈕,看是不是有按鈕

if (k == 2) {

if (x0 == x) {//第一,二按鈕在同行

remove();

}

if (x0 x) {//第一按鈕在第二按鈕下邊

for (n = x0; n = x - 1; n++) {//從空按鈕豎向到第二個按鈕所在行是否有按鈕

if (grid[n][j] != 0) {

k= 0;

break;

}

//沒有按鈕,說明這條路經(jīng)就通了

if (grid[n][j] == 0 n == x -1) {

remove();

}

}

}

if (x0 x) {//第一按鈕在第二按鈕上邊

for (n = x0; n = x + 1; n--) {

if (grid[n][j] != 0) {

k = 0;

break;

}

if (grid[n][j] == 0 n == x +1) {

remove();

}

}

}

}

}//-------------------------------------for

//當上面的檢測與第一個按鈕同行的空格按鈕失敗后(不能找到與第二個按鈕的相連路經(jīng)),下面就執(zhí)行

//檢測與第一個按鈕同列的空格按鈕

for (i = 0; i 8; i++) {

if (grid[i][y0] == 0) {// 判斷和第一個按鈕同列的哪個按鈕為空

if (x i) {//第二個按鈕在這個空按鈕的下面

for (j = x - 1; j = i; j--) {

if (grid[j][y] != 0) {

k = 0;

break;

} else {

k = 1;

}

}

if (k == 1) {

rowPassOne();

}

}

if (x i) {//第二個按鈕在這個空按鈕的上面

for (j = x + 1; j = i; j++) {

if (grid[j][y] != 0) {

k = 0;

break;

} else {

k = 1;

}

}

if (k == 1) {

rowPassOne();

}

}

if (x == i) {//第二個按鈕與這個空按鈕同行

rowPassOne();

}

}

if (k == 2) {

if (y0 == y) {//第二個按鈕與第一個按鈕同列

remove();

}

if (y0 y) {//第二個按鈕在第一個按鈕右邊

for (n = y0; n = y - 1; n++) {

if (grid[i][n] != 0) {

k = 0;

break;

}

if (grid[i][n] == 0 n == y -1) {

remove();

}

}

}

if (y0 y) {//第二個按鈕在第一個按鈕左邊

for (n = y0; n = y + 1; n--) {

if (grid[i][n] != 0) {

k = 0;

break;

}

if (grid[i][n] == 0 n == y +1) {

remove();

}

}

}

}

}//--------------------------------for

}//-------------else

}//------------xiao

public void linePassOne() {

if (y0 j) { // 第一按鈕同行空按鈕在左邊

for (i = y0 - 1; i = j; i--) { // 判斷第一按鈕同左側(cè)空按鈕之間有沒按鈕

if (grid[x0][i] != 0) {

k = 0;

break;

} else {

k = 2;

} // K=2說明通過了第二次驗證

}

}

if (y0 j) { // 第一按鈕同行空按鈕在右邊

for (i = y0 + 1; i = j; i++) {

if (grid[x0][i] != 0) {

k = 0;

break;

} else {

k = 2;

}

}

}

}

public void rowPassOne() {

if (x0 i) {//第一個按鈕在與它同列的那個空格按鈕下面

for (j = x0 - 1; j = i; j--) {

if (grid[j][y0] != 0) {

k = 0;

break;

} else {

k = 2;

}

}

}

if (x0 i) {//第一個按鈕在與它同列的那個空格按鈕上面

for (j = x0 + 1; j = i; j++) {

if (grid[j][y0] != 0) {

k = 0;

break;

} else {

k = 2;

}

}

}

}

public void remove() {

firstButton.setVisible(false);

secondButton.setVisible(false);

fraction();

pressInformation = false;

k = 0;

grid[x0][y0] = 0;

grid[x][y] = 0;

}

public void actionPerformed(ActionEvent e) {

if (e.getSource() == newlyButton) {

int grid[][] = new int[8][7];

this.grid = grid;

randomBuild();

mainFrame.setVisible(false);

pressInformation = false;

init();

}

if (e.getSource() == exitButton)

System.exit(0);

if (e.getSource() == resetButton)

reload();

for (int cols = 0; cols 6; cols++) {

for (int rows = 0; rows 5; rows++) {

if (e.getSource() ==diamondsButton[cols][rows])

estimateEven(cols + 1, rows + 1,diamondsButton[cols][rows]);

}

}

}

public static void main(String[] args) {

LianLianKan llk = new LianLianKan();

llk.randomBuild();

llk.init();

}

}

分享標題:java連連看程序代碼 連連看源代碼
網(wǎng)站網(wǎng)址:http://muchs.cn/article8/hgesip.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供小程序開發(fā)手機網(wǎng)站建設、靜態(tài)網(wǎng)站網(wǎng)頁設計公司、網(wǎng)站營銷企業(yè)建站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都定制網(wǎng)站建設