热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

第十四周java实验作业

实验十四Swing图形界面组件实验时间20178-11-291、实验目的与要求(1)掌握GUI布局管理器用法;在java中的GUI应用程序界面设计中,布局控制通过为容器设置布局管理

实验十四  Swing图形界面组件

实验时间 20178-11-29

1、实验目的与要求

(1) 掌握GUI布局管理器用法;

java中的GUI应用 程序界面设计中,布局控制通过为容器设置布局管理器来实现的。

布局管理器是一组类,实现java.awt.LayoutManger接口

决定容器中组件的位置和大小

Java.awt包中定义了五种布局管理器,每一种布局管理类对应一种布局策略。

每个容器都有与之相关的默认布局管理器。

(2) 掌握各类Java Swing组件用途及常用API;

5种布局管理器

FLowLayout:流布局(Panel的默认布局管理器)

BorderLayout:边框布局(Window、Frame和Dialog的默认布局管理器)

GirdLayout:网格布局

GirdBagLayout:网格组布局

CardLayer:卡片布局

流布局管理器(FlowLayout) 

用于对组件逐行进行定位,每完成一行,新的一行便又开始。与其他布局管理器不同的是,流布局管理器不限制他所管的组建的大小,允许他们有自己的最佳大小。

构造函数有

FlowLayout():生成一个默认的流式布局对象

FlowLayout(int align):设定每一行组件的对齐方式

(FlowLayout.LEFT,FlowLayout.CENTER,FlowLayout.RIGHT)

FlowLayout(int align,int hgap,int vgap)可以设定组件间的水平和垂直距离(缺省时组件之间没有空隙)

 

边框布局管理器(BorderLayout) 
是JFrame的内容窗格的默认布局管理器,

可以选择将空间放在内容窗格的东、南、西、北、中。 且将组件加入其中时,组件会充满其对应的整个区域,如果在这个方位再加入一个组件,会覆盖原本存在的组件。当顶层窗口缩放时,东南西北的组件不会随之变化,中部的组件会等比例变化。 

向容器中加入组件时,若使用两个参数得add()方法,第二个参数必须说明加入组件的放置位置。

frame.add(new JButton("Yes"),BorderLayout.SOUTH);

网格布局管理器(Grid Layout );

网格布局器按行列排列所有的组件
布局类似于表格,每个单元大小一致,当顶层窗口缩放时组件大小也随之变化,但是尺寸比例保持一致。

在网格布局对象的构造器中,需要指定行数和列数

panel.setLayout(new GridLayout(6,10));

frame.SetLayout(new GridLayout(4,4));//形成4x4的网格

放置组件的每个单元具有相同的尺寸。

添加组件,从第一行和第一列开始,然后是第一行的第二列,以此类推。
frame.add(new JButton("1"));

frame.add(new JButton("2"));

GridLayout()生成一个单行单列的网格布局

GridLayout(int rows,int cols) 生成一个设定行数和列数的网格布局,参数之一可以为0,但是不能同时为0 
GridLayout(int rows,int cols,int hgap,int vgap) 可以设置组件之间的水平和垂直间距,hgap表示单元之间的水平间距,vgap表示单元之间的垂直间距

(3)文本输入

文本域:用于获取单行文本输入

文本域的使用方法:

Jpanel panel  = new JPanel();

JTextField = new JTextField("Default input",20);

panel.add(textField);

第一个参数"Default input":将文本域的缺省显示值为Default input

第二个参数为20:表示文本域显示宽度为20列。

若要重新设置列数,可使用setColumns方法

用于文本输入的组件扩展于JTextComponent的JTextField和JTextArea 

String getText()

void set Text(String text)

获取或设置文本组件中的文本

Boolean isEditable()

void set Editable(boolean b)

获取或设置editable特性,这个特性决定了用户是否可以编辑文本组件中的内容。

JTextField和JTextArea都用于文本输入,其中JTextField接收单行文本的输入,而JTextArea可接收多行文本的输入。

