JTable - Aktualisieren / Neu zeichnen.

shidan

Mitglied
Hallöchen ich bins wieder,

Ich bräuchte mal einen kleinen Rat wie man ein JTable neuzeichnen kann ohne gleich die komplette GUI neuzustarten, ich brauche das Neuzeichnen da sich dadurch die Werte in der Tabelle sortieren sollen und die Farbsortierung ,die Speziell im Table festgelgt wurde, sich aktualisiert.

Ich habe leider bereits sämtliche repaint,validate usw. Methoden des Tables auspropiert aber nichts scheint zu funktionieren.

Gruß Shidan
 
S

SlaterB

Gast
wenn das Aussehen von den Einstellungen im TableModel abhängt, geht vielleicht dort
fireTableDataChanged() oder als höchstes Event fireTableStructureChanged()

idealerweise ein vollständiges kleines Testprogramm posten
 

shidan

Mitglied
Uff müsste ich mich drann setzen und mal schaun.

Hier ist die Klassemit der ich mir mein Table einfärbe.

Java:
    class GroupingTable extends JTable {
        /**
		 * 
		 */
		private static final long serialVersionUID = 1L;
		private int keyColumn;
        private Color[] colorModel;
        private int[] colorIndex;   //"Model" zur Speichern der Zeilenfarbe
        
        public GroupingTable(TableModel model, int column) {
            super(model);
            this.keyColumn = column;
            colorModel = new Color[] {this.getBackground(), Color.LIGHT_GRAY};
            determineColor();
        }
        
        //tableChanged Überschrieben, damit das "Farbenmodel" aktualisiert wird
        public void tableChanged(TableModelEvent evt) {
            if (evt.getColumn()==keyColumn)
                determineColor();
            super.tableChanged(evt);
        }
        
        //Methode zum Ermitteln der Zeilenfarbe
        private void determineColor() {
            colorIndex = new int[this.getRowCount()];
            if (colorIndex.length<=0)
                return;
            int colorCount=0;
            colorIndex[0] = colorCount;
            for (int row=1; row<this.getRowCount(); row++) {
            	
                if(this.getValueAt(row, this.convertColumnIndexToView(keyColumn)) != null && this.getValueAt(row, this.convertColumnIndexToView(keyColumn))
                        .equals(this.getValueAt(row-1, this.convertColumnIndexToView(keyColumn))))
                    colorIndex[row] = colorCount & 1;
                else
                    colorIndex[row] = ++colorCount & 1;
            }
        }
        
        //Überschrieben, um die Zeilenfarbe zu setzen.
        public Component prepareRenderer(TableCellRenderer renderer, int row, int column) {
            Component c = (Component) super.prepareRenderer(renderer, row, column);
            for (int i=0; i<this.getSelectedRows().length; i++) {
                if (this.getSelectedRows()[i]==row)
                    return c;
            }
            try{
            	c.setBackground(colorModel[colorIndex[row]]);
            }catch(ArrayIndexOutOfBoundsException ex){
            	
            }
            return c;
        }
    }

Und hier mal meine DefaultTableModel
Java:
setDtm(new DefaultTableModel(data, columnNames){			
			 /**Eigenes DefaultTableModel um nur Zahlen auf der Tabelle 
			  * nach Zeile 2 zu zulassen.
			 */
			private static final long serialVersionUID = 1L;


			@Override
			    public void setValueAt(Object aValue, int row, int col)
			    {
			        // Abbruch wenn der Wert kein Integer ist.	
			        if (aValue instanceof Integer)
			        {
			        	//Abbruch wenn der Wert nicht zwischen 0 - 100 liegt.
			          int value = ((Integer)aValue).intValue();		
			        	  if(value < 0 || value > 100){
			        		  return;			        	  
			          }
			        }
			        // Setze den Wert.
			        super.setValueAt(aValue, row, col);
			    }

			 
			    @Override
			    public Class<?> getColumnClass(int col)
			    {
			        if (col >=2)
			            return Integer.class;
			        else{
			        	return String.class;
			        }
			    }			
		});

StructureChanged bringt leider auch nichts macht es eher nur schlimmer da meine ersten beiden Columns ComboBoxen sind und diese dann einfach mit normalen ersetzt werden.
 

Michael...

