Here is a simple tutorial that illustrates the use of CardLayout with the Netbeans GUI-Builder. For this I am using Netbeans 6.7.1.
1. Create a Java Desktop Application.
data:image/s3,"s3://crabby-images/859bf/859bf56d1c85ba670dab6b64f292ae900a24de9a" alt=""
2. Name your application CardTester (or whatever you want, I am going to name mine CardTester). Make sure you choose an appropriate name for your Application Class including the package name.
data:image/s3,"s3://crabby-images/b9d25/b9d252762c7794aaabfadef0d74702cd21211a7e" alt=""
3. Ensure that the Inspector window is visible. If not look in the Window > Navigation menu for it.
data:image/s3,"s3://crabby-images/e4059/e4059a40b6fb4f7326204f3b0485d4dfa2ab7abc" alt=""
4. Right click on the mainPanel, select Set Layout from the context menu then select Card Layout.
data:image/s3,"s3://crabby-images/797d2/797d23b54506742b4182cab2790490d84d3000db" alt=""
name : card1
Card Name: card1
data:image/s3,"s3://crabby-images/573b1/573b17eefc6f7506cf1db1726c2b1853b0ae1487" alt=""
Change any other property that you wish.
6. Repeat step 5 to add another card. Lets call this one card2. The Inspector window should now look like to following illustration.
data:image/s3,"s3://crabby-images/3d14e/3d14e0fe3ecb5001e4dcd8755db218b8a65ae6b1" alt=""
data:image/s3,"s3://crabby-images/6fde2/6fde2a90065fb99f1998f550d0237198b89fa1e9" alt=""
data:image/s3,"s3://crabby-images/0828e/0828e6aaebcfcd91201be9af260f8f7a67f97b07" alt=""
8. Now we can add some functionality that will cause the cards to flip. For this we can use a single button that will flip the cards as it is clicked. Drag a button to the status panel. Right click on the button and choose Set Action... from the menu.
data:image/s3,"s3://crabby-images/f8f0d/f8f0d9fa77ea81766e46c0920e831df76ad665df" alt=""
data:image/s3,"s3://crabby-images/2b236/2b236066254e2e7a722672bc81b3d8237bf5c018" alt=""
9. Add code.
@Action
public void cardSwitcher() {
CardLayout cl = (CardLayout)(mainPanel.getLayout());
cl.next(mainPanel);
}
10. Run the application. If you are really really lucky, when you click the button the cards will change.
I hope this very simple tutorial makes it a bit easier to use the Netbeans GUI-Builder to create a Card Layout.
For more info on using the Card Layout itself visit this page.
14 comments:
It's a very useful toutorial, but I've another question.
In my main frame I'd like to have a tool bar with two buttons, and use this buttons for change between panel1 and panel2.
I don't understand where put the tool bar, in mainPanel I can't.
Thanks.
Can I use
jPanel1.setvisible(false);
jPanel2.setvisible(true);
to show required panel in card layout?
Thanks so much, I used this to create a signup form with a second card with 'x' on it. Really helped out ALOT! :D
Much aprreciated
Thanks a lot!!!!!
In Netbeans 6.9.1 Works Correctly, except for the "Set Action", but the code works 1000%
Thanks!!!!!
Thanks a lot!!!!!
In Netbeans 6.9.1 Works Correctly, except for the "Set Action", but the code works 1000%
Thanks!!!!!
Thanks a lot!!!!!
In Netbeans 6.9.1 Works Correctly, except for the "Set Action", but the code works 1000%
Thanks!!!!!
@Itbangladesh I think the idea in the card layout is to avoid using setVisible() all together. The card layout manages which "card" to show.
Thanks, great tutorial! When I tried it, I first got the error "cannot find symbol: class CardLayout", perhaps because I created a Java Application instead of a Java Desktop Application. However, everything worked fine after I included "import java.awt.*;"..
Cheers!
this tutorial works but when i tried to use it in an applet file, the 'set action' option is not there.. is there a way to use this method when dealing with applets?
the project that i am working on needs to be embedded in a browser so i can't use this method.. :(
Thanks~
This tutorial is still relevant today. Thanks!
Thanks Vincent.
You are a good teacher!
In Netbeans 7 after adding the code we have to Shift+Ctr+I to import layouts.
Also after dragging a jPanel I had to drag it to MainPanel in inspector window to keep it in same tree structure.
Very good tutorial. Thanks you again.
Thanks a lot.
I am a senior software engineer of 50 years experience who is now trying to learn netbeans and java. I spent several weeks trying to figure this out before I found your tutorial. I am using Netbeans 7. and had just a few little things to adjust.
Many thanks for the tutorial.
It is of great help. I was really struggling with the card layout till I found your blog.
Keep up the good work.
Post a Comment