spiele jetzt schon 2 Tage rum, wie ich am besten 3 Spalten in mein JPanel bekomme.
Ich zeige euch mal ein Beipiel wie ich es mir gedacht hätte:
Jede Zeile enthält eine Checkbox dann soll ein Label kommen und zum Schluss noch ein kleines Icon.
Das ganze soll auf nem ScrollPanel sein.
Die Idee dahinter ist, dass ich mich durch die Checkbox in ein "Topic" sozusagen einschreiben kann.
Bei Klick auf das Label bekomm ich ne Topic-Beschreibung. Und das Icon zeigt an ob neue Nachrichten zur Verfügung stehen. Die Anzahl der Zeilen wird dabei dynamisch festgelegt
All die Sachen sind kein Problem nur mit dem Layout klappts nicht.
Vielleicht hat von euch wer ne Idee.
P.S: Sry für die schlechte Zeichnung, Hand hat etwas gezuckt
wenn du keine `JTable nehmen willst, bietet sich hier das BorderLayout an.
rechts und links, nach West, bzw. Ost, im Center das Label. Evtl. noch die BorderFactory benutzen und fertig.
Habs mit dem BorderLayout schon probiert, aber da passt mir die Darstellung nicht richtig.
Bleibt mir wohl nichts anderes als JTable zu benutzten. Wieder mal nen Haufen lesen
So habs hinbekommen mit nem eigenen Modell.
Bzw ich hab mir ne Klasse geschrieben wie im Tutorial.
Sieht jedenfalls nun so aus:
Jetzt hab ich nur noch das Problem dass die JCheckBox eigentlich nur ein Boolean-Wert ist und ich kann per Klick den Zustand nicht ändern ob checked oder unchecked.
Was ich noch fragen wollte, gibt es was besonderes zu beachten wenn man auf die CheckBox nen Listener legt?
Und der Text sollte eigentlich ein JLabel sein, damit ich zusätzlich nen Tooltip anbringen kann. Ich kann aber nur nen String ausgeben und kein JLabel direkt. Will ich ein JLabel selbst ausgeben bekomm ich die Speicheradresse angezeigt.
So ich hab jetzt noch paar Seiten durchgelesen und schon fleißig implementiert, aber ich hab noch paar kleine Probleme.
Ich poste euch mal, was ich gemacht habe:
Zuerst die Methode, die mein JTable erzeugt:
Java:
/**
* Refresh the list of all available topics
*/publicvoidrefreshList(){// clean the panel
checkBox.removeAll();// get list of topics from past storageLinkedList<String> topics = pastActions.getObject();
checkBox.setLayout(newBoxLayout(checkBox,BoxLayout.Y_AXIS));// ##########################--table--#######################################MyTableModel model =newMyTableModel();
table =newJTable(model){/**
*
*/privatestaticfinallong serialVersionUID =1L;// add specific tooltip to each topicpublicStringgetToolTipText(MouseEvent e){String tip =null;
java.awt.Point point = e.getPoint();int rowIndex =rowAtPoint(point);int colIndex =columnAtPoint(point);int realColumnIndex =convertColumnIndexToModel(colIndex);if(realColumnIndex ==1){// Text columnString topicName =(String)getValueAt(rowIndex, colIndex);
tip = pastActions.getTopicDescription(topicName);}else{// You can omit this part if you know you don't// have any renderers that supply their own tool// tips.
tip =super.getToolTipText(e);}return tip;}};// table color and additional settings
table.setForeground(Color.WHITE);
table.setBackground(newColor(51,51,51));
table.setSelectionBackground(newColor(51,51,51));
table.setSelectionForeground(Color.WHITE);
table.setShowHorizontalLines(false);
table.setShowVerticalLines(false);
table.setColumnSelectionAllowed(true);
table.setAutoResizeMode(JTable.AUTO_RESIZE_OFF);// set width of checkbox column and icon columnTableColumnModel columnModel = table.getColumnModel();
columnModel.getColumn(0).setMaxWidth(20);
columnModel.getColumn(2).setMaxWidth(25);
table.setRowHeight(25);// add cell editor to checkbox columnTableColumn checkBoxColumn = table.getColumnModel().getColumn(0);MyCellEditor editor =newMyCellEditor();
checkBoxColumn.setCellEditor(editor);// for testing set the icon to each rowfor(String top : topics){URL img =OverviewGui.class.getResource("notification.png");ImageIcon imgIcon =newImageIcon(img);TopicRow row =newTopicRow(newBoolean(true), top, imgIcon);
model.addTableRow(row);}
checkBox.add(table);}
Ich arbeite hier mit Pastry/Scribe und Past (P2P Routing Protokoll) und entwickle für meine Bachelor Arbeit eine Publish/Subscribe Anwendung. Auf jeden Fall habe ich auf meiner Gui den Button Refresh und New Topic.
Wenn ich Refresh klicke wird obige Methode ausgeführt. Ziel ist, dass ich meine "Topics" schön aufliste und per checkbox entscheiden will, ob ich mich fürs Topic einschreiben will oder nicht.
Das Problem ist hier: Ich erzeuge 2 Topics (stehen schön als row in der Gui-Table), selektiere Topic 1 und dann Topic 2. Ich will dann beide wieder deselektieren, jedoch wechselt das Häckchen immer zwischen beiden hin und her.
Das 2te Problem ist, wenn ein Eintrag in der Table steht kann ich es anhacken und wieder enthacken. Wenn ich nun refresh klicke funktioniert die nicht mehr.
Leider finde ich den Fehler nicht
Ich poste euch am besten noch mein Model und CellEditor:
MyTableModel
Java:
packagede.peerstream.gui;importjava.util.Vector;importjavax.swing.ImageIcon;importjavax.swing.event.TableModelEvent;importjavax.swing.event.TableModelListener;importjavax.swing.table.TableModel;/**
* This class manages the insertion of data into the table
*
* @author Tobias
*
*/publicclassMyTableModelimplementsTableModel{privateVector<TopicRow> topicRows =newVector<TopicRow>();privateVector<TableModelListener> listeners =newVector<TableModelListener>();publicvoidaddTableRow(TopicRow topicRow){// Index of topicRowint index = topicRows.size();
topicRows.add(topicRow);// Zuerst ein Event, "neue Row an der Stelle index" herstellenTableModelEvent e =newTableModelEvent(this, index, index,TableModelEvent.ALL_COLUMNS,TableModelEvent.INSERT );// Nun das Event verschickenfor(int i =0, n = listeners.size(); i<n; i++){((TableModelListener)listeners.get( i )).tableChanged( e );}}@OverridepublicvoidaddTableModelListener(TableModelListener l){
listeners.add(l);}@OverridepublicClass<?>getColumnClass(int columnIndex){switch( columnIndex ){case0:returnBoolean.class;case1:returnString.class;case2:returnImageIcon.class;default:returnnull;}}@OverridepublicintgetColumnCount(){return3;}@OverridepublicStringgetColumnName(int columnIndex){// TODO Auto-generated method stubreturnnull;}@OverridepublicintgetRowCount(){return topicRows.size();}@OverridepublicObjectgetValueAt(int rowIndex,int columnIndex){TopicRow topicRow =(TopicRow)topicRows.get( rowIndex );switch( columnIndex ){case0:return topicRow.getCheckBox();case1:return topicRow.getLabel();case2:return topicRow.getIcon();default:returnnull;}}@OverridepublicbooleanisCellEditable(int rowIndex,int columnIndex){if(columnIndex ==0){returntrue;}else{returnfalse;}}@OverridepublicvoidremoveTableModelListener(TableModelListener l){// TODO Auto-generated method stub}@OverridepublicvoidsetValueAt(Object aValue,int rowIndex,int columnIndex){if(columnIndex ==0){if(aValue ==(Object)true){
aValue =false;}else{
aValue =true;}}}}
packagede.peerstream.gui;importjava.awt.Color;importjava.awt.Component;importjavax.swing.AbstractCellEditor;importjavax.swing.JCheckBox;importjavax.swing.JTable;importjavax.swing.table.TableCellEditor;/**
* This class is used to vbe able to check and uncheck the checkboxes in the
* first column
*
* @author Tobias
*
*/publicclassMyCellEditorextendsAbstractCellEditorimplementsTableCellEditor{/**
*
*/privatestaticfinallong serialVersionUID =1L;finalJCheckBox check =newJCheckBox();@OverridepublicObjectgetCellEditorValue(){return check.isSelected();}@OverridepublicComponentgetTableCellEditorComponent(JTable table,Object value,boolean isSelected,int row,int column){if(isSelected && column ==0){
check.setSelected(false);}elseif(!isSelected && column ==0){
check.setSelected(true);}
check.setBackground(newColor(51,51,51));return check;}}
Die setValueAt ist sozusagen nur so gehalten um die Funktionalität der checkbox zu teste.
Wie ich oben geschrieben habe lassen sich die Häckchen nicht mehr anklicken oder entfernen nach eine Refresh. Mir ist aufgefallen, dass dies wieder funktioniert, sobald ich in ne Ecke klicke um das Fenster zu vergrößern.
Ja, wenn du einen Component entfernst und dann einen anderen addest musst du natürlich repainten.
Aber wie gesagt, du würdest viel Performance gewinnen wenn du einfach das Model austauschst.