列数为文本域的宽度,如果希望文本域最多能输入N个字符,则将宽度设置为N

JTextField text = new JTextField("Input Here",20);

第二个构造函数可以指定文本区显示的行数和列数。如果需要设置滚动条,则需要将文本区加入JScrollPane中,再讲JScrollPane插入容器。

JTextArea area = new TextArea(4,10);
JScrollPane pane = new JScrollPane(area);
panel.add(pane);
.扩展于JTextField的JPasswordField 
接受单行输入,输入字符被特殊字符掩盖

JLabel 
没有任何修饰,不能响应用户输入,只是容纳文本的组件。可以设置标签的显示文字、图标以及对其方式

其中对其方式是SwingConstants里的常量,如LEFT/RIGHT/CENTER等

JLabel label = new JLabel("User Name:",SwingConstants.RIGHT);
(4)选择组件
.JCheckBox 
复选框自动带有标签和图标,在构造时可以提供,当用户选中复选框时会触发动作事件。

JCheckBox box = new JCheckBox("Bold");
box.setSelected(true);
单选钮(JRadioButton) 
自带标签和图标。单选钮只能多选其一,要打到这种效果需要把所有的单选钮加入ButtonGroup的对象里,从而使得新按钮被按下时,取消前一个选中的按钮的状态。ButtonGroup直接扩展于Object类,所以单选钮需加入容器中进行布局,ButtonGroup和容器(如JPanel)是相互独立的。 
选中时触发动作事件。 
边框(Border) 
任何继承自JComponent的组件都可以使用边框(void setBorder(Border b))。常用的方法是将组件放入容器中,然后容器使用边框。是通过调用BorderFactory的静态方法构建边框。 
同时可以为边框设置标题:

Border etch = BorderFactory.createEtchedBorder();
Border title = BorderFactory.createTitleBorder(etch,"Title");
panel.setBorder(title);
组合框 
JComboBox是泛型类,构建时需注意。 
组合框不仅有下拉选择的功能,还具有文本框编辑的功能。 
获得当前选中内容:

combo.getItemAt(combo.getSelectedIndex());
//Object getItemAt(int index)
当用户从组合框中选中一个选项时,组合框就会产生一个动作事件。

滑动条(JSlider) 
滑动条在构造时默认是横向,如果需要纵向滑动条:

JSlider s = new JSlider(SwingConstants.VERTICAL,min,max,initialValue);
当滑动条滑动时,会触发ChangeEvent,需要调用addChangeListener()并且安装一个实现了ChangeListener接口的对象。这个接口只有一个StateChanged方法

//得到滑动条的当前值
ChangeListener listen = event ->{
JSlider s = (JSlider)event.getSource();
int val = s.getValue(); 
...
};
如果需要显示滑动条的刻度,则setPaintTicks(true); 
如果要将滑动条强制对准刻度,则setSnapToTicks(true); 
如果要为滑动条设置标签,则需要先构建一个Hashtable,将数字与标签对应起来,再调用setLabelTable(Dictionary label);

(5)复杂的布局管理
5-1.GridBagLayout(网格组布局) 
即没有限制的网格布局,行和列的尺寸可以改变,且单元格可以合并 
过程: 
1)建议一个GridBagLayout对象,不需要指定行列数 
2)将容器setLayout为GBL对象 
3)为每个组件建立GridBagConstraints对象,即约束组件的大小以及排放方式 
4)通过add(component,constraints)增加组件 
使用帮助类来管理约束会方便很多。 
不使用布局管理器

frame.setLayout(null);
JButton btn = new JButton("Yes");
frame.add(btn);
btn.setBounds(10,10,100,30);
//void setBounds(int x,int y,int width,int height)//x,y表示左上角的坐标,width/height表示组件宽和高,Component类的方法
5-3.组件的遍历顺序(焦点的顺序):从左至右从上到下

component.setFocusable(false);//组件不设置焦点
(6)菜单
分为JMenuBar/JMenu/JMenuItem,当选择菜单项时会触发一个动作事件,需要注册监听器监听

