16.GUI【图形用户界面】

2024-06-06 13:48
文章标签 16 gui 图形用户界面

本文主要是介绍16.GUI【图形用户界面】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 

                                                 GUI-图形用户界面

 

一、概述

1. GUI:

    GraphicalUser Interface,中文称为图形用户界面。用图形的方式,来显示计算机操作的界面,这样更方便更直观。

2.计算机与用户交互的两种方式:GUI和CLI.

     CLICommand LineUser Interface,中文翻译为命令行用户接口,即常见的DOS命令行操作。这种交互方式需要用户注意一些常用的命令行,操作不直观。

3.Java将GUI这种界面封装为对象,并放在两个包中:java.Awt包和javax.Swing包。

    java.Awt包:Abstract Window Tookit,抽象窗口工具包。需要调用本地系统方法实现功能,属于重量级控件。

    javax.Swing包:在Awt包的基础上建立的一套图形界面系统其中提供了更多的组件,且完全由Java增强了移植性,属于轻量级控件。

二、继承关系图

    

Container:为容器,是一个特殊的组件,该组件中可以通过add方法添加其他组件进来。

Container常用子类:Window Panel(面板,不能单独存在)。

Window常用子类:Frame Dialog

 

三、布局管理器

1. 定义:容器中的组件排列方式,就是布局。

2. 常见的布局管理器:

   1FlowLayout:流式布局管理器。从左向右排列,是Panel默认的布局管理器

   2BorderLayout:边界式布局管理器,东南西北中的排列方式,是Frame的默认布局管理器。如果

                                   窗体中只有一个组件,将会覆盖整个窗体。

  3GridLayout:网格式布局管理器,规则的矩阵

  4CardLayout:卡片式布局管理器,即选项卡

  5GridBayLayout:网格包布局管理器,非规则矩阵

3.如果存在多种布局方式,如何创建窗体界面呢?

    步骤:

            1)先将窗体Frame进行大区域的划分,设置其布局管理器,加入面板Panel。

            2)将组件加入Panel,设置面板的布局管理器。

 

四、简单的窗体创建过程

1.创建Frame窗体

   Frame f = new Frame(“my Frame”);可设置标题,即窗体名字。

2.对窗体进行基本设置,如大小,位置,布局等。

  f.setSize(intwight,int hight);窗体大小设置。

  f.setLocation(intx,int y);窗体显示位置设置,横纵坐标。

  f.setBounds(intx,int y,int wight,int hight),也可以直接用这个方法对大小和位置设置。

  f.setLayout(Layoutlayout),参数为指定的布局管理器,如FlowLayout

3.定义所需组件

   如Buttonb = new Button(“my Button”);可设置组件的名称。

4.将组件通过窗体的add方法添加到窗体中

   f.add(b);将按钮组件添加进窗体。

5.让窗体显示

f.setVisible(booleanb);通过设置参数是true还是false是否显示窗体。

 

五、事件监听机制

1. 组成:

1)事件源(组件):awt或swing包中的那些图形界面组件。

2)事件(Event):每一个事件源都有自己特有的对应事件和共性事件。

3)监听器(Listener):将可触发某一事件的动作(不只一个动作),都封装到侦听器中。

4)事件处理:引发事件后的处理方式。

 

事件源、事件、监听器这个在Java内部已经定义好,直接获取其对象使用即可。我们需要做的就是对产生的动作进行处理。

2.如何处理产生的动作?

   步骤:第一,确定事件源(容器或组件)。通过事件源对象的addXXXListener()方法将监听器注册到该事件源上。该方法中接收

                   XXXListener的子类对象,或者XXXListener的子类XXXAdapter的子类对象。一般用匿名内部类来表示。

         第二.在覆盖方法的时候,方法的参数一般是XXXEvent类型的变量接收。

代码示例:

 

