|
|
|
@ -5,8 +5,14 @@
|
|
|
|
|
*/ |
|
|
|
|
package com.fr.design.gui.itree.checkboxtree; |
|
|
|
|
|
|
|
|
|
import java.awt.Component; |
|
|
|
|
import java.awt.Rectangle; |
|
|
|
|
import com.fr.design.gui.icheckbox.UICheckBox; |
|
|
|
|
|
|
|
|
|
import javax.swing.*; |
|
|
|
|
import javax.swing.event.TreeSelectionEvent; |
|
|
|
|
import javax.swing.event.TreeSelectionListener; |
|
|
|
|
import javax.swing.text.Position; |
|
|
|
|
import javax.swing.tree.*; |
|
|
|
|
import java.awt.*; |
|
|
|
|
import java.awt.event.KeyEvent; |
|
|
|
|
import java.awt.event.KeyListener; |
|
|
|
|
import java.awt.event.MouseEvent; |
|
|
|
@ -16,19 +22,6 @@ import java.beans.PropertyChangeListener;
|
|
|
|
|
import java.util.Hashtable; |
|
|
|
|
import java.util.Vector; |
|
|
|
|
|
|
|
|
|
import javax.swing.*; |
|
|
|
|
import javax.swing.event.TreeSelectionEvent; |
|
|
|
|
import javax.swing.event.TreeSelectionListener; |
|
|
|
|
import javax.swing.text.DefaultEditorKit; |
|
|
|
|
import javax.swing.text.Position; |
|
|
|
|
import javax.swing.tree.DefaultTreeCellRenderer; |
|
|
|
|
import javax.swing.tree.TreeCellRenderer; |
|
|
|
|
import javax.swing.tree.TreeModel; |
|
|
|
|
import javax.swing.tree.TreeNode; |
|
|
|
|
import javax.swing.tree.TreePath; |
|
|
|
|
|
|
|
|
|
import com.fr.design.gui.icheckbox.UICheckBox; |
|
|
|
|
|
|
|
|
|
import static com.fr.design.gui.syntax.ui.rtextarea.RTADefaultInputMap.DEFAULT_MODIFIER; |
|
|
|
|
|
|
|
|
|
/** |
|
|
|
@ -39,11 +32,11 @@ import static com.fr.design.gui.syntax.ui.rtextarea.RTADefaultInputMap.DEFAULT_M
|
|
|
|
|
* select one or several tree nodes and press SPACE key to toggle the |
|
|
|
|
* check box selection for all selected tree nodes. |
|
|
|
|
* <p/> |
|
|
|
|
* In order to retrieve which tree paths are selected, you need to call |
|
|
|
|
* In order to retrieve which tree paths are selected, you need to call |
|
|
|
|
* {@link #getCheckBoxTreeSelectionModel()}. |
|
|
|
|
* It will return the selection model that keeps track of which tree |
|
|
|
|
* It will return the selection model that keeps track of which tree |
|
|
|
|
* paths have been checked. For example |
|
|
|
|
* {@link CheckBoxTreeSelectionModel#getSelectionPaths()} |
|
|
|
|
* {@link CheckBoxTreeSelectionModel#getSelectionPaths()} |
|
|
|
|
* will give the list of paths which have |
|
|
|
|
* been checked. |
|
|
|
|
*/ |
|
|
|
@ -90,8 +83,7 @@ public class CheckBoxTree extends JTree {
|
|
|
|
|
public CheckBoxTree(TreeModel newModel) { |
|
|
|
|
super(newModel); |
|
|
|
|
InputMap inputMap = this.getInputMap(); |
|
|
|
|
inputMap.put(KeyStroke.getKeyStroke(KeyEvent.VK_A, DEFAULT_MODIFIER), |
|
|
|
|
"selectAll"); |
|
|
|
|
inputMap.getParent().put(KeyStroke.getKeyStroke(KeyEvent.VK_A, DEFAULT_MODIFIER), "selectAll"); |
|
|
|
|
init(); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
@ -116,7 +108,7 @@ public class CheckBoxTree extends JTree {
|
|
|
|
|
addPropertyChangeListener(JTree.SELECTION_MODEL_PROPERTY, _modelChangeListener); |
|
|
|
|
updateRowMapper(); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/** |
|
|
|
|
* Inserts the mouse listener at the particular index in the listeners' chain. |
|
|
|
|
* |
|
|
|
@ -127,7 +119,7 @@ public class CheckBoxTree extends JTree {
|
|
|
|
|
private void insertMouseListener(Component component, MouseListener l, int index) { |
|
|
|
|
MouseListener[] listeners = component.getMouseListeners(); |
|
|
|
|
for (int i = 0, length = listeners.length; i < length; i++) { |
|
|
|
|
component.removeMouseListener(listeners[i]); |
|
|
|
|
component.removeMouseListener(listeners[i]); |
|
|
|
|
} |
|
|
|
|
// for (MouseListener listener : listeners) {
|
|
|
|
|
// component.removeMouseListener(listener);
|
|
|
|
@ -173,7 +165,7 @@ public class CheckBoxTree extends JTree {
|
|
|
|
|
* Gets the cell renderer with check box. |
|
|
|
|
* |
|
|
|
|
* @return CheckBoxTree's own cell renderer which has the check box. The actual cell renderer |
|
|
|
|
* you set by setCellRenderer() can be accessed by using {@link #getActualCellRenderer()}. |
|
|
|
|
* you set by setCellRenderer() can be accessed by using {@link #getActualCellRenderer()}. |
|
|
|
|
*/ |
|
|
|
|
public TreeCellRenderer getCellRenderer() { |
|
|
|
|
TreeCellRenderer cellRenderer = super.getCellRenderer(); |
|
|
|
@ -182,8 +174,7 @@ public class CheckBoxTree extends JTree {
|
|
|
|
|
} |
|
|
|
|
if (_treeCellRenderer == null) { |
|
|
|
|
_treeCellRenderer = createCellRenderer(cellRenderer); |
|
|
|
|
} |
|
|
|
|
else { |
|
|
|
|
} else { |
|
|
|
|
_treeCellRenderer.setActualTreeRenderer(cellRenderer); |
|
|
|
|
} |
|
|
|
|
return _treeCellRenderer; |
|
|
|
@ -199,8 +190,7 @@ public class CheckBoxTree extends JTree {
|
|
|
|
|
public TreeCellRenderer getActualCellRenderer() { |
|
|
|
|
if (_treeCellRenderer != null) { |
|
|
|
|
return _treeCellRenderer.getActualTreeRenderer(); |
|
|
|
|
} |
|
|
|
|
else { |
|
|
|
|
} else { |
|
|
|
|
return super.getCellRenderer(); |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
@ -255,8 +245,7 @@ public class CheckBoxTree extends JTree {
|
|
|
|
|
|
|
|
|
|
if (clicksInCheckBox(e, path)) { |
|
|
|
|
return path; |
|
|
|
|
} |
|
|
|
|
else { |
|
|
|
|
} else { |
|
|
|
|
return null; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
@ -264,13 +253,11 @@ public class CheckBoxTree extends JTree {
|
|
|
|
|
protected boolean clicksInCheckBox(MouseEvent e, TreePath path) { |
|
|
|
|
if (!_tree.isCheckBoxVisible(path)) { |
|
|
|
|
return false; |
|
|
|
|
} |
|
|
|
|
else { |
|
|
|
|
} else { |
|
|
|
|
Rectangle bounds = _tree.getPathBounds(path); |
|
|
|
|
if (_tree.getComponentOrientation().isLeftToRight()) { |
|
|
|
|
return e.getX() < bounds.x + _hotspot; |
|
|
|
|
} |
|
|
|
|
else { |
|
|
|
|
} else { |
|
|
|
|
return e.getX() > bounds.x + bounds.width - _hotspot; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
@ -354,8 +341,7 @@ public class CheckBoxTree extends JTree {
|
|
|
|
|
selectionModel.removeSelectionPath(path); |
|
|
|
|
else |
|
|
|
|
selectionModel.addSelectionPath(path); |
|
|
|
|
} |
|
|
|
|
finally { |
|
|
|
|
} finally { |
|
|
|
|
if (!selectionModel.isSingleEventMode()) { |
|
|
|
|
selectionModel.setBatchMode(false); |
|
|
|
|
} |
|
|
|
@ -370,8 +356,8 @@ public class CheckBoxTree extends JTree {
|
|
|
|
|
return; |
|
|
|
|
} |
|
|
|
|
for (int i = 0, length = treePaths.length; i < length; i++) { |
|
|
|
|
TreePath tmpTreePath = treePaths[i]; |
|
|
|
|
toggleSelection(tmpTreePath); |
|
|
|
|
TreePath tmpTreePath = treePaths[i]; |
|
|
|
|
toggleSelection(tmpTreePath); |
|
|
|
|
} |
|
|
|
|
// for (TreePath treePath : treePaths) {
|
|
|
|
|
// toggleSelection(treePath);
|
|
|
|
|