2048小游戏(Java)(swing实现)(一)
自己写的2048小游戏,仅支持鼠标操作
主要是我不知道怎么添加键盘监听
import javax.swing.*;
import java.awt.*;
import java.awt.event.*; public class JF2048 extends JFrame { /**
*
*/
private static final long serialVersionUID = 1L; private Ja2048 ja; public JButton b[] = {
new JButton(),
new JButton(),
new JButton(),
new JButton()
}; public JButton back = new JButton("back"); private ActionListener b0 = new ActionListener(){
public void actionPerformed(ActionEvent e){
ja.cp0();
}}; private ActionListener b1 = new ActionListener(){
public void actionPerformed(ActionEvent e){
ja.cp1();
}}; private ActionListener b2 = new ActionListener(){
public void actionPerformed(ActionEvent e){
ja.cp2();
}}; private ActionListener b3 = new ActionListener(){
public void actionPerformed(ActionEvent e){
ja.cp3();
}}; private ActionListener back1 = new ActionListener(){
public void actionPerformed(ActionEvent e){
ja.back();
}}; public JLabel[][] la ={
{new JLabel(),new JLabel(),new JLabel(),new JLabel()},
{new JLabel(),new JLabel(),new JLabel(),new JLabel()},
{new JLabel(),new JLabel(),new JLabel(),new JLabel()},
{new JLabel(),new JLabel(),new JLabel(),new JLabel()},
}; public JF2048(){ super("2048"); //this.addKeyListener(x); b[0].setBounds(3,20,16,156);
b[1].setBounds(178,20,16,156);
b[2].setBounds(20,3,156,16);
b[3].setBounds(20,178,156,16);
back.setBounds(3,3,16,16); b[0].addActionListener(b0);
b[1].addActionListener(b1);
b[2].addActionListener(b2);
b[3].addActionListener(b3);
back.addActionListener(back1); for(int i =0;i<4;i++)
for(int j =0;j<4;j++){
la[i][j].setBounds(20+40*i,20+40*j,36,36);
la[i][j].setOpaque(true);
//la[i][j].setFont(new Font("幼圆",1,24));
la[i][j].setHorizontalAlignment(SwingConstants.CENTER);
} this.setSize(217,238);
this.add(b[0]);
this.add(b[1]);
this.add(b[2]);
this.add(b[3]);
this.add(back);
for(int i =0;i<4;i++)
for(int j =0;j<4;j++)
this.add(la[i][j]);
JLabel p = new JLabel();
p.setBackground(new Color(127,127,127));
p.setOpaque(true);
this.add(p); } public static void main(String[] args){
JF2048 jf = new JF2048();
jf.ja=new Ja2048(jf);
jf.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
jf.setVisible(true);
} }
界面层代码
import java.awt.*;
public class Ja2048{ public static int[][] state=new int[4][4];
public static int[][] bac=new int[4][4]; private JF2048 linkF; public Ja2048(JF2048 a){
this.linkF = a;
setNull(state,getRandom());
setNull(state,getRandom());
setState();
} public void cp0(){
boolean bool= false;
for(int i = 1;i<4;i++)
for(int j = 0;j<4;j++)
if(state[i][j]!=0&&(state[i-1][j]==0||state[i-1][j]==state[i][j]))
bool=true;
if(!bool)return; for(int i =0;i<4;i++)
for(int j =0;j<4;j++)
bac[i][j]=state[i][j]; int[][] b = new int[4][4];
for(int j=0;j<4;j++){
int[] a ={state[0][j],state[1][j],state[2][j],state[3][j]};
b[j]=LierIntArr.drop(a);
}
setNull(b,getRandom());
int[][] x=new int[4][4];
for(int i=0;i<4;i++)
for(int j=0;j<4;j++)
x[i][j]=b[j][i];
state=x;
setState();
}//向左
public void cp1(){
boolean bool=false;
for(int i=0;i<3;i++)
for(int j=0;j<4;j++)
if(state[i][j]!=0&&(state[i+1][j]==0||state[i+1][j]==state[i][j]))
bool=true;
if(!bool)return;
bac=state;
int[][] b = new int[4][4];
for(int j=0;j<4;j++){
int[] a = {state[3][j],state[2][j],state[1][j],state[0][j]};
b[j]=LierIntArr.drop(a);
}
setNull(b,getRandom());
int[][] x=new int[4][4];
for(int i=0;i<4;i++)
for(int j=0;j<4;j++)
x[i][j]=b[j][3-i];
state=x;
setState();
}//向右
public void cp2(){
boolean bool=false;
for(int i=0;i<4;i++)
for(int j=1;j<4;j++)
if(state[i][j]!=0&&(state[i][j-1]==0||state[i][j-1]==state[i][j]))
bool=true;
if(!bool)return;
bac=state.clone();
int[][] b = new int[4][4];
for(int i=0;i<4;i++)
b[i]=LierIntArr.drop(state[i]);
setNull(b,getRandom());
state=b.clone();
setState();
}//向上
public void cp3(){
boolean bool=false;
for(int i=0;i<4;i++)
for(int j=0;j<3;j++)
if(state[i][j]!=0&&(state[i][j+1]==0||state[i][j+1]==state[i][j]))
bool=true;
if(!bool)return;
bac=state.clone();
int[][] b=new int[4][4];
for(int i=0;i<4;i++){
int[] a ={state[i][3],state[i][2],state[i][1],state[i][0]};
b[i]=LierIntArr.drop(a);
}
setNull(b,getRandom());
int[][] x=new int[4][4];
for(int i=0;i<4;i++)
for(int j=0;j<4;j++)
x[i][j]=b[i][3-j];
state=x;
setState();
}//向下
public void back(){
state=bac.clone();
setState();
}
private void setState(){
for(int i=0;i<4;i++)
for(int j=0;j<4;j++){
if(state[i][j]==0){
linkF.la[i][j].setText("");
linkF.la[i][j].setBackground(new Color(227,227,227));
linkF.la[i][j].setForeground(new Color(0,0,0));
}
else if(state[i][j]==2){
linkF.la[i][j].setText("2");
linkF.la[i][j].setFont(new Font("幼圆",1,20));
linkF.la[i][j].setBackground(new Color(255,255,255));
linkF.la[i][j].setForeground(new Color(0,0,0));
}
else if(state[i][j]==4){
linkF.la[i][j].setText("4");
linkF.la[i][j].setFont(new Font("幼圆",1,20));
linkF.la[i][j].setBackground(new Color(127,227,127));
linkF.la[i][j].setForeground(new Color(0,0,0));
}
else if(state[i][j]==8){
linkF.la[i][j].setText("8");
linkF.la[i][j].setFont(new Font("幼圆",1,20));
linkF.la[i][j].setBackground(new Color(0,127,127));
linkF.la[i][j].setForeground(new Color(255,255,255));
}
else if(state[i][j]==16){
linkF.la[i][j].setText("16");
linkF.la[i][j].setFont(new Font("幼圆",1,20));
linkF.la[i][j].setBackground(new Color(0,255,0));
linkF.la[i][j].setForeground(new Color(255,255,255));
}
else if(state[i][j]==32){
linkF.la[i][j].setText("32");
linkF.la[i][j].setFont(new Font("幼圆",1,20));
linkF.la[i][j].setBackground(new Color(127,127,0));
linkF.la[i][j].setForeground(new Color(255,255,255));
}
else if(state[i][j]==64){
linkF.la[i][j].setText("64");
linkF.la[i][j].setFont(new Font("幼圆",1,20));
linkF.la[i][j].setBackground(new Color(255,0,0));
linkF.la[i][j].setForeground(new Color(255,255,255));
}
else if(state[i][j]==128){
linkF.la[i][j].setText("128");
linkF.la[i][j].setFont(new Font("幼圆",1,20));
linkF.la[i][j].setBackground(new Color(127,255,0));
linkF.la[i][j].setForeground(new Color(255,255,255));
}
else if(state[i][j]==256){
linkF.la[i][j].setText("256");
linkF.la[i][j].setFont(new Font("幼圆",1,20));
linkF.la[i][j].setBackground(new Color(255,255,0));
linkF.la[i][j].setForeground(new Color(0,0,0));
}
else if(state[i][j]==512){
linkF.la[i][j].setText("512");
linkF.la[i][j].setFont(new Font("幼圆",1,20));
linkF.la[i][j].setBackground(new Color(255,255,0));
linkF.la[i][j].setForeground(new Color(0,0,0));
}
else if(state[i][j]==1024){
linkF.la[i][j].setText("1024");
linkF.la[i][j].setFont(new Font("幼圆",1,16));
linkF.la[i][j].setBackground(new Color(63,63,63));
linkF.la[i][j].setForeground(new Color(255,255,255));
}
}//for循环 }//setState方法 private static int getRandom(){
int a = (int)(1000*Math.random());
if(a%10<3)
return 4;
else
return 2;
}//随机生成一个2或4,可通过调整判断条件中的数字大小来调整2和4所占的比率
/**
* 用于在4x4二维数组中随机挑出一个值为0的元素,并将其赋值为给定整数。特殊地,若该二维数组已满,返回false。
* @param x 该二维数组
* @param y 给定整数
* @return
*/
private static boolean setNull(int[][] x,int y){
boolean bool=false;
for(int i=0;i<4;i++)
for(int j=0;j<4;j++)
if(x[i][j]==0)bool=true;
if(!bool)return false; int a = (int)(100*Math.random());
int b = (int)(6+10*Math.random());
int c = a%b;
while(true){
for(int i=0;i<4;i++)
for(int j=0;j<4;j++){
if(x[i][j]==0&&c<=0){
x[i][j]=y;
return true;
}
else if(x[i][j]==0&&c>0)
c--;
i=(i==4?0:i);
j=(j==4?0:j);
}
}
}//boolean setNull(int[][],int)方法用于在4x4二维数组中随机挑出一个值为0的元素,并将其赋值为给定整数。特殊地,若该二维数组已满,返回false。 }
算法层代码
/**
*
* @author qliujinming@qq.com
*
* @see http://www.cnblogs.com/liujinming/
*
*/
public class LierIntArr{
/**
* 该方法用于接受一个整数数组,对该数组进行drop操作后返回
* 示例:接受 2 0 2 0 5 5,返回4 10 0 0 0 0
* @param 需要进行drop操作的数组
* @return drop操作之后的数组
*/
public static int[] drop(int[] a){
int b = a.length;
if(b<=1)return a;
int[] c = new int[b];
int j=0;
for(int i=0;i<b;i++){
if(c[j]==0&&a[i]!=0)
c[j]=a[i];
else if(c[j]!=0&&a[i]==c[j]){
c[j]=2*a[i];
j++;
}
else if(a[i]!=0&&c[j]!=0&&a[i]!=c[j]){
j++;
c[j]=a[i];
}
}
return c;
}
//该方法用于接受一个整数数组,对该数组进行drop操作后返回
//示例:接受 2 0 2 0 5 5,返回4 10 0 0 0 0 public static void main(String[] args){
int[] a = {0,2,0,2,4,0,0,4,2,0,2,5,5,0,10};
int[] b = drop(a);
for(int i = 0;i<b.length;i++)
System.out.print(b[i]+",");
}
//输出结果:4,8,4,10,10,0,0,0,0,0,0,0,0,0,0, }
辅助工具
2048小游戏(Java)(swing实现)(一)的更多相关文章
- 2048小游戏(Java)(swing实现)(二)
这里是上一次的成果,只能用鼠标点,没法用键盘 最近扩充了一下知识面,实现了用键盘操控2048小游戏 但是还是不支持同时使用键盘和鼠标同时操作 import javax.swing.*; //impor ...
- jQuery实践-网页版2048小游戏
▓▓▓▓▓▓ 大致介绍 看了一个实现网页版2048小游戏的视频,觉得能做出自己以前喜欢玩的小游戏很有意思便自己动手试了试,真正的验证了这句话-不要以为你以为的就是你以为的,看视频时觉得看懂了,会写了, ...
- C# 开发2048小游戏
这应该是几个月前,闲的手痒,敲了一上午代码搞出来的,随之就把它丢弃了,当时让别人玩过,提过几条更改建议,但是时至今日,我也没有进行过优化和更改(本人只会作案,不会收场,嘎嘎),下面的建议要给代码爱好的 ...
- Swift实战之2048小游戏
上周在图书馆借了一本Swift语言实战入门,入个门玩一玩^_^正好这本书的后面有一个2048小游戏的实例,笔者跟着实战了一把. 差不多一周的时间,到今天,游戏的基本功能已基本实现,细节我已不打算继续完 ...
- 如何在CentOS上安装一个2048小游戏
如何在centos上安装一个2048小游戏 最近在学习CentOS系统,就琢磨着玩点什么,然后我看到有人在玩2048小游戏,所有我就在想,为啥不装一个2048小游戏搞一下嘞,于是乎,我就开始工作啦 由 ...
- js、jQuery实现2048小游戏
2048小游戏 一.游戏简介: 2048是一款休闲益智类的数字叠加小游戏 二. 游戏玩法: 在4*4的16宫格中,您可以选择上.下.左.右四个方向进行操作,数字会按方向移动,相邻的两个数字相同就会合 ...
- 用js实现2048小游戏
用js实现2048小游戏 笔记仓库:https://github.com/nnngu/LearningNotes 1.游戏简介 2048是一款休闲益智类的数字叠加小游戏.(文末给出源代码和演示地址) ...
- 2048小游戏代码解析 C语言版
2048小游戏,也算是风靡一时的益智游戏.其背后实现的逻辑比较简单,代码量不算多,而且趣味性强,适合作为有语言基础的童鞋来加强编程训练.本篇分析2048小游戏的C语言实现代码. 前言 游戏截图: 游 ...
- Docker从0开始之部署一套2048小游戏
本文记录一下在docker部署一套2048小游戏的过程,在娱乐中熟悉docker的应用部署.docker 安装不在本文讲述之中,参考我的其它博客. 1.获取image镜像. 方法一:daocloud. ...
随机推荐
- Border Layout
------------------siwuxie095 根面板 contentPane 的默认布局就是 Border Layout B ...
- go语言的基本命令
go run命令: 用于运行命令源码文件 只能接受一个命令源码文件以及若干个库源码文件作为文件参数其内部操作是:先编译源码文件在执行 -v:列出被编译的代码包的名称 -work: 显示编译时创建的临时 ...
- C++面向对象类的实例题目十一
题目描述: 写一个程序计算三角形,正方形和圆形3种图形的面积 程序代码: #include<iostream> #include<cmath> #define PAI 3.14 ...
- iOS 打包生成ipa文件(使用终端命令打包)
1. 打开终端 2.在终端输入cd +空格 把工程文件直接拖到终端,然后回车 3. 在终端输入xcodebuild,回车 然后你可以发现工程文件里多了一个build文件夹 在build文件夹中,有一个 ...
- Spring第五天
1. [简答题]:简述一下hibernate和spring框架的整合步骤: 答: 1.加入hibernate jar包 2.编写持久化类 3.添加Hibernate的配置文件:hibernate.cf ...
- JS中的引用类型
JS的数据类型可以分为两类:一类是原始类型(比如数字.布尔值.字符串.undefined.null),另外就是对象类型.我们通常将对象类型称为引用类型.对象值都是引用.举个例子来说明,下如下的代码: ...
- Windows系统 为 Visual Studio软件 搭建 OpenCV2 开发环境
Windows系统 为 Visual Studio软件 搭建 OpenCV2 开发环境 我们的电脑系统:Windows 10 64位 Visual Studio 软件:Visual Studio 20 ...
- PCL—点云分割(RanSaC)低层次点云处理
博客转载自:http://blog.csdn.net/app_12062011/article/details/78131318 点云分割 点云分割可谓点云处理的精髓,也是三维图像相对二维图像最大优势 ...
- 算法Sedgewick第四版-第1章基础-2.1Elementary Sortss-003比较算法及算法的可视化
一.介绍 1. 2. 二.代码 1. package algorithms.elementary21; /*********************************************** ...
- js/jq基础(日常整理记录)-1-纯js格式化时间
一.纯js格式化时间 之前记录了一些,工作中发现的比较常用的使用,就记录一下. 由于很基础,就直接贴出来了,不做分析了. 改造一下Date的原型 Date.prototype.format = fun ...