Absolute Layout
----------------siwuxie095
根面板 contentPane 的默认布局为 Border Layout,将其
切换为 Absolute Layout
Absolute Layout 即 绝对布局,即 它没有任何的限制,可以
在界面中任意摆放控件的位置
在将控件拖动到面板上时,会出现参考线,参考线仅仅是
为了在界面中摆放元素时给出参考,而不具有任何实质性
的吸附功能
「如果不使用参考线,可以自由的将控件移动到任何位置」

当在面板中摆放好某控件,该控件的坐标和大小都是固定的,
不会随窗体的缩放而产生任何变化
在绝对布局的情况下,可以在代码中任意修改元素的坐标和大小
向 contentPane 中添加一个 JLabel,将其文本(text)改为:
This is a label,Rename 为:label
在 Source 中修改代码:

效果如下:

向 contentPane 中添加一个 JButton,将其文本(text)改为:
Run,Rename 为:btnRun
在绝对布局中,虽然不会有布局管理器帮助摆放,但是可以提供
最佳的灵活性
如:可以编写一个线程来为当前的控件提供动画(放大缩小、位置移动)
为 JButton 添加鼠标点击事件,当点击 Run 时,JLabel 上下浮动
|
JButton btnRun = new JButton("Run"); btnRun.addMouseListener(new MouseAdapter() { @Override public void mouseClicked(MouseEvent arg0) { //创建一个 SwingWoker 线程,指定泛型为 String 和 Integer //要覆盖 doInBackground() 和 process() 方法 //创建完成后,需要调用 execute() 方法,将它运行 new SwingWorker<String, Integer>() { //获取 Y 的原坐标,需要将 label 的声明转移到类中 int originalY=label.getY(); @Override protected String doInBackground() throws Exception { while (true) { //每隔 50 毫秒执行一次 Thread.sleep(50); 年到当前时间的毫秒值 //先从整型转换成浮点型,又从浮点型转换成整型 // 100 表示运动的快慢(越小速度越快,反比), // 20 表示运动的幅度(越小幅度越小,正比) //将值 publish() 到 process() 中 publish((int)(Math.sin(System.currentTimeMillis()/100)*20)); } } @Override protected void process(List<Integer> chunks) { //从 chunks 中把值取出来 for (int dynamicY : chunks) { //X 坐标不变,Y 坐标变化,为标签做了一个正弦的动画 label.setLocation(label.getX(), originalY+dynamicY); } } }.execute(); } }); |
效果如下:

在绝对布局中,当控件出现重叠时,层级高的控件会挡住
层级低的控件,并接收鼠标事件

【made by siwuxie095】
Absolute Layout的更多相关文章
- Java swing 如何将一个按钮放置到弹出框框的任意位置?(Absolute layout 布局的使用)
准备: Absolute layout 绝对布局,绝对布局中控件的可以在任意位置放置 如何制作下面那种样子的 弹出框? ---------------------------------------- ...
- ExtJS 布局-Absolute布局(Absolute layout)
更新记录: 2022年5月31日 发布本篇 1.说明 使用xy配置项设置子组件在父容器中绝对位置,本质是将子组件的CSS的position设置为absolute,然后使用x和y配置项映射到CSS的to ...
- ExtJs常用布局--layout详解(含实例)
序言: 笔者用的ExtJs版本:ext-3.2.0 ExtJs常见的布局方式有:border.form.absolute.column.accordion.table.fit.card.anchor ...
- dynamic-css 动态 CSS 库,使得你可以借助 MVVM 模式动态生成和更新 css,从 js 事件和 css 选择器的苦海中脱离出来
dynamic-css 使得你可以借助 MVVM 模式动态生成和更新 css,从而将本插件到来之前,打散.嵌套在 js 中的修改样式的代码剥离出来.比如你要做元素跟随鼠标移动,或者根据滚动条位置的变化 ...
- Android面试题(一)
1. 请描述一下Activity 生命周期. 答: 如下图所示.共有七个周期函数,按顺序分别是: onCreate(), onStart(), onRestart(), onResume(), onP ...
- Xamarin.Forms 简介
An Introduction to Xamarin.Forms 来源:http://developer.xamarin.com/guides/cross-platform/xamarin-forms ...
- android面试题
1. 请描述一下Activity 生命周期. 答: 如下图所示.共有七个周期函数,按顺序分别是: onCreate(), onStart(), onRestart(), onResume(), onP ...
- Android基础面试题
1. 请描述一下Activity 生命周期. 答: 如下图所示.共有七个周期函数,按顺序分别是: onCreate(), onStart(), onRestart(), onResume(), onP ...
- cocos布局分析
HBox和VBox布局 HBox只是一个水平布局包装类. HBox里面所有的孩子节点都会水平排列成一行 VBox仅仅是对垂直布局的一个简便的类封装. VBox把它的子节点布局在一竖列中. Layout ...
随机推荐
- MLPClassifier 隐藏层不包括输入和输出
多层感知机(MLP)原理简介 多层感知机(MLP,Multilayer Perceptron)也叫人工神经网络(ANN,Artificial Neural Network),除了输入输出层,它中间可以 ...
- SQL Sever删除外键
declare @sql varchar(max), @tab_name varchar(128), @fk_name varchar(128);declare c cursor forselect ...
- Vue中mixin的用法
在项目中我们经常会遇到多个组件调用同一个方法的问题,为了避免每次都在.vue文件中定义并调用,我们可采用vue的mixin的用法: 具体使用如下: 我们需要在main.js中引入mixins文件夹下的 ...
- Linux-监控与安全运维之cacti
一:cacti简介 Cacti 在英文中的意思是仙人掌的意思,Cacti是一套基于PHP,MySQL,SNMP及RRDTool开发的网络流量监测图形分析工具.它通过snmpget来获取数据,使用 RR ...
- Knuth-Morris-Pratt 算法
KMP算法是一种改进的字符串匹配算法,由D.E.Knuth,J.H.Morris和V.R.Pratt同时发现,因此人们称它为克努特——莫里斯——普拉特操作(简称KMP算法).KMP算法的关键是利用匹配 ...
- python 中zip函数的使用
1.ta = [1,2,3] tb = [9,8,7] tc = ['a','b','c'] for (a,b,c) in zip(ta,tb,tc): print(a,b,c) 2. ta = [1 ...
- ajax返回
1.几种方式public function getAjax(){ //$data = 'ok'; //$this->ajaxReturn($data); // 'ok' //$this-> ...
- PCM音量控制
http://blog.jianchihu.net/pcm-volume-control.html 一.声音的相关概念 声音是介质振动在听觉系统中产生的反应.声音总可以被分解为不同频率不同强度正弦波的 ...
- 从内存中直接运行PE程序
效果是这样的,假设一个PE数据在内存里面了,我们利用下面我讲的技术可以直接建立一个进程并运行这个PE,当然直接在本进程运行在可以,这两钟技术在前些时日我都有实现,今天我只说关于建立进程并运行的,当然, ...
- UOJ #55 & 洛谷 P3920 紫荆花之恋 —— 动态点分治+替罪羊树
题目:http://uoj.ac/problem/55 https://www.luogu.org/problemnew/show/P3920 参考博客:https://www.cnblogs.com ...