(7).对话框
对话框分为模式对话框和无模对话框,模式对话框就是未处理此对话框之前不允许与其他窗口交互。 
7-1.JOptionPane 
提供了四个用静态方法(showxxxx)显示的对话框: 
构造对话框的步骤: 
1)选择对话框类型(消息、确认、选择、输入) 
2)选择消息类型(String/Icon/Component/Object[]/任何其他对象) 
3)选择图标(ERROR_MESSAGE/INFORMATION_MESSAGE/WARNING_MESSAGE/QUESTION_MESSAGE/PLAIN_MESSAGE) 
4)对于确认对话框,选择按钮类型(DEFAULT_OPTION/YES_NO_OPTION/YES_NO_CANCEL_OPTION/OK_CANCEL_OPTION) 
5)对于选项对话框,选择选项(String/Icon/Component) 
6)对于输入对话框,选择文本框或组合框 
确认对话框和选择对话框调用后会返回按钮值或被选的选项的索引值 
JDialog类 
可以自己创建对话框,需调用超类JDialog类的构造器

public aboutD extends JDialog
{
public aboutD(JFrame owner)
{
super(owner,"About Text",true);
....
}
}
构造JDialog类后需要setVisible才能时窗口可见

if(dialog == null)
dialog = new JDialog();
dialog.setVisible(true);
7-3.文件对话框(JFileChooser类) 
7-4.颜色对话框(JColorChooser类)

2、实验内容和步骤

实验1: 导入第12章示例程序,测试程序并进行组内讨论。

实验1: 导入第12章示例程序,测试程序并进行组内讨论。

测试程序1

elipse IDE中运行教材479页程序12-1,结合运行结果理解程序;

掌握各种布局管理器的用法;

理解GUI界面中事件处理技术的用途。

在布局管理应用代码处添加注释;

package calculator;
import java.awt.*;
import java.awt.event.*;
import javax.swing.*;
/**
* A panel with calculator buttons and a result display.
*/
public class CalculatorPanel extends JPanel//构造器
{
private JButton display;
private JPanel panel;
private double result;//用来保存计算结果的变量
private String lastCommand;//私有的
private boolean start;//保存动作是否开启的变量
public CalculatorPanel()//构造器
{
setLayout(
new BorderLayout());//创建边框布局管理器
//setLayout()设置用户界面上的屏幕组件的格式布局,是Java图形用户界面的常用方法,默认为流式布局
result = 0;
lastCommand
= "=";
start
= true;
// add the display

display
= new JButton("0");
display.setEnabled(
false);
//setEnabled():参数为true标识可以响应事件(即允许用户输入),true标识不能响应事件(即不允许用户输入),
add(display, BorderLayout.NORTH);
ActionListener insert
= new InsertAction();
ActionListener command
= new CommandAction();
// add the buttons in a 4 x 4 grid

panel
= new JPanel();//创建子容器组件
panel.setLayout(new GridLayout(4, 4));//创建4行4列网格布局管理器

addButton(
"0", insert);//数字按钮注册了insert监听器对象
addButton("1", insert);
addButton(
"2", insert);
addButton(
"3", command);//运算按钮注册了command监听器对象

addButton(
"4", insert);
addButton(
"5", insert);
addButton(
"6", insert);
addButton(
"*", command);
addButton(
"7", insert);
addButton(
"8", insert);
addButton(
"9", insert);
addButton(
"+", command);
addButton(
"-", insert);
addButton(
".", insert);
addButton(
"/", command);
addButton(
"=", command);
add(panel, BorderLayout.CENTER);

JButton b1
= new JButton("验证");
add(b1, BorderLayout.SOUTH);

JButton b2
= new JButton("验证2");
add(b2, BorderLayout.WEST);

JButton b3
= new JButton("验证3");
add(b3, BorderLayout.EAST);
}
/**
* Adds a button to the center panel.
*
@param label the button label
*
@param listener the button listener
*/
private void addButton(String label, ActionListener listener)
{
JButton button
= new JButton(label);

button.addActionListener(listener);
panel.add(button);
//把按钮添加到子容器面板上
}
/**
* This action inserts the button action string to the end of the display text.
*/
private class InsertAction implements ActionListener
{
public void actionPerformed(ActionEvent event)
{
String input
= event.getActionCommand();//将获得的变量保存到input临时变量里面
if (start)
{
display.setText(
"");//清零
//setText()输出String类型的字符串变量
start = false;
}
display.setText(display.getText()
+ input);
//完成多个数字的输入操作
}
}
/**
* This action executes the command that the button action string denotes.
*/
private class CommandAction implements ActionListener//实现ActionListener接口
{
public void actionPerformed(ActionEvent event)
{
String command
= event.getActionCommand();//把发出动作的按钮的信息保存到command里面
if (start)
{
if (command.equals("-"))
{
display.setText(command);
//显示负号
start = false;
}
else lastCommand = command;
}
else
{
calculate(Double.parseDouble(display.getText()));
//私有方法
//parseDouble()从display.getText()得到字符串,转化成基本类型(Double)的数据
lastCommand = command;
start
= true;//启动新一轮的计算
}
}
}
/**
* Carries out the pending calculation.
*
@param x the value to be accumulated with the prior result.
*/
public void calculate(double x)
{
if (lastCommand.equals("+")) result += x;
else if (lastCommand.equals("-")) result -= x;
else if (lastCommand.equals("*")) result *= x;
else if (lastCommand.equals("/")) result /= x;
else if (lastCommand.equals("=")) result = x;
display.setText(
"" + result);
}
}

 

