首页 > 编程语言 >GUI编程|PART1

GUI编程|PART1

时间:2023-09-08 12:34:24浏览次数:37  
标签:Frame Button 编程 public PART1 add frame new GUI

GUI编程

怎么学?

  • 是什么
  • 怎么玩
  • 怎么用
  • class文件反编译成可阅读的文件

组件

  • 窗口
  • 弹窗
  • 面板
  • 文本框
  • 列表框
  • 按钮
  • 图片
  • 监听事件
  • 鼠标
  • 键盘事件
  • 外挂:Java
  • 破解工具

1、简介

GUI核心技术Swing AWT,这俩类,

不流行的原因:

  1. 界面不美观
  2. 需要jre环境! jre太大

为什么要学习?

  1. 可以写出自己心中想要的小工具
  2. 工作时可能要维护Swing,概率极小
  3. 了解MVC架构,了解监听!(为什么点击窗口是可以关掉的)

2、AWT

2.1、AWT介绍

  1. 包含很多接口!GUI!
  2. 元素:窗口、按钮、文本框
  3. java.awt

2.2、组件和容器

1、Frame

package com.kuang.lessson01;

import java.awt.*;

//GUI的第一个界面
public class Testframe {

    public static void main(String[] args) {
        //Frame,JDK 看源码
        Frame frame = new Frame("我的第一个Java图形界面窗口");

        //需要设置可见性
        frame.setVisible(true);

        //设置窗口大小 w h
        frame.setSize(400,400);

        //设置背景颜色 color
        frame.setBackground(new Color(85,195,66));

        //设置弹出的位置
        frame.setLocation(200,200);

        //设置窗口不可以拉伸,大小固定
        frame.setResizable(false);

    }

}

问题:发现窗口关闭不掉,停止java程序运行

回顾封装:

package com.kuang.lessson01;

import java.awt.*;

public class TestFrame2 {
    public static void main(String[] args) {
        //展示多个窗口
        MyFrame myFrame1 = new MyFrame(100,100,200,200,Color.blue);
        MyFrame myFrame2 = new MyFrame(300,100,200,200,Color.green);
        MyFrame myFrame3 = new MyFrame(100,300,200,200,Color.yellow);
        MyFrame myFrame4 = new MyFrame(300,300,200,200,Color.pink);
    }
}

//Frame类的继承
class MyFrame extends Frame{
    static int id = 0;//可能存在多个窗口,需要一个计数器

    public MyFrame(int x,int y,int w,int h,Color color){
        super("Myframe+"+(++id));

        setBackground(color);
        setBounds(x,y,w,h);
        setVisible(true);
    }
}

2、面板Panel

解决了关闭问题(添加监听)

package com.kuang.lessson01;

import java.awt.*;
import java.awt.event.WindowAdapter;
import java.awt.event.WindowEvent;
import java.awt.event.WindowListener;

//Panel 面板,可以看成是一个空间,但是不能单独存在
public class TestPanel {
    public static void main(String[] args) {
        Frame frame = new Frame();
        Panel panel = new Panel();

        //设置布局
        frame.setLayout(null);

        //坐标
        frame.setBounds(300,300,500,500);
        frame.setBackground(new Color(40,161,35));

        //panel设置相对坐标 相对于frame
        panel.setBounds(50,50,400,400);
        panel.setBackground(new Color(193,15,60));

        //frame.add(panel)
        frame.add(panel);

        frame.setVisible(true);

        //监听事件 监听窗口关闭事件 System.exit(0)
        //适配器模式
        frame.addWindowListener(new WindowAdapter() {
            //窗口点击关闭的时候要做的
            @Override
            public void windowClosing(WindowEvent e) {
                //结束程序
                System.exit(0);
            }
        });
    }
}

3、布局管理器

  • 流式布局 从左到右

    package com.kuang.lessson01;
    
    import java.awt.*;
    
    public class TestFlowLayout {
        public static void main(String[] args) {
            Frame frame = new Frame();
    
            //按钮组件
           Button button1 = new Button("button1");
            Button button2 = new Button("button2");
            Button button3 = new Button("button3");
    
            //设置为流式布局
            //frame.setLayout(new FlowLayout(FlowLayout.LEFT));  //button123靠左
            //frame.setLayout(new FlowLayout(FlowLayout.RIGHT));  //button123靠右
            frame.setLayout(new FlowLayout(FlowLayout.CENTER));   //button123居中
    
            frame.setSize(200,200);
    
            //把按钮添加上去
            frame.add(button1);
            frame.add(button2);
            frame.add(button3);
    
            frame.setVisible(true);
    
        }
    }
    
    
  • 东西南北中 上下式 BorderLayout

    package com.kuang.lessson01;
    
    import java.awt.*;
    
    public class TestBorderLayout {
        public static void main(String[] args) {
            Frame frame= new Frame("TextBorderLayout");
    
            Button east = new Button("East");
            Button west = new Button("West");
            Button south = new Button("South");
            Button north = new Button("North");
            Button center = new Button("Center");
    
            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.setSize(200,200);
            frame.setVisible(true);
    
    
        }
    }
    
    
  • 表格布局 表格:Grid