<span style="font-size:18px;">f.addWindowlistener(new WindowAdapter()
{public void windowClosing(WindowEvent e){System.exit(0);//表示关闭窗口}
});
</span>

说明:

        1)事件触发后会把事件打包成对象传递给复写方法中参数的变量。(其中包括事件源对象。通过getSource()或者,getComponent()获取。)

        2)若用子类实现WindowListener接口,就需要覆盖其中的7个方法,可只用到其中的关闭动作,其他动作未用到,但却必须重写全部。因为WindowLister的子类WindowAdapter(适配器)已经实现此接口,并覆盖了其中所有方法。那么只需继承WindowAdapter,覆盖需要的方法即可。

        3)明确事件,并对事件进行处理,其实,添加什么监听器就需要添加什么事件。

说明:

        1)事件触发后会把事件打包成对象传递给复写方法中参数的变量。(其中包括事件源对象。通过getSource()或者getComponent()

             获取。)

        2)若用子类实现WindowListener接口,就需要覆盖其中的7个方法,可只用到其中的关闭动作,其他动作未用到,但却必须重写

            全部。因为WindowLister的子类WindowAdapter(适配器)已经实现此接口,并覆盖了其中所有方法。那么只需继承

            WindowAdapter,覆盖需要的方法即可。

        3)明确事件,并对事件进行处理,其实,添加什么监听器就需要添加什么事件。

 

练习:模拟鼠标和键盘