技术分享图片

 

测试程序2

elipse IDE中调试运行教材486页程序12-2,结合运行结果理解程序;

掌握各种文本组件的用法;

记录示例代码阅读理解中存在的问题与疑惑。

技术分享图片

 

测试程序3

elipse IDE中调试运行教材489页程序12-3,结合运行结果理解程序;

掌握复选框组件的用法;

记录示例代码阅读理解中存在的问题与疑惑。

package checkBox;
import java.awt.*;
import java.awt.event.*;
import javax.swing.*;
/**
* A frame with a sample text label and check boxes for selecting font
* attributes.
*/
public class CheckBoxFrame extends JFrame
{
private JLabel label;
private JCheckBox bold;
private JCheckBox italic;
private static final int FOnTSIZE= 24;
public CheckBoxFrame()//构造器
{
// add the sample text label 添加示例文本标签

label
= new JLabel("The quick brown fox jumps over the lazy dog.");
label.setFont(
new Font("Serif", Font.BOLD, FONTSIZE));
add(label, BorderLayout.CENTER);
// this listener sets the font attribute of 此监听器设置字体属性
// the label to the check box state 设置复选框状态的标签

ActionListener listener
= event -> {
int mode = 0;
if (bold.isSelected()) mode += Font.BOLD;
//isSelected() 判断某个元素是否被选中
if (italic.isSelected()) mode += Font.ITALIC;
label.setFont(
new Font("Serif", mode, FONTSIZE));//设置组件的字体
};
// add the check boxes 添加复选框

JPanel buttonPanel
= new JPanel();//创建一个容器类对象

bold
= new JCheckBox("Bold");
bold.addActionListener(listener);
bold.setSelected(
true);
buttonPanel.add(bold);
//

italic
= new JCheckBox("Italic");
italic.addActionListener(listener);
//和41行使用了同一个动作监听器
buttonPanel.add(italic);
add(buttonPanel, BorderLayout.SOUTH);
pack();
}
}


package checkBox;
import java.awt.*;
import javax.swing.*;
/**
*
@version 1.34 2015-06-12
*
@author Cay Horstmann
*/
public class CheckBoxTest
{
public static void main(String[] args)
{
EventQueue.invokeLater(()
-> {
JFrame frame
= new CheckBoxFrame();//实现一个JFrame的类对象
frame.setTitle("CheckBoxTest");//设置框架标题
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);//设置默认的关闭操作
frame.setVisible(true);//设置视图可见
});
}
}

 

