Keypressed function entered but not functioning correctly - java
I am trying to assign key listeners to buttons created in a for loop. For some reason, I cannot get the buttons to change background color on keypress. The System.out.println("passed"); line is being reached, so Im not sure what's going on.
Lots of spaghetti code.. please let me know what else I should add.
import java.awt.BorderLayout;
import java.awt.Color;
import java.awt.Dimension;
import java.awt.Font;
import java.awt.GridLayout;
import java.awt.event.KeyEvent;
import java.awt.event.KeyListener;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JPanel;
import javax.swing.JTextArea;
public class ButtonInPane extends JFrame implements KeyListener {
// input
String input;
//context
JLabel context1, context2;
// default color
Color defaultColor = new JButton().getBackground();
public void addNotify() {
super.addNotify();
requestFocus();
}
// main rows of keys
public String rowOne[] = {
"~",
"1",
"2",
"3",
"4",
"5",
"6",
"7",
"8",
"9",
"0",
"-",
"+",
"h"
};
public String rowTwo[] = {
"Tab",
"Q",
"W",
"E",
"R",
"T",
"Y",
"U",
"I",
"O",
"P",
"[",
"]",
"\\"
};
public String rowThree[] = {
"Caps",
"A",
"S",
"D",
"F",
"G",
"H",
"J",
"K",
"L",
":",
"'",
"Enter"
};
public String rowFour[] = {
"Shift",
"Z",
"X",
"C",
"V",
"B",
"N",
"M",
",",
".",
"?",
" ^"
};
public String rowFive[] = {
" ",
"<",
"v",
">"
};
/**
* Account for chars with no shift: Program toggles Shift key, meaning if a
* user clicks on it, all keys will be toggled to their respective shift
* value. The user can tap the shift key again to change back to regular
* value
*/
public String shiftless[] = {
"1",
"2",
"3",
"4",
"5",
"6",
"7",
"8",
"9",
"0",
"-",
"=",
"q",
"w",
"e",
"r",
"t",
"y",
"u",
"i",
"o",
"p",
"[",
"]",
"\\",
"a",
"s",
"d",
"f",
"g",
"h",
"j",
"k",
"l",
";",
"z",
"x",
"c",
"v",
"b",
"n",
"m",
",",
".",
"/"
};
// Account for special chars
public String specialChars[] = {
"~",
"-",
"+",
"[",
"]",
"\\",
";",
".",
"?"
};
// declare rows of buttons
public JButton buttons_rowOne[], buttons_rowTwo[], buttons_rowThree[], buttons_rowFour[], buttons_rowFive[];
private JTextArea body;
private JPanel top;
private JPanel middle;
private JPanel bottom;
private JPanel contextBox;
// ctor
public ButtonInPane() {
super("Typing Tutor");
this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
this.setResizable(false);
this.getContentPane().setPreferredSize(new Dimension(1000, 600));
this.setLocation(50, 50);
this.setVisible(true);
__init__();
}
public void __init__layout(JPanel top, JPanel middle, JPanel bottom, JPanel contextBox) {
setLayout(new BorderLayout());
add(top, BorderLayout.NORTH);
add(contextBox);
add(middle, BorderLayout.CENTER);
add(bottom, BorderLayout.SOUTH);
}
public void __init__body() {
body = new JTextArea();
body.setPreferredSize(new Dimension(1000, 150));
body.addKeyListener(this);
}
public void __init__panels() {
context1 = new JLabel("Type some text using your keyboard. " +
"The keys you press will be highlighed and the text will be displayed.");
context2 = new JLabel("\nNote: Clicking the buttons with your mouse will not perform any action.");
context1.setFont(new Font("Verdana", Font.BOLD, 14));
context2.setFont(new Font("Verdana", Font.BOLD, 14));
top = new JPanel();
top.setSize(new Dimension(500, 500));
middle = new JPanel();
bottom = new JPanel();
contextBox = new JPanel();
__init__layout(top, middle, bottom, contextBox);
top.setLayout(new BorderLayout());
bottom.setLayout(new GridLayout(5, 5));
top.add(context1);
top.add(context2);
middle.setLayout(new BorderLayout());
middle.add(body, BorderLayout.WEST);
middle.add(body, BorderLayout.CENTER);
}
public void __init__() {
// text area
__init__body();
// panels for layout
__init__panels();
pack();
// get length of row strings
int length_rowOne = rowOne.length;
int length_rowTwo = rowTwo.length;
int length_rowThree = rowThree.length;
int length_rowFour = rowFour.length;
int length_rowFive = rowFive.length;
// create array for each row of buttons
buttons_rowOne = new JButton[length_rowOne];
buttons_rowTwo = new JButton[length_rowTwo];
buttons_rowThree = new JButton[length_rowThree];
buttons_rowFour = new JButton[length_rowFour];
buttons_rowFive = new JButton[length_rowFive];
// create panel for each row of buttons
JPanel r1 = new JPanel(new GridLayout(1, length_rowOne));
JPanel r2 = new JPanel(new GridLayout(1, length_rowTwo));
JPanel r3 = new JPanel(new GridLayout(1, length_rowThree));
JPanel r4 = new JPanel(new GridLayout(1, length_rowFour));
JPanel r5 = new JPanel(new GridLayout(1, length_rowFive));
// draw out the rows of buttons
draw(r1, length_rowOne, r2, length_rowTwo, r3, length_rowThree, r4, length_rowFour, r5, length_rowFive);
}
// draw rows of buttons
public void draw(JPanel r1, int s1, JPanel r2, int s2, JPanel r3, int s3, JPanel r4, int s4, JPanel r5, int s5) {
for (int i = 0; i < s1; i++) {
JButton currentButton = new JButton(rowOne[i]);
currentButton.setPreferredSize(new Dimension(100, 50));
currentButton.addKeyListener(this);
buttons_rowOne[i] = currentButton;
r1.add(buttons_rowOne[i]);
}
for (int i = 0; i < s2; i++) {
JButton currentButton = new JButton(rowTwo[i]);
currentButton.setPreferredSize(new Dimension(100, 50));
currentButton.addKeyListener(this);
buttons_rowTwo[i] = currentButton;
r2.add(buttons_rowTwo[i]);
}
for (int i = 0; i < s3; i++) {
JButton currentButton = new JButton(rowThree[i]);
currentButton.setPreferredSize(new Dimension(100, 50));
currentButton.addKeyListener(this);
buttons_rowThree[i] = currentButton;
r3.add(buttons_rowThree[i]);
}
for (int i = 0; i < s4; i++) {
JButton currentButton = new JButton(rowFour[i]);
currentButton.setPreferredSize(new Dimension(100, 50));
currentButton.addKeyListener(this);
buttons_rowFour[i] = currentButton;
r4.add(buttons_rowFour[i]);
}
for (int i = 0; i < s5; i++) {
JButton currentButton = new JButton(rowFive[i]);
// account for space bar
if (i == 1) {
currentButton = new JButton(rowFive[i]);
currentButton.setPreferredSize(new Dimension(400, 10));
currentButton.setBounds(10, 10, 600, 100);
currentButton.addKeyListener(this);
buttons_rowFive[i] = currentButton;
} else {
currentButton.setPreferredSize(new Dimension(100, 50));
currentButton.addKeyListener(this);
buttons_rowFive[i] = currentButton;
}
r5.add(buttons_rowFive[i]);
}
bottom.add(r1);
bottom.add(r2);
bottom.add(r3);
bottom.add(r4);
bottom.add(r5);
} // !draw(...)
// called when a button is pressed
#Override
public void keyPressed(KeyEvent press) {
Object current = press.getKeyChar();
System.out.println("passed");
for (int i = 0; i < rowOne.length; i++) {
if (current == rowOne[i]) {
buttons_rowOne[i].setBackground(Color.BLACK);
}
}
for (int i = 0; i < rowTwo.length; i++) {
if (current == rowTwo[i]) {
buttons_rowTwo[i].setBackground(Color.BLACK);
}
}
for (int i = 0; i < rowThree.length; i++) {
if (current == rowThree[i]) {
buttons_rowThree[i].setBackground(Color.BLACK);
}
}
for (int i = 0; i < rowFour.length; i++) {
if (current == rowFour[i]) {
buttons_rowFour[i].setBackground(Color.BLACK);
}
}
for (int i = 0; i < rowFive.length; i++) {
if (current == rowFive[i]) {
buttons_rowFive[i].setBackground(Color.BLACK);
}
}
repaint();
} // !keyPressed(...)
// called when a button is released
#Override
public void keyReleased(KeyEvent release) {
Object current = release.getSource();
for (int i = 0; i < 10; i++) {
if (current == rowOne[i]) {
buttons_rowOne[i].setBackground(defaultColor);
} else if (current == rowTwo[i]) {
buttons_rowTwo[i].setBackground(defaultColor);
} else if (current == rowThree[i]) {
buttons_rowThree[i].setBackground(defaultColor);
} else if (current == rowFour[i]) {
buttons_rowFour[i].setBackground(defaultColor);
} else if (current == rowFive[i]) {
buttons_rowFive[i].setBackground(defaultColor);
}
}
repaint();
} // !keyReleased(...)
#Override
public void keyTyped(KeyEvent typed) {
// Object current = typed.getSource().toString();
// StringBuilder sb = new StringBuilder();
// for (int i = 0; i < 14; i++) {
// if (current == rowOne[i]) {
// sb.append(typed.getKeyCode());
// body.append(sb.toString());
// } else if (current == rowTwo[i]) {
// sb.append(typed.getKeyCode());
// body.append(sb.toString());
// } else if (current == rowThree[i]) {
// sb.append(typed.getKeyCode());
// body.append(sb.toString());
// } else if (current == rowFour[i]) {
// sb.append(typed.getKeyCode());
// body.append(sb.toString());
// } else if (current == rowFive[i]) {
// sb.append(typed.getKeyCode());
// body.append(sb.toString());
// }
// }
}
// main method
public static void main(String[] args) {
new ButtonInPane();
} // !main method
private static final long serialVersionUID = 999;
} // !main class
Edit 1:
import java.awt.BorderLayout;
import java.awt.Color;
import java.awt.Dimension;
import java.awt.Font;
import java.awt.GridLayout;
import java.awt.event.KeyEvent;
import java.awt.event.KeyListener;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JPanel;
import javax.swing.JTextArea;
public class ButtonInPane extends JFrame implements KeyListener {
// input
String input;
//context
JLabel context1, context2;
// default color
Color defaultColor = new JButton().getBackground();
public void addNotify() {
super.addNotify();
requestFocus();
}
// main rows of keys
public char rowOne[] = {
'~',
'1',
'2',
'3',
'4',
'5',
'6',
'7',
'8',
'9',
'0',
'-',
'+',
'h'
};
public char rowTwo[] = {
//'Tab', TODO: Make these separate objects
'Q',
'W',
'E',
'R',
'T',
'Y',
'U',
'I',
'O',
'P',
'[',
']',
'\\'
};
public char rowThree[] = {
//'Caps',
'A',
'S',
'D',
'F',
'G',
'H',
'J',
'K',
'L',
':',
'"',
//'Enter'
};
public char rowFour[] = {
//'Shift',
'Z',
'X',
'C',
'V',
'B',
'N',
'M',
',',
'.',
'?',
//' ^'
};
public char rowFive[] = {
//' ',
'<',
'v',
'>'
};
/**
* Account for chars with no shift: Program toggles Shift key, meaning if a
* user clicks on it, all keys will be toggled to their respective shift
* value. The user can tap the shift key again to change back to regular
* value
*/
public char shiftless[] = {
'1',
'2',
'3',
'4',
'5',
'6',
'7',
'8',
'9',
'0',
'-',
'=',
'q',
'w',
'e',
'r',
't',
'y',
'u',
'i',
'o',
'p',
'[',
']',
'\\',
'a',
's',
'd',
'f',
'g',
'h',
'j',
'k',
'l',
';',
'z',
'x',
'c',
'v',
'b',
'n',
'm',
',',
'.',
'/'
};
// Account for special chars
public char specialChars[] = {
'~',
'-',
'+',
'[',
']',
'\\',
';',
'.',
'?'
};
// declare rows of buttons
public JButton buttons_rowOne[], buttons_rowTwo[], buttons_rowThree[], buttons_rowFour[], buttons_rowFive[];
private JTextArea body;
private JPanel top;
private JPanel middle;
private JPanel bottom;
private JPanel contextBox;
// ctor
public ButtonInPane() {
super("Typing Tutor");
this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
this.setResizable(false);
this.getContentPane().setPreferredSize(new Dimension(1000, 600));
this.setLocation(50, 50);
this.setVisible(true);
__init__();
}
public void __init__layout(JPanel top, JPanel middle, JPanel bottom, JPanel contextBox) {
setLayout(new BorderLayout());
add(top, BorderLayout.NORTH);
add(contextBox);
add(middle, BorderLayout.CENTER);
add(bottom, BorderLayout.SOUTH);
}
public void __init__body() {
body = new JTextArea();
body.setPreferredSize(new Dimension(1000, 150));
body.addKeyListener(this);
}
public void __init__panels() {
context1 = new JLabel("Type some text using your keyboard. " +
"The keys you press will be highlighed and the text will be displayed.");
context2 = new JLabel("\nNote: Clicking the buttons with your mouse will not perform any action.");
context1.setFont(new Font("Verdana", Font.BOLD, 14));
context2.setFont(new Font("Verdana", Font.BOLD, 14));
top = new JPanel();
top.setSize(new Dimension(500, 500));
middle = new JPanel();
bottom = new JPanel();
contextBox = new JPanel();
__init__layout(top, middle, bottom, contextBox);
top.setLayout(new BorderLayout());
bottom.setLayout(new GridLayout(5, 5));
top.add(context1);
top.add(context2);
middle.setLayout(new BorderLayout());
middle.add(body, BorderLayout.WEST);
middle.add(body, BorderLayout.CENTER);
}
public void __init__() {
// text area
__init__body();
// panels for layout
__init__panels();
pack();
// get length of row strings
int length_rowOne = rowOne.length;
int length_rowTwo = rowTwo.length;
int length_rowThree = rowThree.length;
int length_rowFour = rowFour.length;
int length_rowFive = rowFive.length;
// create array for each row of buttons
buttons_rowOne = new JButton[length_rowOne];
buttons_rowTwo = new JButton[length_rowTwo];
buttons_rowThree = new JButton[length_rowThree];
buttons_rowFour = new JButton[length_rowFour];
buttons_rowFive = new JButton[length_rowFive];
// create panel for each row of buttons
JPanel r1 = new JPanel(new GridLayout(1, length_rowOne));
JPanel r2 = new JPanel(new GridLayout(1, length_rowTwo));
JPanel r3 = new JPanel(new GridLayout(1, length_rowThree));
JPanel r4 = new JPanel(new GridLayout(1, length_rowFour));
JPanel r5 = new JPanel(new GridLayout(1, length_rowFive));
// draw out the rows of buttons
draw(r1, length_rowOne, r2, length_rowTwo, r3, length_rowThree, r4, length_rowFour, r5, length_rowFive);
}
// draw rows of buttons
public void draw(JPanel r1, int s1, JPanel r2, int s2, JPanel r3, int s3, JPanel r4, int s4, JPanel r5, int s5) {
for (int i = 0; i < s1; i++) {
JButton currentButton = new JButton(rowOne[i]);
currentButton.setPreferredSize(new Dimension(100, 50));
currentButton.addKeyListener(this);
buttons_rowOne[i] = currentButton;
r1.add(buttons_rowOne[i]);
}
for (int i = 0; i < s2; i++) {
JButton currentButton = new JButton(rowTwo[i]);
currentButton.setPreferredSize(new Dimension(100, 50));
currentButton.addKeyListener(this);
buttons_rowTwo[i] = currentButton;
r2.add(buttons_rowTwo[i]);
}
for (int i = 0; i < s3; i++) {
JButton currentButton = new JButton(rowThree[i]);
currentButton.setPreferredSize(new Dimension(100, 50));
currentButton.addKeyListener(this);
buttons_rowThree[i] = currentButton;
r3.add(buttons_rowThree[i]);
}
for (int i = 0; i < s4; i++) {
JButton currentButton = new JButton(rowFour[i]);
currentButton.setPreferredSize(new Dimension(100, 50));
currentButton.addKeyListener(this);
buttons_rowFour[i] = currentButton;
r4.add(buttons_rowFour[i]);
}
for (int i = 0; i < s5; i++) {
JButton currentButton = new JButton(rowFive[i]);
// account for space bar
if (i == 1) {
currentButton = new JButton(rowFive[i]);
currentButton.setPreferredSize(new Dimension(400, 10));
currentButton.setBounds(10, 10, 600, 100);
currentButton.addKeyListener(this);
buttons_rowFive[i] = currentButton;
} else {
currentButton.setPreferredSize(new Dimension(100, 50));
currentButton.addKeyListener(this);
buttons_rowFive[i] = currentButton;
}
r5.add(buttons_rowFive[i]);
}
bottom.add(r1);
bottom.add(r2);
bottom.add(r3);
bottom.add(r4);
bottom.add(r5);
} // !draw(...)
// called when a button is pressed
#Override
public void keyPressed(KeyEvent press) {
char current = press.getKeyChar();
System.out.println("passed");
for (int i = 0; i < rowOne.length; i++) {
if (current == rowOne[i]) {
buttons_rowOne[i].setBackground(Color.BLACK);
}
}
// System.out.println(s1 == s2);
// System.out.println(s1.equals(s2));
for (int i = 0; i < rowTwo.length; i++) {
if (current == rowTwo[i]) {
buttons_rowTwo[i].setBackground(Color.BLACK);
}
}
for (int i = 0; i < rowThree.length; i++) {
if (current == rowThree[i]) {
buttons_rowThree[i].setBackground(Color.BLACK);
}
}
for (int i = 0; i < rowFour.length; i++) {
if (current == rowFour[i]) {
buttons_rowFour[i].setBackground(Color.BLACK);
}
}
for (int i = 0; i < rowFive.length; i++) {
if (current == rowFive[i]) {
buttons_rowFive[i].setBackground(Color.BLACK);
}
}
repaint();
} // !keyPressed(...)
// called when a button is released
#Override
public void keyReleased(KeyEvent release) {
char current = release.getSource();
for (int i = 0; i < 10; i++) {
if (current == rowOne[i]) {
buttons_rowOne[i].setBackground(defaultColor);
} else if (current == rowTwo[i]) {
buttons_rowTwo[i].setBackground(defaultColor);
} else if (current == rowThree[i]) {
buttons_rowThree[i].setBackground(defaultColor);
} else if (current == rowFour[i]) {
buttons_rowFour[i].setBackground(defaultColor);
} else if (current == rowFive[i]) {
buttons_rowFive[i].setBackground(defaultColor);
}
}
repaint();
} // !keyReleased(...)
#Override
public void keyTyped(KeyEvent typed) {
// Object current = typed.getSource().toString();
// StringBuilder sb = new StringBuilder();
// for (int i = 0; i < 14; i++) {
// if (current == rowOne[i]) {
// sb.append(typed.getKeyCode());
// body.append(sb.toString());
// } else if (current == rowTwo[i]) {
// sb.append(typed.getKeyCode());
// body.append(sb.toString());
// } else if (current == rowThree[i]) {
// sb.append(typed.getKeyCode());
// body.append(sb.toString());
// } else if (current == rowFour[i]) {
// sb.append(typed.getKeyCode());
// body.append(sb.toString());
// } else if (current == rowFive[i]) {
// sb.append(typed.getKeyCode());
// body.append(sb.toString());
// }
// }
}
// main method
public static void main(String[] args) {
new ButtonInPane();
} // !main method
private static final long serialVersionUID = 999;
} // !main class
One fundamental issue with your logic is that the if-statements in keyPressed are never true, which is why the print statement is working but not the background color changes. The reason why an if-statement such as if (current == rowOne[i]) would never be true is that the type of current is Object, but you're assigning to it press.getKeyChar(), which is of type char. I'm guessing that this results in auto-boxing, meaning that the char value then becomes a Character object. As for rowOne[i], since the values in rowOne are all of type String, these are - like for current - always objects and not primitives. Directly comparing objects with == only determines if the objects are the same object, meaning that you are comparing the references and not the value. To compare objects, you need to use a.equals(b) to correctly compare the values of the objects (see "Difference between == and .equals() method in Java").
In your case, both of these issues combined are causing the if-statement not to work as expected. I would recommend declaring current as a char, and making your arrays contains char primitives rather than String objects (e.g. 'A' rather than "A"). In this case, you can directly compare two char primitives using == and that would at least solve that problem.
Hope this leads you in the right direction.
Related
Unable to add keyListeners to buttons
I am trying to create a keyboard GUI with some basic functionalities. The problem that I am running into is within my draw(...){...} function, which highlights the addKeyListener() method, with the error: The method addKeyListener(KeyListener) in the type Component is not applicable for the arguments (a3_keyboard) Im not sure what I'm doing wrong. I tried changing my code up with, getContentPane().addKeyListener(this); for (JButton button : first) { button.addKeyListener(this); } for (JButton button : second) { button.addKeyListener(this); } for (JButton button : third) { button.addKeyListener(this); } for (JButton button : fourth) { button.addKeyListener(this); } for (JButton button : fifth) { button.addKeyListener(this); } But that's throwing me the same error. Full code below: import java.awt.*; import java.awt.event.KeyEvent; import javax.swing.*; public class a3_keyboard extends JFrame implements KeyListener { //input String input; //default color Color defaultColor = new JButton().getBackground(); //main rows of keys private String rowOne[] = { "~", "1", "2", "3", "4", "5", "6", "7", "8", "9", "0", "-", "+", "h" }; private String rowTwo[] = { "Tab", "Q", "W", "E", "R", "T", "Y", "U", "I", "O", "P", "[", "]", "\\" }; private String rowThree[] = { "Caps", "A", "S", "D", "F", "G", "H", "J", "K", "L", ":", "'", "Enter" }; private String rowFour[] = { "Shift", "Z", "X", "C", "V", "B", "N", "M", ",", ".", "?", " ^" }; private String rowFive[] = { " ", "<", "v", ">" }; /** Account for chars with no shift: ** Program toggles Shift key, meaning ** if a user clicks on it, all keys will be ** toggled to their respective shift value. The ** user can tap the shift key again to ** change back to regular value */ private String shiftless[] = { "1","2","3","4","5","6","7","8","9","0", "-","=","q","w","e","r","t","y","u","i","o","p", "[","]","\\","a","s","d","f","g","h","j","k","l", ";","z","x","c","v","b","n","m",",",".","/" }; //Account for special chars private String specialChars[] = { "~", "-", "+", "[", "]", "\\", ";", ".", "?" }; private JLabel context = new JLabel("Type some text using your keyboard. " + "The keys you press will be highlighed and the text will be displayed.\n " + "Note: Clicking the buttons with your mouse will not perform any action.") .setFont(new Font("Verdana",Font.BOLD,14)); //declare rows of buttons private JButton buttons_rowOne[], buttons_rowTwo[], buttons_rowThree[], buttons_rowFour[], buttons_rowFive[]; //ctor public a3_keyboard() { super("Typing Tutor"); this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); this.setResizable(false); this.getContentPane().setPreferredSize(new Dimension(1000,600)); this.setLocation(50,50); this.setVisible(true); __init__(); } public void __init__layout(JPanel top, JPanel middle, JPanel bottom, JPanel contextBox) { setLayout(new BorderLayout()); add(top, BorderLayout.NORTH); add(contextBox); add(middle, BorderLayout.CENTER); add(bottom, BorderLayout.SOUTH); } private void __init__body() { JTextArea body = new JTextArea().setPreferredSize(new Dimension(600, 150)); } public void __init__panels() { JPanel top = new JPanel(); JPanel middle = new JPanel(); JPanel bottom = new JPanel(); JPanel contextBox = new JPanel(); __init__layout(top, middle, bottom, contextBox); top.setLayout(new BorderLayout()); bottom.setLayout(new GridLayout(5,1)); top.add(info, BorderLayout.WEST); top.add(info, BorderLayout.SOUTH); middle.setLayout( new BorderLayout()); middle.add(text, BorderLayout.WEST); middle.add(text, BorderLayout.CENTER); } private void __init__() { //text area __init__body(); //panels for layout __init__panels(); pack(); //get length of row strings int length_rowOne = rowOne.length; int length_rowTwo = rowTwo.length; int length_rowThree = rowThree.length; int length_rowFour = rowFour.length; int length_rowFive = rowFive.length; //create array for each row of buttons buttons_rowOne = new JButton[length_rowOne]; buttons_rowTwo = new JButton[length_rowTwo]; buttons_rowThree = new JButton[length_rowThree]; buttons_rowFour = new JButton[length_rowFour]; buttons_rowFive = new JButton[length_rowFive]; //create panel for each row of buttons JPanel r1 = new JPanel(new GridLayout(1, length_rowOne)); JPanel r2 = new JPanel(new GridLayout(1, length_rowTwo)); JPanel r3 = new JPanel(new GridLayout(1, length_rowThree)); JPanel r4 = new JPanel(new GridLayout(1, length_rowFour)); JPanel r5 = new JPanel(new GridLayout(1, length_rowFive)); //draw out the rows of buttons draw( r1, length_rowOne, r2, length_rowTwo, r3, length_rowThree, r4, length_rowFour, r5, length_rowFive ); } //draw rows of buttons public void draw(JPanel r1, int s1, JPanel r2, int s2, JPanel r3, int s3, JPanel r4, int s4, JPanel r5, int s5) { for (int i = 0; i < s1; i++) { JButton currentButton = new JButton(rowOne[i]); currentButton.setPreferredSize(new Dimension(100, 50)); buttons_rowOne[i] = currentButton; buttons_rowOne[i].addKeyListener(this); r1.add(buttons_rowOne[i]); } for (int i = 0; i < s2; i++) { JButton currentButton = new JButton(rowOne[i]); currentButton.setPreferredSize(new Dimension(100, 50)); buttons_rowTwo[i] = currentButton; buttons_rowTwo[i].addKeyListener(this); r1.add(buttons_rowTwo[i]); } for (int i = 0; i < s3; i++) { JButton currentButton = new JButton(rowOne[i]); currentButton.setPreferredSize(new Dimension(100, 50)); buttons_rowThree[i] = currentButton; buttons_rowThree[i].addKeyListener(this); r1.add(buttons_rowThree[i]); } for (int i = 0; i < s4; i++) { JButton currentButton = new JButton(rowOne[i]); currentButton.setPreferredSize(new Dimension(100, 50)); buttons_rowFour[i] = currentButton; buttons_rowFour[i].addKeyListener(this); r1.add(buttons_rowFour[i]); } for (int i = 0; i < s5; i++) { JButton currentButton = new JButton(rowOne[i]); //account for space bar if (i == 1) { currentButton = new JButton(rowFive[i]); currentButton.setPreferredSize(new Dimension(400,10)); currentButton.setBounds(10, 10, 600, 100); buttons_rowFive[i] = currentButton; } else { currentButton.setPreferredSize(new Dimension(100, 50)); buttons_rowFive[i] = currentButton; buttons_rowFive[i].addKeyListener(this); } r1.add(buttons_rowFive[i]); } bottom.add(r1); bottom.add(r2); bottom.add(r3); bottom.add(r4); bottom.add(r5); }//!draw(...) //called when a button is pressed #Override public void activated(KeyEvent press) { int index = press.getKeyCode(); input = String.format("%s", index); }//!activated(...) //called when a button is released #Override public void deactivated(KeyEvent release) { int index = release.getKeyCode(); input = String.format( "%s"+KeyEvent.getKeyText(keyCode) ); this.setBackground(defaultColor);; }//!deactivated(...) //main method public static void main(Strings[] args) { new a3_keyboard(); }//!main method //obtain the JButton’s original background colour before you change its colour }//!main class If Im missing something, please let me know and I'll add it to the question. Edit: New code: import java.awt.*; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import java.awt.event.KeyEvent; import java.awt.event.KeyListener; import javax.swing.*; public class a3_keyboard extends JFrame implements KeyListener { //input String input; //input body JTextArea body; //panels JPanel top, middle, bottom, contextBox = new JPanel(); //default color Color defaultColor = new JButton().getBackground(); //main rows of keys public String rowOne[] = { "~", "1", "2", "3", "4", "5", "6", "7", "8", "9", "0", "-", "+", "h" }; public String rowTwo[] = { "Tab", "Q", "W", "E", "R", "T", "Y", "U", "I", "O", "P", "[", "]", "\\" }; public String rowThree[] = { "Caps", "A", "S", "D", "F", "G", "H", "J", "K", "L", ":", "'", "Enter" }; public String rowFour[] = { "Shift", "Z", "X", "C", "V", "B", "N", "M", ",", ".", "?", " ^" }; public String rowFive[] = { " ", "<", "v", ">" }; /** Account for chars with no shift: ** Program toggles Shift key, meaning ** if a user clicks on it, all keys will be ** toggled to their respective shift value. The ** user can tap the shift key again to ** change back to regular value */ public String shiftless[] = { "1","2","3","4","5","6","7","8","9","0", "-","=","q","w","e","r","t","y","u","i","o","p", "[","]","\\","a","s","d","f","g","h","j","k","l", ";","z","x","c","v","b","n","m",",",".","/" }; //Account for special chars public String specialChars[] = { "~", "-", "+", "[", "]", "\\", ";", ".", "?" }; //declare rows of buttons public JButton buttons_rowOne[], buttons_rowTwo[], buttons_rowThree[], buttons_rowFour[], buttons_rowFive[]; //ctor public a3_keyboard() { super("Typing Tutor"); this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); this.setResizable(false); this.getContentPane().setPreferredSize(new Dimension(1000,600)); this.setLocation(50,50); this.setVisible(true); __init__(); } public void __init__layout(JPanel top, JPanel middle, JPanel bottom, JPanel contextBox) { setLayout(new BorderLayout()); add(top, BorderLayout.NORTH); add(contextBox); add(middle, BorderLayout.CENTER); add(bottom, BorderLayout.SOUTH); } public void __init__body() { JTextArea body = new JTextArea(); body.setPreferredSize(new Dimension(600, 150)); } public void __init__panels() { JLabel context = new JLabel("Type some text using your keyboard. " + "The keys you press will be highlighed and the text will be displayed.\n " + "Note: Clicking the buttons with your mouse will not perform any action."); context.setFont(new Font("Verdana",Font.BOLD,14)); __init__layout(top, middle, bottom, contextBox); top.setLayout(new BorderLayout()); bottom.setLayout(new GridLayout(5,1)); top.add(context, BorderLayout.WEST); top.add(context, BorderLayout.SOUTH); middle.setLayout( new BorderLayout()); middle.add(body, BorderLayout.WEST); middle.add(body, BorderLayout.CENTER); } public void __init__() { //text area __init__body(); //panels for layout __init__panels(); pack(); //get length of row strings int length_rowOne = rowOne.length; int length_rowTwo = rowTwo.length; int length_rowThree = rowThree.length; int length_rowFour = rowFour.length; int length_rowFive = rowFive.length; //create array for each row of buttons buttons_rowOne = new JButton[length_rowOne]; buttons_rowTwo = new JButton[length_rowTwo]; buttons_rowThree = new JButton[length_rowThree]; buttons_rowFour = new JButton[length_rowFour]; buttons_rowFive = new JButton[length_rowFive]; //create panel for each row of buttons JPanel r1 = new JPanel(new GridLayout(1, length_rowOne)); JPanel r2 = new JPanel(new GridLayout(1, length_rowTwo)); JPanel r3 = new JPanel(new GridLayout(1, length_rowThree)); JPanel r4 = new JPanel(new GridLayout(1, length_rowFour)); JPanel r5 = new JPanel(new GridLayout(1, length_rowFive)); //draw out the rows of buttons draw( r1, length_rowOne, r2, length_rowTwo, r3, length_rowThree, r4, length_rowFour, r5, length_rowFive ); } //draw rows of buttons public void draw(JPanel r1, int s1, JPanel r2, int s2, JPanel r3, int s3, JPanel r4, int s4, JPanel r5, int s5) { for (int i = 0; i < s1; i++) { JButton currentButton = new JButton(rowOne[i]); currentButton.setPreferredSize(new Dimension(100, 50)); buttons_rowOne[i] = currentButton; buttons_rowOne[i].addKeyListener(this); r1.add(buttons_rowOne[i]); } for (int i = 0; i < s2; i++) { JButton currentButton = new JButton(rowOne[i]); currentButton.setPreferredSize(new Dimension(100, 50)); buttons_rowTwo[i] = currentButton; buttons_rowTwo[i].addKeyListener(this); r1.add(buttons_rowTwo[i]); } for (int i = 0; i < s3; i++) { JButton currentButton = new JButton(rowOne[i]); currentButton.setPreferredSize(new Dimension(100, 50)); buttons_rowThree[i] = currentButton; buttons_rowThree[i].addKeyListener(this); r1.add(buttons_rowThree[i]); } for (int i = 0; i < s4; i++) { JButton currentButton = new JButton(rowOne[i]); currentButton.setPreferredSize(new Dimension(100, 50)); buttons_rowFour[i] = currentButton; buttons_rowFour[i].addKeyListener(this); r1.add(buttons_rowFour[i]); } for (int i = 0; i < s5; i++) { JButton currentButton = new JButton(rowOne[i]); //account for space bar if (i == 1) { currentButton = new JButton(rowFive[i]); currentButton.setPreferredSize(new Dimension(400,10)); currentButton.setBounds(10, 10, 600, 100); buttons_rowFive[i] = currentButton; buttons_rowFive[i].addKeyListener(this); } else { currentButton.setPreferredSize(new Dimension(100, 50)); buttons_rowFive[i] = currentButton; buttons_rowFive[i].addKeyListener(this); } r1.add(buttons_rowFive[i]); } bottom.add(r1); bottom.add(r2); bottom.add(r3); bottom.add(r4); bottom.add(r5); }//!draw(...) // called when a button is pressed #Override public void keyPressed(KeyEvent pressed) { JButton current = (JButton) pressed.getSource(); current.setBackground(Color.GRAY); body.append(toString(current.getKeyChar())); }//!keyPressed(...) // called when a button is released #Override public void keyReleased(KeyEvent released) { JButton current = (JButton) released.getSource(); current.setBackground(defaultColor); }//!keyReleased(...) #Override public void keyTyped(KeyEvent typed) { JButton current = (JButton) typed.getSource(); } //main method public static void main(String[] args) { new a3_keyboard(); }//!main method private static final long serialVersionUID = 999; }//!main class Edit 2: import java.awt.*; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import java.awt.event.KeyEvent; import java.awt.event.KeyListener; public class ButtonInPane extends JFrame implements KeyListener { //redacted, see below #Override public void keyPressed(KeyEvent press) { JButton current = (JButton) press.getSource(); current.setBackground(Color.GRAY); StringBuilder sb = new StringBuilder(); sb.append(press.getKeyChar()); body.append(sb.toString()); } // !keyPressed(...) // called when a button is released #Override public void keyReleased(KeyEvent release) { JButton current = (JButton) release.getSource(); current.setBackground(defaultColor); } // !keyReleased(...) #Override public void keyTyped(KeyEvent typed) { JButton current = (JButton) typed.getSource(); } // main method public static void main(String[] args) { new ButtonInPane(); } // !main method private static final long serialVersionUID = 999; } // !main class Edit 3: #Override public void keyPressed(KeyEvent press) { Object current = press.getSource().toString(); for (int i = 0; i < 14; i++) { if (current == rowOne[i]) { buttons_rowOne[i].setBackground(Color.GRAY); } else if (current == rowTwo[i]) { buttons_rowTwo[i].setBackground(Color.GRAY); } else if (current == rowThree[i]) { buttons_rowThree[i].setBackground(Color.GRAY); } else if (current == rowFour[i]) { buttons_rowFour[i].setBackground(Color.GRAY); } else if (current == rowFive[i]) { buttons_rowFive[i].setBackground(Color.GRAY); } } } // !keyPressed(...) // called when a button is released #Override public void keyReleased(KeyEvent release) { Object current = release.getSource().toString(); for (int i = 0; i < 14; i++) { if (current == rowOne[i]) { buttons_rowOne[i].setBackground(defaultColor); } else if (current == rowTwo[i]) { buttons_rowTwo[i].setBackground(defaultColor); } else if (current == rowThree[i]) { buttons_rowThree[i].setBackground(defaultColor); } else if (current == rowFour[i]) { buttons_rowFour[i].setBackground(defaultColor); } else if (current == rowFive[i]) { buttons_rowFive[i].setBackground(defaultColor); } } } // !keyReleased(...) #Override public void keyTyped(KeyEvent typed) { // Object current = typed.getSource().toString(); // StringBuilder sb = new StringBuilder(); // for (int i = 0; i < 14; i++) { // if (current == rowOne[i]) { // sb.append(typed.getKeyCode()); // body.append(sb.toString()); // } else if (current == rowTwo[i]) { // sb.append(typed.getKeyCode()); // body.append(sb.toString()); // } else if (current == rowThree[i]) { // sb.append(typed.getKeyCode()); // body.append(sb.toString()); // } else if (current == rowFour[i]) { // sb.append(typed.getKeyCode()); // body.append(sb.toString()); // } else if (current == rowFive[i]) { // sb.append(typed.getKeyCode()); // body.append(sb.toString()); // } // } }
This version puts the keylistener on the correct component. However you now need to redesign this given your new understanding... Because as the code is right now, the jtext area body simply gets a repeat of the key as you press them. There are several ways you could solve this. Some of the brute force and others more intricate but elegant. Ping me if you still want help. import java.awt.BorderLayout; import java.awt.Color; import java.awt.Dimension; import java.awt.Font; import java.awt.GridLayout; import java.awt.event.KeyEvent; import java.awt.event.KeyListener; import javax.swing.JButton; import javax.swing.JFrame; import javax.swing.JLabel; import javax.swing.JPanel; import javax.swing.JTextArea; public class ButtonInPane extends JFrame implements KeyListener { // input String input; //context JLabel context1, context2; // default color Color defaultColor = new JButton().getBackground(); // main rows of keys public String rowOne[] = { "~", "1", "2", "3", "4", "5", "6", "7", "8", "9", "0", "-", "+", "h" }; public String rowTwo[] = { "Tab", "Q", "W", "E", "R", "T", "Y", "U", "I", "O", "P", "[", "]", "\\" }; public String rowThree[] = { "Caps", "A", "S", "D", "F", "G", "H", "J", "K", "L", ":", "'", "Enter" }; public String rowFour[] = { "Shift", "Z", "X", "C", "V", "B", "N", "M", ",", ".", "?", " ^" }; public String rowFive[] = { " ", "<", "v", ">" }; /** * Account for chars with no shift: Program toggles Shift key, meaning if a * user clicks on it, all keys will be toggled to their respective shift * value. The user can tap the shift key again to change back to regular * value */ public String shiftless[] = { "1", "2", "3", "4", "5", "6", "7", "8", "9", "0", "-", "=", "q", "w", "e", "r", "t", "y", "u", "i", "o", "p", "[", "]", "\\", "a", "s", "d", "f", "g", "h", "j", "k", "l", ";", "z", "x", "c", "v", "b", "n", "m", ",", ".", "/" }; // Account for special chars public String specialChars[] = { "~", "-", "+", "[", "]", "\\", ";", ".", "?" }; // declare rows of buttons public JButton buttons_rowOne[], buttons_rowTwo[], buttons_rowThree[], buttons_rowFour[], buttons_rowFive[]; private JTextArea body; private JPanel top; private JPanel middle; private JPanel bottom; private JPanel contextBox; // ctor public ButtonInPane() { super("Typing Tutor"); this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); this.setResizable(false); this.getContentPane().setPreferredSize(new Dimension(2000, 600)); this.setLocation(50, 50); this.setVisible(true); __init__(); } public void __init__layout(JPanel top, JPanel middle, JPanel bottom, JPanel contextBox) { setLayout(new BorderLayout()); add(top, BorderLayout.NORTH); add(contextBox); add(middle, BorderLayout.CENTER); add(bottom, BorderLayout.SOUTH); } public void __init__body() { body = new JTextArea(); body.setPreferredSize(new Dimension(600, 150)); body.addKeyListener(this); } public void __init__panels() { context1 = new JLabel("Type some text using your keyboard. " + "The keys you press will be highlighed and the text will be displayed."); context2 = new JLabel("\nNote: Clicking the buttons with your mouse will not perform any action."); context1.setFont(new Font("Verdana", Font.BOLD, 14)); context2.setFont(new Font("Verdana", Font.BOLD, 14)); top = new JPanel(); top.setSize(new Dimension(500, 500)); middle = new JPanel(); bottom = new JPanel(); contextBox = new JPanel(); __init__layout(top, middle, bottom, contextBox); top.setLayout(new BorderLayout()); bottom.setLayout(new GridLayout(5, 1)); top.add(context2); top.add(context1); middle.setLayout(new BorderLayout()); middle.add(body, BorderLayout.WEST); middle.add(body, BorderLayout.CENTER); } public void __init__() { // text area __init__body(); // panels for layout __init__panels(); pack(); // get length of row strings int length_rowOne = rowOne.length; int length_rowTwo = rowTwo.length; int length_rowThree = rowThree.length; int length_rowFour = rowFour.length; int length_rowFive = rowFive.length; // create array for each row of buttons buttons_rowOne = new JButton[length_rowOne]; buttons_rowTwo = new JButton[length_rowTwo]; buttons_rowThree = new JButton[length_rowThree]; buttons_rowFour = new JButton[length_rowFour]; buttons_rowFive = new JButton[length_rowFive]; // create panel for each row of buttons JPanel r1 = new JPanel(new GridLayout(1, length_rowOne)); JPanel r2 = new JPanel(new GridLayout(1, length_rowTwo)); JPanel r3 = new JPanel(new GridLayout(1, length_rowThree)); JPanel r4 = new JPanel(new GridLayout(1, length_rowFour)); JPanel r5 = new JPanel(new GridLayout(1, length_rowFive)); // draw out the rows of buttons draw(r1, length_rowOne, r2, length_rowTwo, r3, length_rowThree, r4, length_rowFour, r5, length_rowFive); } // draw rows of buttons public void draw(JPanel r1, int s1, JPanel r2, int s2, JPanel r3, int s3, JPanel r4, int s4, JPanel r5, int s5) { for (int i = 0; i < s1; i++) { JButton currentButton = new JButton(rowOne[i]); currentButton.setPreferredSize(new Dimension(100, 50)); buttons_rowOne[i] = currentButton; r1.add(buttons_rowOne[i]); } for (int i = 0; i < s2; i++) { JButton currentButton = new JButton(rowTwo[i]); currentButton.setPreferredSize(new Dimension(100, 50)); buttons_rowTwo[i] = currentButton; r2.add(buttons_rowTwo[i]); } for (int i = 0; i < s3; i++) { JButton currentButton = new JButton(rowThree[i]); currentButton.setPreferredSize(new Dimension(100, 50)); buttons_rowThree[i] = currentButton; r3.add(buttons_rowThree[i]); } for (int i = 0; i < s4; i++) { JButton currentButton = new JButton(rowFour[i]); currentButton.setPreferredSize(new Dimension(100, 50)); buttons_rowFour[i] = currentButton; r4.add(buttons_rowFour[i]); } for (int i = 0; i < s5; i++) { JButton currentButton = new JButton(rowFive[i]); // account for space bar if (i == 1) { currentButton = new JButton(rowFive[i]); currentButton.setPreferredSize(new Dimension(400, 10)); currentButton.setBounds(10, 10, 600, 100); buttons_rowFive[i] = currentButton; } else { currentButton.setPreferredSize(new Dimension(100, 50)); buttons_rowFive[i] = currentButton; } r5.add(buttons_rowFive[i]); } bottom.add(r1); bottom.add(r2); bottom.add(r3); bottom.add(r4); bottom.add(r5); } // !draw(...) // called when a button is pressed #Override public void keyPressed(KeyEvent press) { StringBuilder sb = new StringBuilder(); sb.append(press.getKeyChar()); body.append(sb.toString()); } // !keyPressed(...) // called when a button is released #Override public void keyReleased(KeyEvent release) { Object current = release.getSource(); } // !keyReleased(...) #Override public void keyTyped(KeyEvent typed) { Object current = typed.getSource(); } // main method public static void main(String[] args) { new ButtonInPane(); } // !main method private static final long serialVersionUID = 999; } // !main class
How to add a scrollpane in the frame window
I want to add a scrollpane in the frame window or comboPanel. Below code, the guiFrame.add(scrollpane) is not working, why it is not working? How can I add the scrollpane to comboPanel or the guiFrame? import java.awt.BorderLayout; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import java.awt.event.ItemEvent; import java.awt.event.ItemListener; import javax.swing.BoxLayout; import javax.swing.JButton; import javax.swing.JComboBox; import javax.swing.JFrame; import javax.swing.JLabel; import javax.swing.JPanel; public class ExtraComboBox { private int maxFields = 4; // The max number of fields allowed in the dialog JComboBox fruits[] = new JComboBox[maxFields]; JPanel comboPanel; JFrame guiFrame; String[] valOptions3 = { "&" }; String[] valOptions2 = { "|->", "|=>" }; String[] valOptions1 = { "0", "1", "2", "3", "4", "5", "6", "7", "8", "9" }; String[] valOptions0 = { "0", "1", "2", "3", "4", "5", "6", "7", "8", "9" }; String[] fruitOptions1 = { "", "Delay1", "Delay2", "Delay3" }; JButton addField; int count1 = 0; JLabel dudel[] = new JLabel[maxFields]; JComboBox dude2[] = new JComboBox[maxFields]; String[] valOptions = { "Unknown", "0", "1" }; String[] s = { "a", "b", "c", "d", "e", "f", "g", "h", "i" }; private JLabel comboLbl; public static void main(String[] args) { new ExtraComboBox(); } public ExtraComboBox() { guiFrame = new JFrame(); // make sure the program exits when the frame closes guiFrame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); guiFrame.setTitle("ComboBox GUI"); guiFrame.setSize(350, 350); // The first JPanel contains a JLabel and JCombobox comboPanel = new JPanel(); addField = new JButton("Add Field"); addField.addActionListener(new ActionListener() { #Override public void actionPerformed(ActionEvent event) { if (event.getSource().equals(addField)) { if (count1 < maxFields) { comboLbl = new JLabel("Select a relation:"); fruits[count1] = new JComboBox<String>(fruitOptions1); MyItemListener2 actionListener2 = new MyItemListener2(count1); fruits[count1].addItemListener(actionListener2); // System.out.println("HI: " + fruits[count1].getParent()); dude2[count1] = new JComboBox<String>(); System.out.println("ADD FIELDS: " + count1); comboPanel.add(comboLbl); comboPanel.add(fruits[count1]); comboPanel.add(dude2[count1]); guiFrame.validate(); guiFrame.repaint(); count1++; } else { System.out.println("You reached the maximum of 4 fields."); } } } }); comboPanel.setLayout(new BoxLayout(comboPanel, BoxLayout.Y_AXIS)); comboPanel.add(addField); // The JFrame uses the BorderLayout layout manager. // Put the two JPanels and JButton in different areas. guiFrame.add(comboPanel, BorderLayout.NORTH); // make sure the JFrame is visible guiFrame.setVisible(true); } class MyItemListener2 implements ItemListener { private int index; public MyItemListener2(int pIndex) { super(); index = pIndex; } // This method is called only if a new item has been selected. public void itemStateChanged(ItemEvent evt) { if (evt.getStateChange() == ItemEvent.SELECTED) { // Item was just selected System.out.println("COUNTER: " + index); System.out.println(evt.getItem()); dude2[index].removeAllItems(); switch ((String) evt.getItem()) { case "Delay1": for (int i = 0; i < valOptions1.length; i++) { dude2[index].addItem(valOptions1[i]); // dude1 = new JComboBox(valOptions1); System.out.println(valOptions1[i]); } break; case "Delay2": for (int j = 0; j < valOptions2.length; j++) { System.out.println(valOptions2[j]); dude2[index].addItem(valOptions2[j]); // dude1 = new JComboBox(valOptions1); } break; case "Delay3": for (int j = 0; j < valOptions3.length; j++) { System.out.println(valOptions3[j]); dude2[index].addItem(valOptions3[j]); // dude1 = new JComboBox(valOptions1); } } } } } }
How can I add the scrollpane to comboPanel or the guiFrame? You add the comboPanel to the JViewport of the JScrollPane and then you add the scroll pane to the JFrame. //guiFrame.add(comboPanel, BorderLayout.NORTH); JScrollPane scrollPane = new JScrollPane( comboPanel ); guiFrame.add(scrollPane, BorderLayout.CENTER); It is better to add the scrollpane to the CENTER, then it will get all the space available to the frame.
Retriving the String accosiated with a JCheckBox
I have a lottery game problem and I am able to count the number of checked boxes correctly but I do not understand how to get the String number assigned to the JcheckBox. I thought I could use .getText but that did not work. I am not sure if I am using the proper listener. import java.awt.BorderLayout; import java.awt.Color; import java.awt.Container; import java.awt.FlowLayout; import java.awt.Font; import java.awt.GridLayout; import java.awt.event.ItemEvent; import java.awt.event.ItemListener; import javax.swing.JButton; import javax.swing.JCheckBox; import javax.swing.JFrame; import javax.swing.JLabel; import javax.swing.JPanel; public class JLottery2 extends JFrame implements ItemListener { private String[] lotteryNumbers = { "1", "2", "3", "4", "5", "6", "7", "8", "9", "10", "11", "12", "13", "14", "15", "16", "17", "18", "19", "20", "21", "22", "23", "24", "25", "26", "27", "28", "29", "30" }; private JPanel jp1 = new JPanel(); private JPanel jp2 = new JPanel(); private JPanel jp3 = new JPanel(new GridLayout(3, 10, 5, 5)); private JLabel jl1 = new JLabel("The Lottery Game!!!!!"); private JLabel jl2 = new JLabel( "To play, pick six number that match the randomly selected numbers."); private FlowLayout layout = new FlowLayout(); private GridLayout gridBase = new GridLayout(3, 1, 5, 5); private GridLayout grid = new GridLayout(3, 10, 5, 5); private Font heading = new Font("Palatino Linotype", Font.BOLD, 24); private Font bodyText = new Font("Palatino Linotype", Font.BOLD, 14); private Color color1 = new Color(4, 217, 225); private Color color2 = new Color(4, 225, 129); private int maxNumber = 6; private int counter = 0; private int[] randomNum; private String[] userPickedNumbers; Container con = getContentPane(); public JLottery2() { super("The Lottery Game"); con.setLayout(gridBase); con.add(jp1); jp1.setLayout(layout); jp1.add(jl1); jl1.setFont(heading); jp1.setBackground(color1); con.add(jp2); jp2.setLayout(layout); jp2.add(jl2); jl2.setFont(bodyText); jp2.setBackground(color1); con.add(jp3); jp3.setLayout(grid); for (int i = 0; i < lotteryNumbers.length; i++) { JCheckBox checkBox[] = new JCheckBox[lotteryNumbers.length]; checkBox[i] = new JCheckBox(lotteryNumbers[i]); jp3.add(checkBox[i]); jp3.setBackground(color2); checkBox[i].addItemListener(this); } setSize(500, 300); setDefaultCloseOperation(EXIT_ON_CLOSE); } public void randNumber() { randomNum = new int[maxNumber]; for (int i = 0; i < maxNumber; i++) { randomNum[i] = ((int) (Math.random() * 100) % lotteryNumbers.length + 1); System.out.println(randomNum[i]); } } public static void main(String[] args) { JLottery2 frame = new JLottery2(); frame.setVisible(true); } public void itemStateChanged(ItemEvent e) { if (e.getStateChange() == ItemEvent.SELECTED && counter < maxNumber) { counter++; System.out.println("add"); System.out.println(counter); } else if (e.getStateChange() == ItemEvent.DESELECTED && counter < maxNumber) { counter--; System.out.println("deduct"); System.out.println(counter); } if (counter == maxNumber) { System.out.println("max"); jp3.setVisible(false); randNumber(); System.out.println(userPickedNumbers); } } }
((JCheckBox)e.getSource()).getText() works fine for me with your code.
Changing ImageIcon to another picture with button click
So I want to replace an ImageIcon in a JLabel every time a button is pressed. I made it so the image, label, and GridBagConstraints are public. When I try to change it though nothing happens. Am I going about this the wrong way or? Thanks! package hi.low; import java.awt.*; import java.awt.event.*; import java.util.ArrayList; import javax.swing.*; import java.util.Random; import java.util.ArrayList; public class Card_panel extends JPanel implements ActionListener { private final int WIDTH = 400, HEIGHT = 200; private static String[] imageList = { "images/2h.png", "images/3h.png", "images/4h.png", "images/5h.png", "images/6h.png", "images/7h.png", "images/8h.png", "images/9h.png", "images/th.png", "images/jh.png", "images/qh.png", "images/kh.png", "images/ah.png", "images/2d.png", "images/3d.png", "images/4d.png", "images/5d.png", "images/6d.png", "images/7d.png", "images/8d.png", "images/9d.png", "images/td.png", "images/jd.png", "images/qd.png", "images/kd.png", "images/ad.png", "images/2c.png", "images/3c.png", "images/4c.png", "images/5c.png", "images/6c.png", "images/7c.png", "images/8c.png", "images/9c.png", "images/tc.png", "images/jc.png", "images/qc.png", "images/kc.png", "images/ac.png", "images/2s.png", "images/3s.png", "images/4s.png", "images/5s.png", "images/6s.png", "images/7s.png", "images/8s.png", "images/9s.png", "images/ts.png", "images/js.png", "images/qs.png", "images/ks.png", "images/as.png" }; private static int imageNum = -1; GridBagConstraints gbc = new GridBagConstraints(); GridBagConstraints c = new GridBagConstraints(); ImageIcon image; JLabel label; private static ArrayList<Card> deck; private static Card tempCard, currentCard; public Card_panel() { deck = new ArrayList(); char[] suits = {'h', 'd', 'c', 's'}; char[] values = {'2', '3', '4', '5', '6', '7', '8', '9', 't', 'j', 'q', 'k', 'a'}; for(int a = 0; a<suits.length; a++) { for(int b = 0; b<values.length; b++) { tempCard = new Card(suits[a],values[b]); deck.add(tempCard); } } int rand_num; int cards_left = 52; Random generator = new Random( System.currentTimeMillis() ); for(int a = 0; a<52; a++) { rand_num = generator.nextInt(cards_left); currentCard = deck.get(rand_num); deck.remove(rand_num); cards_left -= 1; } setPreferredSize(new Dimension(WIDTH, HEIGHT)); setBackground (Color.green.darker().darker()); setLayout(new GridBagLayout()); gbc.gridx = 0; gbc.gridy = 0; gbc.gridwidth = 2; image = new ImageIcon(imageList[0]); label = new JLabel("", image, JLabel.CENTER); add( label, gbc ); gbc.gridx = 0; gbc.gridy++; gbc.gridwidth = 1; JButton higher = new JButton("Higher"); higher.setActionCommand("higher"); higher.addActionListener (this); add( higher, gbc ); gbc.gridx++; JButton lower = new JButton("Lower"); lower.setActionCommand("lower"); lower.addActionListener (this); add( lower, gbc ); } #Override public void actionPerformed(ActionEvent e) { String Action; Action = e.getActionCommand (); if (Action.equals ("higher")) { System.out.println("User chose higher!"); //function to check if it is right if right go to next card image = new ImageIcon(imageList[1]); label = new JLabel("", image, JLabel.CENTER); add( label, gbc ); } if (Action.equals ("lower")) { System.out.println("User chose lower!"); //function to check if it is right if right go to next card } } }
Rather then trying to create and add a new label each time, simply call setIcon on the label itself Something more like... image = new ImageIcon(imageList[1]); label.setIcon(image); Check out How to use lables for more details. I might also suggest that you load the images first, so you don't need to keep reloading them/creating new objects on each actionPerformed I'd also recommend ImageIO over ImageIcon
Can't drag to resize JTable columns
Long story short, I'm making a custom Swing component that's basically a JTable with a panel on its side. The table should of course be scrollable and have a table header, but since I only want the header to be above the actual JTable and not above the side panel, I had to pull some tricks to make it work. But that part works fine. However, in the process I've somehow managed to break the mouse-drag-column-resizing functionality of the JTableHeader. I am completely clueless as to why and what I can do about it. Below is a minimal working sample to illustrate my problem. import java.awt.Dimension; import java.awt.Rectangle; import java.awt.event.ComponentAdapter; import java.awt.event.ComponentEvent; import javax.swing.JFrame; import javax.swing.JPanel; import javax.swing.JScrollPane; import javax.swing.JViewport; import javax.swing.Scrollable; import javax.swing.table.JTableHeader; final class FooTable extends JPanel implements Scrollable { public FooTable() { initComponents(); } // Generated by NetBeans IDE #SuppressWarnings("unchecked") // <editor-fold defaultstate="collapsed" desc="Generated Code"> private void initComponents() { java.awt.GridBagConstraints gridBagConstraints; sidePanel = new javax.swing.JPanel(); table = new javax.swing.JTable(); setLayout(new java.awt.GridBagLayout()); sidePanel.setMinimumSize(new java.awt.Dimension(70, 0)); sidePanel.setPreferredSize(new java.awt.Dimension(70, 0)); sidePanel.setLayout(null); gridBagConstraints = new java.awt.GridBagConstraints(); gridBagConstraints.gridx = 0; gridBagConstraints.gridy = 0; gridBagConstraints.fill = java.awt.GridBagConstraints.BOTH; gridBagConstraints.anchor = java.awt.GridBagConstraints.NORTHWEST; gridBagConstraints.weighty = 1.0; add(sidePanel, gridBagConstraints); table.setFont(table.getFont().deriveFont(table.getFont().getSize()+1f)); table.setModel(new javax.swing.table.DefaultTableModel( new Object [][] { {"1", "A", "I", "-"}, {"2", "B", "II", "--"}, {"3", "C", "III", "---"}, {"4", "D", "IV", "----"}, {"5", "E", "V", "-----"}, {"6", "F", "VI", "------"}, {"7", "G", "VII", "-------"}, {"8", "H", "VIII", "--------"}, {"9", "I", "IX", "---------"}, {"10", "J", "X", "----------"} }, new String [] { "Column 1", "Column 2", "Column 3", "Column 4" } )); table.setRowHeight(24); table.setSelectionMode(javax.swing.ListSelectionModel.MULTIPLE_INTERVAL_SELECTION); gridBagConstraints = new java.awt.GridBagConstraints(); gridBagConstraints.gridx = 1; gridBagConstraints.gridy = 0; gridBagConstraints.fill = java.awt.GridBagConstraints.BOTH; gridBagConstraints.anchor = java.awt.GridBagConstraints.NORTHWEST; gridBagConstraints.weightx = 1.0; add(table, gridBagConstraints); }// </editor-fold> public JScrollPane createScrollView() { JScrollPane jsp = new JScrollPane(this); JViewport jvp = new JViewport(); final JTableHeader th = new JTableHeader(); th.setTable(table); th.setColumnModel(table.getColumnModel()); th.setResizingAllowed(true); jvp.setView(new JPanel() { { setLayout(null); add(th); th.setLocation(70, 0); FooTable.this.addComponentListener(new ComponentAdapter() { #Override public void componentResized(ComponentEvent e) { th.setSize(FooTable.this.getWidth(), th.getPreferredSize().height); } }); setPreferredSize(new Dimension(th.getPreferredSize().width, th.getPreferredSize().height)); } }); jsp.setColumnHeader(jvp); return jsp; } // Variables declaration - do not modify private javax.swing.JPanel sidePanel; private javax.swing.JTable table; // End of variables declaration // // Scrollable implementation // public Dimension getPreferredScrollableViewportSize() { Dimension d = new Dimension(); d.width = sidePanel.getPreferredSize().width + table.getPreferredSize().width; d.height = sidePanel.getPreferredSize().height + table.getPreferredSize().height; return d; } public int getScrollableUnitIncrement(Rectangle visibleRect, int orientation, int direction) { return table.getScrollableUnitIncrement(visibleRect, orientation, direction); } public int getScrollableBlockIncrement(Rectangle visibleRect, int orientation, int direction) { return table.getScrollableBlockIncrement(visibleRect, orientation, direction); } public boolean getScrollableTracksViewportWidth() { return table.getScrollableTracksViewportWidth(); } public boolean getScrollableTracksViewportHeight() { return table.getScrollableTracksViewportHeight(); } // // Test program // public static void main(String[] args) { JFrame f = new JFrame(); f.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); FooTable fooTable = new FooTable(); f.add(fooTable.createScrollView()); f.pack(); f.setVisible(true); } }
I think what you are missing is also telling the JTable about the JTableHeader. In the method createScrollView try adding the following just before returning: table.setTableHeader(th);