Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 179063
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 11, 20262026-05-11T14:20:26+00:00 2026-05-11T14:20:26+00:00

I have a JTree that implements multi selection logic. This works great when I

  • 0

I have a JTree that implements multi selection logic.

This works great when I do all my selections using the mouse + Ctrl key pressed. If user makes selections with the Ctrl key unpressed it breaks my logic.

I can’t really see why it breaks but I think that a possible solution is to always indicate the TreeSelectionModel that the selection has been make with the Ctrl key pressed.

What would you suggest?

  • 1 1 Answer
  • 3 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. 2026-05-11T14:20:26+00:00Added an answer on May 11, 2026 at 2:20 pm

    I think I’ve found the solution

    You will need to extend JTree and DefaultTreeSelectionModel.

    JTree relevant methods:

    ///////////////////////////////////////////////////// ///////////////////////////////////////////////////// /// Implement selection using 'adding' only logic. // ///////////////////////////////////////////////////// /////////////////////////////////////////////////////  @Override public void setSelectionPath(TreePath path) {      System.out.println('MLDebugJTree: setSelectionPath(' + path + ')');      addSelectionPath(path);      return;     //super.setSelectionPath(path); }  @Override public void setSelectionPaths(TreePath[] paths) {      System.out.println('MLDebugJTree: setSelectionPaths(' + paths + ')');      addSelectionPaths(paths);      return; }  @Override public void setSelectionRow(int row) {      System.out.println('MLDebugJTree: setSelectionRow(' + row + ')');      addSelectionRow(row);      return;     //super.setSelectionRow(row); }  @Override public void setSelectionRows(int[] rows) {      System.out.println('MLDebugJTree: setSelectionRows(' + rows + ')');      addSelectionRows(rows);      return;     //super.setSelectionRows(rows); } 

    DefaultSelectionModel relevant methods :

    package com.ml.tree2.model.impl;  import javax.swing.tree.DefaultTreeSelectionModel; import javax.swing.tree.TreePath;  public class MLTreeSelectionModel extends DefaultTreeSelectionModel { private static final long serialVersionUID = -4270031800448415780L;  @Override public void addSelectionPath(TreePath path) {     // Don't do overriding logic here because addSelectionPaths is ultimately called.     super.addSelectionPath(path); }  @Override public void addSelectionPaths(TreePath[] paths) {     if(paths != null) {         for(TreePath path : paths) {              TreePath[] toAdd = new TreePath[1];             toAdd[0] = path;              if (isPathSelected(path)) {                 // If path has been previously selected REMOVE THE SELECTION.                 super.removeSelectionPaths(toAdd);             } else {                 // Else we really want to add the selection...                 super.addSelectionPaths(toAdd);             }         }     } } 

    HTH.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I have a custom JTree implementation that implemts convertValueToText . This implementation depends on
I create a Jtree that all of its nodes have User object, I fill
I have a JTree which I give objects that implement the TreeNode interface, and
I'm using a custom TreeModel for a JTree. I have an issue when I
I have a JTree and the Nodes are a abstract class (Item) that extends
I am writing this application in Java, where I have a JTree on the
I have a simple Jython GUI that displays an XML file in a JTree.
I have a JTree that stores ShipmentItems and the .toString() on them shows the
I have a Jtree using DefaultTreeModel, each individual node contains a UserObject containing various
I have recognized that each time I initiate the second LEFT mouse click on

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.