技术分享图片

 

测试程序4

elipse IDE中调试运行教材491页程序12-4,运行结果理解程序;

掌握单选按钮组件的用法;

记录示例代码阅读理解中存在的问题与疑惑。

技术分享图片

 

测试程序5

elipse IDE中调试运行教材494页程序12-5,结合运行结果理解程序;

掌握边框的用法;

记录示例代码阅读理解中存在的问题与疑惑。

技术分享图片

 

测试程序6

elipse IDE中调试运行教材498页程序12-6,结合运行结果理解程序;

掌握组合框组件的用法;

记录示例代码阅读理解中存在的问题与疑惑。

技术分享图片

 

测试程序7

elipse IDE中调试运行教材501页程序12-7,结合运行结果理解程序;

掌握滑动条组件的用法;

记录示例代码阅读理解中存在的问题与疑惑。

技术分享图片

 

测试程序8

elipse IDE中调试运行教材512页程序12-8,结合运行结果理解程序;

掌握菜单的创建、菜单事件监听器、复选框和单选按钮菜单项、弹出菜单以及快捷键和加速器的用法。

记录示例代码阅读理解中存在的问题与疑惑。

技术分享图片

 

测试程序9

elipse IDE中调试运行教材517页程序12-9,结合运行结果理解程序;

掌握工具栏和工具提示的用法;

记录示例代码阅读理解中存在的问题与疑惑。

技术分享图片

 

测试程序10

elipse IDE中调试运行教材524页程序12-1012-11,结合运行结果理解程序,了解GridbagLayout的用法。

elipse IDE中调试运行教材533页程序12-12,结合程序运行结果理解程序,了解GroupLayout的用法。

记录示例代码阅读理解中存在的问题与疑惑。

技术分享图片

 

测试程序11

elipse IDE中调试运行教材539页程序12-1312-14,结合运行结果理解程序;

掌握定制布局管理器的用法。

记录示例代码阅读理解中存在的问题与疑惑。

技术分享图片

 

测试程序12

elipse IDE中调试运行教材544页程序12-1512-16,结合运行结果理解程序;

掌握选项对话框的用法。

记录示例代码阅读理解中存在的问题与疑惑。

技术分享图片

 

测试程序13

elipse IDE中调试运行教材552页程序12-1712-18,结合运行结果理解程序;

掌握对话框的创建方法;

记录示例代码阅读理解中存在的问题与疑惑。

技术分享图片

 

测试程序14

elipse IDE中调试运行教材556页程序12-1912-20,结合运行结果理解程序;

掌握对话框的数据交换用法;

记录示例代码阅读理解中存在的问题与疑惑。

技术分享图片

 

测试程序15

elipse IDE中调试运行教材556页程序12-21、12-2212-23,结合程序运行结果理解程序;

掌握文件对话框的用法;

记录示例代码阅读理解中存在的问题与疑惑。

技术分享图片

 

测试程序16

elipse IDE中调试运行教材570页程序12-24,结合运行结果理解程序;

了解颜色选择器的用法。

记录示例代码阅读理解中存在的问题与疑惑。

技术分享图片

 

实验2组内讨论反思本组负责程序,理解程序总体结构,梳理程序GUI设计中应用的相关组件,整理相关组件的API,对程序中组件应用的相关代码添加注释。

实验3:组间协同学习:在本班课程QQ群内,各位同学对实验1中存在的问题进行提问,提问时注明实验1中的测试程序编号,负责对应程序的小组需及时对群内提问进行回答。

总结:本周主要学习了有关Swing用户界面组件,内容有点多,大致看了一点。通过小组的商讨,了解了这些程序的大致的思路,但是还是要继续学习。


