Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_jdk
提交
05aca2da
D
dragonwell8_jdk
项目概览
openanolis
/
dragonwell8_jdk
通知
4
Star
2
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
D
dragonwell8_jdk
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
05aca2da
编写于
8月 23, 2019
作者:
D
dmarkov
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
8225505: ctrl-F1 does not show the tooltip of a menu item (JMenuItems)
Reviewed-by: psadhukhan, serb
上级
6e17f9b1
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
188 addition
and
5 deletion
+188
-5
src/share/classes/javax/swing/ToolTipManager.java
src/share/classes/javax/swing/ToolTipManager.java
+44
-5
test/javax/swing/ToolTipManager/JMenuItemToolTipKeyBindingsTest/JMenuItemToolTipKeyBindingsTest.java
...olTipKeyBindingsTest/JMenuItemToolTipKeyBindingsTest.java
+144
-0
未找到文件。
src/share/classes/javax/swing/ToolTipManager.java
浏览文件 @
05aca2da
/*
* Copyright (c) 1997, 201
3
, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 1997, 201
9
, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
...
...
@@ -28,6 +28,8 @@ package javax.swing;
import
java.awt.event.*
;
import
java.awt.*
;
import
javax.swing.event.MenuKeyEvent
;
import
javax.swing.event.MenuKeyListener
;
/**
* Manages all the <code>ToolTips</code> in the system.
...
...
@@ -409,8 +411,14 @@ public class ToolTipManager extends MouseAdapter implements MouseMotionListener
component
.
addMouseListener
(
this
);
component
.
removeMouseMotionListener
(
moveBeforeEnterListener
);
component
.
addMouseMotionListener
(
moveBeforeEnterListener
);
component
.
removeKeyListener
(
accessibilityKeyListener
);
component
.
addKeyListener
(
accessibilityKeyListener
);
// use MenuKeyListener for menu items/elements
if
(
component
instanceof
JMenuItem
)
{
((
JMenuItem
)
component
).
removeMenuKeyListener
((
MenuKeyListener
)
accessibilityKeyListener
);
((
JMenuItem
)
component
).
addMenuKeyListener
((
MenuKeyListener
)
accessibilityKeyListener
);
}
else
{
component
.
removeKeyListener
(
accessibilityKeyListener
);
component
.
addKeyListener
(
accessibilityKeyListener
);
}
}
/**
...
...
@@ -421,7 +429,11 @@ public class ToolTipManager extends MouseAdapter implements MouseMotionListener
public
void
unregisterComponent
(
JComponent
component
)
{
component
.
removeMouseListener
(
this
);
component
.
removeMouseMotionListener
(
moveBeforeEnterListener
);
component
.
removeKeyListener
(
accessibilityKeyListener
);
if
(
component
instanceof
JMenuItem
)
{
((
JMenuItem
)
component
).
removeMenuKeyListener
((
MenuKeyListener
)
accessibilityKeyListener
);
}
else
{
component
.
removeKeyListener
(
accessibilityKeyListener
);
}
}
// implements java.awt.event.MouseListener
...
...
@@ -841,7 +853,7 @@ public class ToolTipManager extends MouseAdapter implements MouseMotionListener
* Post Tip: Ctrl+F1
* Unpost Tip: Esc and Ctrl+F1
*/
private
class
AccessibilityKeyListener
extends
KeyAdapter
{
private
class
AccessibilityKeyListener
extends
KeyAdapter
implements
MenuKeyListener
{
public
void
keyPressed
(
KeyEvent
e
)
{
if
(!
e
.
isConsumed
())
{
JComponent
source
=
(
JComponent
)
e
.
getComponent
();
...
...
@@ -858,5 +870,32 @@ public class ToolTipManager extends MouseAdapter implements MouseMotionListener
}
}
}
@Override
public
void
menuKeyTyped
(
MenuKeyEvent
e
)
{}
@Override
public
void
menuKeyPressed
(
MenuKeyEvent
e
)
{
if
(
postTip
.
equals
(
KeyStroke
.
getKeyStrokeForEvent
(
e
)))
{
// get element for the event
MenuElement
path
[]
=
e
.
getPath
();
MenuElement
element
=
path
[
path
.
length
-
1
];
// retrieve currently highlighted element
MenuSelectionManager
msm
=
e
.
getMenuSelectionManager
();
MenuElement
selectedPath
[]
=
msm
.
getSelectedPath
();
MenuElement
selectedElement
=
selectedPath
[
selectedPath
.
length
-
1
];
if
(
element
.
equals
(
selectedElement
))
{
// show/hide tooltip message
JComponent
source
=
(
JComponent
)
element
.
getComponent
();
ToolTipManager
.
this
.
show
(
source
);
e
.
consume
();
}
}
}
@Override
public
void
menuKeyReleased
(
MenuKeyEvent
e
)
{}
}
}
test/javax/swing/ToolTipManager/JMenuItemToolTipKeyBindingsTest/JMenuItemToolTipKeyBindingsTest.java
0 → 100644
浏览文件 @
05aca2da
/*
* Copyright (c) 2019, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
/* @test
* @key headful
* @bug 8225505
* @summary CTRL + 1 does not show tooltip message for menu items
* @run main/manual JMenuItemToolTipKeyBindingsTest
*/
import
javax.swing.JFrame
;
import
javax.swing.JMenu
;
import
javax.swing.JMenuBar
;
import
javax.swing.JMenuItem
;
import
javax.swing.SwingUtilities
;
import
java.awt.Button
;
import
java.awt.Dialog
;
import
java.awt.Panel
;
import
java.awt.TextArea
;
import
java.awt.event.ActionEvent
;
import
java.awt.event.ActionListener
;
import
java.util.concurrent.atomic.AtomicBoolean
;
public
class
JMenuItemToolTipKeyBindingsTest
{
private
static
final
long
TIMEOUT
=
5
*
60
*
1000
;
private
static
final
AtomicBoolean
testCompleted
=
new
AtomicBoolean
(
false
);
private
static
volatile
boolean
testResult
=
false
;
private
static
Dialog
controlDialog
;
private
static
JFrame
testFrame
;
private
static
final
String
instructions
=
"Verify that \"CTRL\" + \"F1\" key sequence shows/hides tool tip message"
+
"\nfor menu items.\n"
+
"\n1. Open pop-up menu \"Menu\", (i.e. press \"F10\")."
+
"\n2. Navigate to some menu element using keyboard."
+
"\n3. Press \"CTRL\" + \"F1\" once menu item is selected."
+
"\nIf tooltip message is displayed for the item then press \"Pass\","
+
"\n otherwise press \"Fail\"."
;
public
static
void
main
(
String
[]
args
)
throws
Exception
{
try
{
SwingUtilities
.
invokeAndWait
(()
->
createAndShowGUI
());
waitForCompleting
();
if
(!
testResult
)
{
throw
new
RuntimeException
(
"Test FAILED!"
);
}
}
finally
{
if
(
controlDialog
!=
null
)
{
controlDialog
.
dispose
();
}
if
(
testFrame
!=
null
)
{
testFrame
.
dispose
();
}
}
}
private
static
void
createAndShowGUI
()
{
controlDialog
=
new
Dialog
((
JFrame
)
null
,
"JMenuItemToolTipKeyBindingsTest"
);
TextArea
messageArea
=
new
TextArea
(
instructions
,
15
,
80
,
TextArea
.
SCROLLBARS_BOTH
);
controlDialog
.
add
(
"North"
,
messageArea
);
Button
passedButton
=
new
Button
(
"Pass"
);
passedButton
.
addActionListener
(
new
ActionListener
()
{
@Override
public
void
actionPerformed
(
ActionEvent
e
)
{
testResult
=
true
;
completeTest
();
}
});
Button
failedButton
=
new
Button
(
"Fail"
);
failedButton
.
addActionListener
(
new
ActionListener
()
{
@Override
public
void
actionPerformed
(
ActionEvent
e
)
{
testResult
=
false
;
completeTest
();
}
});
Panel
buttonPanel
=
new
Panel
();
buttonPanel
.
add
(
"West"
,
passedButton
);
buttonPanel
.
add
(
"East"
,
failedButton
);
controlDialog
.
add
(
"South"
,
buttonPanel
);
controlDialog
.
setBounds
(
250
,
0
,
500
,
500
);
controlDialog
.
setVisible
(
true
);
testFrame
=
new
JFrame
(
"JMenuItemToolTipKeyBindingsTest"
);
testFrame
.
setSize
(
200
,
200
);
JMenuBar
jMenuBar
=
new
JMenuBar
();
JMenu
jMenu
=
new
JMenu
(
"Menu"
);
for
(
int
i
=
0
;
i
<
3
;
i
++)
{
JMenuItem
jMenuItem
=
new
JMenuItem
(
"Item "
+
i
);
jMenuItem
.
setToolTipText
(
"Tooltip "
+
i
);
jMenu
.
add
(
jMenuItem
);
}
jMenuBar
.
add
(
jMenu
);
testFrame
.
setJMenuBar
(
jMenuBar
);
testFrame
.
setVisible
(
true
);
}
private
static
void
completeTest
()
{
testCompleted
.
set
(
true
);
synchronized
(
testCompleted
)
{
testCompleted
.
notifyAll
();
}
}
private
static
void
waitForCompleting
()
throws
Exception
{
synchronized
(
testCompleted
)
{
long
startTime
=
System
.
currentTimeMillis
();
while
(!
testCompleted
.
get
())
{
testCompleted
.
wait
(
TIMEOUT
);
if
(
System
.
currentTimeMillis
()
-
startTime
>=
TIMEOUT
)
{
break
;
}
}
}
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录