Verbesserung für JRadioButton

Mikesh

Mitglied
Hey an alle,

vorweg ich bin quasi kompletter Anfänger was das Programmieren angeht, daher ist der folgende Code für viele Fortgeschrittene bestimmt nicht sonderlich schön anzusehen.

Problem: Ich habe mit Swing einen BMI-Rechner programmiert bei dem die Möglichkeit besteht auszuwählen ob man direkt den BMI-Wert möchte oder eine Erläuterung, z.B. bei einem BMI von 32 "leichtes Übergewicht". Wie gesagt der Rechner läuft, allerdings bin ich mit meiner Lösung nicht wirklich zufrieden, es kommt mir alles etwas umständlich vor. Hätte mir vielleicht jemand einen Tipp wie ich z.B die Sache mit den RadioButtons besser lösen könnte?
Code:
import javax.swing.*;

import java.awt.*;
import java.awt.event.*;

public class BmiRechner extends JFrame {

    // Attribute

    private JPanel jPanel1 = new JPanel();

    private JLabel jLabelGE = new JLabel();
    private JLabel jLabelGR = new JLabel();
    private JLabel jLabelBMI = new JLabel();

    private JTextField txtGroesse = new JTextField(4);
    private JTextField txtGewicht = new JTextField(4);
    private JTextField txtBMI = new JTextField(15);

    private JButton btnBerechnung = new JButton();

    private JRadioButton jRbZahl = new JRadioButton();
    private JRadioButton jRbText = new JRadioButton();
    private ButtonGroup gruppe = new ButtonGroup();

    double gewicht;
    double groesse;
    double bmi;

    // Konstruktor

    public BmiRechner() {
        initUI();
    }

    // Methoden

    private void initUI() {

        jPanel1.setLayout(new FlowLayout());
        this.setTitle("BMI-Rechner");

        jLabelGE.setText("Gewicht in Kg: ");
        jPanel1.add(jLabelGE);
        txtGewicht.setText("");
        jPanel1.add(txtGewicht);
        jLabelGR.setText("Größe in cm: ");
        jPanel1.add(jLabelGR);
        txtGroesse.setText("");
        jPanel1.add(txtGroesse);
        jRbZahl.setText("Zahlenwert");
        jPanel1.add(jRbZahl);
        gruppe.add(jRbZahl);
        jRbText.setText("Erläuterung");
        jPanel1.add(jRbText);
        gruppe.add(jRbText);
        btnBerechnung.setText("Berechnung");
        jPanel1.add(btnBerechnung);
        jLabelBMI.setText("BMI");
        jPanel1.add(jLabelBMI);
        txtBMI.setText("");
        jPanel1.add(txtBMI);

        this.getContentPane().add(jPanel1);
        pack();
        setDefaultCloseOperation(EXIT_ON_CLOSE);

        jRbText.addActionListener(new ActionListener() {

            @Override
            public void actionPerformed(ActionEvent ae) {
                // TODO Auto-generated method stub
                jLabelBMI.setText("Erläuterung");
                txtBMI.setText("");
                pack();

            }

        });
        jRbZahl.addActionListener(new ActionListener() {

            @Override
            public void actionPerformed(ActionEvent ae) {
                // TODO Auto-generated method stub
                jLabelBMI.setText("BMI");
                txtBMI.setText("");
                pack();

            }

        });

        btnBerechnung.addActionListener(new ActionListener() {

            @Override
            public void actionPerformed(ActionEvent e) {
                try {
                    double gewicht = Double.parseDouble(txtGewicht.getText());
                    double groesse = Double.parseDouble(txtGroesse.getText());
                    double bmi;
                    bmi = gewicht / (groesse * groesse);
                    if (jRbText.isSelected() == true && bmi < 20) {
                        txtBMI.setText("Untergewicht");
                    } else if (jRbText.isSelected() == true && bmi >= 20
                            && bmi < 25) {
                        txtBMI.setText("Normalgewicht");

                    } else if (jRbText.isSelected() == true && bmi >= 25
                            && bmi < 30) {
                        txtBMI.setText("Übergewicht (Grad I)");

                    } else if (jRbText.isSelected() == true && bmi >= 30
                            && bmi < 40) {
                        txtBMI.setText("Starkes Übergewicht (Grad II)");

                    } else if (jRbText.isSelected() == true && bmi > 40) {
                        txtBMI.setText("Extremes Übergewicht (GradIII)");

                    } else if (jRbZahl.isSelected() == true) {
                        txtBMI.setText("" + bmi);

                    }
                } catch (NumberFormatException er) {
                    txtBMI.setText("###FEHLER###");
                }
            }

        });

    }

}

