Problem mit meinen Klassen

Butterkeks01

Mitglied
Hey,
Ich habe ein Problem, un zwar gibt der getter ImageSelection.getName() immer nur "null" zurück und ich weiß nicht warum.
Obwohl ich in der unteren Klasse den String "name" zugewiesen habe.

Vielleicht kann mir einer helfen
PS: Bin noch ein relativer Neuling, deswegen sorry sollte ich irgendwas nicht sofort verstehen ^^



Java:
package test;


import java.awt.Font;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.io.File;
import java.util.Scanner;

import javax.swing.Icon;
import javax.swing.ImageIcon;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.SwingConstants;
import javax.swing.border.Border;
import javax.swing.border.LineBorder;


public class DragImage {
    public static void main(String args[]) {
        
        Border border = LineBorder.createGrayLineBorder();
        Font labelFont = new Font("Arial", Font.CENTER_BASELINE, 130);
        
        JFrame frame = new JFrame();
        JLabel jLabel = new JLabel("+", SwingConstants.CENTER);
        JButton jButton = new JButton("test");
        
        
        
        
        jLabel.setTransferHandler(new ImageSelection());
        
        String name = ImageSelection.getName();
        
        frame.setVisible(true);
        frame.setSize(900, 700);
        frame.setTitle("Automatisierung");
        frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
        frame.setLocationRelativeTo(null);
        frame.setResizable(false);
        frame.setLayout(null);
        
        
        String adress = "";
        Icon icon = new ImageIcon(adress);
        jLabel.setBounds(10, 8, 134, 188);
        jLabel.setFont(labelFont);
        jLabel.setVisible(true);
        jLabel.setBorder(border);
        jLabel.setIcon(icon);
        
        jButton.setBounds(300, 8, 134, 188);
        jButton.setVisible(true);
        jButton.addActionListener(new ActionListener() {
            
            @Override
            public void actionPerformed(ActionEvent e) {
                System.out.println("test " + name);
                
            }
        });
        
        frame.add(jButton);
        frame.add(jLabel);

        
        
        
        
    }


}


Java:
package test;

import java.awt.datatransfer.DataFlavor;
import java.awt.datatransfer.Transferable;
import java.awt.datatransfer.UnsupportedFlavorException;
import java.io.IOException;
import javax.swing.AbstractButton;
import javax.swing.JComponent;
import javax.swing.JLabel;
import javax.swing.TransferHandler;

class ImageSelection extends TransferHandler implements Transferable {
    
    static String name;
    private static final long serialVersionUID = 3181571469332838353L;
    private static final DataFlavor flavors[] = { DataFlavor.javaFileListFlavor };

    @Override
    public boolean canImport(JComponent comp, DataFlavor flavor[]) {
        if (!(comp instanceof JLabel) && !(comp instanceof AbstractButton)) {
            return false;
        }
        for (int i = 0, n = flavor.length; i < n; i++) {
            for (int j = 0, m = flavors.length; j < m; j++) {
                if (flavor[i].equals(flavors[j])) {
                    return true;
                }
            }
        }
        return false;
    }

    

    @Override
    /*
     * This will set the name.
     */
    public boolean importData(JComponent comp, Transferable t) {
                    try {

                        name = String.valueOf(t.getTransferData(flavors[0]));
                        
                        System.out.println(name);
                        
                    } catch (UnsupportedFlavorException | IOException e) {
                        e.printStackTrace();
                    }   
        return false;
        
    }
    
    
    public static String getName() {
        return name;
        
    }
    

    

    @Override
    public Object getTransferData(DataFlavor flavor) throws UnsupportedFlavorException, IOException {
        // TODO Auto-generated method stub
        return false;
    }



    @Override
    public DataFlavor[] getTransferDataFlavors() {
        // TODO Auto-generated method stub
        return null;
    }



    @Override
    public boolean isDataFlavorSupported(DataFlavor flavor) {
        // TODO Auto-generated method stub
        return false;
    }
    
}
 
K