<span style="font-size:18px;">/** 鼠标和键盘监听是很多组件都有的。所以要放到component.* * 鼠标:按下和释放可以分开。是两个动作。比如关闭界面时突然又不想关,可以不释放,并移动鼠标。*/
import java.awt.Button;
import java.awt.FlowLayout;
import java.awt.Frame;
import java.awt.TextField;
import java.awt.event.KeyAdapter;
import java.awt.event.KeyEvent;
import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent;
import java.awt.event.WindowAdapter;
import java.awt.event.WindowEvent;public class MouseAndKeyDemo {//先明确组件。需要用到时才初始化。private Frame f;private TextField tf;private Button but;public MouseAndKeyDemo(){init();}public void init() {//创建窗体f = new Frame("演示鼠标和键盘监听");//设置边界f.setBounds(400,200,500,400);//设置布局f.setLayout(new FlowLayout());tf = new TextField(35);but = new Button("一个按钮");//添加组件f.add(tf);f.add(but);myEvent();//设置窗体可见f.setVisible(true);}private void myEvent() {//添加关闭效果f.addWindowListener(new WindowAdapter() {@Overridepublic void windowClosing(WindowEvent e) {System.exit(0);}});//在按钮上添加一个鼠标监听but.addMouseListener(new MouseAdapter(){private int count = 0;//记录触发次数
//			@Override//鼠标进入
//			public void mouseEntered(MouseEvent e) {
//				
//				System.out.println("Mouse enter..."+count++);
//				tf.setText("Mouse enter..."+count++);//显示在文本框中
//			}@Override//鼠标单击,双击public void mouseClicked(MouseEvent e) {if(e.getClickCount()==2)//设置双击。在MouseEvent中。tf.setText("Mouse doubleclick..."+count++);//显示在文本框中}});//给文本框添加键盘监听tf.addKeyListener(new KeyAdapter(){/** e.getKeyChar():获取键盘字符。* e.getKeyCode():获取键盘字符对应的ASII码。* KeyEvent。getKeyText():获取键名称。* KeyEvent里将所有的键定义成常量,方便应用。* */@Overridepublic void keyPressed(KeyEvent e) {
//				System.out.println("key pressed..."+KeyEvent.getKeyText(e.getKeyCode())+":::"+e.getKeyCode());//输入数字int code = e.getKeyCode();if(!(code>=KeyEvent.VK_0 && code<=KeyEvent.VK_9)){System.out.println("必须是数字");e.consume();//可以不用默认的事件。在这里就是:不是数字的,就不输入到文本框。}//控制组合键。if(e.isControlDown() && e.getKeyCode()==KeyEvent.VK_ENTER){System.out.println(" enter run...");}}});}//主函数,创建鼠标键盘对象public static void main(String[] args) {new MouseAndKeyDemo();}}</span>


六、应用

1.对话框(Dialog)

    何时需要产生对话框:此对象时需要在调用时,才创建对象。如:当在误操作的时候,就需要出现提示错误信息的对话框,此时才创建的这个对象。

对话框练习

<span style="font-size:18px;">/*
列出指定目录下的内容,当输入的路径不正确时,给出错误提示信息。
*/import java.io.*;
import java.awt.*;
import java.awt.event.*;class MyWindowDemo 
{//定义所需组件引用private Frame f;private Button but,bok;private TextField tf;private TextArea ta;private Dialog d;private Label lab;//构造函数MyWindowDemo(){init();}//窗体基本设置于功能实现public void init(){//组件实例化f=new Frame("我的Window");but=new Button("跳转");tf=new TextField(50);ta=new TextArea(30,60);//基本设置f.setBounds(300,150,500,500);f.setLayout(new FlowLayout());//添加组件f.add(tf);f.add(but);f.add(ta);//窗体事件myEvent();//窗体显示f.setVisible(true);}//注册事件public void myEvent(){//窗体关闭功能f.addWindowListener(new WindowAdapter(){public void windowClosing(WindowEvent e){System.exit(0);}});//“跳转”按钮事件but.addActionListener(new ActionListener(){public void actionPerformed(ActionEvent e){showFile();//列出目录内容在文本区中}});//文本框键盘事件tf.addKeyListener(new KeyAdapter(){public void keyPressed(KeyEvent e){//如果键盘按下Enter键,就将目录内容显示在文本区中if(e.getKeyCode()==KeyEvent.VK_ENTER)showFile();}});}//目录内容显示在文本区中方法private void showFile(){String path=tf.getText();//获取输入的路径File dir=new File(path);//将路径封装成对象//判断输入的路径是否存在,且是否是文件夹if (dir.exists()&&dir.isDirectory()){ta.setText("");//清空文本区中的内容---------String names[]=dir.list();//列出目录下的内容//遍历for (String name : names ){ta.append(name+"\r\n");//添加进文本区中}}else{//对话框基本设置d=new Dialog(f,"错误提示",true);d.setBounds(400,200,280,150);d.setLayout(new FlowLayout());bok=new Button("确定");lab=new Label();//添加按钮和文本d.add(bok);d.add(lab);//对话框关闭事件d.addWindowListener(new WindowAdapter(){public void windowClosing(WindowEvent e){d.setVisible(false);//退出对话框}});//“确定”按钮事件bok.addActionListener(new ActionListener(){public void actionPerformed(ActionEvent e){d.setVisible(false);//按确认键,退出对话框}});String info="您输入的路径:"+path+"是错误的,请重输!";lab.setText(info);//设置标签文本内容d.setVisible(true);//显示对话框}}public static void main(String[] args) {//运行窗体new MyWindowDemo();}
}
</span>


 

2.菜单(Menu)

   菜单的关系图

 

  • Menu:菜单,继承MenuItem;有右三角的图标存在,可添加MenuMenuItem
  • MenuBar:菜单栏,可添加菜单和菜单条目。一般先创建菜单栏,再创建菜单。
  • MenuItem:菜单条目,也称菜单项,无右三角的图标存在,是最终的菜单项。
  • 菜单的事件处理和组件一样,可以对类型为MenuItemMenu的对象这个事件源添加活动监听ActionListener,并进行相关的事件处理。
  • 通过setMenuBar()方法,将菜单添加到Frame中。

菜单练习

<span style="font-size:18px;">import java.awt.*;
import java.awt.event.*;class MyMenuDemo 
{//定义组件引用private Frame f;private MenuBar mb;private Menu m,subMenu;private MenuItem closeItem,subItem;//构造函数MyMenuDemo(){init();}
//窗体设置与功能实现	public void init(){//窗体设置
f = new Frame("my window");f.setBounds(300,100,500,600);f.setLayout(new FlowLayout());mb = new MenuBar();//创建菜单条m = new Menu("文件");//创建菜单subMenu = new Menu("子菜单");//菜单下面的子菜单subItem = new MenuItem("子条目");//子菜单包含的菜单条目closeItem = new MenuItem("退出");//菜单包含的条目//菜单添加菜单组件subMenu.add(subItem);m.add(subMenu);m.add(closeItem);mb.add(m);//窗体添加菜单组件f.setMenuBar(mb);//窗体上事件myEvent();//窗体显示f.setVisible(true);}private void myEvent(){//关闭菜单具备关闭事件closeItem.addActionListener(new ActionListener(){public void actionPerformed(ActionEvent e){System.exit(0);}});//窗体关闭功能f.addWindowListener(new WindowAdapter(){public void windowClosing(WindowEvent e){System.exit(0);	}});}public static void main(String[] args) {new MyMenuDemo();}
}
</span>


 

3.双击jar包执行

     既然是图形化界面,就需要通过图形化界面的形式运行程序,而不是用Dos命令行执行,那么如何通过双击jar包就执行程序呢?这就需要将程序的class文件打包。

步骤如下:

        1、首先要在java文件中导入一个包,没有则需创建一个包,如package mymenu;

        2、生成包:通过编译javac -d c:\myclass MyMenu.java,此时则在c盘下的myclass文件夹下生成了所有的.class文件

        3、在此目录下新建一个文件,如1.txt或者其他任意名称任意扩展名的文件都可以,然后在其中编辑固定的格式:“Main-Class: mymenu.MenuDemo”,只写引号中的内容。需要在冒号后有一个空格,在文件末尾要回车。

        4、编译:jar -cvfm my.jar 1.txt mymenu即可。如果想添加其他信息,则直接编译jar即可得出相应的命令

        5、此时双击即可执行。

说明:

        1)在固定格式中:

                a、如果无空格:在编译的时候,就会报IO异常,提示无效的头字段,即invalidheader field。这说明1.txt在被IO流读取。

                b、如果无回车:在列表清单.MF中不会加入相应的加载主类的信息,也就是说配置清单的属性主类名称不会加载进清单中,也就不会执行。

        2jar文件必须在系统中注册,才能运行。注册方法如下:

        A.对于XP系统:

               a.打开任意对话框,在菜单栏点击工具按钮,选择文件夹选项

               b.选择新建--->扩展名,将扩展名设置为jar,确定

               c.选择高级,可更改图标,然后点击新建,命名为open

               d.在用于可执行应用程序中,点浏览,将jdk下的bin的整个文件路径添加进来,并在路径后添加-jar即可。

       B.对于win7系统:

               a.改变打开方式:右击.jar文件,点击打开方式,选择默认程序为jdkbin中的javaw.exe应用程序。

               b.修改关联程序的注册表:打开注册表(win+r),找到注册表路径\HKEY_CLASSES_ROOT\Aplications\javaw.exe\shell\open\command下的字符串值,右击点修改,在原路径的中添加-jar,如:"C:\ProgramFiles\Java\jre6\bin\javaw.exe" -jar "%1",注意-jar两边要有空格,保存。

              c.双击即可执行jar程序,如果仍不能执行,则需下载最新版的jdk

