Java实现拼图小游戏(3)—— 添加图片(含JFrame源码阅读)

简介: 用法:可以简单记忆为JLabel是一个管理容器,创建对象以后管理括号内的东西。比如上面我们新建了一个对象icon,应该被放入到JLabel容器中,所以括号内传递的参数就是icon

一、前言


本文主要是实现拼图小游戏中的添加图片功能


二、步骤


1.在IDEA中导入图片


  • 首先把要用的图片都放在一个文件夹中
  • 复制文件夹
  • 点击项目名称,并Ctrl+V黏贴文件夹


8cc8913968f64691bb324e67cf7fd8c5.png


然后等待一下就会发现图片已经全部都导入进来了


7a26d4275f98481a8020017da5a1f425.png


2. 创建一个图片ImageIcon的对象


1️⃣ImageIcon方法的使用


由于我们不知道这个方法如何使用,所以我们可以通过阅读源码或者查看API的方式来查找方法的用法,这里我们介绍一下阅读源码的方式


  • 使用Ctrl+N来搜素一下ImageIcon方法


a05d489f439d4a00bae288c588b448a4.png


  • 使用Ctrl+F12来查找查看当前类的所有方法和成员变量,由于我们要添加图片,图片名称又是String类型的,所以我们选择String类型的方法


f0031b95f259426ba84124ee19b4d997.png


  • 可以看到这里让我们在括号内传递的参数是文件名,即图片名字


526f40f140c14e3a8f2098ad3b1be140.png


所以格式为:


ImageIcon icon = new ImageIcon("...(此处填写图片路径)")


2️⃣传递方法内参数(图片路径)


所以此处我们要传递的参数就是图片的名字,但是计算机要寻找图片是按照路径来的,所以我们要复制图片存放的路径


  • 我们先随便选中一张图片,右键点击


ee775635b74c4f2a97256266c4fe1f33.png


  • 选择复制路径


  • 黏贴到上面的括号中


3. 创建JLabel的对象(一个用来放图片的容器)


用法:可以简单记忆为JLabel是一个管理容器,创建对象以后管理括号内的东西

比如上面我们新建了一个对象icon,应该被放入到JLabel容器中,所以括号内传递的参数就是icon


JLabel jLabel = new JLabel(icon)


4.调整位置


416cf4939c3142f79558f060d97b8517.png


  • jLabel.setBounds是用来设置位置和大小的一个方法,里面的四个参数分别是:X坐标、Y坐标、长度、宽度


4015405fe89045e2a3e23556de0ff58a.png


5. 将容器放到界面中


注意:隐藏容器要手动获取,图片放在这个隐藏容器中,默认图片放在正中间,所以我们要取消默认设置,并以 XY 轴坐标形式来存放图片


手动获取隐藏容器:getContentPane()

取消放置在正中间:setLayout(null),放在初始化界面的方法中


cfe6e7c5da9546658390ab1487bc0cc5.png


再使用add函数添加


this.getContentPane().add(jLabel)


三、源码阅读


  • Ctrl+F12搜素,并选中空参构造的函数


6c3165b0034d4ebbb22623aa4868f150.png


  • 可以看到里面有函数FrameInit(),我们再用Ctrl+B来跟进一下


8060a0e873b046e78f611714c47a0b70.png


  • 这边有一个creatRootPane(),我们继续跟进


5cad9fd053a344669b5f3d8bf834cc30.png


  • 可以看到底层源码中已经帮我们新建好了对象,所以不需要我们自己再去构造了


693abd0169b54dbaa668632c4be03149.png


四、完整代码


 private void initImage() {
        //创建第一张图片
        //创建ImageIcon
        ImageIcon icon1 = new ImageIcon("F:\\IDEA\\PuzzleGame\\image\\image\\animal\\animal3\\1.jpg");
        //创建JLabel管理容器
        JLabel jLabel1 = new JLabel(icon1);
        //设定图片位置
        jLabel1.setBounds(0,0,105,105);
        //将JLabel放到界面中
        this.getContentPane().add(jLabel1);
        //创建第二张图片
        ImageIcon icon2 = new ImageIcon("F:\\IDEA\\PuzzleGame\\image\\image\\animal\\animal3\\2.jpg");
        JLabel jLabel2 = new JLabel(icon2);
        jLabel2.setBounds(105,0,105,105);
        this.getContentPane().add(jLabel2);
        //创建第三张图片
        ImageIcon icon3 = new ImageIcon("F:\\IDEA\\PuzzleGame\\image\\image\\animal\\animal3\\3.jpg");
        JLabel jLabel3 = new JLabel(icon3);
        jLabel3.setBounds(210,0,105,105);
        this.getContentPane().add(jLabel3);
        //创建第四张图片
        ImageIcon icon4 = new ImageIcon("F:\\IDEA\\PuzzleGame\\image\\image\\animal\\animal3\\4.jpg");
        JLabel jLabel4 = new JLabel(icon4);
        jLabel4.setBounds(315,0,105,105);
        this.getContentPane().add(jLabel4);
    }


