Java拼图游戏

1 图片制作

       选择你喜欢的一张图片,(友情提示:图片尽量在400*600 范围内),然后通过网上的在线分割图片,或者你ps等其他软件,把图片分割为大小相等的12份.如下图所示

我们首先创建一个勇于描述游戏中显示的图片的实体类:Picture类,代码如下

public class Picture {
    private String alisa;//别名
    private String picPath;//预览图片的路径
    private String[] subPicPaths;//拼图区的切片图片路径
    //省略了setter/getter 构造方法的代码
}

这里我们就应用了java的OOP思想,把游戏中的一个拼图抽象成一个Picture类, 上图左边的小图片对应Picture类的subPicPaths属性, 右边的预览图对应Picture类的picPath属性,以及我们给这个拼图取了一个名称,对应Picture的alisa属性.

        我们已经封装好了Picture类,接下来我们需要编写我们的游戏主界面类 MainFrame,我们现在的程序不是运行在控制台,而是运行一个界面窗口,所有我们的主界面类必须实现Swing包下的JFrame类,JFrame简单的理解就是一个游戏窗口.


2.编码实现

public class MainFrame extends JFrame{
    private String[] items = {"小熊","美女"};
    private Map<String,Picture> picMap = new HashMap<>(); //游戏中的图片
    private static final long serialVersionUID = -3974891708686273202L;
    private JComboBox<String> imgComboBox; //选择图片的下拉框
    private PictureCanvasPanle canvasPanle; //拼图区的面板
    private PicturePreviewPanel previewPanle; //预览区的面板
    private JTextField nameTxt; //显示图片名词的文本域
    public static Picture selectedPicture;  //被选中的图片
    private JButton startBtn;  //开始按钮
    public static JTextField stepTxt; //显示步数的文本域
 
    //添加图片
    public void setMap(){
        for(int i = 0; i < items.length;i++){
            String[] subPaths = new String[12];
            for(int j = 0; j < subPaths.length; j++){
                subPaths[j] = "image/" +(i+1)+"-"+(j+1)+".jpg";
            }
            Picture pic = new Picture(items[i], "image/" +(i+1)+".jpg", subPaths);
            picMap.put(pic.getAlisa(), pic);
        }
    }
 
    //无参构造方法,进行界面的初始化
    public MainFrame(){
        setMap();
        //初始化
        init(); 
        //添加组件
        addComponent();
        //添加拼图和预览
        addPreview();
        //给组件添加事件
        addActionLisener();
    }
 
    //给界面上的组件绑定事件
    private void addActionLisener() {
        //给下拉框添加事件
        imgComboBox.addActionListener(new ActionListener() {
            @SuppressWarnings("unchecked")
            @Override
            public void actionPerformed(ActionEvent e) {
                JComboBox<String> cbx = (JComboBox<String>) e.getSource();
                selectedPicture = picMap.get(cbx.getSelectedItem());
                previewPanle.setPath(selectedPicture.getPicPath());
                nameTxt.setText("图片名称:"+cbx.getSelectedItem());
                canvasPanle.changePictureCell();
                previewPanle.repaint();
            }
        });
        
        //给开始按钮添加事件监听
        startBtn.addActionListener(new ActionListener() {
            @Override
            public void actionPerformed(ActionEvent e) {
                //把移动的步数清零
                canvasPanle.stepNum = 0;
                stepTxt.setText("步数:"+canvasPanle.stepNum);
                //打乱拼图区的小方块
                canvasPanle.start();
            }
        }); 
    }
 
    //添加预览图片
    private void addPreview() {
        JPanel mainPanle = new JPanel();
        mainPanle.setLayout(new GridLayout(1,2));
        canvasPanle = new PictureCanvasPanle();
        previewPanle = new PicturePreviewPanel();
        mainPanle.add(canvasPanle,BorderLayout.WEST);
        mainPanle.add(previewPanle,BorderLayout.EAST);
        
        this.add(mainPanle,BorderLayout.CENTER);
    }
 
    private void addComponent() {
        //上部分的内容
        JPanel topPanel = new JPanel();
        //设置布局器
        topPanel.setLayout(new GridLayout(1,2));
        //给上面板添加左右面板
        //左面板
        JPanel leftPanel = new JPanel();
        //设置背景颜色
        leftPanel.setBackground(Color.PINK);
        leftPanel.setBorder(new TitledBorder("游戏设置区"));
        //添加其他组件
        //设置左边的布局
        leftPanel.setLayout(new FlowLayout(FlowLayout.CENTER,10,10));
        
        //标签
        JLabel infoLabel = new JLabel("选择图片: ");
        leftPanel.add(infoLabel);
        //设置下拉框
        imgComboBox = new JComboBox<String>(items);
        imgComboBox.setBackground(Color.PINK);
        leftPanel.add(imgComboBox);
        
        //设置添加按钮
        startBtn = new JButton("Start");
        startBtn.setBackground(Color.PINK);
        leftPanel.add(startBtn);
        
        //添加
        topPanel.add(leftPanel, BorderLayout.WEST);
        
        
        //右面板
        JPanel rightPanle = new JPanel();
        rightPanle.setBackground(Color.PINK);
        rightPanle.setBorder(new TitledBorder("游戏状态区"));
        rightPanle.setLayout(new GridLayout(1,2));
        
        nameTxt = new JTextField("图片名称:小熊");
        nameTxt.setEditable(false);
        nameTxt.setBackground(Color.PINK);
        
        stepTxt = new JTextField("步数:0");
        stepTxt.setEditable(false);
        stepTxt.setBackground(Color.PINK);
        rightPanle.add(nameTxt,BorderLayout.WEST);
        rightPanle.add(stepTxt,BorderLayout.EAST);
        
        topPanel.add(rightPanle, BorderLayout.EAST);
        //把这个面板添加到窗口
        this.add(topPanel,BorderLayout.NORTH);
    }
 
    private void init() {
        //设置窗体的标题
        this.setTitle("拼图游戏");
        //设置窗体的大小
        this.setSize(1000, 720);
        //设置窗体在屏幕居中
        this.setLocationRelativeTo(null);
        //设置固定大小
        this.setResizable(false);
        //设置窗口的默认关闭操作
        this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
        selectedPicture = this.picMap.get(items[0]);
    }
    
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值