Want to protect your cyber security and still get fast solutions? Ask a secure question today.Go Premium

x
?
Solved

Help on an applet

Posted on 2002-04-05
11
Medium Priority
?
167 Views
Last Modified: 2013-11-23
   I'm trying to make an applet with checkboxes and it would have many different comibinations of if statements to get this done for the appropriate boxes checked, but I am faced with two problems. First, the if statements get really long because I have to indicate not only which box is checked, but also which one is not for it to work properly (at least from my way of doing it). Is there a way to reduce this?
    Also, since the statements are really long, so is my CheckBoxListener class. Is there a way to make this a seprate class in order to make my applet class shorter and easier to read? Here's my code. By the way, any other pionters would be much obliged.

import javax.swing.*;
import java.awt.*;
import java.awt.event.*;

public class WarApplet extends JApplet {
    JCheckBox englandButton = new JCheckBox("England");
    JCheckBox franceButton = new JCheckBox("France");
    JCheckBox russiaButton = new JCheckBox("Russia");
    JCheckBox unitedStatesButton = new JCheckBox("United States");

    JTextArea txt = new JTextArea("Please choose a country.",10, 10);
   
    public void init() {
      englandButton.setSelected(false);
      franceButton.setSelected(false);
      russiaButton.setSelected(false);
      unitedStatesButton.setSelected(false);
      
      Container cp = getContentPane();

      JPanel checkPanel = new JPanel();
      checkPanel.setLayout(new GridLayout(0,1));
      checkPanel.add(englandButton);
      checkPanel.add(franceButton);
      checkPanel.add(russiaButton);      
      checkPanel.add(unitedStatesButton);
      cp.add(checkPanel, BorderLayout.WEST);

      txt.setLineWrap(true);
      txt.setWrapStyleWord(true);
      txt.setEditable(false);
      cp.add(txt, BorderLayout.CENTER);
      
      englandButton.addItemListener(new CheckBoxListener());
      franceButton.addItemListener(new CheckBoxListener());
      russiaButton.addItemListener(new CheckBoxListener());
      unitedStatesButton.addItemListener(new CheckBoxListener());
    }

    class CheckBoxListener implements ItemListener {
      public void itemStateChanged(ItemEvent e) {
          if (englandButton.isSelected() &&
            !franceButton.isSelected() &&
            !russiaButton.isSelected() &&
            !unitedStatesButton.isSelected())
            txt.setText(WarInfo.info[0]);
          else if (!englandButton.isSelected() &&
                 franceButton.isSelected() &&
                 !russiaButton.isSelected() &&
                 !unitedStatesButton.isSelected())
            txt.setText(WarInfo.info[1]);
          else if (!englandButton.isSelected() &&
                 !franceButton.isSelected() &&
                 russiaButton.isSelected() &&
                 !unitedStatesButton.isSelected())
            txt.setText(WarInfo.info[2]);
          else if (!englandButton.isSelected() &&
                 !franceButton.isSelected() &&
                 !russiaButton.isSelected() &&
                 unitedStatesButton.isSelected())
            txt.setText(WarInfo.info[3]);
          else if (englandButton.isSelected() &&
                 franceButton.isSelected() &&
                 russiaButton.isSelected() &&
                 unitedStatesButton.isSelected())
            txt.setText(WarInfo.info[4]);
          else if (!englandButton.isSelected() &&
                 franceButton.isSelected() &&
                 !russiaButton.isSelected() &&
                 unitedStatesButton.isSelected())
            txt.setText(WarInfo.info[5]);
          else if (!englandButton.isSelected() &&
                 !franceButton.isSelected() &&
                 russiaButton.isSelected() &&
                 unitedStatesButton.isSelected())
            txt.setText(WarInfo.info[6]);
          else if (englandButton.isSelected() &&
                 franceButton.isSelected() &&
                 !russiaButton.isSelected() &&
                 !unitedStatesButton.isSelected())
            txt.setText(WarInfo.info[7]);
          else if (englandButton.isSelected() &&
                 !franceButton.isSelected() &&
                 !russiaButton.isSelected() &&
                 unitedStatesButton.isSelected())
            txt.setText(WarInfo.info[8]);
          else if (englandButton.isSelected() &&
                 franceButton.isSelected() &&
                 russiaButton.isSelected() &&
                 !unitedStatesButton.isSelected())
            txt.setText(WarInfo.info[9]);
          else txt.setText("Please choose a country.");
      }
    }
   
}

   
0
Comment
Question by:alrav79
11 Comments
 
