Получить строку из EditText без обнуляемой ошибки - PullRequest
0 голосов
/ 28 августа 2018

Я обнаружил, что проблема в том, что EditText возвращает NullPointerException ( Документация ). Сейчас я часами искал в Google решения и нашел некоторые, но они не работают для меня. Кто-то может редактировать мой код так, чтобы я правильно получил значение из Edittext в виде строки. Вот мой код:

XML

<?xml version="1.0" encoding="utf-8"?>

<android.support.constraint.ConstraintLayout 

xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity">

<!-- Page Title -->
<TextView
    android:id="@+id/PageTitle"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_marginEnd="8dp"
    android:layout_marginStart="8dp"
    android:layout_marginTop="8dp"
    android:text="@string/test_title"
    android:textAlignment="center"
    android:textSize="24sp"
    android:textStyle="bold"
    app:layout_constraintEnd_toEndOf="parent"
    app:layout_constraintHorizontal_bias="0.5"
    app:layout_constraintStart_toStartOf="parent"
    app:layout_constraintTop_toTopOf="parent" />

<!-- Input 1 -->
<EditText
    android:id="@+id/input1"
    android:layout_width="140dp"
    android:layout_height="40dp"
    android:layout_marginEnd="8dp"
    android:layout_marginStart="8dp"
    android:layout_marginTop="8dp"
    android:inputType="text"
    android:text=""
    android:hint="@string/hint_input"
    app:layout_constraintEnd_toStartOf="@+id/translation1"
    app:layout_constraintHorizontal_bias="0.5"
    app:layout_constraintStart_toStartOf="parent"
    app:layout_constraintTop_toBottomOf="@+id/PageTitle"
    android:imeOptions="actionNext"/>

<!-- Translation 1 -->
<TextView
    android:id="@+id/translation1"
    android:layout_width="140dp"
    android:layout_height="40dp"
    android:layout_marginEnd="8dp"
    android:layout_marginTop="8dp"
    android:gravity="center"
    android:text="@string/test"
    android:textAlignment="center"
    android:textSize="18sp"
    app:layout_constraintEnd_toEndOf="parent"
    app:layout_constraintHorizontal_bias="0.5"
    app:layout_constraintStart_toEndOf="@+id/input1"
    app:layout_constraintTop_toBottomOf="@+id/PageTitle"/>

<!--Check button-->
<Button
    android:id="@+id/button"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_marginBottom="8dp"
    android:layout_marginEnd="8dp"
    android:layout_marginStart="8dp"
    android:layout_marginTop="8dp"
    android:onClick="Check"
    android:text="@string/check_btn"
    app:layout_constraintBottom_toBottomOf="parent"
    app:layout_constraintEnd_toEndOf="@+id/translation1"
    app:layout_constraintStart_toStartOf="@+id/input1"
    app:layout_constraintTop_toBottomOf="@+id/PageTitle" />

 </android.support.constraint.ConstraintLayout>

Java

package com.bnf.overhooring;

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.EditText;

public class MainActivity extends AppCompatActivity {

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
}

String right = getString(R.string.right);
String wrong = getString(R.string.wrong);
String translation1 = getString(R.string.translation1);

EditText input1 = (EditText) findViewById(R.id.input1);
String string1 = input1.getText().toString();

public void Check(View view) {
    if (string1.equals(translation1)) input1.setText(right);
    else input1.setText(wrong);
 }
}

трассировка стека