Bin über jeden Tipp dankbar! War aber trotzdem schon froh, dass ich das Ding selbst zum laufen bekommen hab :D
Viele Grüße und schönes Wochenende
 

Blender3D

Top Contributor
vorweg ich bin quasi kompletter Anfänger was das Programmieren angeht, daher ist der folgende Code für viele Fortgeschrittene bestimmt nicht sonderlich schön anzusehen.
Ich habe Dir Deinen Code etwas in Form gebracht, indem ich:
1) die Logik des BMI in eine eigene Klasse gepackt habe.
2) Man sollte nicht von JFrame erben. Ich erbe von einem JPanel den ich in den JFrame einsetze.
3) Ich habe die RadioButtons entfernt und zeige beide Werte ständig an. Macht mehr Sinn.
4) Ok Button habe ich auch entfernt. Die Neuberechnung steuere ich mit einem Fokuslistener. Das bedeutet immer wenn Du auf die andere Eingabe wechselst wird neu berechnet.
Du brauchst so nur mehr 7 anstatt 9 Komponenten für die Anzeige.
5) Der BMI Wert wird auf 2 Kommastellen angezeigt.

upload_2018-5-18_16-1-59.png
Hier der Code dazu :
Code:
public class BodyMassIndex {
    private double weight = 0;

    private double size = 0;

    /**
     * @param weight
     *            in kilogram
     * @param size
     *            in meter
     */
    public BodyMassIndex(double weight, double size) {
        this.weight = weight;
        this.size = size;
    }

    public BodyMassIndex(String weight, String size) throws NumberFormatException {
        this.weight = Double.parseDouble(weight);
        this.size = Double.parseDouble(size);
    }

    public double getBMI() {
        return weight / (size * size);
    }

    public String getFormattedStringBMI(int numDecimal) {
        return (String.format("%." + numDecimal + "f", getBMI()));
    }

    public double getSize() {
        return size;
    }

    public double getWeight() {
        return weight;
    }

    @Override
    public String toString() {
        double bmi = getBMI();
        if (bmi < 20)
            return "Untergewicht";
        if (bmi < 25)
            return "Normalgewicht";
        if (bmi < 30)
            return "\"Übergewicht (Grad I)\"";
        if (bmi < 40)
            return "Starkes Übergewicht (Grad II)";
        return "Extremes Übergewicht (GradIII)";
    }

}

Code:
mport java.awt.Color;
import java.awt.Dimension;
import java.awt.FlowLayout;
import java.awt.event.FocusEvent;
import java.awt.event.FocusListener;
import javax.swing.JLabel;
import javax.swing.JPanel;
import javax.swing.JTextField;
import javax.swing.SwingConstants;
import javax.swing.border.LineBorder;

@SuppressWarnings("serial")
public class BMIPanel extends JPanel implements FocusListener {
    private JLabel labelBMIValue = new JLabel("", SwingConstants.CENTER);
    private JLabel labelBMIText = new JLabel("", SwingConstants.CENTER);
    private JTextField txtSize = new JTextField(6);
    private JTextField txtWeight = new JTextField(6);
    BodyMassIndex bmi = new BodyMassIndex(70, 1.75); // default value

    public BMIPanel(int width, int height) {
        super.setPreferredSize(new Dimension(width, height));
        setLayout(new FlowLayout());
        initLayout(width);
        updateBMIValuesDisplay();
        txtSize.addFocusListener(this);
        txtWeight.addFocusListener(this);
    }

    @Override
    public void focusGained(FocusEvent e) {
        updateValues();
    }

    @Override
    public void focusLost(FocusEvent e) {
        updateValues();
    }

    private double getdoubleValue(String value, double oldValue) {
        try {
            oldValue = Double.parseDouble(value.trim());
        } catch (NumberFormatException e) {
        }
        return oldValue;
    }

