- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我想知道内部类的标准做法(在 Java 中,但我想它适用于所有 OO 语言)。所以我有一个 JFrame 子类 ControllerWindow
,它包含一个 JPanel 子类 MapPanel
,我在上面绘制(因此它需要覆盖 paintComponent 方法)并且需要实现鼠标监听器。我目前有效的解决方案是在一个单独的类中使用 MapPanel
实现 MouseListener 但是当我把这个展示给前几天管理我的类(class)的人时他似乎认为(我们有一点语言障碍) 这应该在 ControllerWindow
的内部类中,或者至少 MouseListener 应该是内部类。
所以我的问题是这里的标准解决方案是什么,将 MouseListener 放在内部类中,将 JPanel 放在不同的内部类中,还是仍然放在单独的类中?在一个内部类中实现 MouseListener 的 JPanel?为什么?
对我来说最重要的是它有效,但如果可能的话,我想了解并理解这些东西背后的标准做法。
编辑:下面当前代码的非常简化的版本。
class ControllerWindow extends JFrame{
...
MapPanel drawPanel = new MapPanel();
...
}
和一个单独的类:
class MapPanel extends JPanel implements MouseListener{
...
public void paintComponent(Graphics g){
...//fillRects etc.
}
//MouseListener methods
public void mouseReleased(MouseEvent e){
requestFocus();
...
repaint()
...
}
public void mousePressed(MouseEvent e){}
public void mouseEntered(MouseEvent e){}
public void mouseExited(MouseEvent e){}
public void mouseClicked(MouseEvent e){}
}
在这种情况下是否可以将两个类放在同一个文件中?我不打算将 MapPanel
用于 ControllerWindow
以外的任何东西。
最佳答案
通常使用匿名内部类作为事件监听器,因为代码通常非常简单(因此单独的类可能有点矫枉过正)并且使处理程序代码“靠近”注册监听器的代码可以提高人们的可读性试图理解您的代码,因为与事件相关的所有代码都在一个地方。
编辑:对于只实现一个监听器方法的类来说尤其如此。对于像 MouseListener 这样的多方法接口(interface)可能不太正确,因为实现完整接口(interface)的类会更加冗长。
关于java - 为 GUI 使用内部类的标准?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1894181/
我最近在读 CSAPP。在 10.9 节中,它说标准 I/O 不应该与 socket 一起使用,原因如下: (1) The restrictions of standard I/O Restricti
似乎是一个足够标准的问题,可以保证解决方案中的标准设计: 假设我想在文件中写入 x+2(或更少)个字符串。 x 字符串构成一个部分的内容,这两个字符串构成该部分的页眉和页脚。要注意的是,如果内容中没有
代码版本管理 在项目中,代码的版本管理非常重要。每个需求版本的代码开发在版本控制里都应该经过以下几个步骤。 在master分支中拉取该需求版本的两个分支,一个feature分支,
我有以下sql查询,我需要获取相应的hibernate条件查询 SELECT COUNT(DISTINCT employee_id) FROM erp_hr_payment WHERE payment
所以我正在编写一些代码,并且最近遇到了实现一些 mixin 的需要。我的问题是,设计混音的正确方法是什么?我将使用下面的示例代码来说明我的确切查询。 class Projectile(Movable,
我的环境变量包含如下双引号: $echo $CONNECT_SASL_JAAS_CONFIG org.apache.kafka.common.security.plain.PlainLoginModu
示例: /** * This function will determine whether or not one string starts with another string. * @pa
有没有办法在 Grails 中做一个不区分大小写的 in 子句? 我有这个: "in"("name", filters.tags) 我希望它忽略大小写。我想我可以做一个 sqlRestriction
我搜索了很长时间,以查找将哪些boost库添加到std库中,但是我只找到了一个新库的完整列表(如此处:http://open-std.org/jtc1/sc22/wg21/docs/library_t
我已经通过使用这个肮脏的黑客解决了我的问题: ' Filter managerial functions ActiveSheet.Range("$A$1:$BW$2211").Auto
因此,我很难理解我需要遵循的标准,以便我的 Java 程序能够嵌入 HTML。我是否只需将我的主类扩展到 Applet 类,或者我还需要做更多的事情吗?另外,在我见过的每个 Applet 示例中,它都
我对在 Hibernate 中使用限制有疑问。 我必须创建条件,设置一些限制,然后选择日期字段最大值的记录: Criteria query = session.createCriteria(Stora
我有标准: ICriteria criteria = Session.CreateCriteria() .SetFetchMode("Entity1", FetchMo
我很难编写条件来选择所有子集合或孙集合为空的实体。我可以将这些作为单独的条件来执行,但我无法将其组合成一个条件。 类结构: public class Component { p
@Entity class A { @ManyToMany private List list; ... } @Entity class B { ... } 我想使用条件(不是 sql 查询)从 A
我的数据库中有以下表结构: Table A: Table B: Table C: _______________
请帮助我: 我有下一张 table : 单位 ID 姓名 用户 ID 姓名 利率 单位 ID 用户 ID 我不明白如何从 SQL 创建正确的条件结构: 代码: SELECT * FROM Unit W
我正在构建一个包含项目的网站,每个项目都有一个页面,例如: website.com/book/123 website.com/film/456 website.com/game/789 每个项目都可以
我需要使用两个属性的组合来过滤结果列表。一个简单的 SQL 语句如下所示: SELECT TOP 10 * FROM Person WHERE FirstName + ' ' + LastName L
我有一个“ super 实体”SuperEntity 和三个扩展父类(super class)的实体 ChildEntity1、...、ChildEntity3。 搜索数据库中的所有实体很容易,即我们
我是一名优秀的程序员,十分优秀!