Top Contributor
Hier ist die Klassemit der ich mir mein Table einfärbe.

Java:
    class GroupingTable extends JTable {[/QUOTE]
Schön, mal nach langer Zeit seinen Code wieder mal zu sehen. Doch der hat denke ich mit dem Problem erst einmal nichts zu tun, da hier ja die tableChanged(...) überschrieben ist und die GroupingTable somit auf Änderungen im Model reagiert - sofern die Table korrekt vom Model benachrichtigt wird.
[quote="shidan, post: 786362"]StructureChanged bringt leider auch nichts macht es eher nur schlimmer da meine ersten beiden Columns ComboBoxen sind und diese dann einfach mit normalen ersetzt werden.[/QUOTE]
Wie schauts mit fireDataChanged() aus? Wenn Änderungen am TableModel bzw. dessen Daten vorgenommen werden muss die JTable korrekt informiert werden.

Und das wurde ja ebenfalls bereits von SlaterB erwähnt:
idealerweise ein vollständiges kleines Testprogramm posten
 

shidan

Mitglied
Jap, danke nocheinmal dafür. Hat mir nen gutes Stück arbeit erspart da ich noch kaum Erfahrung hatte mit umschreiben von SwingComponenten.

Ich hab mir hier mal eine GUI zusammengeklickt ( Tut mir Leid für die Faulheit)

Hier sieht man es ungefähr da ich die RefreshMethode genauso habe.
Java:
import java.awt.BorderLayout;
import java.awt.Color;
import java.awt.Component;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.util.Collections;
import java.util.Comparator;
import java.util.Vector;

import javax.swing.DefaultCellEditor;
import javax.swing.JButton;
import javax.swing.JComboBox;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JTable;

import javax.swing.WindowConstants;
import javax.swing.event.TableModelEvent;
import javax.swing.table.DefaultTableModel;
import javax.swing.table.TableCellRenderer;
import javax.swing.table.TableColumn;
import javax.swing.table.TableModel;
import javax.swing.SwingUtilities;




/**
* This code was edited or generated using CloudGarden's Jigloo
* SWT/Swing GUI Builder, which is free for non-commercial
* use. If Jigloo is being used commercially (ie, by a corporation,
* company or business for any purpose whatever) then you
* should purchase a license for each developer using Jigloo.
* Please visit [url=http://www.cloudgarden.com]Cloud Garden (Java Resources)[/url] for details.
* Use of Jigloo implies acceptance of these licensing terms.
* A COMMERCIAL LICENSE HAS NOT BEEN PURCHASED FOR
* THIS MACHINE, SO JIGLOO OR THIS CODE CANNOT BE USED
* LEGALLY FOR ANY CORPORATE OR COMMERCIAL PURPOSE.
*/
public class table extends javax.swing.JFrame {
	private JScrollPane jScrollPane1;
	private JButton jButton1;
	private JButton jButton2;
	private JPanel jPanel1;
	private JTable jTable1;
	private JComboBox comboBox_names;
	private JComboBox comboBox_projekts;
	private DefaultTableModel jTable1Model;
	private JButton jButton3;
	/**
	* Auto-generated main method to display this JFrame
	*/
	public static void main(String[] args) {
		SwingUtilities.invokeLater(new Runnable() {
			public void run() {
				table inst = new table();
				inst.setLocationRelativeTo(null);
				inst.setVisible(true);
			}
		});
	}
	
	public table() {
		super();
		initGUI();
	}
	
	private void initGUI() {
		try {
			BorderLayout thisLayout = new BorderLayout();
			setDefaultCloseOperation(WindowConstants.DISPOSE_ON_CLOSE);
			getContentPane().setLayout(thisLayout);
			{
				jScrollPane1 = new JScrollPane();
				getContentPane().add(jScrollPane1, BorderLayout.CENTER);
				jScrollPane1.setPreferredSize(new java.awt.Dimension(392, 203));
				{
					jButton1 = new JButton();
					jScrollPane1.setViewportView(jButton1);
					jButton1.setText("jButton1");
				}
				{
					jTable1Model = 
						new DefaultTableModel(
								new String[][] { { "Blub:1", "2" }, { "Blub:3", "4" },{"Blub:1","7"},{"Blub:2","8"}},
								new String[] { "Column 1", "Column 2" ,"Column 3"});
					jTable1 = new GroupingTable(jTable1Model,0);
					jScrollPane1.setViewportView(jTable1);
					jTable1.setModel(jTable1Model);			
					
					TableColumn tColumnNames = jTable1.getColumnModel().getColumn(0);
					TableColumn tColumnProjekts = jTable1.getColumnModel().getColumn(1);
					

					comboBox_names = new JComboBox();
			
					//ComboxBox f�r Namen und Projekte werden mit den Namen und Projekten gef�llt.
					comboBox_names.addItem("");			
					for(int i = 0; i < 3; i++){
						comboBox_names.addItem("Blub:"+i);
					}
					
					//CellEditor f�r die ComboBoxen.
					tColumnNames.setCellEditor(new DefaultCellEditor(comboBox_names));			
					jTable1.setPreferredSize(new java.awt.Dimension(390, 178));
				}
			}
			{
				jPanel1 = new JPanel();
				getContentPane().add(jPanel1, BorderLayout.NORTH);
				jPanel1.setPreferredSize(new java.awt.Dimension(392, 33));
				{
					jButton2 = new JButton();
					jPanel1.add(jButton2);
					jButton2.setText("Refresh");
					jButton2.addActionListener(new ActionListener() {
					

						public void actionPerformed(ActionEvent evt) {
							System.out.println("Sortieren");
							sortAllRowsBy(jTable1Model, 0, true);
						}
					});
				}
				{
					jButton3 = new JButton();
					jPanel1.add(jButton3);
					jButton3.setText("Neue Reihe");
					jButton3.addActionListener(new ActionListener() {
						public void actionPerformed(ActionEvent evt) {
							jTable1Model.addRow(new String[]{});							
						}
					});
				}
			}
			pack();
			setSize(400, 300);
		} catch (Exception e) {
		    //add your error handling code here
			e.printStackTrace();
		}
	}
	
	class GroupingTable extends JTable {
        /**
		 * 
		 */
		private static final long serialVersionUID = 1L;
		private int keyColumn;
        private Color[] colorModel;
        private int[] colorIndex;   //"Model" zur Speichern der Zeilenfarbe
        
        public GroupingTable(TableModel model, int column) {
            super(model);
            this.keyColumn = column;
            colorModel = new Color[] {this.getBackground(), Color.LIGHT_GRAY};
            determineColor();
        }
        
        //tableChanged Überschrieben, damit das "Farbenmodel" aktualisiert wird
        public void tableChanged(TableModelEvent evt) {
            if (evt.getColumn()==keyColumn)
                determineColor();
            super.tableChanged(evt);            
        }
        
        //Methode zum Ermitteln der Zeilenfarbe
        private void determineColor() {
            colorIndex = new int[this.getRowCount()];
            if (colorIndex.length<=0)
                return;
            int colorCount=0;
            colorIndex[0] = colorCount;
            for (int row=1; row<this.getRowCount(); row++) {
            	
                if(this.getValueAt(row, this.convertColumnIndexToView(keyColumn)) != null && this.getValueAt(row, this.convertColumnIndexToView(keyColumn))
                        .equals(this.getValueAt(row-1, this.convertColumnIndexToView(keyColumn))))
                    colorIndex[row] = colorCount & 1;
                else
                    colorIndex[row] = ++colorCount & 1;
            }
        }
        
        //Überschrieben, um die Zeilenfarbe zu setzen.
        public Component prepareRenderer(TableCellRenderer renderer, int row, int column) {
            Component c = (Component) super.prepareRenderer(renderer, row, column);
            for (int i=0; i<this.getSelectedRows().length; i++) {
                if (this.getSelectedRows()[i]==row)
                    return c;
            }
            try{
            	c.setBackground(colorModel[colorIndex[row]]);
            }catch(ArrayIndexOutOfBoundsException ex){
            	
            }
            return c;
        }        
	}
	
	
	//Sortiermethoden.
	
	
	public void sortAllRowsBy(DefaultTableModel model, int colIndex, boolean ascending) {
	    Vector<Object> data = model.getDataVector();
	    Collections.sort(data, new ColumnSorter(colIndex, ascending));
	    model.fireTableStructureChanged();
	}
	// This comparator is used to sort vectors of data
	public class ColumnSorter implements Comparator<Object> {
	    int colIndex;
	    boolean ascending;
	    ColumnSorter(int colIndex, boolean ascending) {
	        this.colIndex = colIndex;
	        this.ascending = ascending;
	    }
	    @SuppressWarnings("unchecked")
		public int compare(Object a, Object b) {
	        Vector<Object> v1 = (Vector<Object>)a;
	        Vector<Object> v2 = (Vector<Object>)b;
	        Object o1 = v1.get(colIndex);
	        Object o2 = v2.get(colIndex);

	        // Treat empty strains like nulls
	        if (o1 instanceof String && ((String)o1).length() == 0) {
	            o1 = null;
	        }
	        if (o2 instanceof String && ((String)o2).length() == 0) {
	            o2 = null;
	        }

	        // Sort nulls so they appear last, regardless
	        // of sort order
	        if (o1 == null && o2 == null) {
	            return 0;
	        } else if (o1 == null) {
	            return 1;
	        } else if (o2 == null) {
	            return -1;
	        } else if (o1 instanceof Comparable) {
	            if (ascending) {
	                return ((Comparable<Object>)o1).compareTo(o2);
	            } else {
	                return ((Comparable<Object>)o2).compareTo(o1);
	            }
	        } else {
	            if (ascending) {
	                return o1.toString().compareTo(o2.toString());
	            } else {
	                return o2.toString().compareTo(o1.toString());
	            }
	        }
	    }
	}
}

Das Problem ist halt wenn man sich ein paar Reihne dazuklickt und diese mit Werten füllt, aktualisiert sich die Farbe nicht und wenn ich FireTable-Data oder StructureChange aufrufe sind die ComboBoxen weg.
 

Michael...

Top Contributor
Code:
fireTableStructureChanged
darfst Du nicht aufrufen, da dann die JTable davon ausgehen muss, dass eventuell ein ganz neues TableModel dargestellt werden muss und dadurch gehen dann natürlich solche Sachen wie CellEditoren verloren.
Rufe nach dem Sortieren einfach nur
Code:
fireTableDataChanged()
am Model auf.

Du musst allerdings die Bedingung in der überschriebenen tableChanged() der GroupingTable noch anpassen, da mit dieser Bedingung
Code:
if (evt.getColumn()==keyColumn)
die Zeilenfarbe nur bei einer Änderung in der konkreten Spalte neu ermittelt wird.
Ersetze sie erst einmal z.B. durch
Code:
if (this.getColumnCount()>keyColumn)
- nun wird allerdings bei jeder Änderung in der Tabelle das Farbmodel neu berechnet.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
ralfb1105 Swing JTable aktualisieren AWT, Swing, JavaFX & SWT 5
D JTable nach INSERT aktualisieren /refreshen AWT, Swing, JavaFX & SWT 1
S Swing Mal wieder JTable Ansicht aktualisieren AWT, Swing, JavaFX & SWT 10
B JTable aktualisieren AWT, Swing, JavaFX & SWT 22
Kenan89 JTable aktualisieren AWT, Swing, JavaFX & SWT 21
C jTable aktualisieren AWT, Swing, JavaFX & SWT 2
C Daten aus DB -> JTable aktualisieren klappt nicht AWT, Swing, JavaFX & SWT 16
C Swing Inhalt einer JTable aktualisieren und filten nach Feldern die nicht in der Tabelle sind AWT, Swing, JavaFX & SWT 3
K Swing JTable Model aktualisieren AWT, Swing, JavaFX & SWT 2
K JTable aktualisieren AWT, Swing, JavaFX & SWT 9
L Swing Daten in JTable aktualisieren AWT, Swing, JavaFX & SWT 5
S Swing JTable nach einer Änderung einer Zelle komplett aktualisieren. AWT, Swing, JavaFX & SWT 10
S JTable aktualisieren AWT, Swing, JavaFX & SWT 4
U JTable in einem Tab aktualisieren aus anderem Tab heraus initiiert AWT, Swing, JavaFX & SWT 4
A JComboBox bei Veränderungen in der JTable mit aktualisieren AWT, Swing, JavaFX & SWT 6
G Swing JTable will sich einfach nicht aktualisieren AWT, Swing, JavaFX & SWT 4
N JTable aktualisieren AWT, Swing, JavaFX & SWT 2
calzone Swing JTable, Werte aktualisieren klappt nicht! AWT, Swing, JavaFX & SWT 7
G JTable bei Insert in DB via jdbc aktualisieren AWT, Swing, JavaFX & SWT 9
M Wie, ein JTable / JPanel / JContentPane aktualisieren? AWT, Swing, JavaFX & SWT 3
G JTable aktualisieren fireTableDataChanged()? AWT, Swing, JavaFX & SWT 1
J GUI (JTable) während Rekursion aktualisieren AWT, Swing, JavaFX & SWT 4
S jTable beim Klick auf Button aktualisieren AWT, Swing, JavaFX & SWT 7
F JTable Daten aktualisieren AWT, Swing, JavaFX & SWT 2
N JTable aktualisieren AWT, Swing, JavaFX & SWT 8
M JTable aktualisieren AWT, Swing, JavaFX & SWT 17
C JTable aktualisieren AWT, Swing, JavaFX & SWT 5
H JTable aktualisieren / InternalFrames auf Panel beschränken AWT, Swing, JavaFX & SWT 6
I JTable aktualisieren AWT, Swing, JavaFX & SWT 4
H JTable aktualisieren AWT, Swing, JavaFX & SWT 7
J JTable aktualisieren AWT, Swing, JavaFX & SWT 5
J Drag und drop aus einer JTable - bitte um Unterstützung AWT, Swing, JavaFX & SWT 2
S HPRO und UPRO gemeinsame JTABLE gemeinsamer RENDERER ? AWT, Swing, JavaFX & SWT 1
F Swing JTable - MultiHeader inkl. Eingabemöglichkeit AWT, Swing, JavaFX & SWT 1
S JTable - Feldinhalte anzeigen AWT, Swing, JavaFX & SWT 15
D Swing JTable Spaltenbreite AWT, Swing, JavaFX & SWT 1
W Gibt es einen "automatischen Listener" in Swing oder JTable oder der ATM-Klasse? AWT, Swing, JavaFX & SWT 14
G jTable - getSelectedRow() AWT, Swing, JavaFX & SWT 3
I JTable mit einem Button zu einer Detail Seite springen AWT, Swing, JavaFX & SWT 4
P JTable Listener für die Änderung einzelner Zellen oder Rows AWT, Swing, JavaFX & SWT 2
D Tastaturabfragen CTRL+t, CTRL+E bei eine JTable, bestehend aus JTextAteas AWT, Swing, JavaFX & SWT 4
P Checkboxes in JTable nicht editable AWT, Swing, JavaFX & SWT 9
F Best-Practise: JTable Text in Zelle zu groß AWT, Swing, JavaFX & SWT 2
izoards JTable in CSV File schreiben... AWT, Swing, JavaFX & SWT 23
Kohl Jedes Objekt einer JTable um ein Zeichen verkürzen AWT, Swing, JavaFX & SWT 7
I JTable, DefaultTableModel, zwei Zahlen multiplizieren. AWT, Swing, JavaFX & SWT 26
M JTABLE / wie oft wurde gewürfelt. AWT, Swing, JavaFX & SWT 1
F JTable vergrößern AWT, Swing, JavaFX & SWT 2
H JTable: Diverse NullPointer-Exceptions zur Laufzeit AWT, Swing, JavaFX & SWT 3
J Swing Werte des JTable werden nicht angezeigt AWT, Swing, JavaFX & SWT 9
T Swing JTable cellRenderer mit jpg Hintergrundfarbe lässt sich nicht ändern. AWT, Swing, JavaFX & SWT 1
HoT Einzelne Zelle in JTable Rahmen unten setzen AWT, Swing, JavaFX & SWT 24
B JTable Zellen zusammenfügen AWT, Swing, JavaFX & SWT 3
M Swing Cell Renderer für Zeilenumbruch in JTable AWT, Swing, JavaFX & SWT 0
H JTable im JSplitPane darstellen AWT, Swing, JavaFX & SWT 2
MadMax2506 Swing JTable lädt sehr lange AWT, Swing, JavaFX & SWT 1
D Zeilenumbruch in einer JTable AWT, Swing, JavaFX & SWT 9
R Swing JTable und Spaltenausrichtung AWT, Swing, JavaFX & SWT 8
G JTable füllen AWT, Swing, JavaFX & SWT 1
H JTable TableCellEditor-Problem AWT, Swing, JavaFX & SWT 0
W Swing JTable Zeilenumbruch innerhalb einer Zelle AWT, Swing, JavaFX & SWT 3
J Datensatz in jTable ausgeben AWT, Swing, JavaFX & SWT 3
M Swing Automatischer Editorstart in JTable-Zelle AWT, Swing, JavaFX & SWT 5
adiko01 JTable: Nur markierte Zeilen aus der Tabelle in CSV exportiern AWT, Swing, JavaFX & SWT 9
M JTable.setDefaultRenderer(...) greift nicht AWT, Swing, JavaFX & SWT 0
J JTable: Eingabe in Tabellenzelle korrigieren AWT, Swing, JavaFX & SWT 4
T Problem mit JTable Sortierung AWT, Swing, JavaFX & SWT 2
D MySQL Daten in JTable anzeigen AWT, Swing, JavaFX & SWT 2
H Swing Jtable extra spalte AWT, Swing, JavaFX & SWT 6
S Swing Rechteck über JTable zeichnen (per MouseListener) AWT, Swing, JavaFX & SWT 1
A JTable mit Daten füllen AWT, Swing, JavaFX & SWT 1
VfL_Freak Swing Einzelne Zeile in jTable selektieren klappt nicht AWT, Swing, JavaFX & SWT 7
N AWT jTable CellRenderer AWT, Swing, JavaFX & SWT 6
T Swing JTable valueChanged datensatz löschen AWT, Swing, JavaFX & SWT 1
0 Swing JTable aus anderer Klasse updaten AWT, Swing, JavaFX & SWT 5
S Jtable defaultRenderer wohin damit ? AWT, Swing, JavaFX & SWT 23
T Swing JTable / FocusListener AWT, Swing, JavaFX & SWT 0
it_is_all Warum wird die JTable im JDialog nicht angezeigt? AWT, Swing, JavaFX & SWT 1
L Swing JTable im Panel darstellen AWT, Swing, JavaFX & SWT 8
T Swing Double Click bei Buttons in JTable AWT, Swing, JavaFX & SWT 9
J addRow bei JTable AWT, Swing, JavaFX & SWT 6
M Jtable gibt -1 wert bei selectedRow und Column AWT, Swing, JavaFX & SWT 3
Meeresgott Swing JTable AWT, Swing, JavaFX & SWT 4
J JTable Selection Listener funktioniert nicht AWT, Swing, JavaFX & SWT 4
C Swing Daten in JTable wiedergeben per TableModel und MVC Pattern AWT, Swing, JavaFX & SWT 16
Z Swing Drag&Drop zwischen JTable und JTree AWT, Swing, JavaFX & SWT 4
Thallius JTable dynamisch Spaltenanzahl verändern AWT, Swing, JavaFX & SWT 2
Thallius JTable dynamisch laden? AWT, Swing, JavaFX & SWT 2
B Swing JTable sortieren AWT, Swing, JavaFX & SWT 2
T Swing JTable auslesen und befüllen AWT, Swing, JavaFX & SWT 8
B JTable wird nicht angezeigt AWT, Swing, JavaFX & SWT 1
J JTable und Suchlogik AWT, Swing, JavaFX & SWT 4
Viktim Swing JTable mit Tab verlassen AWT, Swing, JavaFX & SWT 1
F Swing Spaltenbreite einer Column eines JTable auslesen AWT, Swing, JavaFX & SWT 5
Viktim Swing JTable Mit Tab druch Zeilen Wechseln AWT, Swing, JavaFX & SWT 5
Thallius Warum refrehsed mein JTable nicht? AWT, Swing, JavaFX & SWT 5
Ghostman1711 Hinzufügen ausgewählter Dateinen des Filechoosers zu einem JTable AWT, Swing, JavaFX & SWT 9
S Swing JTable - Einzelne Rows einfärben AWT, Swing, JavaFX & SWT 11
M Wert einer Zelle aus JTable ziehen AWT, Swing, JavaFX & SWT 4
K JTable getValueAt() klappt nicht immer AWT, Swing, JavaFX & SWT 1

Ähnliche Java Themen

Neue Themen


Oben