五、优化代码


  • 如果要添加十五张图片的话,代码量就太大了,所以我们要优化代码,我们可以看坐标(图片左上角的坐标轴)的变化找找规律
  • 第一排Y轴值都为0,X轴的值是0、105、210、305,都相差105,那么他们都是105的整数倍,从0倍开始到3倍(列);同理,第一列的X轴值都为0,Y轴的值是0、105、210、305,那么他们都是105的整数倍,从0倍开始到3倍(列)
  • 我们可以用两层循环来优化,内层循环是X轴的值,即列,外层循环是Y轴的值,即行,但是要注意的是在修改图片路径的时候,如果定义的变量放在字符串内,那么将识别不了该图片,而是要把变量单独拿出来放在外面


优化后的代码


private void initImage() {
        int n = 1;
        for(int i = 0; i < 4; i++){
            for(int j = 0; j < 4; j++){
                JLabel jLabel = new JLabel(new ImageIcon("F:\\IDEA\\PuzzleGame\\image\\image\\animal\\animal3\\"+n+".jpg"));
                jLabel.setBounds(105 * j, 105 * i,105,105);
                this.getContentPane().add(jLabel);
                n++;
            }
        }
    }


六、测试代码


01b4d29fda1d413b8e0ccada5bd45dcf.png


七、结语


添加图片的代码并不复杂,但是我们要学会用所学知识去优化代码,使得代码尽量简洁,提高代码的可读性

相关文章
|
16天前
|
Java
Java开发实现图片URL地址检验,如何编码?
【10月更文挑战第14天】Java开发实现图片URL地址检验,如何编码?
46 4
|
16天前
|
Java
Java开发实现图片地址检验,如果无法找到资源则使用默认图片,如何编码?
【10月更文挑战第14天】Java开发实现图片地址检验,如果无法找到资源则使用默认图片,如何编码?
49 2
|
16天前
|
Java 数据安全/隐私保护
Java ffmpeg 实现视频加文字/图片水印功能
【10月更文挑战第22天】在 Java 中使用 FFmpeg 实现视频加文字或图片水印功能,需先安装 FFmpeg 并添加依赖(如 JavaCV)。通过构建 FFmpeg 命令行参数,使用 `drawtext` 滤镜添加文字水印,或使用 `overlay` 滤镜添加图片水印。示例代码展示了如何使用 JavaCV 实现文字水印。
|
22天前
|
前端开发 小程序 Java
java基础:map遍历使用;java使用 Patten 和Matches 进行正则匹配;后端传到前端展示图片三种情况,并保存到手机
这篇文章介绍了Java中Map的遍历方法、使用Pattern和matches进行正则表达式匹配,以及后端向前端传输图片并保存到手机的三种情况。
15 1
|
23天前
|
算法 Java Linux
java制作海报四:java BufferedImage 转 InputStream 上传至OSS。png 图片合成到模板(另一个图片)上时,透明部分变成了黑色
这篇文章主要介绍了如何将Java中的BufferedImage对象转换为InputStream以上传至OSS,并解决了png图片合成时透明部分变黑的问题。
43 1
|
Java
Java实现一个打飞机的小游戏
Java实现一个打飞机的小游戏,毕业设计,计算机毕业设计。Java实现一个打飞机的小游戏,毕业设计,计算机毕业设计。Java实现一个打飞机的小游戏,毕业设计,计算机毕业设计。Java实现一个打飞机的小游戏,毕业设计,计算机毕业设计。
169 0
Java实现一个打飞机的小游戏
|
8天前
|
监控 安全 Java
在 Java 中使用线程池监控以及动态调整线程池时需要注意什么?
【10月更文挑战第22天】在进行线程池的监控和动态调整时,要综合考虑多方面的因素,谨慎操作,以确保线程池能够高效、稳定地运行,满足业务的需求。
79 38
|
5天前
|
安全 Java
java 中 i++ 到底是否线程安全?
本文通过实例探讨了 `i++` 在多线程环境下的线程安全性问题。首先,使用 100 个线程分别执行 10000 次 `i++` 操作,发现最终结果小于预期的 1000000,证明 `i++` 是线程不安全的。接着,介绍了两种解决方法:使用 `synchronized` 关键字加锁和使用 `AtomicInteger` 类。其中,`AtomicInteger` 通过 `CAS` 操作实现了高效的线程安全。最后,通过分析字节码和源码,解释了 `i++` 为何线程不安全以及 `AtomicInteger` 如何保证线程安全。
java 中 i++ 到底是否线程安全?
|
9天前
|
Java 调度
[Java]线程生命周期与线程通信
本文详细探讨了线程生命周期与线程通信。文章首先分析了线程的五个基本状态及其转换过程,结合JDK1.8版本的特点进行了深入讲解。接着,通过多个实例介绍了线程通信的几种实现方式,包括使用`volatile`关键字、`Object`类的`wait()`和`notify()`方法、`CountDownLatch`、`ReentrantLock`结合`Condition`以及`LockSupport`等工具。全文旨在帮助读者理解线程管理的核心概念和技术细节。
25 1
[Java]线程生命周期与线程通信
|
7天前
|
安全 Java
在 Java 中使用实现 Runnable 接口的方式创建线程
【10月更文挑战第22天】通过以上内容的介绍,相信你已经对在 Java 中如何使用实现 Runnable 接口的方式创建线程有了更深入的了解。在实际应用中,需要根据具体的需求和场景,合理选择线程创建方式,并注意线程安全、同步、通信等相关问题,以确保程序的正确性和稳定性。