前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【错误记录】Java AWT 图形界面编程设置键盘事件没有响应 ( 设置键盘事件 | 键盘事件必须设置到 Frame / JFrame 对象上 )

【错误记录】Java AWT 图形界面编程设置键盘事件没有响应 ( 设置键盘事件 | 键盘事件必须设置到 Frame / JFrame 对象上 )

作者头像
韩曙亮
发布2023-05-09 17:48:44
5080
发布2023-05-09 17:48:44
举报

一、报错信息


实现一个需求 , 按键 数字 按键 , 让 Canvas 画布中绘制的图像根据按下的数值进行缩放 ;

在 AWT 自定义 Canvas 组件中 , 添加按键事件 , 下面定义的 KeyAdapter 中的 keyPressed 函数不回调 ;

代码语言:javascript
复制
        addKeyListener(new KeyAdapter() {
            @Override
            public void keyPressed(KeyEvent e) {
                if (e.getKeyCode() >= KeyEvent.VK_NUMPAD1 && e.getKeyCode() <= KeyEvent.VK_NUMPAD9) {
                    // 根据按键计算出缩放比例
                    scale = e.getKeyCode() - 96;

                    // 基于鼠标位置和比例, 计算最新的偏移
                    restore();
                    repaint();  // 重新绘制画布
                }
            }
        });

出现问题的博客代码 : 【Java AWT 图形界面编程】使用小键盘按键缩放 Canvas 画布中绘制的背景图像 ( 键盘按键监听 + 绘制超大图像 + 鼠标拖动 + 鼠标滚轮缩放 + 以当前鼠标指针位置为缩放中心 示例 ) ;

二、解决方案


鼠标事件 , 可以添加到具体的 Component 组件上 ,

但是凡是涉及到 键盘 的事件 , 必须添加到顶级组件 , 也就是窗口组件上 , 如 : Frame / JFrame 组件上 , 才能生效 ;

否则就会出现上述情况 , 为 组件设置的 KeyAdapter / KeyListener 监听 , 根本不回调相应的回调函数 ;

将 KeyAdapter / KeyListener 监听器 设置到 JFrame 窗口上 , 此时在该应用中按下对应的按键 , 就会回调 keyPressed 函数 ;

代码语言:javascript
复制
    public void initKeyListener(JFrame frame) {
        frame.addKeyListener(new KeyAdapter() {
            @Override
            public void keyPressed(KeyEvent e) {
                if (e.getKeyCode() >= KeyEvent.VK_NUMPAD1 && e.getKeyCode() <= KeyEvent.VK_NUMPAD9) {
                    // 根据按键计算出缩放比例
                    scale = e.getKeyCode() - 96;

                    // 基于鼠标位置和比例, 计算最新的偏移
                    restore();
                    repaint();  // 重新绘制画布
                }
            }
        });
    }

调用 JFrame#addKeyListener(new KeyAdapter(){}) 设置的键盘按键监听 , 即可实现想要的功能 ;

代码语言:javascript
复制
JFrame.addKeyListener(new KeyAdapter() {
 @Override
 public void keyPressed(KeyEvent e) { }
 });
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2023-05-08,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、报错信息
  • 二、解决方案
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档