[英]Why are my TextViews null?
我想如果用户输入一个无效数字,则两个TextView
应该更改其文本。
我抬头检查是否有多个具有相同ID的TextView
,结果是我的TextView
的每个ID都是唯一的。
每次我输入无效数字来强行输入错误时,我的应用就会崩溃。 如果我在调试中启动应用程序并标记了我的两个“问题代码”。 结果是两个TextView
都为null
。
我不知道为什么会这样,因为ID是唯一的,而且我不会更改当前的布局。
我的Java代码:
public void checkingInput(View view) {
TextView eKnowledge = (TextView) findViewById(R.id.enterKnowledge);
try{
int inputNumber = Integer.parseInt(eKnowledge.getText().toString());
_knowledge = KnowledgeLevel.fromUserInput(inputNumber);
test();
hideKeyboard(view);
} catch(NumberFormatException e){
errorKnowledge();
hideKeyboard(view);
}
}
@SuppressLint("SetTextI18n")
public void test() {
setContentView(R.layout.test);
TextView test = (TextView) findViewById(R.id.textView_nur_einmal_benutzt_hoff_ich);
switch(_knowledge) {
case NOOB:
test.setText("ENUM = NOOB");
break;
case BEGINNER:
test.setText("ENUM = BEGINNER");
break;
case ADVANCED:
test.setText("ENUM = ADV");
break;
case PRO:
test.setText("ENUM = PRO");
break;
case GRANDMASTER:
test.setText("ENUM = GM");
break;
case ERROR:
errorKnowledge();
break;
case FAIL:
test.setText("FEHLER!");
break;
}
}
@SuppressLint("SetTextI18n")
public void errorKnowledge(){
TextView hKnowledge = (TextView) findViewById(R.id.testWissenstandHeader);
TextView tKnowledge = (TextView) findViewById(R.id.testWissenstandText);
/* da ist der fehler ... einmal mit dem debugger durch zeigt es doch direkt: hKnowledge und tKnowledge sind null, daher die NullPointerException */
hKnowledge.getResources().getString(R.string.FehlerGefunden);
hKnowledge.getResources().getColor(android.R.color.holo_red_dark);
tKnowledge.getResources().getString(R.string.FehlerText1);
tKnowledge.getResources().getColor(android.R.color.holo_red_light);
}
private enum KnowledgeLevel {
FAIL, ERROR, NOOB, BEGINNER, ADVANCED, PRO, GRANDMASTER;
static KnowledgeLevel fromUserInput(final int input)
{
if (input >= 11 || input <= -1) {
return ERROR;
}
else if (input == 10) {
return GRANDMASTER;
}
else if (input >= 7) {
return PRO;
}
else if (input >= 4) {
return ADVANCED;
}
else if (input >= 1 ) {
return BEGINNER;
}
else if (input == 0) {
return NOOB;
}
return FAIL;
}
}
而我的XML:
<TextView
android:id="@+id/testWissenstandHeader"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginBottom="8dp"
android:layout_marginStart="8dp"
android:layout_marginEnd="8dp"
android:layout_marginTop="8dp"
android:text="Bla"
android:textAlignment="center"
android:textColor="#511613"
android:textSize="32sp"
android:textStyle="bold"
app:layout_constraintBottom_toBottomOf="@+id/kastenKnowledge"
app:layout_constraintLeft_toLeftOf="@+id/kastenKnowledge"
app:layout_constraintRight_toRightOf="@+id/kastenKnowledge"
app:layout_constraintTop_toTopOf="@+id/kastenKnowledge"/>
<TextView
android:id="@+id/testWissenstandText"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginEnd="16dp"
android:layout_marginStart="16dp"
android:layout_marginTop="16dp"
android:text='BlaBla'
android:textAlignment="center"
android:textColor="#E0E0E0"
android:textSize="20sp"
app:layout_constraintHorizontal_bias="0.512"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toBottomOf="@+id/testWissenstandHeader"/>
我研究了一下,在stackoverflow.com上发现的唯一解决方案是我需要使用setContentView();
但是我有两个问题:
1.如果不更改布局,为什么要使用它?
2.我尝试过,但我的应用程序没有崩溃,但我的文本没有更改。 ( setContentView();
在使用setText();"
之前使用setText();"
)
这是我的整个错误报告(无调试问题):
08-10 00:14:53.580 2774-2774/com.example.alexander.hashtagnevereverbuggy E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.example.alexander.hashtagnevereverbuggy, PID: 2774
java.lang.IllegalStateException: Could not execute method for android:onClick
at android.support.v7.app.AppCompatViewInflater$DeclaredOnClickListener.onClick(AppCompatViewInflater.java:293)
at android.view.View.performClick(View.java:4756)
at android.view.View$PerformClick.run(View.java:19749)
at android.os.Handler.handleCallback(Handler.java:739)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:135)
at android.app.ActivityThread.main(ActivityThread.java:5221)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:899)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694)
Caused by: java.lang.reflect.InvocationTargetException
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at android.support.v7.app.AppCompatViewInflater$DeclaredOnClickListener.onClick(AppCompatViewInflater.java:288)
at android.view.View.performClick(View.java:4756)
at android.view.View$PerformClick.run(View.java:19749)
at android.os.Handler.handleCallback(Handler.java:739)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:135)
at android.app.ActivityThread.main(ActivityThread.java:5221)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:899)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694)
Caused by: java.lang.NullPointerException: Attempt to invoke virtual method 'android.content.res.Resources android.widget.TextView.getResources()' on a null object reference
at com.example.alexander.hashtagnevereverbuggy.MainActivity.errorKnowledge(MainActivity.java:112)
at com.example.alexander.hashtagnevereverbuggy.MainActivity.test(MainActivity.java:97)
at com.example.alexander.hashtagnevereverbuggy.MainActivity.checkingInput(MainActivity.java:68)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at android.support.v7.app.AppCompatViewInflater$DeclaredOnClickListener.onClick(AppCompatViewInflater.java:288)
at android.view.View.performClick(View.java:4756)
at android.view.View$PerformClick.run(View.java:19749)
at android.os.Handler.handleCallback(Handler.java:739)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:135)
at android.app.ActivityThread.main(ActivityThread.java:5221)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:899)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694)
编辑:
package com.example.alexander.hashtagnevereverbuggy;
import android.annotation.SuppressLint;
import android.app.Fragment;
import android.app.FragmentManager;
import android.app.FragmentTransaction;
import android.content.Context;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.text.Html;
import android.view.View;
import android.view.inputmethod.InputMethodManager;
import android.widget.Button;
import android.widget.ImageButton;
import android.widget.ImageView;
import android.widget.TextView;
import java.util.HashMap;
import com.google.android.gms.ads.AdRequest;
import com.google.android.gms.ads.AdView;
import com.google.android.gms.ads.MobileAds;
import java.util.Map;
@SuppressWarnings("deprecation")
public class MainActivity extends AppCompatActivity implements Heroes {
private KnowledgeLevel _knowledge = KnowledgeLevel.NOOB;
private static FragmentManager _fragmentManager;
private enum WerteTextFelder {
TITLE,TYP, DAMAGE, LADUNG, KUGELN, NACHLADEDAUER, HEILUNG, HEADSHOT, WIRKUNGSDAUER, EXTRAEFFEKT, BESONDERHEIT
}
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
MobileAds.initialize(this, getString(R.string.AppID));
_fragmentManager = getFragmentManager();
Button testButtonAnfang = (Button) findViewById(R.id.AnfangsButton);
testButtonAnfang.setOnClickListener(new View.OnClickListener(){
@Override
public void onClick(View v) {
setContentView(R.layout.testwissenstand);
}
});
}
@Override
public void onBackPressed() {
if(getFragmentManager().getBackStackEntryCount() > 0) {
getFragmentManager().popBackStack();
}
super.onBackPressed();
}
public void checkingInput(View view) {
TextView eKnowledge = (TextView) findViewById(R.id.enterKnowledge);
try{
int inputNumber = Integer.parseInt(eKnowledge.getText().toString());
_knowledge = KnowledgeLevel.fromUserInput(inputNumber);
test();
hideKeyboard(view);
} catch(NumberFormatException e){
errorKnowledge();
hideKeyboard(view);
}
}
@SuppressLint("SetTextI18n")
public void test() {
setContentView(R.layout.test);
TextView test = (TextView) findViewById(R.id.textView_nur_einmal_benutzt_hoff_ich);
switch(_knowledge) {
case NOOB:
test.setText("ENUM = NOOB");
break;
case BEGINNER:
test.setText("ENUM = BEGINNER");
break;
case ADVANCED:
test.setText("ENUM = ADV");
break;
case PRO:
test.setText("ENUM = PRO");
break;
case GRANDMASTER:
test.setText("ENUM = GM");
break;
case ERROR:
errorKnowledge();
break;
case FAIL:
test.setText("FEHLER!");
break;
}
}
@SuppressLint("SetTextI18n")
public void errorKnowledge(){
TextView hKnowledge = (TextView) findViewById(R.id.testWissenstandHeader);
TextView tKnowledge = (TextView) findViewById(R.id.testWissenstandText);
/* da ist der fehler ... einmal mit dem debugger durch zeigt es doch direkt: hKnowledge und tKnowledge sind null, daher die NullPointerException */
hKnowledge.getResources().getString(R.string.FehlerGefunden);
hKnowledge.getResources().getColor(android.R.color.holo_red_dark);
tKnowledge.getResources().getString(R.string.FehlerText1);
tKnowledge.getResources().getColor(android.R.color.holo_red_light);
}
private enum KnowledgeLevel {
FAIL, ERROR, NOOB, BEGINNER, ADVANCED, PRO, GRANDMASTER;
static KnowledgeLevel fromUserInput(final int input)
{
if (input >= 11 || input <= -1) {
return ERROR;
}
else if (input == 10) {
return GRANDMASTER;
}
else if (input >= 7) {
return PRO;
}
else if (input >= 4) {
return ADVANCED;
}
else if (input >= 1 ) {
return BEGINNER;
}
else if (input == 0) {
return NOOB;
}
return FAIL;
}
}
public static void addTransaction(Fragment fragment, String tag){
if (_fragmentManager != null) {
FragmentTransaction fragmentTransaction = _fragmentManager.beginTransaction();
fragmentTransaction.add(fragment, tag);
fragmentTransaction.addToBackStack(tag);
fragmentTransaction.commit();
}
}
private void hideKeyboard(View view){
InputMethodManager imm = (InputMethodManager)getSystemService(Context.INPUT_METHOD_SERVICE);
imm.hideSoftInputFromWindow(view.getWindowToken(), 0);
}
private class geileListener implements View.OnClickListener{
private Hero hero;
private geileListener (Hero hero) {
this.hero = hero;
}
@Override
public void onClick(View view) {
setContentView(hero.getHeroLayout());
}
}
private void advertisment() {
/*Notwendig um advertisment im showlock darzustellen*/
AdView mAdView = (AdView) findViewById(R.id.adView);
AdRequest adRequest = new AdRequest.Builder().build();
mAdView.loadAd(adRequest);
}
public void showPreview (Hero hero) {
setContentView(hero.getPreviewLayout());
ImageButton button = (ImageButton) findViewById(R.id.imageButton_Preview);
button.setImageResource(hero.getPreviewImage());
button.setOnClickListener(new geileListener(hero));
advertisment();
}
private Map<WerteTextFelder, TextView> getWerteTextFelder() {
setContentView(R.layout.werte);
Map<WerteTextFelder, TextView> map = new HashMap<>();
TextView Titel = (TextView) findViewById(R.id.textView_Überschrift);
TextView Typ = (TextView) findViewById(R.id.textView_Werte_0);
TextView Damage = (TextView) findViewById(R.id.textView_Wert_1);
TextView Ladung = (TextView) findViewById(R.id.textView_Wert_2);
TextView Kugeln = (TextView) findViewById(R.id.textView_Wert_3);
TextView Nachladedauer = (TextView) findViewById(R.id.textView_Wert_4);
TextView Heilung = (TextView) findViewById(R.id.textView_Wert_5);
TextView Headshot = (TextView) findViewById(R.id.textView_Wert_6);
TextView Wirkungsdauer = (TextView) findViewById(R.id.textView_Wert_7);
TextView ExtraEffekt = (TextView) findViewById(R.id.textView_Wert_8);
TextView wert9 = (TextView) findViewById(R.id.textView_Wert_9);
map.put(WerteTextFelder.TITLE, Titel);
map.put(WerteTextFelder.TYP, Typ);
map.put(WerteTextFelder.DAMAGE, Damage);
map.put(WerteTextFelder.LADUNG, Ladung);
map.put(WerteTextFelder.KUGELN, Kugeln);
map.put(WerteTextFelder.NACHLADEDAUER, Nachladedauer);
map.put(WerteTextFelder.HEILUNG, Heilung);
map.put(WerteTextFelder.HEADSHOT, Headshot);
map.put(WerteTextFelder.WIRKUNGSDAUER, Wirkungsdauer);
map.put(WerteTextFelder.EXTRAEFFEKT, ExtraEffekt);
map.put(WerteTextFelder.BESONDERHEIT, wert9);
return map;
}
其他所有内容(4k代码行)都非常重要
在onCreate()
,必须调用setContentView(R.layout.whateveryourxml)
。 之后,但仍然可以追溯到onCreate,可以调用errorKnowledge()
。 这应确保两个TextView都不为null。
[编辑:我想弄清楚, 你必须的onCreate期间调用setContentView方法,或者你TextViews将解析为空。 假设您已完成操作(如您发布的代码中所示),请继续阅读!]
这些代码行对我来说似乎不正确。 他们看起来好像不会做任何事情:
hKnowledge.getResources().getString(R.string.FehlerGefunden);
hKnowledge.getResources().getColor(android.R.color.holo_red_dark);
tKnowledge.getResources().getString(R.string.FehlerText1);
tKnowledge.getResources().getColor(android.R.color.holo_red_light);
您没有看到任何效果的原因是这些是返回某些值的get语句,但是实际上您没有使用这些值做任何事情。
我觉得您实际上想说的是:
hKnowledge.setText(R.string.FehlerGefunden);
hKnowledge.setTextColor(android.R.color.holo_red_dark);
tKnowledge.setText(R.string.FehlerText1);
tKnowledge.setTextColor(android.R.color.holo_red_dark);
我还建议您花一些时间在onCreate方法中以完成所有findView的工作,这样您就不必一遍又一遍地做。 (它也更清晰一些,为您节省了很多样板java。)
您可以将各种TextView元素(等)定义为该类的私有成员,因此-例如,仅针对我们已经在讨论的2个TextView:
private TextView hKnowledge;
private TextView tKnowledge;
...
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
hKnowledge = (TextView) findViewById(R.id.testWissenstandHeader);
tKnowledge = (TextView) findViewById(R.id.testWissenstandText);
...
}
完成此操作后,您可以从类中的其他任何地方引用两个TextView,就像它们的成员一样:hKnowledge和tKnowledge;
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.