kneitzel

Gast
Also ich verstehe derzeit nicht, wo Du glaubst, dass name gesetzt wird. Die Methode main wird aufgerufen, Du erzeugst dann eine neue Instanz der Klasse, aber das setzt den namen nicht. Und dann speicherst Du den name in der lokalen variable name. An der Stelle wird name also null sein.

Und diese lokale Variable wird dann ausgegeben, wenn ich es richtig gesehen habe.

Und generell solltest Du das Design überdenken. Diese static Elemente in ImageSelection scheinen sehr dubios zu sein - vor allem da es auch noch Instanzen der Klasse geben soll ...
 

Butterkeks01

Mitglied
Also ich verstehe derzeit nicht, wo Du glaubst, dass name gesetzt wird. Die Methode main wird aufgerufen, Du erzeugst dann eine neue Instanz der Klasse, aber das setzt den namen nicht. Und dann speicherst Du den name in der lokalen variable name. An der Stelle wird name also null sein.

Und diese lokale Variable wird dann ausgegeben, wenn ich es richtig gesehen habe.

Und generell solltest Du das Design überdenken. Diese static Elemente in ImageSelection scheinen sehr dubios zu sein - vor allem da es auch noch Instanzen der Klasse geben soll ...

Kannst du mir vielleicht zeigen was ich machen muss damit es funktioniert?
 
K

kneitzel

Gast
Also ich verstehe derzeit nicht, was Dein Code überhaupt machen soll und das macht es relativ schwer bis unmöglich, konkrete Hinweise zu geben.

- Am Anfang wäre mein Tipp immer, auf static ganz zu verzichten (bis auf die main Methode natürlich).
- Dann wäre der nächste Tipp, die Funktionalität in der main sehr gering zu halten. In der main Methode sollten nur existenzielle Objekte für die Applikation erzeugt werden. Dies ist aber minimal.
- Komplexe Dinge werden immer in Klassen gekapselt. Als Beispiel nehmen wir einfach einmal das, was Du in der main aufbaust. Da wird ja eine Frame erstellt und gefüllt. Das ist prädestiniert für eine Klasse und im Konstruktor werden dann alle Element erzeugt. Also sowas wie:

Java:
public class MainFrame {
    private Border border;
    private Font labelFont;
        
    private JFrame frame;
    private JLabel jLabel;
    private JButton jButton;
    
