- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
问候 Swing 专家,这是一个很好的(我希望)问题。
以下是我看到的任务要求和可能的解决方案。我希望有过如此核心经验的人分享一些对此的想法。
这不需要编码或类似的东西,我只需要一般建议,关于我需要使用的事实,哪种方法更可靠驻留在 sun.swing 和/或 javax.swing.plaf 包中的私有(private) 符号。
任务是修改/更改 JFileChooser 行为(实际上只是一点点)。
当用户在文件名 JTextField 中按下回车键,并且该字段包含指向目录的路径时,不要“选择”该目录,而是切换到该目录。是的,对话框被配置为接受目录,但我们只需要接受点击“打开”按钮,以及(可能)在文件列表中双击。
防止用户通过在文件名文本字段中按回车键选择包含超过 1GB 数据的目录/文件
这里有几个通用的解决方案选项:
一个。监听 JFileChooser 提供的基于属性的更改(AFAICS 是事后触发的,不会提供我们在这里需要的控制程度)。
修补 javax.swing.plaf.basic.BasicFileChooserUI(通过反射,破坏私有(private)级封装)并更改对
的引用private Action approveSelectionAction = new ApproveSelectionAction();
以便我们的自定义操作对 1 和 2 进行额外检查。此方法与 plaf 包链接,如果此 UI 类下的某个类以某种方式覆盖此操作,则可能会失败。
遍历 JFileChooser 组件层次结构,找到 JTextField(它显然应该在组件树中只出现一次),用我们的自定义检查装饰卡在该 JTextField 上的所有 Action 监听器。我的调试 session 显示此 JTextField 是 JTextField 的某个匿名子类,位于 sun.swing.FilePane 中。这种方法似乎对 OO 更友好,但对于某些操作系统,此文本字段可能不存在,或者其他一些 JTextField 也存在于层次结构中。
好吧,公共(public) JFileChooser API 似乎不足以实现该行为,而其他两个选项要么很神奇,要么不可移植(长期),甚至两者兼而有之。
那么,问题是:您会选择哪种方法,为什么?
最佳答案
关于option2,不需要使用反射来自定义accept Action。您可以只覆盖 approveSelection() 方法。像这样的东西:
JFileChooser chooser = new JFileChooser( new File(".") )
{
public void approveSelection()
{
if (getSelectedFile().exists())
{
System.out.println("duplicate");
return;
}
else
super.approveSelection();
}
};
关于java - 改变 JFileChooser 行为 : preventing "choose" on enter in file path JTextField,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4232275/
Wordpress 有一个名为 Akismet 的垃圾邮件过滤插件,它似乎能够将任何文本块分类为垃圾邮件。唯一需要注意的是,您需要浏览他们的界面,而且他们的数据库/算法不是开源的,也不是现成的。 还有
我想为 hmailserver 上的每个邮箱设置每天发送的最大电子邮件数,以避免垃圾邮件。我正在寻找在 hmailserver 管理和 COM API 中执行此操作的问题。 最佳答案 我相信 hMai
我已经在我的博客上放了验证码,我仍然收到垃圾邮件发送者,是否有脚本可以让他们这样做还是他们手工做? 最佳答案 这取决于您使用的验证码类型。一些用于生成 CAPTCHA 挑战的方法很容易通过光学字符识别
除了验证码之外,还有其他方法可以用于 pastie.org 或 p.ramaze.net 等网络应用程序吗?对于我的口味,CAPTCHA 需要太长时间才能制作小糊状物。 最佳答案 你可以试试 Hone
我有一个页面,登录用户可以在其中发表评论。我想阻止用户同时发表评论以防止垃圾邮件。为此,我希望评论之间有 30 秒的间隔(我应该将时间存储在 session 中吗?) .这个方法好吗? 最佳答案 se
我使用 Angular 5.2 和 Auth0 进行身份验证。登录由 Auth0 在托管登录页面上完成。该页面重定向到我的 Angular 应用程序中的回调页面 myapp.com/login-cal
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,因为
是否可以使用 angularjs 拦截器来阻止请求? $provide.factory('myHttpInterceptor', function($q, someService) { retur
前几天发现了这个网站。您点击一个 DIV(按钮),它就会增加您的分数。 http://clickingbad.nullism.com/ 我自己想,我只需注入(inject) jQuery 并编写一个循
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,
通过使用 jQuery 插件验证,我试图验证我的表单。当验证通过时,我希望 JavaScript 使用表单中的值触发,然后停止。浏览新/同一网站时无需实际提交表单。 这可以通过 jquery 验证实现
我有一个表单 Form1,它带有一个创建附加表单的按钮。但是,我只想一次创建 1 个附加表单。以下是我的代码实现。我尝试使用 Focus 属性,但它不起作用。 private void addLoca
我制作了自己的组件,它与一些 Unity 内置组件冲突(例如 Rigidbody 与 Rigidbody2D 冲突)。所以我需要确保这些组件不会一起存在于同一个游戏对象中。有办法吗?自己的组件是什么时
我尝试为 MySQL 数据库编写第一个触发器。它应该在当前时间和“容量”中的给定时间戳的上下文中防止在“course_student”上插入(以及稍后更新) ,但我仍然遇到语法错误。 DELIMITE
我的 PHP 脚本中有以下查询: SELECT SUM(score) + 1200 AS rating FROM users_ratings WHERE user_fk = ? 问题在于,如果用户在表
我有时会忘记从函数中返回结果: def f(*args): # do stuff result = # an expression # oops forgot to return resu
我试图搜索此内容,但没有找到任何答案。让我们看看这个: class Foo { Foo(); Bar a; // 'a', the object, gets created (even
我意识到恶意用户可以在提交表单之前在浏览器中修改表单的 html。例如,切换两个相同类型的输入字段的名称。 我正在创建一个很大程度上依赖于数据库中每个条目之间关系的网站。 如果发生这种情况,可能会危及
我有一个类,在类构造函数中我想检查已传递的几个参数,如果任何参数未通过检查,我想阻止该类初始化。我该怎么做? Class MyClass { MyClass(int no); }; MyClass:
我在 redis 中有一个散列,其中一个字段的值为字符串化数组,每当用户注册一个事件时, 从redis中获取这个字符串化数组 后台解析,将用户的用户名添加到数组中 将数组字符串化并存储回哈希 如果两个
我是一名优秀的程序员,十分优秀!