Jython - Gestion des événements
La gestion des événements dans Java swing nécessite que le contrôle (comme JButton ou JList, etc.) soit enregistré auprès de l'écouteur d'événements respectif. L'interface d'écouteur d'événements ou la classe Adapter correspondante doit être implémentée ou sous-classée avec sa méthode de gestion des événements remplacée. En Jython, la gestion des événements est très simple. Nous pouvons passer n'importe quelle fonction en tant que propriété de la fonction de gestion d'événements correspondant au contrôle.
Voyons d'abord comment un événement de clic est géré en Java.
Pour commencer, nous devons importer le java.awt.event package. Ensuite, la classe étendant JFrame doit implémenter l'interface ActionListener.
public class btnclick extends JFrame implements ActionListener
Ensuite, nous devons déclarer l'objet JButton, l'ajouter au ContentPane du frame puis l'enregistrer avec ActionListener par la méthode addActionListener ().
JButton b1 = new JButton("Click here");
getContentPane().add(b1);
b1.addActionListener(this);
Désormais, la méthode actionPerformed () de l'interface ActionListener doit être remplacée pour gérer l'événement ActionEvent.
Voici tout le code Java -
import java.awt.event.*;
import javax.swing.*;
public class btnclick extends JFrame implements ActionListener {
btnclick() {
JButton b1 = new JButton("Click here");
getContentPane().add(b1);
b1.addActionListener(this);
}
public void actionPerformed(ActionEvent e) {
System.out.println("Clicked");
}
public static void main(String args[]) {
btnclick b = new btnclick();
b.setSize(300,200);
b.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
b.setVisible(true);
}
}
Maintenant, nous allons écrire le code Jython équivalent au même code.
Pour commencer, nous n'avons pas besoin d'importer l'ActionEvent ou l'ActionListener, puisque le typage dynamique de Jython nous permet d'éviter de mentionner ces classes dans notre code.
Deuxièmement, il n'est pas nécessaire d'implémenter ou de sous-classer ActionListener. Au lieu de cela, toute fonction définie par l'utilisateur est immédiatement fournie au constructeur JButton en tant que valeur deactionPerformed propriété de haricot.
button = JButton('Click here!', actionPerformed = clickhere)
le clickhere() La fonction est définie comme une fonction Jython standard, qui gère l'événement click sur le bouton.
def change_text(event):
print clicked!'
Voici le code équivalent Jython.
from javax.swing import JFrame, JButton
frame = JFrame("Hello")
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE)
frame.setLocation(100,100)
frame.setSize(300,200)
def clickhere(event):
print "clicked"
btn = JButton("Add", actionPerformed = clickhere)
frame.add(btn)
frame.setVisible(True)
La sortie du code Java et Jython est identique. Lorsque le bouton est cliqué, il imprimera le message «cliqué» sur la console.
Dans le code Jython suivant, deux objets JTextField sont fournis dans la fenêtre JFrame pour entrer des marques dans «phy» et «maths». L'objet JButton exécute la fonction add () lorsque l'utilisateur clique dessus.
btn = JButton("Add", actionPerformed = add)
La fonction add () lit le contenu de deux champs de texte par la méthode getText () et les analyse en entiers, de sorte que l'addition puisse être effectuée. Le résultat est ensuite placé dans le troisième champ de texte par la méthode setText ().
def add(event):
print "add"
ttl = int(txt1.getText())+int(txt2.getText())
txt3.setText(str(ttl))
Le code complet est donné ci-dessous -
from javax.swing import JFrame, JLabel, JButton, JTextField
from java.awt import Dimension
frame = JFrame("Hello")
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE)
frame.setLocation(100,100)
frame.setSize(300,200)
frame.setLayout(None)
def add(event):
print "add"
ttl = int(txt1.getText())+int(txt2.getText())
txt3.setText(str(ttl))
lbl1 = JLabel("Phy")
lbl1.setBounds(60,20,40,20)
txt1 = JTextField(10)
txt1.setBounds(120,20,60,20)
lbl2 = JLabel("Maths")
lbl2.setBounds(60,50,40,20)
txt2 = JTextField(10)
txt2.setBounds(120, 50, 60,20)
btn = JButton("Add", actionPerformed = add)
btn.setBounds(60,80,60,20)
lbl3 = JLabel("Total")
lbl3.setBounds(60,110,40,20)
txt3 = JTextField(10)
txt3.setBounds(120, 110, 60,20)
frame.add(lbl1)
frame.add(txt1)
frame.add(lbl2)
frame.add(txt2)
frame.add(btn)
frame.add(lbl3)
frame.add(txt3)
frame.setVisible(True)
Lorsque le code ci-dessus est exécuté à partir de l'invite de commande, la fenêtre suivante apparaît. Entrez des marques pour «Phy», Maths »et cliquez sur le bouton« Ajouter ». Le résultat sera affiché en conséquence.
Événement Jython JRadioButton
La classe JRadioButton est définie dans le javax.swing package. Il crée un bouton à bascule sélectionnable avec des états d'activation ou de désactivation. Si plusieurs boutons radio sont ajoutés dans un ButtonGroup, leur sélection est mutuellement exclusive.
Dans l'exemple suivant, deux objets de la classe JRadioButton et deux JLabels sont ajoutés à un conteneur Jpanel dans un BoxLayout vertical. Dans le constructeur des objets JRadioButton, leOnCheck()function est définie comme la valeur de la propriété actionPerformed. Cette fonction est exécutée lorsque le bouton radio est cliqué pour changer son état.
rb1 = JRadioButton("Male", True,actionPerformed = OnCheck)
rb2 = JRadioButton("Female", actionPerformed = OnCheck)
Notez que l'état par défaut du bouton radio est faux (non sélectionné). Le bouton rb1 est créé avec son état de départ True (sélectionné).
Les deux boutons radio sont ajoutés à un ButtonGroup radio pour les rendre mutuellement exclusifs, de sorte que si l'un est sélectionné, l'autre est automatiquement désélectionné.
grp = ButtonGroup()
grp.add(rb1)
grp.add(rb2)
Ces deux boutons radio ainsi que deux étiquettes sont ajoutés à un objet de panneau dans la disposition verticale avec une zone de séparation de 25 pixels en hauteur entre rb2 et lbl2.
panel = JPanel()
panel.setLayout(BoxLayout(panel, BoxLayout.Y_AXIS))
panel.add(Box.createVerticalGlue())
panel.add(lbl)
panel.add(rb1)
panel.add(rb2)
panel.add(Box.createRigidArea(Dimension(0,25)))
panel.add(lbl1)
Ce panneau est ajouté à un objet JFrame de niveau supérieur, dont la propriété visible est définie sur «True» à la fin.
frame = JFrame("JRadioButton Example")
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE)
frame.setLocation(100,100)
frame.setSize(250,200)
frame.setVisible(True)
The complete code of radio.py is given below:
from javax.swing import JFrame, JPanel, JLabel, BoxLayout, Box
from java.awt import Dimension
from javax.swing import JRadioButton,ButtonGroup
frame = JFrame("JRadioButton Example")
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE)
frame.setLocation(100,100)
frame.setSize(250,200)
panel = JPanel()
panel.setLayout(BoxLayout(panel, BoxLayout.Y_AXIS))
frame.add(panel)
def OnCheck(event):
lbl1.text = ""
if rb1.isSelected():
lbl1.text = lbl1.text+"Gender selection : Male"
else:
lbl1.text = lbl1.text+"Gender selection : Female "
lbl = JLabel("Select Gender")
rb1 = JRadioButton("Male", True,actionPerformed = OnCheck)
rb2 = JRadioButton("Female", actionPerformed = OnCheck)
grp = ButtonGroup()
grp.add(rb1)
grp.add(rb2)
lbl1 = JLabel("Gender Selection :")
panel.add(Box.createVerticalGlue())
panel.add(lbl)
panel.add(rb1)
panel.add(rb2)
panel.add(Box.createRigidArea(Dimension(0,25)))
panel.add(lbl1)
frame.setVisible(True)
Exécutez le script Jython ci-dessus et modifiez la sélection du bouton radio. La sélection apparaîtra dans l'étiquette en bas.
Événement Jython JCheckBox
Comme le JRadioButton, L'objet JCheckBox est également un bouton sélectionnable avec une case à cocher rectangulaire en plus de sa légende. Ceci est généralement utilisé pour donner à l'utilisateur la possibilité de sélectionner plusieurs options dans la liste des éléments.
Dans l'exemple suivant, deux cases à cocher et une étiquette du package swing sont ajoutées à un JPanel dans BoxLayout vertical. L'étiquette en bas affiche l'état de sélection instantané de deux cases à cocher.
Les deux cases à cocher sont déclarées avec le constructeur dont la propriété actionPerformed est définie sur OnCheck() fonction.
box1 = JCheckBox("Check1", actionPerformed = OnCheck)
box2 = JCheckBox("Check2", actionPerformed = OnCheck)
La fonction OnCheck () vérifie l'état de sélection de chaque case à cocher et affiche le message correspondant sur l'étiquette en bas.
def OnCheck(event):
lbl1.text = ""
if box1.isSelected():
lbl1.text = lbl1.text + "box1 selected "
else:
lbl1.text = lbl1.text + "box1 not selected "
if box2.isSelected():
lbl1.text = lbl1.text + "box2 selected"
else:
lbl1.text = lbl1.text + "box2 not selected"
Ces boîtes et un objet JLabel sont ajoutés à un JPanel avec un espace réservé de 50 pixels de hauteur ajouté entre eux.
panel = JPanel()
panel.setLayout(BoxLayout(panel, BoxLayout.Y_AXIS))
panel.add(Box.createVerticalGlue())
panel.add(box1)
panel.add(box2)
panel.add(Box.createRigidArea(Dimension(0,50)))
panel.add(lbl1)
Le panneau lui-même est ajouté à une fenêtre JFrame de niveau supérieur, dont la propriété visible est définie sur true à la fin.
frame = JFrame("JCheckBox Example")
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE)
frame.setLocation(100,100)
frame.setSize(250,150)
frame.add(panel)
frame.setVisible(True)
Exécutez le code ci-dessus et testez la sélection de cases à cocher. L'état instantané des deux cases à cocher est affiché en bas.
Événement JList Jython
Le contrôle JList dans le package swing fournit à l'utilisateur une liste déroulante d'éléments à choisir. La JComboBox fournit une liste déroulante d'éléments. En Java, l'événement de sélection est traité en implémentant la méthode valueChanged () dans ListSelectionListener. En Jython, un gestionnaire d'événements est affecté à la propriété valueChanged de l'objet JList.
Dans l'exemple suivant, un objet JList et une étiquette sont ajoutés à un JFrame dans BorderLayout. La JList est remplie avec une collection d'éléments dans un tuple. Sa propriété valueChanged est définie sur la fonction listSelect ().
lang = ("C", "C++", "Java", "Python", "Perl", "C#", "VB", "PHP", "Javascript", "Ruby")
lst = JList(lang, valueChanged = listSelect)
La fonction de gestionnaire d'événements obtient l'index de l'élément sélectionné et extrait l'élément correspondant de l'objet JList à afficher sur l'étiquette en bas.
def listSelect(event):
index = lst.selectedIndex
lbl1.text = "Hello" + lang[index]
Les objets JList et JLabel sont ajoutés au JFrame à l'aide de BorderLayout.
Le code complet est donné ci-dessous -
from javax.swing import JFrame, JPanel, JLabel, JList
from java.awt import BorderLayout
frame = JFrame("JList Example")
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE)
frame.setLocation(100,100)
frame.setSize(300,250)
frame.setLayout(BorderLayout())
def listSelect(event):
index = lst.selectedIndex
lbl1.text = "Hello" + lang[index]
lang = ("C", "C++", "Java", "Python", "Perl", "C#", "VB", "PHP", "Javascript", "Ruby")
lst = JList(lang, valueChanged = listSelect)
lbl1 = JLabel("box1 not selected box2 not selected")
frame.add(lst, BorderLayout.NORTH)
frame.add(lbl1, BorderLayout.SOUTH)
frame.setVisible(True)
La sortie du code suivant est la suivante.