This shows you the differences between two versions of the page.
poo:breviare:breviar-10 [2018/11/27 15:52] matei.teodorescu |
poo:breviare:breviar-10 [2020/12/10 13:47] (current) carmen.odubasteanu |
||
---|---|---|---|
Line 1: | Line 1: | ||
====== Breviar ====== | ====== Breviar ====== | ||
- | ===== Laborator 10 - Interfete ===== | + | ===== Laborator 10 - Interfete grafice ===== |
* Responsabil: [[mihai.nan.cti@gmail.com|Mihai Nan]] | * Responsabil: [[mihai.nan.cti@gmail.com|Mihai Nan]] | ||
Line 40: | Line 40: | ||
super(text); | super(text); | ||
setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); | setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); | ||
- | setMinimumSize(new Dimension (3 0 0, 2 0 0)); | + | setMinimumSize(new Dimension (300, 200)); |
getContentPane().setBackground (Color.blue); | getContentPane().setBackground (Color.blue); | ||
setLayout(new SpringLayout()); | setLayout(new SpringLayout()); | ||
Line 63: | Line 63: | ||
Un buton poate fi creat folosind clasa **//JButton//**. De obicei, butonul este contruit | Un buton poate fi creat folosind clasa **//JButton//**. De obicei, butonul este contruit | ||
folosind unul dintre constructorii: | folosind unul dintre constructorii: | ||
+ | * public JButton(); -> un buton fara text | ||
+ | * public JButton(String text) -> un buton cu text dat ca parametru | ||
+ | * public JButton(String text, Icon ico) -> buton cu text si imagine | ||
+ | |||
- | * **//public JButton(); // un buton fara text//** | ||
- | * **//public JButton(String text) // un buton cu text dat ca parametru//** | ||
- | * **//public JButton(String text, Icon ico) // buton cu text si imagine//** | ||
Textul de pe buton poate fi modificat folosind metoda **//setText(String text)//** sau poate fi preluat folosind metoda **//getText()//**. Metodele **//setLabel()//** si **//getLabel()//** sunt considerate obsolete si nu se mai folosesc in prezent. | Textul de pe buton poate fi modificat folosind metoda **//setText(String text)//** sau poate fi preluat folosind metoda **//getText()//**. Metodele **//setLabel()//** si **//getLabel()//** sunt considerate obsolete si nu se mai folosesc in prezent. | ||
+ | <code java> | ||
+ | |||
+ | class Button extends JFrame implements ActionListener{ | ||
+ | private JButton button; | ||
+ | |||
+ | public Button(String text){ | ||
+ | super(text); | ||
+ | setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); | ||
+ | setMinimumSize(new Dimension(300, 200)); | ||
+ | getContentPane().setBackground(Color.blue); | ||
+ | setLayout(new SpringLayout()); | ||
+ | button = new JButton("Apasa"); | ||
+ | button.addActionListener(this); | ||
+ | add(button); | ||
+ | show(); | ||
+ | pack(); | ||
+ | } | ||
+ | |||
+ | public static void main (String args[]){ | ||
+ | Button b = new Button ("LaboratorPOO"); | ||
+ | } | ||
+ | |||
+ | @Override | ||
+ | public void actionPerformed(ActionEvent e){ | ||
+ | |||
+ | /* | ||
+ | JButton button = (JButton)e.getSource(); | ||
+ | if (button.getText().equals("Apasa")) // valabil daca aveam mai multe butoane ascultate de acest ascultator | ||
+ | */ | ||
+ | System.out.println("Butonul a fost apasat ! " ) ; | ||
+ | } | ||
+ | } | ||
+ | |||
+ | </code> | ||
+ | |||
+ | Din moment ce butonul reprezinta o componenta, poate fi adaugat pe un container folosind metoda **//add(Component c)//** a containerului. Butonul **//JButton//** este sensibil la evenimente de tip **//ActionEvent//**, asadar, modalitatea de atasare a ascultatorilor si de creare evenimente este similara butoanelor **//Button//** din pachetul **//java.awt//**. | ||
+ | |||
+ | === Crearea componentelor text === | ||
+ | |||
+ | <code java> | ||
+ | |||
+ | class Text extends JFrame implements ActionListener{ | ||
+ | private JButton button; | ||
+ | private JTextField user; | ||
+ | private JPasswordField pass; | ||
+ | |||
+ | public Text (String text){ | ||
+ | super(text); | ||
+ | setDefaultCloseOperation (JFrame.EXIT_ON_CLOSE); | ||
+ | setMinimumSize(new Dimension(300, 200)); | ||
+ | getContentPane().setBackground(Color.blue); | ||
+ | setLayout(new FlowLayout()); | ||
+ | button = new JButton ("Apasa"); | ||
+ | button.addActionListener(this); | ||
+ | add(button); | ||
+ | user = new JTextField(15); | ||
+ | add(user); | ||
+ | pass = new JPasswordField(15); | ||
+ | add(pass); | ||
+ | show(); | ||
+ | pack(); | ||
+ | } | ||
+ | |||
+ | public static void main (String args[]){ | ||
+ | Text b = new Text ("LaboratorPOO"); | ||
+ | } | ||
+ | |||
+ | @Override | ||
+ | public void actionPerformed(ActionEvent e){ | ||
+ | /* | ||
+ | JButton button = (JButton)e.getSource(); | ||
+ | if (button.getText().equals("Apasa")) // valabil daca aveam mai multe butoane ascultate de acest ascultator | ||
+ | */ | ||
+ | System.out.println(user.getText() + pass.getText()); | ||
+ | } | ||
+ | } | ||
+ | |||
+ | </code> | ||
+ | |||
+ | Vom folosi trei tipuri de componete text: **//JTextField//**, **//JTextArea//** si **//JPasswordField//**. Componenta **//JTextFiled//** este un camp de text cu un singur rand pe care pot incapea mai multe caractere. In general, aceasta componenta este folosita pentru a introduce un text de dimensiuni mici. Componenta **//JTextArea//** este un camp de text care permite introducerea unui text pe mai multe randuri, deci, aceasta componenta este folosita pentru texte de dimensiuni mai mari. Componenta **//JPasswordField//** este similara componentei **//JTextField//**, doar ca, aceasta ascunde caracterele introduse de utilizator ca in cazul unui camp pentru introducerea parolei obisnuit. | ||
+ | |||
+ | Metoda folosita pentru preluarea textului dintr-o componenta text este: **//getText()//** care returneaza o instanta de **//String//**. Pentru a modifica textul dintrun camp de text, se foloseste metoda **//setText(String text)//**. Componenta **//JTextArea//** are in comportament si metoda **//append(String text)//** care permite adaugarea unui text la componenta. | ||
+ | |||
+ | === Butoane de selectie === | ||
+ | |||
+ | Clasele **//JCheckBox//** si **//JRadioButton//** definesc componente de tip butoane de selectie. Standard, butoanele **//JCheckBox//** sunt folosite pentru a crea liste de optiuni de tip multiple-choice (din care poti selecta mai multe variante), iar **//JRadioButton//** pentru crearea de liste de tip single-choice (din care se poate selecta o singura optiune). Astfel, pentru butoanele **//JRadioButton//** adaugam o noua clasa **//ButtonGroup//** cu ajutorul careia precizam care sunt butoanele din care se selecteaza o singura optiune. **//ButtonGroup//** defineste un grup de butoane. Din butoanele ce apartin aceluiasi grup, nu putem selecta decat o singura optiune. | ||
+ | |||
+ | Ambele tipuri de componente se creaza similar butoanelor **//JButton//**. In general, acestea nu sunt folosite cu evenimente si prin verificari ale starilor acestora (se verifica daca este sau nu select la un anumit eveniment). Verificarea starii unei astfel de componente se face folosind medoda **//isSelected()//** care returneaza **//true//** daca butonul este bifat si **//false//** daca nu este bifat. | ||
+ | |||
+ | <note important> | ||
+ | Pentru o intelegere mai buna, se recomanda analizarea exemplelor propuse in arhiva laboratorului. | ||
+ | </note> | ||
+ | |||
+ | === JScrollPane === | ||
+ | |||
+ | **//JScrollPane//** este o componenta folosita pentru adaugarea de bare de defilare pentru o alta componenta care ar putea depasi dimensiunile containerului in care este adaugata. Instanta **//JScrollPane//** nu este folosita in actiunile directe pe care le are componenta pe care o sustine. La construire instantei, i se da o componenta pentru care este creata si pe care adauga bare de defilare (scrollbars). Apoi, instanta **//JScrollPane//** este adaugata pe container in locul componentei din instanta **//JScrollPane//**. | ||
+ | |||
+ | <code java> | ||
+ | |||
+ | class Text extends JFrame{ | ||
+ | private JTextArea textArea; | ||
+ | private JScrollPane scroll; | ||
+ | |||
+ | public Text (String text){ | ||
+ | super(text); | ||
+ | setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); | ||
+ | setMinimumSize(new Dimension(300, 200)); | ||
+ | getContentPane().setBackground(Color.blue); | ||
+ | setLayout(new FlowLayout()); | ||
+ | textArea = new JTextArea(200, 100); | ||
+ | textArea.setLineWrap(true); | ||
+ | textArea.setWrapStyleWord(true); | ||
+ | textArea.setFont(new Font("Tahoma", 2, 1 2)); | ||
+ | scroll = new JScrollPane(textArea); | ||
+ | add(scroll); | ||
+ | show(); | ||
+ | pack(); | ||
+ | } | ||
+ | |||
+ | public static void main (String args[]) { | ||
+ | Text b = new Text("LaboratorPOO"); | ||
+ | } | ||
+ | } | ||
+ | |||
+ | </code> | ||
+ | |||
+ | === Etichete === | ||
+ | |||
+ | O eticheta reprezinta cea mai simpla componenta. Aceasta este folosita pentru afisarea unui text static in cele mai multe cazuri. Textul de pe o eticheta poate fi modificat sau preluat folosind metodele **//getText()//** si **//setText(String text)//**. | ||
+ | |||
+ | <note warning> | ||
+ | Un **//JLabel//** poate fi uzitat si pentru afisarea unei imagini. In acest caz, nu i se aplica niciun text, ci doar un **//imageIcon//**, aceasta modalitate fiind considerata cea mai simpla de a afisa o imagine intr-un container. | ||
+ | </note> | ||
+ | |||
+ | |||
+ | ==== Tratarea evenimentelor ==== | ||
+ | |||
+ | Un eveniment este produs de o actiune a utilizatorului asupra unei componente grafice si reprezinta mecanismul prin care utilizatorul comunica efectiv cu programul. Exemple de evenimente sunt: apasarea unui buton, modificarea textului intr-un control de editare, inchiderea sau redimensionarea unei ferestre, etc. Componentele care genereaza anumite evenimente se mai numesc si surse de evenimente. | ||
+ | |||
+ | Interceptarea evenimentelor generate de componentele unui program se realizeaza prin intermediul unor clase de tip listener (ascultator, consumator de evenimente). In Java, orice obiect poate ”consuma” evenimentele generate de o anumita componenta grafica. | ||
+ | |||
+ | Avand in vedere gama larga de evenimente existente in limbajul Java, am ales sa vi le prezint pe cele considerate mai important, intr-o serie de exemple incluse in arhiva laboratorului. |