package com.kuang.lessson01;

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(2,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);
    }
}

练习题

构思80%

代码20%

分析过程
  1. frame窗
  2. 四个大的面板
    • border
      • 左:button
      • 中:面板
      • 右:button
代码实现
package com.kuang.lessson01;

import java.awt.*;

public class TestPractice {
    public static void main(String[] args) {

        //总 Frame
        Frame frame = new Frame("TestPractice");
        frame.setSize(400,300);
        frame.setLocation(400,500);
        frame.setBackground(Color.BLUE);
        frame.setLayout(new GridLayout(2,1));
        frame.setVisible(true);


        //4个面板
        Panel p1 = new Panel(new BorderLayout());
        Panel p2 = new Panel(new GridLayout(2,1));
        Panel p3 = new Panel(new BorderLayout());
        Panel p4 = new Panel(new GridLayout(2,2));
        //上面
        p1.add(new Button("East-1"),BorderLayout.EAST);
        p1.add(new Button("West-1"),BorderLayout.WEST);
        p2.add(new Button(("p2-btn-1")));
        p2.add(new Button(("p2-btn-2")));
        p1.add(p2,BorderLayout.CENTER);
        //下面
        p3.add(new Button("East-2"),BorderLayout.EAST);
        p3.add(new Button("West-2"),BorderLayout.WEST);
        //中间四个
       for(int i=1;i<5;i++)
        {
            p4.add(new Button("p4-"+i));
        }

       p3.add(p4,BorderLayout.CENTER);
       frame.add(p1);
       frame.add(p3);
    }
}

小结

  • Frame是一个顶级窗口
  • Panel无法单独显示,必须添加到某个容器里面
  • 布局管理器
    • 流式
    • 东西南北中
    • 表格
  • 大小、定位、背景颜色、可见性、监听

标签:Frame,Button,编程,public,PART1,add,frame,new,GUI
From: https://www.cnblogs.com/yuyuyu627/p/17687268.html

相关文章

  • oj练习题程序编程题
    打印图形Description按要求输出由*组成的图案Input无需输入Output输出下面由“组成的图案卡  11  print('*')print("***")print("*****")print("*")print("*")print("*")  11 ......
  • 网络编程学习大纲&&网络编程1.1
    网络编程的学习大纲计算机网络体系结构模型,网络编程专业术语(socket/IP/端口号),通信时序图传输协议:TCP协议/UDP协议多进程并发服务器,多线程并发服务器网络编程IO模型:阻塞IO/非阻塞IO/多路复用/信号驱动超时接收数据方法回顾系统编程中进程的通信方式管道无名管道(只能亲......
  • 《Java编程思想第四版》学习笔记26
    //:Cleanup.java//Payingattentiontoexceptions//inconstructorsimportjava.io.*;classInputFile{privateBufferedReaderin;InputFile(Stringfname)throwsException{try{in=newBufferedReader(......
  • nicegui:Python 图形界面库,简单好用
    前言在现代计算机应用程序开发中,图形用户界面(GUI)是用户与程序交互的重要组成部分。然而,GUI开发往往需要大量的代码和复杂的布局,给开发者带来了一定的挑战。在本篇博文中,将介绍nicegui,它是一个简单易用的图形用户界面库,提供了一种简化GUI开发的方式,使开发者能够更快速地构建吸......
  • go并发编程系列七:使用goroutine写一个线程池
    TRANSLATEwithxEnglishArabicHebrewPolishBulgarianHindiPortugueseCatalanHmongDawRomanianChineseSimplifiedHungarianRussianChineseTraditionalIndonesianSlovakCzechItalianSlovenianDanishJapaneseSpanishDutchKl......
  • 函数式编程
    函数式编程概念函数式编程是一种编程范式,它强调将计算过程视为数学函数的组合和转换,而不是通过改变状态和数据的操作来实现程序的功能。在JavaScript中,函数式编程成为了一种流行的编程风格,特别是在处理数据、异步操作和复杂逻辑时。以下是一些函数式编程在JavaScript中的核心概念和......
  • spring中的aop(面向切面编程)需要到导入的包与简单示例
    2023-09-07<?xmlversion="1.0"encoding="UTF-8"?><projectxmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://......
  • 2023“钉耙编程”中国大学生算法设计超级联赛(4)
    1003SimpleSetProblem题意:分别从k个集合中选一个元素组成一个数组\((a_1,a_2,a_3,...,a_k)\),求max\((a_1,a_2,a_3,...,a_k)\)-min\((a_1,a_2,a_3,...,a_k)\)的最小值。分析:我们给每个集合中的元素添加一个id标识它属于哪个集合,然后将所有集合合并并按数值大小从......
  • 趣味微项目:玩转Python编程,轻松学习快乐成长!
    ......
  • [论文阅读] Explicit Boundary Guided Semi-Push-Pull Contras
    ExplicitBoundaryGuidedSemi-Push-PullContrastiveLearningforSupervisedAnomalyDetectionIntroduction只关注正常样本可能会限制AD模型的可判别性。如图1(a)所示,在没有异常情况的情况下,决策边界通常是隐式的,没有足够的判别性。在无监督异常检测中,由于缺乏对异常的了解......