推荐阅读
  • 本文介绍如何通过Windows批处理脚本定期检查并重启Java应用程序,确保其持续稳定运行。脚本每30分钟检查一次,并在需要时重启Java程序。同时,它会将任务结果发送到Redis。 ... [详细]
  • CSS 布局:液态三栏混合宽度布局
    本文介绍了如何使用 CSS 实现液态的三栏布局,其中各栏具有不同的宽度设置。通过调整容器和内容区域的属性,可以实现灵活且响应式的网页设计。 ... [详细]
  • Vue 2 中解决页面刷新和按钮跳转导致导航栏样式失效的问题
    本文介绍了如何通过配置路由的 meta 字段,确保 Vue 2 项目中的导航栏在页面刷新或内部按钮跳转时,始终保持正确的 active 样式。具体实现方法包括设置路由的 meta 属性,并在 HTML 模板中动态绑定类名。 ... [详细]
  • 深入理解 Oracle 存储函数:计算员工年收入
    本文介绍如何使用 Oracle 存储函数查询特定员工的年收入。我们将详细解释存储函数的创建过程,并提供完整的代码示例。 ... [详细]
  • 本文总结了2018年的关键成就,包括职业变动、购车、考取驾照等重要事件,并分享了读书、工作、家庭和朋友方面的感悟。同时,展望2019年,制定了健康、软实力提升和技术学习的具体目标。 ... [详细]
  • 在计算机技术的学习道路上,51CTO学院以其专业性和专注度给我留下了深刻印象。从2012年接触计算机到2014年开始系统学习网络技术和安全领域,51CTO学院始终是我信赖的学习平台。 ... [详细]
  • Linux 系统启动故障排除指南:MBR 和 GRUB 问题
    本文详细介绍了 Linux 系统启动过程中常见的 MBR 扇区和 GRUB 引导程序故障及其解决方案,涵盖从备份、模拟故障到恢复的具体步骤。 ... [详细]
  • 本文介绍了如何使用jQuery根据元素的类型(如复选框)和标签名(如段落)来获取DOM对象。这有助于更高效地操作网页中的特定元素。 ... [详细]
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • 本文介绍如何在 Xcode 中使用快捷键和菜单命令对多行代码进行缩进,包括右缩进和左缩进的具体操作方法。 ... [详细]
  • 在Linux系统中配置并启动ActiveMQ
    本文详细介绍了如何在Linux环境中安装和配置ActiveMQ,包括端口开放及防火墙设置。通过本文,您可以掌握完整的ActiveMQ部署流程,确保其在网络环境中正常运行。 ... [详细]
  • QUIC协议:快速UDP互联网连接
    QUIC(Quick UDP Internet Connections)是谷歌开发的一种旨在提高网络性能和安全性的传输层协议。它基于UDP,并结合了TLS级别的安全性,提供了更高效、更可靠的互联网通信方式。 ... [详细]
  • 深入理解OAuth认证机制
    本文介绍了OAuth认证协议的核心概念及其工作原理。OAuth是一种开放标准,旨在为第三方应用提供安全的用户资源访问授权,同时确保用户的账户信息(如用户名和密码)不会暴露给第三方。 ... [详细]
  • 2023 ARM嵌入式系统全国技术巡讲旨在分享ARM公司在半导体知识产权(IP)领域的最新进展。作为全球领先的IP提供商,ARM在嵌入式处理器市场占据主导地位,其产品广泛应用于90%以上的嵌入式设备中。此次巡讲将邀请来自ARM、飞思卡尔以及华清远见教育集团的行业专家,共同探讨当前嵌入式系统的前沿技术和应用。 ... [详细]
  • 理解存储器的层次结构有助于程序员优化程序性能,通过合理安排数据在不同层级的存储位置,提升CPU的数据访问速度。本文详细探讨了静态随机访问存储器(SRAM)和动态随机访问存储器(DRAM)的工作原理及其应用场景,并介绍了存储器模块中的数据存取过程及局部性原理。 ... [详细]
author-avatar
斯林力克密封材料科技有限公司
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有