Swing学习2——图标添加Icon接口使用
废话没有,看代码。
主要就是通过实现Icon接口在标签添加一个圆形图标,并在框架中显示。
package com.sword.swing_test; import javax.swing.*;
import java.awt.*;
import java.awt.event.WindowAdapter;
import java.awt.event.WindowEvent; public class DrawIcon implements Icon {
//在Swing中通过Icon接口创建图标,Icon中有三个方法必须实现
//public int getIconWidth()、public int getIconHeight()、
// public void paintIcon(Component arg0,Graphics arg1,int arg2,int arg4)
private int width;
private int height;
public int getIconWidth(){
return this.width;
}
public int getIconHeight(){
return this.height;
}
public DrawIcon(int width,int height){
this.width=width;
this.height=height;
}
//实现paintIcon方法
public void paintIcon(Component arg0,Graphics arg1,int x,int y){
//绘制一个圆形
arg1.fillOval(x,y,width,height);
}
public static void main(String[] arg){
JFrame jf=new JFrame("IconTest");
Container container=jf.getContentPane();
DrawIcon icon=new DrawIcon(15,15);
//JLabel(标签)中其中之一构造方法为public(String text,Icon icon,int aligment)
//第三个参数为控制text即标签文本的对齐方式,用SwingConstants的静态常量
JLabel jl=new JLabel("Sword",icon,SwingConstants.CENTER);
container.add(jl);
/*这里为什么使用Container的setBackground而不是JFrame的setBackground?
我们先理论的说一下:在Swing编程体系中Swing容器分为三种,其中顶层容器又分为
四层;自上而下分别为glass pane(玻璃面板)、
content pane(内容面板)和menu bar(菜单条)、
layered pane(分层面板)、root pane(根面板)
frame的设置属性在这些面板之下表现,我们看到的也是从上往下的结果。
通俗说就是Container默认背景颜色设置颜色为white,位于JFrame层的上面,JFrame设置的背景
颜色会被Container的背景颜色遮蔽起来。
*/
//jf.setBackground();
container.setBackground(Color.GREEN);
//设置窗口关闭触发事件的一种方式
jf.addWindowListener(new WindowAdapter(){
@Override
public void windowClosing(WindowEvent e){
System.exit(0);
}
});
//jf.setDefaultCloseOperation(WindowConstants.EXIT_ON_CLOSE);j
jf.setSize(500,500);
jf.setVisible(true);
}
}
Swing学习2——图标添加Icon接口使用的更多相关文章
- AI学习吧-购物车-添加商品接口
create接口流程 需求:向购物车添加商品 流程:写shopping_cart路由--->写ShoppingCart视图函数--->使用Authuser校验用户是否登录--->首先 ...
- Jetpack Compose学习(3)——图标(Icon) 按钮(Button) 输入框(TextField) 的使用
原文地址: Jetpack Compose学习(3)--图标(Icon) 按钮(Button) 输入框(TextField) 的使用 | Stars-One的杂货小窝 本篇分别对常用的组件:图标(Ic ...
- QT5版本添加icon图标步骤
QT5版本添加icon图标方法收藏 方法1: step1: 把要显示的图标文件,比如为1.ico文件放到工程v的根目录下 step2: 修改当前项目XXX.pro文件,在文件末尾添加如下内容(注意=的 ...
- 如何快速的给你的项目添加icon图标
如何快速的给你的项目添加icon图标 下载软件 如何制作图片 将制作的图标拖到项目当中 设置启动页 注意: 如果手动添加了启动页的话,记得将Launch Screen中的东西清除掉
- 给网页标题添加icon小图标
so easy: 给网页标题添加icon小图标: 直接在html文件的head部分添加下面代码(注意href的路径): <link rel="icon" type=" ...
- 【Flutter学习】基本组件之图标组件Icon
一,概述 图标组件(Icon)为展示图标的组件,该组件不可交互,要实现可交互的图标,可以考虑使用IconButton组件. 图标组件相关的几个组件: IconButton:可交互的Icon: Icon ...
- 解决android4.0系统中菜单(Menu)添加Icon无效问题
本文转载自: http://blog.csdn.net/stevenhu_223/article/details/9705173 在Android4.0系统中,创建菜单Menu,通过setIcon方法 ...
- xcode5项目图标添加
转载文章 地址http://www.360doc.com/content/14/0103/08/14615320_342227413.shtml 最近提交itunesconnect应用时,有个警告说缺 ...
- JavaSE学习总结(六)——接口、抽象类、内部类
一.不需要实例化的原因 看一个示例: package com.zhangguo.chapter5.s1; /**动物园*/ public class Zoo { public static void ...
随机推荐
- C#实现基于ffmpeg加虹软的人脸识别demo及开发分享
对开发库的C#封装,屏蔽使用细节,可以快速安全的调用人脸识别相关API.具体见github地址.新增对.NET Core的支持,在Linux(Ubuntu下)测试通过.具体的使用例子和Demo详解,参 ...
- java异常处理try catch finally
1 异常 1.1 异常处理的作用 在编程时,如果出现文件打开失败,读写文件就会异常退出.如果出现内存溢出错误,程序也会异常退出.如果不能对这些异常进行处理.程序则无法正常运行.所 ...
- 1GB pages can only be allocated at boot time using hugepages= and not freed afterwards
2018-6-27 9:12:38 https://stackoverflow.com/questions/26385554/error-setting-nr-hugepages-via-sysfs ...
- ch.ethz.ssh2.Session和com.jcraft.jsch.Session
通过Jsch连接step 1引入jar包<!-- jcraft包 --> <dependency> <groupId>com.j ...
- jquery源码解读
最近一直在研读 jQuery 源码,初看源码一头雾水毫无头绪,真正静下心来细看写的真是精妙,其结构明晰,高内聚.低耦合,兼具优秀的性能与便利的扩展性,在浏览器的兼容性(功能缺陷.渐进增强)优雅的处理能 ...
- FPM一:简单的road map(GAF)
首先要有个简单的认识: 1.FPM支持的几种UI配置界面接口: Object Instance Floorplan (OIF) Overview Page Floorplan (OVP) Guided ...
- 突破防盗链Referrer
//引用的源码网站的js<script src="https://raw.githack.com/jpgerek/referrer-killer/master/referrer-kil ...
- Model First 开发方式
概述 在项目一开始,没有数据库时,可以借助 EF 设计模型,然后根据模型同步完成数据库中表的创建,这就是 Model First 开发方式. 总结一点就是:现有模型再有表. 创建 Model Firs ...
- vue-lazyload懒加载插件的使用
vue-lazyload懒加载插件的使用其实很简单,不想vue-loader官网用法写的那么简单.下面代码演示: 1.安装插件 npm install vue-lazyload --save 2. ...
- 使用monitor.bat用DDMS查看其它项目的布局
查看结果