LVL 92

Accepted Solution

by:
objects earned 200 total points
ID: 6922445
>  Is there a way to make this a seprate class

It actually already is a seperate class :-) It's what's called an inner class.
You are free to make it a non-inner class, just move it into it's own .java file CheckBoxListener.java.

It's not entirely clear what you're trying to do, so I can't really comment on improvements to your logic.

A minor side note, you don't actually appear to need seperate instance of your listener for each cb, one would suffice.
0
 

Expert Comment

by:cini_gm
ID: 6922475
This way u can break this class. Save the two classes in the same directory and compile it

import javax.swing.*;
import java.awt.*;
import java.awt.event.*;

public class WarApplet extends JApplet {
   JCheckBox englandButton = new JCheckBox("England");
   JCheckBox franceButton = new JCheckBox("France");
   JCheckBox russiaButton = new JCheckBox("Russia");
   JCheckBox unitedStatesButton = new JCheckBox("United States");

   JTextArea txt = new JTextArea("Please choose a country.",10, 10);
   
   public void init() {
     englandButton.setSelected(false);
     franceButton.setSelected(false);
     russiaButton.setSelected(false);
     unitedStatesButton.setSelected(false);
     
     Container cp = getContentPane();

     JPanel checkPanel = new JPanel();
     checkPanel.setLayout(new GridLayout(0,1));
     checkPanel.add(englandButton);
     checkPanel.add(franceButton);
     checkPanel.add(russiaButton);    
     checkPanel.add(unitedStatesButton);
     cp.add(checkPanel, BorderLayout.WEST);

     txt.setLineWrap(true);
     txt.setWrapStyleWord(true);
     txt.setEditable(false);
     cp.add(txt, BorderLayout.CENTER);
     
     englandButton.addItemListener(new CheckBoxListener());
     franceButton.addItemListener(new CheckBoxListener());
     russiaButton.addItemListener(new CheckBoxListener());
     unitedStatesButton.addItemListener(new CheckBoxListener());
   }
}

import javax.swing.*;
import java.awt.*;
import java.awt.event.*;

public class CheckBoxListener implements ItemListener {
     public void itemStateChanged(ItemEvent e) {
         if (englandButton.isSelected() &&
          !franceButton.isSelected() &&
          !russiaButton.isSelected() &&
          !unitedStatesButton.isSelected())
          txt.setText(WarInfo.info[0]);
         else if (!englandButton.isSelected() &&
               franceButton.isSelected() &&
               !russiaButton.isSelected() &&
               !unitedStatesButton.isSelected())
          txt.setText(WarInfo.info[1]);
         else if (!englandButton.isSelected() &&
               !franceButton.isSelected() &&
               russiaButton.isSelected() &&
               !unitedStatesButton.isSelected())
          txt.setText(WarInfo.info[2]);
         else if (!englandButton.isSelected() &&
               !franceButton.isSelected() &&
               !russiaButton.isSelected() &&
               unitedStatesButton.isSelected())
          txt.setText(WarInfo.info[3]);
         else if (englandButton.isSelected() &&
               franceButton.isSelected() &&
               russiaButton.isSelected() &&
               unitedStatesButton.isSelected())
          txt.setText(WarInfo.info[4]);
         else if (!englandButton.isSelected() &&
               franceButton.isSelected() &&
               !russiaButton.isSelected() &&
               unitedStatesButton.isSelected())
          txt.setText(WarInfo.info[5]);
         else if (!englandButton.isSelected() &&
               !franceButton.isSelected() &&
               russiaButton.isSelected() &&
               unitedStatesButton.isSelected())
          txt.setText(WarInfo.info[6]);
         else if (englandButton.isSelected() &&
               franceButton.isSelected() &&
               !russiaButton.isSelected() &&
               !unitedStatesButton.isSelected())
          txt.setText(WarInfo.info[7]);
         else if (englandButton.isSelected() &&
               !franceButton.isSelected() &&
               !russiaButton.isSelected() &&
               unitedStatesButton.isSelected())
          txt.setText(WarInfo.info[8]);
         else if (englandButton.isSelected() &&
               franceButton.isSelected() &&
               russiaButton.isSelected() &&
               !unitedStatesButton.isSelected())
          txt.setText(WarInfo.info[9]);
         else txt.setText("Please choose a country.");
     }
   }
   

