TablooProto.java
8.57 KB
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
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
package ihm;
/*
* TablooProto.java requires no other files.
*
*/
import java.awt.Color;
import java.awt.Component;
import javax.swing.JFrame;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import javax.swing.table.AbstractTableModel;
import java.awt.Dimension;
import java.awt.GridLayout;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.ObjectInputStream;
import java.util.Collections;
import javax.swing.JLabel;
import javax.swing.JPanel;
import javax.swing.table.DefaultTableCellRenderer;
import javax.swing.table.TableColumn;
import kernel.Grid;
import kernel.exception.CellNotFoundException;
import kernel.exception.InvalidIntervalException;
public class TablooProto extends JPanel {
private static final long serialVersionUID = 1L;
// Fourni: ne rien changer.
public TablooProto() throws ClassNotFoundException, IOException {
super(new GridLayout(1, 0));
// modele de donnees
// cf. plus loin la inner classe MyTableModel a modifier...
MyTableModel tableModel = new MyTableModel();
// la JTable et ses parametres
JTable table = new JTable(tableModel);
table.setPreferredScrollableViewportSize(new Dimension(1000, 500));
table.setGridColor(Color.BLACK);
table.setShowGrid(true);
// on ajoute un scroll
JScrollPane scrollPane = new JScrollPane(table, JScrollPane.VERTICAL_SCROLLBAR_AS_NEEDED, JScrollPane.HORIZONTAL_SCROLLBAR_AS_NEEDED);
add(scrollPane);
table.setAutoResizeMode(JTable.AUTO_RESIZE_OFF);
// parametrage de la 1ere ligne = noms des colonnes
((DefaultTableCellRenderer) table.getTableHeader().getDefaultRenderer()).setHorizontalAlignment(JLabel.CENTER);
// parametrage de la 1ere colonne consacree a la numerotation des lignes
TableColumn tm = table.getColumnModel().getColumn(0);
tm.setPreferredWidth(tm.getPreferredWidth() * 2 / 3);
tm.setCellRenderer(new PremiereColonneSpecificRenderer(Color.LIGHT_GRAY));
}
// Inner class pour changer l'aspect de la premiere colonne consacree a la numerotation des lignes
// Fourni: ne rien changer.
class PremiereColonneSpecificRenderer extends DefaultTableCellRenderer {
/**
*
*/
private static final long serialVersionUID = 1L;
Color couleur;
public PremiereColonneSpecificRenderer(Color couleur) {
super();
this.couleur = couleur;
this.setHorizontalAlignment(JLabel.CENTER);
}
@Override
public Component getTableCellRendererComponent(JTable table, Object value, boolean isSelected, boolean hasFocus, int row, int column) {
Component cell = super.getTableCellRendererComponent(table, value, isSelected, hasFocus, row, column);
cell.setBackground(couleur);
return cell;
}
}
// Inner class pour etablir la connexion entre la JTable graphique et un modele de donnees.
// Pour nous le modele de donnees sera une grille du noyau de representation et de calcul
// construite et sauvegardee par serialisation comme precedemmment.
// Dans ce prototype exemple, le modele de donnees est une simple matrice de String "en dur".
// Il faudra le remplacer par une connexion a une telle grille.
class MyTableModel extends AbstractTableModel {
/**
*
*/
private static final long serialVersionUID = 1L;
// TODO
// remplacer ce tableau en dur du prototype par la grille serialisee:
// noyau.Grille calc;
Grid calc;
MyTableModel() throws ClassNotFoundException, IOException {
// TODO: remplacer cette initialisation par le chargement de la grille serialisee
File fichier = new File("essai.ser") ;
ObjectInputStream ois = new ObjectInputStream(new FileInputStream(fichier)) ;
calc = (Grid)ois.readObject() ;
ois.close();
}
@Override
// Standard: doit retourner le nbre de colonnes de la JTable
public int getColumnCount() {
// TODO: remplacer par le nbre de colonnes de la grille
// + 1 pour la colonne 0 consacrée aux numeros de ligne)
//return Collections.max(calc.getTotalColumn())+1;
return 10;
}
@Override
// Standard: doit retourner le nbre de lignes de la JTable
public int getRowCount() {
// TODO: remplacer par le nbre de lignes de la grille
return Collections.max(calc.getTotalLine())+1;
//return 10;
}
// Standard: doit renvoyer le nom de la colonne a afficher en tete
// Fourni: ne rien changer.
@Override
public String getColumnName(int col) {
if (col == 0) {
return ""; // colonne consacrée aux numeros de ligne
} else {
return "" + (char) ((int) ('A') + col - 1);
}
}
// Utilitaire interne fourni (ne rien changer)
// Retourne le nom d'une case a partir de ses coordonnees dans la JTable.
String getNomCase(int row, int col) {
return this.getColumnName(col) + String.valueOf(row + 1); // row commence a 0
}
@Override
// Standard: doit renvoyer le contenu a afficher de la case correspondante
public Object getValueAt(int row, int col) {
if (col == 0) {
// Fourni: ne rien changer.
// en colonne 0 : numeros de lignes
return "" + String.valueOf(row + 1);
} else {
// TODO: remplacer par le contenu + la valeur
// de la case de nom getNomCase(row, col)
// dans la grille (comme dans la figure 1 du sujet).
try {
return "" + calc.getDevelopedFormula(this.getColumnName(col), row+1)+"="+calc.getValue(this.getColumnName(col), row+1);
} catch (CellNotFoundException e) {
}
}
return 0;
}
// Standard.
// Fourni: ne rien changer.
@Override
public Class getColumnClass(int c) {
return getValueAt(0, c).getClass();
}
// Standard: determine si une case est editable ou non.
// Fourni: ne rien changer.
// Seules les cases de la 1er colonne ne le sont pas
// (consacrees a la numerotation des lignes)
@Override
public boolean isCellEditable(int row, int col) {
if (col < 1) {
return false; // col 0 consacree a la numerotation des lignes (non editable)
} else {
return true;
}
}
// Standard: l'utilisateur a entré une valeur dans une case,
// mettre a jour le modèle de donnees connecte.
// L'utilisateur a modifie une case.
// Si c'est une valeur numerique (sinon ne rien faire)
// - modifier la case correspondante dans la grille si cette case existe
// - ajouter la case correspondante dans la grille
@Override
public void setValueAt(Object value, int row, int col) {
// TODO remplacer par le code correspondant
if (value instanceof String) {
if (calc.getCellsId().contains(this.getNomCase(row, col)))
try {
calc.setValue(this.getColumnName(col), row+1, Double.parseDouble((String)value));
} catch (CellNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
else
try {
calc.createCell(this.getColumnName(col), row+1, Double.parseDouble((String)value));
} catch (InvalidIntervalException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
// Ne pas modifier :
// mise a jour automatique de l'affichage suite a la modification
fireTableCellUpdated(row, col);
}
}
// Fin de la inner class MyTableModel
// Exécution de l'interface graphique a partir d'un terminal.
// TODO: parametrer le tout par un fichier de grille serialisee.
public static void main(String[] args) throws ClassNotFoundException, IOException {
// TODO: parametrer le tableur par un fichier de grille serialisee
// a charger comme modele de donnees.
TablooProto tableur = new TablooProto();
// Creation de l'application et lancement
// Fourni: ne rien changer.
JFrame frame = new JFrame("TABLO");
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
tableur.setOpaque(true);
frame.setContentPane(tableur);
frame.pack();
frame.setVisible(true);
}
}