    private void initLayout(int width) {
        JLabel labelSize = new JLabel("  Größe in m  ");
        JLabel labelWeight = new JLabel(" Gewicht in kg  ");
        JLabel labelBMI = new JLabel("BMI ==", SwingConstants.CENTER);
      
        labelSize.setBorder(new LineBorder(Color.RED));
        labelWeight.setBorder(new LineBorder(Color.RED));
        labelBMI.setBorder(new LineBorder(Color.RED));
        labelBMIValue.setBorder(new LineBorder(Color.BLACK));
        int h = 2 * getFont().getSize();
        labelBMI.setPreferredSize(new Dimension(width/4, h));
        labelBMIValue.setPreferredSize(new Dimension(width / 5, h));
        labelBMIText.setBorder(new LineBorder(Color.BLACK));
        labelBMIText.setPreferredSize(new Dimension(width / 2, h));
        add(labelSize);
        add(txtSize);
        add(labelWeight);
        add(txtWeight);
        add(labelBMI);
        add(labelBMIValue);
        add(labelBMIText);
    }

    private void updateBMIValuesDisplay() {
        txtSize.setText(bmi.getSize() + "");
        txtWeight.setText(bmi.getWeight() + "");
        labelBMIValue.setText(bmi.getFormattedStringBMI(2));
        labelBMIText.setText(" " + bmi);
    }

    private void updateValues() {
        double size = getdoubleValue(txtSize.getText(), bmi.getSize());
        double weight = getdoubleValue(txtWeight.getText(), bmi.getWeight());
        bmi = new BodyMassIndex(weight, size);
        updateBMIValuesDisplay();
    }
}

Code:
import javax.swing.JFrame;

public class start {
    public static void main(String[] args) {  
        JFrame frame = new JFrame("BMI Rechner");
        frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
        frame.add(new BMIPanel(400, 60));
        frame.setResizable(false);
        frame.pack();
        frame.setVisible(true);
    }
}

;)
 

Mikesh

Mitglied
Super, ja so sieht das alles natürlich schon besser aus, Danke!Denke da hilft nur programmieren, programmieren und programmieren. Bin mal gespannt ob ich mein Snake hinbekomme^^. Gibt es zwar schon fertig im Netz aber das ist ja nicht der Sinn der Sache
 

Blender3D

Top Contributor
Das habe ich ihm schon gesagt, diesbezüglich ist er aber lernresistent
Hab den Hinweis nicht wirklich verstanden gehabt. Da ich die vom Forum angebotene Funktion benutze.
Wäre aber eine Idee den angebotenen Tag von
Code:
automatisch auf
Java:
einzustellen, da wir hier ein Java Forum haben.
 

Blender3D

