提交 154ca48c 编写于 作者: D dmarkov

8023474: First mousepress doesn't start editing in JTree

Reviewed-by: alexp, anthony
上级 fe1cbe3c
...@@ -972,6 +972,10 @@ public abstract class Component implements ImageObserver, MenuContainer, ...@@ -972,6 +972,10 @@ public abstract class Component implements ImageObserver, MenuContainer,
public AccessControlContext getAccessControlContext(Component comp) { public AccessControlContext getAccessControlContext(Component comp) {
return comp.getAccessControlContext(); return comp.getAccessControlContext();
} }
public void revalidateSynchronously(Component comp) {
comp.revalidateSynchronously();
}
}); });
} }
...@@ -2977,6 +2981,13 @@ public abstract class Component implements ImageObserver, MenuContainer, ...@@ -2977,6 +2981,13 @@ public abstract class Component implements ImageObserver, MenuContainer,
* @since 1.7 * @since 1.7
*/ */
public void revalidate() { public void revalidate() {
revalidateSynchronously();
}
/**
* Revalidates the component synchronously.
*/
final void revalidateSynchronously() {
synchronized (getTreeLock()) { synchronized (getTreeLock()) {
invalidate(); invalidate();
......
/* /*
* Copyright (c) 1997, 2011, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
...@@ -42,6 +42,7 @@ import javax.swing.plaf.TreeUI; ...@@ -42,6 +42,7 @@ import javax.swing.plaf.TreeUI;
import javax.swing.tree.*; import javax.swing.tree.*;
import javax.swing.text.Position; import javax.swing.text.Position;
import javax.swing.plaf.basic.DragRecognitionSupport.BeforeDrag; import javax.swing.plaf.basic.DragRecognitionSupport.BeforeDrag;
import sun.awt.AWTAccessor;
import sun.swing.SwingUtilities2; import sun.swing.SwingUtilities2;
import sun.swing.DefaultLookup; import sun.swing.DefaultLookup;
...@@ -2165,11 +2166,7 @@ public class BasicTreeUI extends TreeUI ...@@ -2165,11 +2166,7 @@ public class BasicTreeUI extends TreeUI
nodeBounds.width, nodeBounds.width,
nodeBounds.height); nodeBounds.height);
editingPath = path; editingPath = path;
if (editingComponent instanceof JComponent) { AWTAccessor.getComponentAccessor().revalidateSynchronously(editingComponent);
((JComponent)editingComponent).revalidate();
} else {
editingComponent.validate();
}
editingComponent.repaint(); editingComponent.repaint();
if(cellEditor.shouldSelectCell(event)) { if(cellEditor.shouldSelectCell(event)) {
stopEditingInCompleteEditing = false; stopEditingInCompleteEditing = false;
......
/* /*
* Copyright (c) 2008, 2012, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2008, 2013, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
...@@ -236,6 +236,11 @@ public final class AWTAccessor { ...@@ -236,6 +236,11 @@ public final class AWTAccessor {
*/ */
AccessControlContext getAccessControlContext(Component comp); AccessControlContext getAccessControlContext(Component comp);
/**
* Revalidates the component synchronously.
*/
void revalidateSynchronously(Component comp);
} }
/* /*
......
/*
* Copyright (c) 2013, 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
* @bug 8023474
* @summary Tests that the first mouse press starts editing in JTree
* @author Dmitry Markov
* @run main bug8023474
*/
import sun.awt.SunToolkit;
import javax.swing.*;
import javax.swing.event.CellEditorListener;
import javax.swing.tree.DefaultMutableTreeNode;
import javax.swing.tree.DefaultTreeModel;
import javax.swing.tree.TreeCellEditor;
import javax.swing.tree.TreeCellRenderer;
import java.awt.*;
import java.awt.event.InputEvent;
import java.util.EventObject;
public class bug8023474 {
private static JTree tree;
public static void main(String[] args) throws Exception {
SunToolkit toolkit = (SunToolkit) Toolkit.getDefaultToolkit();
Robot robot = new Robot();
robot.setAutoDelay(50);
SwingUtilities.invokeAndWait(new Runnable() {
public void run() {
createAndShowGUI();
}
});
toolkit.realSync();
Point point = getRowPointToClick(1);
robot.mouseMove(point.x, point.y);
robot.mousePress(InputEvent.BUTTON1_MASK);
robot.mouseRelease(InputEvent.BUTTON1_MASK);
toolkit.realSync();
Boolean result = (Boolean)tree.getCellEditor().getCellEditorValue();
if (!result) {
throw new RuntimeException("Test Failed!");
}
}
private static void createAndShowGUI() {
try {
UIManager.setLookAndFeel("javax.swing.plaf.metal.MetalLookAndFeel");
} catch (Exception e) {
throw new RuntimeException(e);
}
DefaultMutableTreeNode root = new DefaultMutableTreeNode("root");
DefaultMutableTreeNode item = new DefaultMutableTreeNode("item");
DefaultMutableTreeNode subItem = new DefaultMutableTreeNode("subItem");
root.add(item);
item.add(subItem);
DefaultTreeModel model = new DefaultTreeModel(root);
tree = new JTree(model);
tree.setCellEditor(new Editor());
tree.setEditable(true);
tree.setRowHeight(30);
tree.setCellRenderer(new CheckboxCellRenderer());
JFrame frame = new JFrame("bug8023474");
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
frame.add(new JScrollPane(tree));
frame.setSize(400, 300);
frame.setVisible(true);
}
private static Point getRowPointToClick(final int row) throws Exception {
final Point[] result = new Point[1];
SwingUtilities.invokeAndWait(new Runnable() {
public void run() {
Rectangle rect = tree.getRowBounds(row);
Point point = new Point(rect.x + 10, rect.y + rect.height / 2);
SwingUtilities.convertPointToScreen(point, tree);
result[0] = point;
}
});
return result[0];
}
private static class Editor extends JPanel implements TreeCellEditor {
private JCheckBox checkbox;
public Editor() {
setOpaque(false);
checkbox = new JCheckBox();
add(checkbox);
}
public Component getTreeCellEditorComponent(JTree tree, Object value, boolean isSelected,
boolean expanded, boolean leaf, int row) {
checkbox.setText(value.toString());
checkbox.setSelected(false);
return this;
}
public Object getCellEditorValue() {
return checkbox.isSelected();
}
public boolean isCellEditable(EventObject anEvent) {
return true;
}
public boolean shouldSelectCell(EventObject anEvent) {
return true;
}
public boolean stopCellEditing() {
return true;
}
public void cancelCellEditing() {
}
public void addCellEditorListener(CellEditorListener l) {
}
public void removeCellEditorListener(CellEditorListener l) {
}
}
private static class CheckboxCellRenderer extends JPanel implements TreeCellRenderer {
private JCheckBox checkbox;
public CheckboxCellRenderer() {
setOpaque(false);
checkbox = new JCheckBox();
add(checkbox);
}
public Component getTreeCellRendererComponent(JTree tree, Object value, boolean selected, boolean expanded,
boolean leaf, int row, boolean hasFocus) {
checkbox.setText(value.toString());
checkbox.setSelected(false);
return this;
}
}
}
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册