流式布局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的更多相关文章

  1. Java基础 awt Graphics2D 生成矩形图片并向内写入字符串

        JDK :OpenJDK-11      OS :CentOS 7.6.1810      IDE :Eclipse 2019‑03 typesetting :Markdown   code ...

  2. Java基础 awt Frame 设置窗体的背景颜色

        JDK :OpenJDK-11      OS :CentOS 7.6.1810      IDE :Eclipse 2019‑03 typesetting :Markdown   code ...

  3. Java基础 awt Graphics2D 生成矩形图片并向其中画一条直线

        JDK :OpenJDK-11      OS :CentOS 7.6.1810      IDE :Eclipse 2019‑03 typesetting :Markdown   code ...

  4. Java基础 awt Frame 窗体的大小不可调

        JDK :OpenJDK-11      OS :CentOS 7.6.1810      IDE :Eclipse 2019‑03 typesetting :Markdown   code ...

  5. Java基础 awt Frame 设置窗体的大小 位置 可见性

        JDK :OpenJDK-11      OS :CentOS 7.6.1810      IDE :Eclipse 2019‑03 typesetting :Markdown   code ...

  6. Java基础 awt Frame 窗体在屏幕的中间显示

        JDK :OpenJDK-11      OS :CentOS 7.6.1810      IDE :Eclipse 2019‑03 typesetting :Markdown   code ...

  7. Java基础 awt Frame 点击叉后,在控制台输出提示信息并关闭程序

        JDK :OpenJDK-11      OS :CentOS 7.6.1810      IDE :Eclipse 2019‑03 typesetting :Markdown   code ...

  8. Java基础 awt Font 四种字体样式

        JDK :OpenJDK-11      OS :CentOS 7.6.1810      IDE :Eclipse 2019‑03 typesetting :Markdown   code ...

  9. Java基础 awt Button 点击按钮后在控制台输出文字

        JDK :OpenJDK-11      OS :CentOS 7.6.1810      IDE :Eclipse 2019‑03 typesetting :Markdown   code ...

随机推荐

  1. RDD常用方法之subtract&intersection&cartesian

    subtract Return an RDD with the elements from `this` that are not in `other` .     def subtract(othe ...

  2. 剑指Offer:解决难题时的三大方法

    1.画图 让抽象的东西变得直观生动起来.比如设计二叉树,链表,栈,队列这些数据结构时. 2.举例子 同样可以化抽象为直观.能够更清晰的展现思路.从例子归纳出一般做法. 3.分解 有时问题本身是比较复杂 ...

  3. 许小年:宁可踏空,不可断粮<转>

    http://www.daonong.com/g/25/xsqy/2014/0716/51074.html 文│许小年 中欧国际工商学院教授 为什么我们企业的创新能力长期处于低水平呢? 深入观察,内心 ...

  4. CentOS7.2部署OpenStack(一)—环境准备

    1.系统环境 # uname -r 3.10.0-327.el7.x86_64 # cat /etc/redhat-release CentOS Linux release 7.2.1511 (Cor ...

  5. mysql 连接空闲超8小时自动断开连接问题(linux)

    在mysql配置文件里添加wait_timeout和interactive_timeout两个值 [mysqld] wait_timeout= interactive_timeout= 超时时间,10 ...

  6. 两种open()函数

    C语言中文件操作函数中,open()有两种形式: 一种形式是有两个参数open2: 另一种形式是有三个参数open3: 共有的参数有两个,第一个是"被打开文件的路径",第二个是&q ...

  7. ue4标签测试与总结(UPROPERTY)

    学习UE4框架中的标签,本篇是总结成员变量标签UPROPERTY. 引擎版本:4.12.5 前期准备: 1.新建项目,C++空模板,新建C++类,继承AActor,名称MyActor. 使用TestA ...

  8. Hive的安装

    Hive的安装   第一步:解压并安装:第二步:配置 1)root用户下,解压后,改名为hive,并将hive文件夹赋给hadoop用户 tar -zxvf hive-0.9.0.tar.gz -C ...

  9. BitLocker 加密工具挂起和恢复命令行(windows7)

    如果你的硬盘使用BitLocker加密了,但是有时候需要高效率的硬盘做某些事情,可以暂时挂起加密,命令行如下方便做个bat. 挂起: manage-bde -protectors -disable C ...

  10. ASP.NET Misconfiguration: Missing Error Handling

    Abstract: An ASP .NET application must enable custom error pages in order to prevent attackers from ...