Skip to main content

BoxLayout can"t be shared error



I have this Java JFrame class, in which I want to use a boxlayout, but I get an error saying java.awt.AWTError: BoxLayout can't be shared . I've seen others with this problem, but they solved it by creating the boxlayout on the contentpane, but that is what I'm doing here. Here's my code:







class edit_dialog extends javax.swing.JFrame{

javax.swing.JTextField title = new javax.swing.JTextField();

public edit_dialog(){

setDefaultCloseOperation(javax.swing.JFrame.DISPOSE_ON_CLOSE);

setTitle("New entity");

getContentPane().setLayout(

new javax.swing.BoxLayout(this, javax.swing.BoxLayout.PAGE_AXIS));

add(title);

pack();

setVisible(true);

}

}




Comments

  1. Your problem is that you're creating a BoxLayout for a JFrame (this), but setting it as the layout for a JPanel (getContentPane()). Try:

    getContentPane().setLayout(
    new BoxLayout(getContentPane(), BoxLayout.PAGE_AXIS)
    );

    ReplyDelete
  2. I've also found this error making this:

    JPanel panel = new JPanel(new BoxLayout(panel, BoxLayout.PAGE_AXIS));


    The JPanel isn't initialized yet when passing it to the BoxLayout. So split this line like this:

    JPanel panel = new JPanel();
    panel.setLayout(new BoxLayout(panel, BoxLayout.PAGE_AXIS));


    This will work.

    ReplyDelete
  3. I think that one important thing to highlight from the previous answers is that the BoxLayout's target (the first parameter) should be the same Container that the setLayout method is being called upon as in the following example:

    JPanel XXXXXXXXX = new JPanel();
    XXXXXXXXX.setLayout(new BoxLayout(XXXXXXXXX, BoxLayout.Y_AXIS));

    ReplyDelete

Post a Comment

Popular posts from this blog

Why is this Javascript much *slower* than its jQuery equivalent?

I have a HTML list of about 500 items and a "filter" box above it. I started by using jQuery to filter the list when I typed a letter (timing code added later): $('#filter').keyup( function() { var jqStart = (new Date).getTime(); var search = $(this).val().toLowerCase(); var $list = $('ul.ablist > li'); $list.each( function() { if ( $(this).text().toLowerCase().indexOf(search) === -1 ) $(this).hide(); else $(this).show(); } ); console.log('Time: ' + ((new Date).getTime() - jqStart)); } ); However, there was a couple of seconds delay after typing each letter (particularly the first letter). So I thought it may be slightly quicker if I used plain Javascript (I read recently that jQuery's each function is particularly slow). Here's my JS equivalent: document.getElementById('filter').addEventListener( 'keyup', function () { var jsStart = (new Date).getTime()...