    public MainFrame() {
        border = LineBorder.createGrayLineBorder();
        labelFont = new Font("Arial", Font.CENTER_BASELINE, 130);
        
        frame = new JFrame();
        jLabel = new JLabel("+", SwingConstants.CENTER);
        jButton = new JButton("test");
        jLabel.setTransferHandler(new ImageSelection());
        String name = ImageSelection.getName();
        frame.setVisible(true);
        frame.setSize(900, 700);
        frame.setTitle("Automatisierung");
        frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
        frame.setLocationRelativeTo(null);
        frame.setResizable(false);
        frame.setLayout(null);
        
        String adress = "";
        Icon icon = new ImageIcon(adress);
        jLabel.setBounds(10, 8, 134, 188);
        jLabel.setFont(labelFont);
        jLabel.setVisible(true);
        jLabel.setBorder(border);
        jLabel.setIcon(icon);
        
        jButton.setBounds(300, 8, 134, 188);
        jButton.setVisible(true);
        jButton.addActionListener(new ActionListener() {
}
==> Das ist aber nur ein Beispielcode!

- Bezüglich das TransferHandlers:
Du hast da ja ganz offensichtlich eine Instanz der Klasse, die Du benutzt:
jLabel.setTransferHandler(new ImageSelection());
==> Die Instanz kannst Du ja auch in einer Instanzvariable speichern. Dann könnte name auch nicht mehr statisch sein. Und in dem Action Listener könntest Du auf die Instanz von ImageSelection zugreifen und getName() aufrufen. (Wenn da also der Name später gesetzt wird, dann kannst Du ihn abfragen!)

Das wären einfach nur ein paar Ideen, die mir so durch den Kopf gehen. Aber ohne genaue Details zu kennen, ist es sehr schwer, zu einem Design etwas zu sagen.
 

Butterkeks01

Mitglied
Also ich verstehe derzeit nicht, was Dein Code überhaupt machen soll und das macht es relativ schwer bis unmöglich, konkrete Hinweise zu geben.

- Am Anfang wäre mein Tipp immer, auf static ganz zu verzichten (bis auf die main Methode natürlich).
- Dann wäre der nächste Tipp, die Funktionalität in der main sehr gering zu halten. In der main Methode sollten nur existenzielle Objekte für die Applikation erzeugt werden. Dies ist aber minimal.
- Komplexe Dinge werden immer in Klassen gekapselt. Als Beispiel nehmen wir einfach einmal das, was Du in der main aufbaust. Da wird ja eine Frame erstellt und gefüllt. Das ist prädestiniert für eine Klasse und im Konstruktor werden dann alle Element erzeugt. Also sowas wie:

Java:
public class MainFrame {
    private Border border;
    private Font labelFont;
       
    private JFrame frame;
    private JLabel jLabel;
    private JButton jButton;
   
    public MainFrame() {
        border = LineBorder.createGrayLineBorder();
        labelFont = new Font("Arial", Font.CENTER_BASELINE, 130);
       
        frame = new JFrame();
        jLabel = new JLabel("+", SwingConstants.CENTER);
        jButton = new JButton("test");
        jLabel.setTransferHandler(new ImageSelection());
        String name = ImageSelection.getName();
        frame.setVisible(true);
        frame.setSize(900, 700);
        frame.setTitle("Automatisierung");
        frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
        frame.setLocationRelativeTo(null);
        frame.setResizable(false);
        frame.setLayout(null);
       
        String adress = "";
        Icon icon = new ImageIcon(adress);
        jLabel.setBounds(10, 8, 134, 188);
        jLabel.setFont(labelFont);
        jLabel.setVisible(true);
        jLabel.setBorder(border);
        jLabel.setIcon(icon);
       
        jButton.setBounds(300, 8, 134, 188);
        jButton.setVisible(true);
        jButton.addActionListener(new ActionListener() {
}
==> Das ist aber nur ein Beispielcode!

- Bezüglich das TransferHandlers:
Du hast da ja ganz offensichtlich eine Instanz der Klasse, die Du benutzt:
jLabel.setTransferHandler(new ImageSelection());
==> Die Instanz kannst Du ja auch in einer Instanzvariable speichern. Dann könnte name auch nicht mehr statisch sein. Und in dem Action Listener könntest Du auf die Instanz von ImageSelection zugreifen und getName() aufrufen. (Wenn da also der Name später gesetzt wird, dann kannst Du ihn abfragen!)

Das wären einfach nur ein paar Ideen, die mir so durch den Kopf gehen. Aber ohne genaue Details zu kennen, ist es sehr schwer, zu einem Design etwas zu sagen.

Ja Du hast recht, mein Code ist wirklich nicht schön. Ich habe außerdem noch ein bisschen rum probiert und habe es erneuert und tatsächlich ich habe mir mit den static methoden ein Eigentor geschossen ^^

Ich habe also die Static Methoden zu Instanz methoden geändert und dann über this.name den richtigen Wert bekommen.

Und nochmal zu meiner Struktur, ich sollte wirklich lernen mehr in Klassen zu machen, da ich momentan so ziemlich alles versuche in der "main" methode zu machen.

Nochmals Danke :)
Mit freundlichen Grüßen
Butterkeks
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
krgewb Problem mit Umlauten und Eszett bei InputStream Allgemeine Java-Themen 3
Max246Sch Backtracking Problem Box Filler Allgemeine Java-Themen 6
NightVision402 VisualVM Startskript Problem Allgemeine Java-Themen 3
javaBoon86 Email Server Connection Problem Allgemeine Java-Themen 1
F Problem mit PDFBOX Library Allgemeine Java-Themen 1
A Java modul Problem Allgemeine Java-Themen 4
D Read JSON File Problem Allgemeine Java-Themen 9
urmelausdemeis Exception in thread "main" java.lang.Error: Unresolved compilation problem: Allgemeine Java-Themen 7
J Problem mit JasperReports Allgemeine Java-Themen 8
M log4j Problem mit jlink Allgemeine Java-Themen 19
8u3631984 Problem beim Mocken von Record Klassen Allgemeine Java-Themen 4
torresbig Website login Problem - Jsoup, wie bisher, klappt nicht! Allgemeine Java-Themen 31
P Selenium . getText Problem Allgemeine Java-Themen 9
A Jar zu Exe Problem Allgemeine Java-Themen 13
sserio Variablen Liste erstellt und ein Problem mit dem Index Allgemeine Java-Themen 6
S Folgendes Problem bei einem Programm Allgemeine Java-Themen 1
stormyark Problem beim Klassen erstellen Allgemeine Java-Themen 1
A Thread.sleep Problem Allgemeine Java-Themen 2
A Problem bei der Nachbarschafttest Allgemeine Java-Themen 11
Splayfer Problem: no main manifest attribute Allgemeine Java-Themen 3
G javamail Problem beim Empfangen von Nachrichten Allgemeine Java-Themen 3
Splayfer JDA Problem mit MessageCounter Allgemeine Java-Themen 0
Splayfer Problem mit BufferedWriter Allgemeine Java-Themen 3
F Streams als Alternative für dieses Problem ? Allgemeine Java-Themen 15
N Maven Problem mit Datenbanktreiber (H2 Embedded) Allgemeine Java-Themen 12
T Problem beim Umwandeln in eine Jar-Datei Allgemeine Java-Themen 3
B Einfach Elemente zweier Arraylisten kreuz und quer vergleichen, min und max Problem? Allgemeine Java-Themen 16
C ArrayList Problem Allgemeine Java-Themen 3
kev34 nim-Spiel problem Allgemeine Java-Themen 1
D Firebase retrieve data Problem, Child Element wird nicht angesprochen Allgemeine Java-Themen 0
G Welches Problem besteht bei den Typparametern? Allgemeine Java-Themen 5
temi Problem mit Aufrufreihenfolge bei Vererbung Allgemeine Java-Themen 3
Sumo_ow "ArrayIndexOutofBoundsException: 2" Array Problem Allgemeine Java-Themen 6
T PIM basierend auf netbeans via AnyDesk Problem Allgemeine Java-Themen 3
xGh0st2014 Problem mit Java Array Allgemeine Java-Themen 1
Kirby.exe Verständnis Problem bei Rucksack Problem Allgemeine Java-Themen 6
B Eclipse-Lombok-Problem Allgemeine Java-Themen 19
I Input/Output ObjectOutputStream - Problem Allgemeine Java-Themen 7
1 Multiple Choice Knapsack- Problem Allgemeine Java-Themen 2
kodela Problem mit strukturiertem Array Allgemeine Java-Themen 18
E Problem mit Gridlayout und Button Allgemeine Java-Themen 2
A Array Problem Allgemeine Java-Themen 8
bueseb84 Problem Allgemeine Java-Themen 0
S Problem mit Arrays Allgemeine Java-Themen 1
D Nullpointer Exception Problem Allgemeine Java-Themen 5
A HashMap Methode "get()"-Problem Allgemeine Java-Themen 28
J Problem beim Umstellen auf Java jdk 13 Allgemeine Java-Themen 3
J Problem bei Install java 13 Allgemeine Java-Themen 3
X Profitable Reise Problem Allgemeine Java-Themen 32
A Problem beim öffnen von Java-Installern Allgemeine Java-Themen 1
Dann07 Problem mit JavaMail API Allgemeine Java-Themen 26
J Problem beim Generischen Klassen und Interfaces Allgemeine Java-Themen 2
L Klassen Algorithmus für das folgende Problem entwickeln? Allgemeine Java-Themen 30
J Clear-Problem Allgemeine Java-Themen 10
B Problem zu einem Java Projekt Allgemeine Java-Themen 6
S JFileChooser Problem Allgemeine Java-Themen 4
M Traveling Salesman - MST Heuristik Problem Allgemeine Java-Themen 4
J Traveling Salesman Problem Allgemeine Java-Themen 14
E Java Editor Problem mit 2er Exceptions Allgemeine Java-Themen 12
C code oder Bibliotheken für 2-Center Problem Allgemeine Java-Themen 4
M Salesman Problem - Bruteforce Algorithmus Allgemeine Java-Themen 23
S Methoden Problem mit NullPointerException Allgemeine Java-Themen 9
Javafan02 Problem mit if-clause Allgemeine Java-Themen 17
J Lombok Problem mit Konstruktoren bei Verberbung Allgemeine Java-Themen 1
kodela Event Handling Problem mit der Alt-Taste Allgemeine Java-Themen 16
W Threads Problem Allgemeine Java-Themen 15
D (Verständnis-)Problem mit Unterklasse Allgemeine Java-Themen 4
S Problem mit Generic bei unmodifiableCollection Allgemeine Java-Themen 4
S jserialcomm Problem Allgemeine Java-Themen 1
Flynn Thread-Problem... Allgemeine Java-Themen 2
J Generische Interface - Problem Allgemeine Java-Themen 3
G Problem beim GUI Allgemeine Java-Themen 9
L Applet Problem "security: Trusted libraries list file not found" ? Allgemeine Java-Themen 7
A OOP Problem beim Berechnen der größten Fläche eines Ringes Allgemeine Java-Themen 19
T Problem mit externen Datenbankzugriff über SSH Tunnel Allgemeine Java-Themen 4
F Problem beim Einlesen einer Textdatei Allgemeine Java-Themen 12
S Java OpenOffice Problem mit Windows-Benutzerwechsel Allgemeine Java-Themen 19
K Threads RAM Problem Allgemeine Java-Themen 20
P Operatoren Problem mit Zähler in recursiver Schleife Allgemeine Java-Themen 2
C Int Problem Allgemeine Java-Themen 8
C J2V8 NodeJs Java Bride Problem und Frage!?!? Allgemeine Java-Themen 1
J Problem bei Hashmap Key-Abfrage Allgemeine Java-Themen 4
C Webseiten Programm problem Allgemeine Java-Themen 5
M LocalDate Problem Allgemeine Java-Themen 4
J "Problem Objektorientierung" Allgemeine Java-Themen 20
geekex Problem Meldung! Was tun?! Allgemeine Java-Themen 19
T Klassen Override Problem Allgemeine Java-Themen 7
L Unbekanntes Problem Allgemeine Java-Themen 1
FrittenFritze Problem mit einer JComboBox, Event temporär deaktivieren Allgemeine Java-Themen 11
Blender3D Java Swing Programm Windows 10 Autostart Problem Allgemeine Java-Themen 2
F HTTPS Zertifikat Problem Allgemeine Java-Themen 3
M OpenCV KNearest Problem Allgemeine Java-Themen 0
Tommy Nightmare Project Euler: Problem 22 Allgemeine Java-Themen 2
C Abstrakte Klasse, lokale Variable-Problem Allgemeine Java-Themen 1
N Vererbung Design-Problem mit vorhandenen, von der Klasse unabhängigen Methoden Allgemeine Java-Themen 12
P Eclipse Projekt anlegen macht Problem Allgemeine Java-Themen 1
RalleYTN META-INF/services Problem Allgemeine Java-Themen 3
F Java Mail Problem: Authentifizierung wird nicht immer mitgeschickt Allgemeine Java-Themen 1
I Problem beim Aufrufen, von Objektmethoden/ -variablen Allgemeine Java-Themen 6
K Thread Problem Allgemeine Java-Themen 6

Ähnliche Java Themen

Neue Themen


Oben