0
 
LVL 92

Expert Comment

by:objects
ID: 6922483
Yes, you'll need to pass reference to the relevant objects or provide methods to perform required functionality.
0
Concerto's Cloud Advisory Services

Want to avoid the missteps to gaining all the benefits of the cloud? Learn more about the different assessment options from our Cloud Advisory team.

 
LVL 92

Expert Comment

by:objects
ID: 6922484
The same way ANY classes would interact.
0
 

Author Comment

by:alrav79
ID: 6922597
ok, I now put the classes in their own appropriate files, and both of them compile perfectly. But when the applet loads, it acts as if the if statements arent there. No matter what i check, there is no response. I passed reference by making a WarApplet object "a" in the CheckBoxListener class, like this:

WarApplet a  = new WarApplet();
...
...
..
if (a.england.isSelected())
..
you get the point
0
 
LVL 86

Expert Comment

by:CEHJ
ID: 6923064
A more elegant way to do this would be to take a bit masking approach. You'll find if you create an array of checkboxes, this may help in connection with this way of doing things.

final static int FRANCE =  1 << 0;
final static int ENGLAND = 1 << 1;
...

final static int FRANCE_ENGLAND = ENGLAND | FRANCE;


0
 
LVL 92

Expert Comment

by:objects
ID: 6923374
You need to pass a reference of WarApplet to you listener class, not create a new one.
0
 

Author Comment

by:alrav79
ID: 6924624
explain how please with an example
0
 
LVL 92

Expert Comment

by:objects
ID: 6924636
public CheckBoxListener(WarApplet applet)
{
   a = applet;
}
0
 
LVL 9

Expert Comment

by:Venci75
ID: 7933256
No comment has been added lately, so it's time to clean up this TA.
I will leave a recommendation in the Cleanup topic area that this question is:
Answered by: objects
Please leave any comments here within the next seven days.
 
PLEASE DO NOT ACCEPT THIS COMMENT AS AN ANSWER!
 
Venci75
EE Cleanup Volunteer
0
 

Expert Comment

by:SpideyMod
ID: 7984190
per recommendation

SpideyMod
Community Support Moderator @Experts Exchange
0

Featured Post

What does it mean to be "Always On"?

Is your cloud always on? With an Always On cloud you won't have to worry about downtime for maintenance or software application code updates, ensuring that your bottom line isn't affected.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Introduction Java can be integrated with native programs using an interface called JNI(Java Native Interface). Native programs are programs which can directly run on the processor. JNI is simply a naming and calling convention so that the JVM (Java…
In this post we will learn how to connect and configure Android Device (Smartphone etc.) with Android Studio. After that we will run a simple Hello World Program.
Viewers will learn about arithmetic and Boolean expressions in Java and the logical operators used to create Boolean expressions. We will cover the symbols used for arithmetic expressions and define each logical operator and how to use them in Boole…
This tutorial covers a practical example of lazy loading technique and early loading technique in a Singleton Design Pattern.
Suggested Courses
Course of the Month11 days, 8 hours left to enroll

564 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question