《Java核心技术 卷I》JFrame组件中显示信息

组件中显示信息

JFrame结构复杂,由四层窗格,其中根窗格、层级窗格和玻璃窗格人们并不太关心,他们要用来组织菜单栏和内容窗格以及实现观感,Swing程序员最关心的是内容窗格(content pane),添加到窗体的所有组件都会自动添加到内容窗格中。

JFrame的内部结构

将一个组件添加到窗体中,消息将绘制在这个组件上,要在一个组件上绘制,需要定义一个拓展JComponent的类,并覆盖其中的paintComponent方法。此方法只有一个Graphics类型的参数,对于屏幕来说,画笔对象的度量单位是像素,坐标(0,0)指示所绘制组件的的左上角。

案例如下:

java 复制代码
package notHelloWorld;

import java.awt.Dimension;
import java.awt.EventQueue;
import java.awt.Graphics;

import javax.swing.JComponent;
import javax.swing.JFrame;

public class NotHelloWorld {

    public static void main(String[] args) {
        EventQueue.invokeLater(()->{
            var frame = new NotHelloWorldFrame();
            frame.setTitle("非你好世界");
            frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
            frame.setVisible(true);
            
        });
    }

}

class NotHelloWorldFrame extends JFrame {
    public NotHelloWorldFrame() {
        add(new NotHelloWorldComponent());
        pack();
    }
}

class NotHelloWorldComponent extends JComponent {
    
    public static final int MESSAGE_X = 75;
    public static final int MESSAGE_Y = 100;
    
    private static final int DEFAULT_WIDTH = 300;
    private static final int DEFAULT_HEIGHT  = 200;
    //画字符串
    @Override
    protected void paintComponent(Graphics g) {
        g.drawString("不是你好世界程序", MESSAGE_X, MESSAGE_Y);
    }
    //尺寸,参考大小
    @Override
    public Dimension getPreferredSize() {
        return new Dimension(DEFAULT_WIDTH, DEFAULT_HEIGHT);
    }
}

javax.swing.JFrame 1.2

  • Component add(Component c),将一个给定的组件添加到该窗体的内容窗格中,并返回这个组件。

java.awt.Component 1.0

  • void repaint(),尽可能快的重新绘制组件
  • Dimension getPreferredSize(),覆盖这个方法,以返回这个组件的首选大小。

javax.swing.JComponent 1.2

  • void paintComponent(Graphics g),覆盖这个方法来描述需要如何绘制组件

java.awt.Window 1.0

  • void pack(),调整窗口大小,要考虑其组件的首选大小。
相关推荐
jt君4242635 分钟前
React Native JSI 深入剖析 — 第 5 部分中文技术整理:用 HostObject 把 C++ 类暴露给 JavaScript
前端·react native
胡萝卜术37 分钟前
滑动窗口最大值:从暴力到单调队列,层层优化全解析
前端·javascript·面试
fluffyox39 分钟前
Notion 的公式栏里,藏着一台虚拟机——逆向 + 用 600 行 JS 复刻它的编译器与栈式 VM
前端
kyriewen2 小时前
2026 年了,这 6 个 npm 包可以卸载了——浏览器原生 API 已经能替代
前端·javascript·npm
aqi003 小时前
15天学会AI应用开发(八)使用向量数据库实现RAG功能
人工智能·python·大模型·ai编程·ai应用
Csvn4 小时前
`functools.lru_cache` —— 一行代码搞定缓存加速
后端·python
Csvn4 小时前
Monorepo 迁移血泪史:从 Multi-Repo 到 Turborepo,这 3 个坑我帮你踩完了
前端
星栈5 小时前
Dioxus 多页面怎么做:`dioxus-router`、嵌套路由、`Outlet` 和页面组织,一篇给你讲顺
前端·rust·前端框架
用户987409238875 小时前
用 Remotion + edge-tts 打造中文教学视频全自动流水线
前端