练习:利用Menu组件完成一个简单的记事本程序。

<span style="font-size:18px;">/*
练习:利用Menu组件完成一个简单的记事本程序。
需求:具有文件菜单,文件中有打开,保存和退出功能。将写好的程序变为双击可执行的程序。
*/package mymenu;
import java.awt.*;
import java.awt.event.*;
import java.io.*;class MyMenuText
{//定义组件引用private Frame f;private TextArea ta;private MenuBar mb;private Menu fileMe;private MenuItem openMi,saveMi,otherSaveMi,closeMi;private FileDialog openDia,saveDia;private File file;//构造函数MyMenuText(){init();}//功能实现private void init(){//组件实例化f=new Frame("MyText");ta=new TextArea();mb=new MenuBar();fileMe=new Menu("文件");openMi=new MenuItem("打开");saveMi=new MenuItem("保存");otherSaveMi=new MenuItem("另存为");closeMi=new MenuItem("退出");openDia=new FileDialog(f,"选择打开的文件",FileDialog.LOAD);saveDia=new FileDialog(f,"保存到哪里",FileDialog.SAVE);//基本设置f.setBounds(300,150,600,500);//添加组件f.add(ta);f.setMenuBar(mb);mb.add(fileMe);fileMe.add(openMi);fileMe.add(saveMi);fileMe.add(otherSaveMi);fileMe.add(closeMi);//窗体中事件myEvent();//窗体显示f.setVisible(true);}private void myEvent(){//窗体关闭功能f.addWindowListener(new WindowAdapter(){public void windowClosing(WindowEvent e){System.exit(0);}});//打开事件openMi.addActionListener(new ActionListener(){public void actionPerformed(ActionEvent e){//显示文件对话窗口openDia.setVisible(true);//------------------String dir=openDia.getDirectory();//获取目录String fileName=openDia.getFile();//获取文件名if(dir==null||fileName==null)//对打开了文件对话框,但未做出操作的处理return;file=new File(dir,fileName);//文件对象try{ta.setText("");//每打开一个文件时,将文本区的内容清空//带缓冲技术的读取流BufferedReader br=new BufferedReader(new FileReader(file));String line=null;//读一行while ((line=br.readLine())!=null){//添加到文本区域ta.append(line+"\r\n");}br.close();//关流}catch (IOException ie){throw new RuntimeException("文件打开失败");}}});//保存事件saveMi.addActionListener(new ActionListener(){public void actionPerformed(ActionEvent e){//如果是第一次保存,则显示文件对话框if(file==null)//-------------{//显示文件对话框saveDia.setVisible(true);//----------------------String dir=saveDia.getDirectory();String filename=saveDia.getFile();if(dir==null||filename==null)//--------------------return;file=new File(dir,filename);}save();//保存文件方法}});//另存为事件otherSaveMi.addActionListener(new ActionListener(){public void actionPerformed(ActionEvent e){//不管是不是第一次保存,都显示文件对话框saveDia.setVisible(true);//----------------------String dir=saveDia.getDirectory();String filename=saveDia.getFile();if(dir==null||filename==null)//--------------------return;file=new File(dir,filename);save();//保存文件方法//保存时,默认文件对话框位置在打开文件的位置openDia.setFile(file.getName());}});//退出事件closeMi.addActionListener(new ActionListener(){public void actionPerformed(ActionEvent e){System.exit(0);}});}//保存文件private void save(){			try{//带缓冲区的写入流BufferedWriter bw=new BufferedWriter(new FileWriter(file));//获取文本区域中的内容String text=ta.getText();bw.write(text);//写入文件中bw.close();//关流}catch (IOException ie){throw new RuntimeException("文件保存失败");}}public static void main(String[] args) {//程序运行new MyMenuText();}
}
</span>


 

 