E/AndroidRuntime: FATAL EXCEPTION: main
              Process: com.bnf.overhooring, PID: 30985
              java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{com.bnf.overhooring/com.bnf.overhooring.MainActivity}: java.lang.NullPointerException: Attempt to invoke virtual method 'android.content.res.Resources android.content.Context.getResources()' on a null object reference
                  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2849)
                  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3045)
                  at android.app.ActivityThread.-wrap14(ActivityThread.java)
                  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1642)
                  at android.os.Handler.dispatchMessage(Handler.java:102)
                  at android.os.Looper.loop(Looper.java:154)
                  at android.app.ActivityThread.main(ActivityThread.java:6776)
                  at java.lang.reflect.Method.invoke(Native Method)
                  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1496)
                  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1386)
               Caused by: java.lang.NullPointerException: Attempt to invoke virtual method 'android.content.res.Resources android.content.Context.getResources()' on a null object reference
                  at android.content.ContextWrapper.getResources(ContextWrapper.java:86)
                  at android.view.ContextThemeWrapper.getResourcesInternal(ContextThemeWrapper.java:127)
                  at android.view.ContextThemeWrapper.getResources(ContextThemeWrapper.java:121)
                  at android.support.v7.app.AppCompatActivity.getResources(AppCompatActivity.java:542)
                  at android.content.Context.getString(Context.java:476)
                  at com.bnf.overhooring.MainActivity.<init>(MainActivity.java:16)
                  at java.lang.Class.newInstance(Native Method)
                  at android.app.Instrumentation.newActivity(Instrumentation.java:1086)
                  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2839)
                  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3045) 
                  at android.app.ActivityThread.-wrap14(ActivityThread.java) 
                  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1642) 
                  at android.os.Handler.dispatchMessage(Handler.java:102) 
                  at android.os.Looper.loop(Looper.java:154) 
                  at android.app.ActivityThread.main(ActivityThread.java:6776) 
                  at java.lang.reflect.Method.invoke(Native Method) 
                  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1496) 
                  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1386) 

Ответы [ 2 ]

0 голосов
/ 29 августа 2018

Ваш урезанный код выглядит так:

public class MainActivity extends AppCompatActivity {

    String right = getString(R.string.right);
    String wrong = getString(R.string.wrong);
    String translation1 = getString(R.string.translation1);
}

То, что происходит, когда вы вызываете getString(), довольно сложно, но важно понять, что для этого требуется объект Resources. Этот Resources объект не «готов» сразу, когда создается экземпляр вашей активности, и именно тогда вы пытаетесь вызвать getString().

В общем, дождитесь вызова super.onCreate(), прежде чем пытаться получить доступ к структуре ресурсов; это включает в себя вызов getString().

Вы можете исправить это, изменив код так, чтобы он выглядел следующим образом:

public class MainActivity extends AppCompatActivity {

    private String right;
    private String wrong;
    private String translation1;
    private EditText input1;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        this.right = getString(R.string.right);
        this.wrong = getString(R.string.wrong);
        this.translation1 = getString(R.string.translation1);
        this.input1 = (EditText) findViewById(R.id.input1);
    }

    public void Check(View view) {
        String string1 = input1.getText().toString();

        if (string1.equals(translation1)) {
            input1.setText(right);
        }
        else {
            input1.setText(wrong);
        }
    }
}

Важная вещь, которую мы здесь сделали, - это перенести присваивание right, wrong, translation1 и input1 в наш onCreate() метод. Мы также гарантируем, что вызовы getString() происходят после super.onCreate(), а вызов findViewById() происходит после setContentView(). Порядок очень важен.

Наконец, нет причины присваивать значение string1, пока ваш Check() метод не будет вызван. Таким образом, мы гарантируем, что мы работаем с самым последним значением из нашего EditText.

0 голосов
/ 28 августа 2018

Вы не можете получить доступ к представлениям, пока onCreate не произойдет в жизненном цикле. Это когда андроид инициализирует все представления, и вы можете получить к нему доступ.

Это прекрасно работает для меня

package com.example.casti.myapplication;


import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.EditText;

public class MainActivity extends AppCompatActivity {

    String right = "right";
    String wrong = "wrong";
    String translation1 = "translation1";

    EditText input1;
    String string1;


    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        input1 = findViewById(R.id.input1);
        string1 = input1.getText().toString();
    }

    public void Check(View view) {
        if (string1.equals(translation1)) input1.setText(right);
        else input1.setText(wrong);
    }

}

...