Java基础---AWT
流式布局FlowLayout
package net.zyz; import java.awt.Button;
import java.awt.FlowLayout;
import java.awt.Frame; public class TestFlowLayout { public static void main(String[] args) {
Frame frame=new Frame("Flow Layout");
//设置窗口的布局方式为FlowLayout,元素在窗口中左对齐,元素水平间距为10,垂直间距为20
frame.setLayout(new FlowLayout(FlowLayout.LEFT,10,20));
for(int i=1;i<=10;i++){
frame.add(new Button("按纽"+i));
}
frame.pack();
frame.setVisible(true);
} }
边界布局BorderLayout
package net.zyz; import java.awt.BorderLayout;
import java.awt.Button;
import java.awt.Frame; public class TestBorderLayout { public static void main(String[] args) {
Frame frame=new Frame("Border Layout");
//边界布局是frame默认的布局方式
Button button1=new Button("东");
frame.add(button1, BorderLayout.EAST); Button button2=new Button("西");
frame.add(button2, BorderLayout.WEST); Button button3=new Button("南");
frame.add(button3, BorderLayout.SOUTH); Button button4=new Button("北");
frame.add(button4, BorderLayout.NORTH); Button button5=new Button("中");
frame.add(button5, BorderLayout.CENTER); frame.pack();
frame.setVisible(true);
} }
表格布局GridLayout
package net.zyz; import java.awt.Button;
import java.awt.Frame;
import java.awt.GridLayout; public class TestGridLayout { public static void main(String[] args) {
Frame frame=new Frame("Grid Layout");
//frame默认的布局为BorderLayout
frame.setLayout(new GridLayout(2, 3));
for(int i=1;i<=5;i++){
frame.add(new Button("按纽"+i));
}
//setSize只指定窗口的大小,位置在原点(0,0)
//setBound既可指定位置,又可指定大小
// frame.setSize(300,200);
//pack会将窗口中的组件正好包裹起来,即大小自适应
frame.pack();
frame.setVisible(true);
} }
综合布局
package net.zyz; import java.awt.BorderLayout;
import java.awt.Button;
import java.awt.Frame;
import java.awt.GridLayout;
import java.awt.Panel; public class TestMutiLayout { public static void main(String[] args) {
Frame frame=new Frame("MutiLayout");
//窗口分成2行1列,分上下两个panel
frame.setLayout(new GridLayout(2, 1)); //第1个panel采用BorderLayout
Panel p1=new Panel();
p1.setLayout(new BorderLayout());
Button b11=new Button("ButtonWest");
Button b12=new Button("ButtonEast");
//CENTER部分再使用panel并采用GridLayout
Panel p11=new Panel();
p11.setLayout(new GridLayout(2, 1));
Button b13=new Button("ButtonUp");
Button b14=new Button("ButtonDown");
p11.add(b13);
p11.add(b14);
p1.add(b11, BorderLayout.EAST);
p1.add(b12, BorderLayout.WEST);
p1.add(p11, BorderLayout.CENTER); //第2个panel采用BorderLayout
Panel p2=new Panel();
p2.setLayout(new BorderLayout());
Button b21=new Button("ButtonWest");
Button b22=new Button("ButtonEast");
//CENTER部分再使用panel并采用GridLayout
Panel p21=new Panel();
p21.setLayout(new GridLayout(2, 2));
for(int i=1;i<=4;i++){
p21.add(new Button("Button"));
}
p2.add(b21, BorderLayout.EAST);
p2.add(b22, BorderLayout.WEST);
p2.add(p21, BorderLayout.CENTER); frame.add(p1);
frame.add(p2);
frame.setSize(300,200);;
frame.setVisible(true);
} }
绘图Graphics
package net.zyz; import java.awt.Color;
import java.awt.Frame;
import java.awt.Graphics; public class TestGraphics { public static void main(String[] args) {
new FrameDraw();
} }
class FrameDraw extends Frame{
/**
*
*/
private static final long serialVersionUID = 1L;
public FrameDraw() {
setSize(400,300);
setVisible(true);
}
@Override
/**
* Object->Component->Container->Window->Frame
* paint是Container类的方法,在继承Frame类中要重写,重写后系统就会自动调用
*/
public void paint(Graphics g) {
Color color=g.getColor();
g.setColor(Color.RED);
g.drawOval(50, 50, 200, 150);
g.setColor(new Color(0, 255, 0));
g.fillRect(100, 100, 200, 50);
g.setColor(color);
}
}
动作事件监听java.awt.event.ActionListener
Button
package net.zyz; import java.awt.BorderLayout;
import java.awt.Button;
import java.awt.Frame;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener; public class TestActionListener { public static void main(String[] args) {
new Frame2();
} } class Frame2 extends Frame { /**
*
*/
private static final long serialVersionUID = 1L; public Frame2() {
super("Event Listener");
Button button1 = new Button("button");
Button button2 = new Button("button");
button1.setActionCommand("button1");
button2.setActionCommand("button2");
//button1和button2加入同一个监听器,如何区分?
button1.addActionListener(new monitor());
button2.addActionListener(new monitor());
add(button1, BorderLayout.NORTH);
add(button2, BorderLayout.SOUTH);
pack();
setVisible(true);
}
} class monitor implements ActionListener {
@Override
public void actionPerformed(ActionEvent e) {
Button button=(Button)e.getSource();
//首先要得到事件源对象,因getSource()返回的是Object,需强制转换为Button
String actionCommand=button.getActionCommand();
/**
* Button的getLabel()方法得到是按纽上的文字,有可能两个按纽的文本会一样,如本例
* Button的getName()得到的是按纽的name,这个name值是由系统命名的,第1个Button的name是button0
* 最好使用getActionCommand()方法进行区分处理
*/
if(actionCommand.equals("button1")){
System.out.println("你按下了button1按纽");
}else if(actionCommand.equals("button2")){
System.out.println("你按下了button2按纽");
}
}
}
TextField
package net.zyz; import java.awt.Frame;
import java.awt.TextField;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener; public class TestTextField { public static void main(String[] args) {
new TFFrame();
}
}
class TFFrame extends Frame{
/**
*
*/
private static final long serialVersionUID = 1L; public TFFrame() {
TextField txt1=new TextField(10);
//对于Button、TextField等标准组件,一般都采用ActionEvent
txt1.addActionListener(new monitorTF());
add(txt1);
pack();
setVisible(true);
}
}
class monitorTF implements ActionListener{
@Override
/**
* 对于按纽来说默认的动作事件是单击,文本框默认事件的是按回车键,
* 这些事件执行时,系统回自动调用actionPerformed方法
* 所以需要在监听器里要重写该方法,ActionListener接口里也只有这一个方法
*/
public void actionPerformed(ActionEvent e) {
TextField tf1=(TextField)(e.getSource());
System.out.println(tf1.getText());
tf1.setText("");
}
}
Window事件监听WindowListener
package net.zyz; import java.awt.Frame;
import java.awt.event.WindowAdapter;
import java.awt.event.WindowEvent; public class TestWindowClose { public static void main(String[] args) {
new FrameWindowCloseTest();
}
} class FrameWindowCloseTest extends Frame {
private static final long serialVersionUID = 1L; public FrameWindowCloseTest() {
setSize(300, 200);
setVisible(true);
/*
* addWindowListener方法的参数为继承了WindowAdapter的匿名类
* 该匿名类直接写在方法的内部
* 一般情况下很少使用,只有代码简单且无需变动时才临时使用,推荐使用内部类
*/
this.addWindowListener(new WindowAdapter() {
public void windowClosing(WindowEvent e) {
setVisible(false);
System.exit(0);
}
}); /*
* addWindowListener()方法的参数为WindowListener对象
* 而WindowListener是一个接口,里面有6、7个类似windowClosing()的方法
* 如果要来实现接口的话,则需要实现接口里的每一个方法
* jdk提供了实现WinowListener接口的抽象类WindowAdapter,
* 其实WindowApdater类中实现的方法并无实际代码
* 对于类中的方法,子类是不需要全都实现。本例中只要重写windowClosing()方法即可。
* monitor extends WindowAdapter implements WindowListener
* WindowAdapter只是一个中间件,过渡一下
*/
}
}
鼠标事件监听器MouseListener
package net.zyz; import java.awt.Color;
import java.awt.Frame;
import java.awt.Graphics;
import java.awt.Point;
import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent;
import java.util.ArrayList;
import java.util.Iterator; public class TestMouseListener { public static void main(String[] args) {
new FramePoints();
}
}
class FramePoints extends Frame{ private static final long serialVersionUID = 1L;
ArrayList<Point> points; public FramePoints() {
points=new ArrayList<Point>();
this.addMouseListener(new MonitorPoint());
this.addWindowListener(new WindowClose(this));
setSize(500,400);
setVisible(true);
} @Override
public void paint(Graphics g) {
g.setColor(Color.GREEN);
Iterator<Point> iterator=points.iterator();
while (iterator.hasNext()) {
Point point = (Point) iterator.next();
g.fillOval(point.x, point.y, 10, 10);
}
} //监听鼠标事件:MouseAdapter implements MouseListener
class MonitorPoint extends MouseAdapter{
@Override
public void mousePressed(MouseEvent e) {
FramePoints f=(FramePoints)e.getSource();
points.add(new Point(e.getX(), e.getY()));
f.repaint();
}
} //监听窗口事件:WindowAdapter implements WindowListener
// class MonitorWindow extends WindowAdapter{
// public void windowClosing(WindowEvent e) {
// setVisible(false);
// System.exit(0);
// }
// }
}
按键事件监听器KeyListener
package net.zyz; import java.awt.Frame;
import java.awt.event.KeyAdapter;
import java.awt.event.KeyEvent;
import java.awt.event.WindowAdapter;
import java.awt.event.WindowEvent; public class TestKey { public static void main(String[] args) {
new FrameKey().lanch();
}
} class FrameKey extends Frame {
private static final long serialVersionUID = 1L; void lanch() {
setSize(300, 200);
this.addKeyListener(new KeyAdapter() {
@Override
public void keyPressed(KeyEvent e) {
int keyCode = e.getKeyCode();
/**
* getKeyCode()方法得到是按键的虚拟键码,
* 如按A键无论大小写都是65(美式键盘布局),而且跟键盘布局也有关。
* 如果按组合键的话,会激活多个keyPressed事件,
* 如shift+A组合键getKeyCode()方法就会得到两个键值,但getKeyChar()方法只会得到一个字符('a')
* 所以keyPressed事件最好和getKeyCode()方法结合使用
* 虚拟键码 用于报告按下了键盘上的哪个键,而不是一次或多次键击组合生成的字符(如 "A" 是由 shift + "a" 生成的)。
* 例如,按下 Shift 键会生成 keyCode 为 VK_SHIFT 的 KEY_PRESSED 事件,
* 而按下 'a' 键将生成 keyCode 为 VK_A 的 KEY_PRESSED 事件。
* 释放 'a' 键后,会激发 keyCode 为 VK_A 的 KEY_RELEASED 事件。
* 另外,还会生成一个 keyChar 值为 'A' 的 KEY_TYPED 事件。
*/
System.out.println(keyCode);
System.out.println(e.getKeyChar());
switch (keyCode) {
case KeyEvent.VK_UP:
System.out.println("up");
break;
case KeyEvent.VK_DOWN:
System.out.println("down");
break;
case KeyEvent.VK_LEFT:
System.out.println("left");
break;
case KeyEvent.VK_RIGHT:
System.out.println("right");
break;
default:
break;
}
}
});
this.addWindowListener(new WindowAdapter() {
@Override
public void windowClosing(WindowEvent e) {
setVisible(false);
System.exit(0);
}
});
setVisible(true);
}
}
Java基础---AWT的更多相关文章
- Java基础 awt Graphics2D 生成矩形图片并向内写入字符串
JDK :OpenJDK-11 OS :CentOS 7.6.1810 IDE :Eclipse 2019‑03 typesetting :Markdown code ...
- Java基础 awt Frame 设置窗体的背景颜色
JDK :OpenJDK-11 OS :CentOS 7.6.1810 IDE :Eclipse 2019‑03 typesetting :Markdown code ...
- Java基础 awt Graphics2D 生成矩形图片并向其中画一条直线
JDK :OpenJDK-11 OS :CentOS 7.6.1810 IDE :Eclipse 2019‑03 typesetting :Markdown code ...
- Java基础 awt Frame 窗体的大小不可调
JDK :OpenJDK-11 OS :CentOS 7.6.1810 IDE :Eclipse 2019‑03 typesetting :Markdown code ...
- Java基础 awt Frame 设置窗体的大小 位置 可见性
JDK :OpenJDK-11 OS :CentOS 7.6.1810 IDE :Eclipse 2019‑03 typesetting :Markdown code ...
- Java基础 awt Frame 窗体在屏幕的中间显示
JDK :OpenJDK-11 OS :CentOS 7.6.1810 IDE :Eclipse 2019‑03 typesetting :Markdown code ...
- Java基础 awt Frame 点击叉后,在控制台输出提示信息并关闭程序
JDK :OpenJDK-11 OS :CentOS 7.6.1810 IDE :Eclipse 2019‑03 typesetting :Markdown code ...
- Java基础 awt Font 四种字体样式
JDK :OpenJDK-11 OS :CentOS 7.6.1810 IDE :Eclipse 2019‑03 typesetting :Markdown code ...
- Java基础 awt Button 点击按钮后在控制台输出文字
JDK :OpenJDK-11 OS :CentOS 7.6.1810 IDE :Eclipse 2019‑03 typesetting :Markdown code ...
随机推荐
- 黑马程序员_ Objective-c 概述及面向对象与三大特性
-----------android培训.java培训.java学习型技术博客.期待与您交流!------------ (一).语法概述 1. oc介绍:(.m文件) 1> c语言的基础上,增加 ...
- jQuery中关于height,innerWidth与outerWidth的区别
jQuery width() 和 height() 方法 width() 方法设置或返回元素的宽度(不包括内边距.边框或外边距). height() 方法设置或返回元素的高度(不包括内边距.边框或外边 ...
- 向架构师进军-->可重用架构资源
如果你对项目管理.系统架构有兴趣,请加微信订阅号"softjg",加入这个PM.架构师的大家庭 软件架构有三个主要来源:拿取.方法以及直觉.拿取也就是可重用资源.对于一个标准的系统 ...
- AIDL小结
AIDL : Android Interface Define Language(接口定义语言) Service中跨进程间通信利器.... 一般都会有Client端和Server端(Server端提供 ...
- Salt 安装方式(CentOS)
安装前必备环境:2.6.6<Pythin<3.x 本文内容是参考 中国SaltStack用户组 里面 Salt中文手册 中的安装内容实践之后总结的. 初学者可用Ubuntu系统学习安装,因 ...
- Java程序员必须知道的10个调试技巧
调试可以帮助识别和解决应用程序缺陷,在本文中,将使用大家常用的的开发工具Eclipse来调试Java应用程序. 但这里介绍的调试方法基本都是通用的,也适用于NetBeans IDE,我们会把重点放在运 ...
- 激活PHPStorm 2016.3
通过互联网激活PHPStorm 2016.3: http://jetbrains.tencent.click http://172.245.22.235:1017 http://idea.imsxm. ...
- 如果客户端禁用cookie,session还能使用吗?
记得在以前找工作的时候,可多次被问到如果客户端被禁用cookie,session还能使用吗? 今天终于找到了相关的答案:我们来看一下: session是在服务器段保持会话数据的一种方法,对应的cook ...
- SpringMVC学习笔记(一)
一.MVC的流程图 分析流程图 1. 首先用户发送请求---->前端控制器,前端控制器根据请求信息(如URL)来决定选择哪一个页面控制器进行处理并把请求委托给它,即以前的控制器的控制逻辑部分:图 ...
- XML.03-DOM和SAX解析
body,td { font-family: calibri; font-size: 10pt } XML.03-DOM和SAX解析 XML的DOM解析 解析 处理 回写 XML的SAX解析 SAX和 ...