GUI的学习理解
1. 简介
GUI的核心技术:Swing 、AWT(抽象的窗口工具)
2.AWT
-
AWT包含了很多的类和接口
-
元素:窗口、按钮、文本框
-
java.awt包
组件和容器
1. Frame
public class TestFrame {
public static void main(String[] args) {
Frame frame = new Frame("我的第一个界面");
//需要设置可见性
frame.setVisible(true);
//设置窗口大小
frame.setSize(400,400);
//设置背景
frame.setBackground(new Color(66, 199, 29));
//弹出的初始位置
frame.setLocation(200,200);
//设置大小固定
frame.setResizable(false);
}
}
效果图:

问题:窗口关闭不掉,停止java程序运行即可!
拓展:(编码一个MyFrame类继承于Frame类,可以用较少代码量形成多个窗口)
public class TestFrame02 {
public static void main(String[] args) {
//展示多个窗口
MyFrame myFrame01 = new MyFrame(100, 100, 200, 200, Color.blue);
MyFrame myFrame02 = new MyFrame(300, 100, 200, 200, Color.pink);
MyFrame myFrame03 = new MyFrame(100, 300, 200, 200, Color.red);
MyFrame myFrame04 = new MyFrame(300, 300, 200, 200, Color.green);
}
}
class MyFrame extends Frame{
//设置好id,方便窗口的记录
static int id = 0;
public MyFrame(int x,int y,int w,int h,Color color){
//由于是继承了父类,故不需要创建一个新的类.来实现方法
super("MyFrame+"+(++id));
setBounds(x,y,w,h);
setVisible(true);
setBackground(color);
setResizable(false);
}
}
效果图:
2.面板Panel
package com.ge.lesson01;
import java.awt.*;
import java.awt.event.WindowAdapter;
import java.awt.event.WindowEvent;
//Panel可以看作是一个空间,但是不能单独存在
public class TestPanel {
public static void main(String[] args) {
//先new一个Frame和一个Panel
Frame frame = new Frame();
Panel panel01 = new Panel();
//设置布局
frame.setLayout(null);
//设置Frame、Panel的位置和颜色
frame.setBounds(100,100,500,500);
frame.setBackground(new Color(36, 187, 133));
panel01.setBounds(150,100,200,200);
panel01.setBackground(new Color(170, 28, 28));
//将Panel添加进Frame中
frame.add(panel01);
//设置背景Frame的可见性
frame.setVisible(true);
//监听事件,监听窗口关闭事件 System.exit(0)
//适配器模式:
frame.addWindowListener(new WindowAdapter() {
PS:上面添加了监听器事件,解决了上一个实验中无法关闭窗口的问题。
效果图:
3.布局管理器
-
流式布局
package com.ge.lesson01;
import java.awt.*;
public class TestFlowLayout {
public static void main(String[] args) {
Frame frame = new Frame();
frame.setLayout(new FlowLayout(FlowLayout.LEFT));
Button button01 = new Button("button1");
Button button02 = new Button("button2");
Button button03 = new Button("button3");
frame.setBounds(100,100,300,300);
frame.add(button01);
frame.add(button02);
frame.add(button03);
frame.setBackground(new Color(35, 65, 220));
frame.setVisible(true);
}
}
![]()
-
东南西北中
package com.ge.lesson01;
import java.awt.*;
public class TestBorderLayout {
public static void main(String[] args) {
Frame frame = new Frame("ewsnc");
Button east = new Button("East");
Button west = new Button("West");
Button south = new Button("South");
Button center = new Button("Center");
Button north = new Button("North");
frame.add(east,BorderLayout.EAST);
frame.add(west,BorderLayout.WEST);
frame.add(south,BorderLayout.SOUTH);
frame.add(north,BorderLayout.NORTH);
frame.add(center,BorderLayout.CENTER);
frame.setBounds(100,100,500,500);
frame.setVisible(true);
//frame.setBackground(new Color(48, 98, 220));
}
}

-
表格布局
package com.ge.lesson01;
import java.awt.*;
public class TestGridLayout {
public static void main(String[] args) {
Frame frame = new Frame("TestGridLayout");
Button btn1 = new Button("btn1");
Button btn2 = new Button("btn2");
Button btn3 = new Button("btn3");
Button btn4 = new Button("btn4");
Button btn5 = new Button("btn5");
Button btn6 = new Button("btn6");
frame.setLayout(new GridLayout(3,2));
frame.add(btn1);
frame.add(btn2);
frame.add(btn3);
frame.add(btn4);
frame.add(btn5);
frame.add(btn6);
frame.pack();//Java函数,会自动选择一个最优秀的布局
frame.setVisible(true);
frame.setSize(500,500);
}
}

作业:
package com.ge.lesson01;
import java.awt.*;
public class assignment {
public static void main(String[] args) {
Frame frame = new Frame();
frame.setVisible(true);
frame.setBounds(100,100,400,300);
frame.setLayout(new GridLayout(2,1));
Panel panel01 = new Panel(new BorderLayout());
Panel panel02 = new Panel(new GridLayout(2,1));
Panel panel03 = new Panel(new BorderLayout());
Panel panel04 = new Panel(new GridLayout(2,2));
panel01.add(new Button("btn01"),BorderLayout.WEST);
panel01.add(new Button("btn02"),BorderLayout.EAST);
panel01.add(panel02,BorderLayout.CENTER);
panel02.add((new Button("btn03")));
panel02.add((new Button("btn04")));
panel03.add(new Button("btn05"),BorderLayout.WEST);
panel03.add(new Button("btn06"),BorderLayout.EAST);
panel03.add(panel04,BorderLayout.CENTER);
panel04.add((new Button("btn07")));
panel04.add((new Button("btn08")));
panel04.add((new Button("btn09")));
panel04.add((new Button("btn010")));
frame.add(panel01);
frame.add(panel03);
}
}
PS:在面板04中其实完全可以用for循环的,上边这样写有一些冗杂。
总结
-
Frame是一个顶级窗口
-
Panel无法单独显示,必须添加到某个容器中。
-
布局管理器
-
流失布局
-
东西南北中布局
-
表格布局
-
-
大小、定位、背景颜色、可见性、监听
4.事件监听
当某个事情发生的时候,干什么?
package com.ge.lesson02;
import java.awt.*;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.awt.event.WindowAdapter;
import java.awt.event.WindowEvent;
public class TestActionEvent {
public static void main(String[] args) {
Frame frame = new Frame("按钮实验");
Button button = new Button("btn01");
button.addActionListener(new MyActionListener());
frame.setVisible(true);
frame.setBounds(100,100,400,400);
frame.add(button);
CloseWindow(frame);
}
private static void closeWindow(Frame frame){
frame.addWindowListener(new WindowAdapter() {
下面为多个按钮共享一个监听器(事件):
package com.ge.lesson02;
import java.awt.*;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.awt.event.WindowAdapter;
import java.awt.event.WindowEvent;
public class TestActionEvent02 {
public static void main(String[] args) {
//两个按钮实现同一个监听
Frame frame = new Frame("按钮实验02");
Button button01 = new Button("btn01");
Button button02 = new Button("btn02");
frame.setVisible(true);
frame.setBounds(100,100,400,300);
frame.setLayout(new GridLayout(2,1));
//有了下面两行的定义,事件发生后e中的值为所编辑的内容(如aileaile),否则为按钮的名字,(如btn01)
button02.setActionCommand("aileaile");
button01.setActionCommand("爱了爱了");
frame.add(button01);
frame.add(button02);
button01.addActionListener(new MyActionListener1());
button02.addActionListener(new MyActionListener1());
frame.addWindowListener(new WindowAdapter() {
5.输入框TextFiled监听
package com.ge.lesson02;
import java.awt.*;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
public class TestText01 {
public static void main(String[] args) {
//启动!
MyFrame myFrame = new MyFrame();
}
}
class MyFrame extends Frame{
public MyFrame(){
TextField textField = new TextField();
add(textField);
//监听这个文本框输入的文字,接下来按下Enter,就会触发这个输入框的事件
textField.addActionListener(new MyActionListener2());
//设置替换编码
textField.setEchoChar('*');
setVisible(true);
pack();
}
}
class MyActionListener2 implements ActionListener{
6.简易计算器,组合+内部类回顾复习
oop原则:组合>继承
目前代码:
package com.ge.lesson02;
import java.awt.*;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.awt.event.WindowAdapter;
import java.awt.event.WindowEvent;
//简易计算器
public class TestCalc {
public static void main(String[] args) {
new Calc();
}
}
//计算器
class Calc extends Frame{
public Calc(){
//3个文本框
TextField num01 = new TextField(10);
TextField num02 = new TextField(10);
TextField num03 = new TextField(20);
//1个按钮
Button button = new Button("=");
//1个标签
Label label = new Label("+");
setBounds(100,100,500,80);
// pack();
setLayout(new FlowLayout());
add(num01);
add(label);
add(num02);
add(button);
add(num03);
//当按了“=”按钮时,监听器行动
button.addActionListener(new MyCalcLestion(num01,num02,num03));
setVisible(true);
new CloseWindow(this);
}
}
//监听器
class MyCalcLestion implements ActionListener{
private TextField num1,num2,num3;
public MyCalcLestion(TextField num1,TextField num2,TextField num3){
this.num1=num1;
this.num2=num2;
this.num3=num3;
}