这篇关于16.GUI【图形用户界面】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1036290

相关文章

Java 创建图形用户界面(GUI)入门指南(Swing库 JFrame 类)概述

概述 基本概念 Java Swing 的架构 Java Swing 是一个为 Java 设计的 GUI 工具包,是 JAVA 基础类的一部分,基于 Java AWT 构建,提供了一系列轻量级、可定制的图形用户界面(GUI)组件。 与 AWT 相比,Swing 提供了许多比 AWT 更好的屏幕显示元素,更加灵活和可定制,具有更好的跨平台性能。 组件和容器 Java Swing 提供了许多

【JavaScript】LeetCode:16-20

文章目录 16 无重复字符的最长字串17 找到字符串中所有字母异位词18 和为K的子数组19 滑动窗口最大值20 最小覆盖字串 16 无重复字符的最长字串 滑动窗口 + 哈希表这里用哈希集合Set()实现。左指针i,右指针j,从头遍历数组,若j指针指向的元素不在set中,则加入该元素,否则更新结果res,删除集合中i指针指向的元素,进入下一轮循环。 /*** @param

Golang GUI入门——andlabs ui

官方不提供gui标准库,只好寻求第三方库。 https://github.com/google/gxui 这个gui库是谷歌内部人员提供的,并不是谷歌官方出品,现在停止维护,只好作罢。 第三方gui库 找了好多,也比较了好多,最终决定使用的是还是 https://github.com/andlabs/ui 相信golang gui还会发展的更好,期待更优秀的gui库 由于andlabs

16 子组件和父组件之间传值

划重点 子组件 / 父组件 定义组件中:props 的使用组件中:data 的使用(有 return 返回值) ; 区别:Vue中的data (没有返回值);组件方法中 emit 的使用:emit:英文原意是:触发、发射 的意思components :直接在Vue的方法中声明和绑定要使用的组件 小炒肉:温馨可口 <!DOCTYPE html><html lang="en"><head><

react笔记 8-16 JSX语法 定义数据 数据绑定

1、jsx语法 和vue一样  只能有一个根标签 一行代码写法 return <div>hello world</div> 多行代码返回必须加括号 return (<div><div>hello world</div><div>aaaaaaa</div></div>) 2、定义数据 数据绑定 constructor(){super()this.state={na

GUI编程08:画笔paint

本节内容视频链接:10、画笔paint_哔哩哔哩_bilibilihttps://www.bilibili.com/video/BV1DJ411B75F?p=10&vd_source=b5775c3a4ea16a5306db9c7c1c1486b5 package com.yundait.lesson03;import java.awt.*;import java.awt.event.Wind

C++入门(06)安装QT并快速测试体验一个简单的C++GUI项目

文章目录 1. 清华镜像源下载2. 安装3. 开始菜单上的 QT 工具4. 打开 Qt Creator5. 简单的 GUI C++ 项目5.1 打开 Qt Creator 并创建新项目5.2 设计界面5.3 添加按钮的点击事件5.4 编译并运行项目 6. 信号和槽(Signals and Slots) 这里用到了C++类与对象的很多概念 1. 清华镜像源下载 https://

打靶记录16——Momentum

靶机: https://download.vulnhub.com/momentum/Momentum.ova 下载后使用 VirtualBox 打开 难度:中 目标:取得 root 权限 + 2 Flag 攻击方法: 主机发现端口扫描信息收集Web 路径爆破XSS 漏洞JS 脚本分析AES 解密Redis 认证漏洞 主机发现 sudo arp-scan -l 端口扫描和服务发

Git Gui 查看分支历史的时候中文显示乱码

如图所示 在Git Gui工具栏上选择-编辑-选项: 选择:Default File Contents Encoding, change为UTF-8 成功:

结合Python与GUI实现比赛预测与游戏数据分析

在现代软件开发中,用户界面设计和数据处理紧密结合,以提升用户体验和功能性。本篇博客将基于Python代码和相关数据分析进行讨论,尤其是如何通过PyQt5等图形界面库实现交互式功能。同时,我们将探讨如何通过嵌入式预测模型为用户提供赛果预测服务。 本文的主要内容包括: 基于PyQt5的图形用户界面设计。结合数据进行比赛预测。文件处理和数据分析流程。 1. PyQt5 图形用户界面设计