Top Contributor
du meinst einfach nur das =java in dem öffnenden Tag ergänzen. Dann wirds Java
Genau als Defaultwert.
Ich habe die Code Tagfunktion relativ schnell nach einem Hinweis benutzt.
Den Tipp mit den Java Tag hab ich erst jetzt realisiert.
Grund. Ich habe in den 80er Jahren zu programmieren begonnen. Damals hat man teilweise noch mit Hex-Editoren programmiert. Auf meinem C64 habe ich so einen eigenen Macro Assemlber geschrieben.
Von daher bin ich es gewohnt Code auch ohne Formatierung zu lesen. Und ich ging davon aus, dass die Code Funktion das macht. :oops: Mein Fehler. Sorry.
Aber wie schon gesagt -> sollte vielleicht per Default so eingestellt sein.
:)
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
J Best Practice [Code Verbesserung] TXT einlesen und in Arrayliste speichern Java Basics - Anfänger-Themen 5
J Erste Schritte Caesar - Code Verbesserung Java Basics - Anfänger-Themen 2
E Hilfe zur Performance Verbesserung gesucht Java Basics - Anfänger-Themen 1
H ActionListener Verbesserung möglich? (This) Java Basics - Anfänger-Themen 3
M Code verbesserung Java Basics - Anfänger-Themen 11
M Code aus IntelliJ in "Textform" für Word-Paper? Java Basics - Anfänger-Themen 10
G Icon für App Java Basics - Anfänger-Themen 1
Kerstininer Vererbung Hilfe beim lernen von Objektorientierung für eine Klausur Java Basics - Anfänger-Themen 10
Sniper1000 Java 391 für Windows Java Basics - Anfänger-Themen 37
P Wieso kann ich als Index für einen Array einen Char angeben? Java Basics - Anfänger-Themen 3
benny1993 Java Programm erstellen für ein Fußball-Turnier Java Basics - Anfänger-Themen 3
V Durchschnittliche Volatility in Prozent für 4 Stunden berechnen Java Basics - Anfänger-Themen 14
P Welches SDK für das erstellen einer ausführbaren Datei? Java Basics - Anfänger-Themen 4
C negamax-Algorithmus für Tic-Tac-Toe spielt manchmal falsch Java Basics - Anfänger-Themen 10
D Apache HTTPClient für alle Fälle Java Basics - Anfänger-Themen 41
J Layout Manager, welcher ist der Richtige für mein Program? Java Basics - Anfänger-Themen 1
J Fehlermeldung unverständlich für Jakarta Java Basics - Anfänger-Themen 17
M Minimax-Algorithmus für Vier gewinnt Java Basics - Anfänger-Themen 11
M GUI für Vier-Gewinnt. Java Basics - Anfänger-Themen 4
I JPA Query für mehrere Klassen Java Basics - Anfänger-Themen 3
D Quellcode für cmd funktioniert nicht Java Basics - Anfänger-Themen 9
R Operatoren Rechenoperation in Java verwenden für Calculator Java Basics - Anfänger-Themen 2
R Operatoren Rechenoperation verwenden für Taschenrechner. Java Basics - Anfänger-Themen 32
Ostkreuz Counter für Booleanwerte Java Basics - Anfänger-Themen 8
B Regex Ausdrücke für Monate Java Basics - Anfänger-Themen 7
I BlueJ Queue Frage für Klausur Java Basics - Anfänger-Themen 2
K loop pausieren für eine bestimmte Anzahl? Java Basics - Anfänger-Themen 1
Jxhnny.lpz Randomisier für Buttons Java Basics - Anfänger-Themen 13
W Intuitive interface für Komponenten Java Basics - Anfänger-Themen 4
M "Class<T> clazz" im Constructor - auch für int möglich? Java Basics - Anfänger-Themen 7
B Schrankensystem mit Farberkennung für Flashgame funktioniert nicht wie geplant Java Basics - Anfänger-Themen 4
I Code für Bezahlsystem (auch bei Offline Aktivität) Java Basics - Anfänger-Themen 7
U jUnit 5 Test für eine addMethode Java Basics - Anfänger-Themen 18
M monte carlo Algorithmus für 4 gewinnt Java Basics - Anfänger-Themen 12
frager2345 Java Singleton Muster -> Methode für Konstruktor mit Parametern Java Basics - Anfänger-Themen 3
izoards Sortier Algorithmus für Bounding Box Elememte Links nach Rechts und von Oben nach Unten Java Basics - Anfänger-Themen 33
M generate Methode für Streams Java Basics - Anfänger-Themen 6
I Datenmodell für "Tags" Java Basics - Anfänger-Themen 6
Lion.King for-Kontrollstruktur für Pyramide Java Basics - Anfänger-Themen 8
B Mit Countdown Midnestdauer für Teilaufgabenerledigung erzwingen Java Basics - Anfänger-Themen 8
J File length als Prüfwert für Download Java Basics - Anfänger-Themen 5
K Spieleidee gesucht für Informatikprojekt - JAVA (BlueJ)? Java Basics - Anfänger-Themen 15
P Zähler Variable für mehrere Objekte Java Basics - Anfänger-Themen 6
javamanoman Java für Online Banking Java Basics - Anfänger-Themen 12
NadimArazi Wie kann ich eine collision detection für die Paddles in meinem Pong Programm hinzufügen? Java Basics - Anfänger-Themen 4
JordenJost Java ist auch eine Insel für Anfänger Java Basics - Anfänger-Themen 2
P9cman Tipps für Rekursive Aufgaben mit Strings oder allgemein Java Basics - Anfänger-Themen 2
F Suche nach betreuender Person für eine Jahresarbeit der 12. Klasse. Java Basics - Anfänger-Themen 6
I SQL / JPA Query für StartDate und EndDate Java Basics - Anfänger-Themen 1
T getMethode für ein Array Java Basics - Anfänger-Themen 2
Fats Waller Farben mixen für den Hintergrund ? Java Basics - Anfänger-Themen 1
H Suche jemanden für kleine Uni-Abgabe/ mit Vergütung Java Basics - Anfänger-Themen 1
K Für was braucht man die left und right shift operatoren? Was bringen die, also welchen Zweck haben die? Java Basics - Anfänger-Themen 15
N Api nur für Textdatein (.txt) Java Basics - Anfänger-Themen 2
bluetrix Programmieren eines Bots für Zahlen-Brettspiel Java Basics - Anfänger-Themen 9
M Wie kann eine Methode für ein vorhandenes "Array von char" einen Index-Wert zurückliefern? Java Basics - Anfänger-Themen 3
R Ist Java das Richtige für mich? Java Basics - Anfänger-Themen 4
E Mittelquadratmethode für Hexadezimalzahlen Java Basics - Anfänger-Themen 1
P Einfacher regulärer Ausdruck (RegEx) für E-Mail-Adressen Java Basics - Anfänger-Themen 2
Kiki01 Wie würde eine geeignete Schleife aussehen, die die relative Häufigkeit für jeden Charakter in einem Text bestimmt? Java Basics - Anfänger-Themen 3
N Fehler im Code (Aufgabe für Anfänger) Java Basics - Anfänger-Themen 11
O Wie erstelle ich eine Instanz in einer Klasse für die ich die Instanz will? Java Basics - Anfänger-Themen 4
S BubbleSort für ArrayLists Java Basics - Anfänger-Themen 3
T Übungsbuch für Anfänger Java Basics - Anfänger-Themen 3
L Konzept für Quiz Java Basics - Anfänger-Themen 33
D Methoden Plathhalter für Integer in einer Methode Java Basics - Anfänger-Themen 19
B Datentyp für Einzelnes Objekt oder Liste Java Basics - Anfänger-Themen 9
D Welche GUI Library für eine Client Server Chat App Java Basics - Anfänger-Themen 14
T Algorithmus für Index mit min-Wert Java Basics - Anfänger-Themen 2
Aqtox Hallo ich muss für die Schule ein Wuerfell Duell erstellen jedoch habe ich ein fehler Java Basics - Anfänger-Themen 4
L loop für Namen Java Basics - Anfänger-Themen 11
kxrdelis Konstruktor für ein Rechtwinkliges Dreieck Java Basics - Anfänger-Themen 10
S Fehler bei Code mit SubStrings für mich nicht auffindbar. Java Basics - Anfänger-Themen 4
nevel Programm für die Summer der Zahlen 1- 1ß Java Basics - Anfänger-Themen 12
I Entity erstellen, die für API gedacht ist Java Basics - Anfänger-Themen 33
C Archiv für eigene Klassen Java Basics - Anfänger-Themen 9
A Junit Test für MysqlDataSource JDBC Java Basics - Anfänger-Themen 3
Animal-Mother BMI Rechner erstellen für W/M Java Basics - Anfänger-Themen 7
E Kleines Java-Projekt für Anfänger Java Basics - Anfänger-Themen 10
A Java die richtige Programmiersprache für mein Projekt? Java Basics - Anfänger-Themen 1
I DecimalFormat in Zahlenformat für Währung, habe 7,99, bekomme aber 7 Java Basics - Anfänger-Themen 4
L Methode für Zweidimensionale Arrays Java Basics - Anfänger-Themen 4
Kanaska Datentyp für Zahlenbereiche Java Basics - Anfänger-Themen 7
T Startbildschirm für ein Spiel erstellen Java Basics - Anfänger-Themen 0
U BestPractise für Deployment unter Windows gesucht Java Basics - Anfänger-Themen 12
lilrack UML Diagramm für Parkplatzverwaltung Java Basics - Anfänger-Themen 8
W Mehrfach das gleiche Attribut für ein Objekt erzeugen (mit verschiedenen Werten) Java Basics - Anfänger-Themen 2
B Generische Typen für dynamisches Formular Java Basics - Anfänger-Themen 3
C Was ist nötig für ein Java-Programm auf Server für Website Java Basics - Anfänger-Themen 18
T Vererbung Verschiedene Attribute für vererbte Klassen Java Basics - Anfänger-Themen 4
T Start-Activity für Java Maven Web-Anwendung festlegen Java Basics - Anfänger-Themen 2
T Alternative für switch case Java Basics - Anfänger-Themen 1
P Ressourcen für JSON & API Informationen? Java Basics - Anfänger-Themen 1
M Java Einstellung von Apache POI für MS Word Erstellung mit Eclipse Java Basics - Anfänger-Themen 6
L Compiler-Fehler SupressWarning für clone() Java Basics - Anfänger-Themen 6
P Wie für EIN Java Programm von 64bit Java (=Standard) auf 32bit Java Installation (Windows) umschalten? Java Basics - Anfänger-Themen 6
B Methode für jede beliebe Entity erstellen Java Basics - Anfänger-Themen 7
D Ampel für Mitarbeiter zum An-/Abwesend zeigen Java Basics - Anfänger-Themen 28
T Wahrscheinlichkeiten für Slot Machine Java Basics - Anfänger-Themen 13
C Konvertierung des int typs in den double typ für die Ausgabe mit Nachkommastellen Java Basics - Anfänger-Themen 4

Ähnliche Java Themen

Neue Themen


Oben