Recyclerviewを使用するのはこれが初めてであり、Android:onClick="addItem"
これは、recyclerviewにテキスト行を追加しようとしたときに得られるものです。通常、スマートフォンを使用してアプリをテストします。
Java.lang.IllegalStateException: Could not execute method of the activity
at Android.view.View$1.onClick(View.Java:4012)
at Android.view.View.performClick(View.Java:4761)
at Android.view.View$PerformClick.run(View.Java:19767)
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:5312)
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:901)
at com.Android.internal.os.ZygoteInit.main(ZygoteInit.Java:696)
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.view.View$1.onClick(View.Java:4007)
at Android.view.View.performClick(View.Java:4761)
at Android.view.View$PerformClick.run(View.Java:19767)
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:5312)
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:901)
at com.Android.internal.os.ZygoteInit.main(ZygoteInit.Java:696)
Caused by: Java.lang.NullPointerException: Attempt to invoke virtual method 'Android.text.Editable Android.widget.EditText.getText()' on a null object reference
at com.sapps.app.testapp2.MainActivity.addItem(MainActivity.Java:53)
at Java.lang.reflect.Method.invoke(Native Method)
at Java.lang.reflect.Method.invoke(Method.Java:372)
at Android.view.View$1.onClick(View.Java:4007)
at Android.view.View.performClick(View.Java:4761)
at Android.view.View$PerformClick.run(View.Java:19767)
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:5312)
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:901)
at com.Android.internal.os.ZygoteInit.main(ZygoteInit.Java:696)
ここにエラーがあると思うコードがありますが、正確にはわかりません:
public class MainActivity extends ActionBarActivity {
private EditText mText;
private RecyclerView.LayoutManager mLayoutManager;
private RecyclerView recyclerView;
private Button btn;
private CustomRecyclerAdapter mAdapter;
private List<Data> mData = new ArrayList<>();
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
// Initializing views.
mText = (EditText) findViewById(R.id.textEt);
recyclerView = (RecyclerView) findViewById(R.id.recycler);
// If the size of views will not change as the data changes.
recyclerView.setHasFixedSize(true);
// Setting the LayoutManager.
mLayoutManager = new LinearLayoutManager(this);
recyclerView.setLayoutManager(mLayoutManager);
// Setting the adapter.
CustomRecyclerAdapter mAdapter = new CustomRecyclerAdapter();
recyclerView.setAdapter(mAdapter);
}
// Called when add button is clicked.
public void addItem(View v) {
if(mText!=null) {
Data dataToAdd = new Data(mText.getText().toString()); mData.add(dataToAdd);
}
}
}
そして、確実に知るための私のrecyclerviewアダプターは次のとおりです。
public class CustomRecyclerAdapter extends RecyclerView.Adapter<RecyclerViewHolder> {
CustomRecyclerAdapter mAdapter;
private List<Data> mData = Collections.emptyList();
public CustomRecyclerAdapter() {
// Pass context or other static stuff that will be needed.
}
public void updateList(List<Data> data) {
mData = data;
notifyDataSetChanged();
}
@Override
public int getItemCount() {
return mData.size();
}
@Override
public RecyclerViewHolder onCreateViewHolder(ViewGroup viewGroup, int position) {
LayoutInflater inflater = LayoutInflater.from(viewGroup.getContext());
View itemView = inflater.inflate(R.layout.list_item, viewGroup, false);
return new RecyclerViewHolder(itemView);
}
@Override
public void onBindViewHolder(RecyclerViewHolder viewHolder, int position) {
viewHolder.title.setText(mData.get(position).text);
}
public void addItemInRec(int position, Data data) {
mData.add(data);
notifyItemInserted(position);
}
public void removeItem(int position) {
mData.remove(position);
notifyItemRemoved(position);
}
}
私のMainActivity xmlファイル:
<LinearLayout xmlns:Android="http://schemas.Android.com/apk/res/Android"
xmlns:tools="http://schemas.Android.com/tools"
Android:orientation="vertical"
Android:layout_width="match_parent"
Android:layout_height="match_parent"
tools:context=".MainActivity">
<LinearLayout
Android:orientation="horizontal"
Android:layout_width="match_parent"
Android:layout_height="wrap_content">
<EditText
Android:id="@+id/textEt"
Android:layout_width="0dp"
Android:layout_height="wrap_content"
Android:layout_weight="1"
Android:hint="Text"/>
<Button
Android:layout_width="wrap_content"
Android:layout_height="wrap_content"
Android:text="Add"
Android:onClick="addItem"/>
</LinearLayout>
<Android.support.v7.widget.RecyclerView
Android:id="@+id/recycler"
Android:layout_width="match_parent"
Android:layout_height="match_parent"
Android:scrollbars="vertical"/>
</LinearLayout>
たぶんそれは私のViewHolderです:
public class RecyclerViewHolder extends RecyclerView.ViewHolder {
public TextView title;
public RecyclerViewHolder(View itemView) {
super(itemView);
title = (TextView) itemView.findViewById(R.id.title);
}
}
またはData.Javaクラス:
public class Data {
public String text;
public Data(String text) {
this.text = text;
}
}
getText()
呼び出しでNULLポインターを取得しています
次の行を意味します。
EditText mText = (EditText) findViewById(R.id.textEt);
nullを返します。解決策は、textEt
がその上にあるようにレイアウトをチェックして修正することです。
編集:
レイアウト内にあることが確実な場合は、EditText
宣言を削除してください。
クラススコープでprivate EditText mText;
として宣言します
setContentView(R.layout.name_of_layout_here);
mText = (EditText) findViewById(R.id.textEt);
キーはエラーメッセージにあります。
_Caused by: Java.lang.NullPointerException: Attempt to invoke virtual method 'Android.text.Editable Android.widget.EditText.getText()' on a null object reference
at com.sapps.app.testapp2.MainActivity.addItem(MainActivity.Java:53)
_
エラー出力から学習するための良いヒントは、各「Caused by」ステートメントを調べ、参照されている独自のファイルのいずれかが見つかるまでログをスキャンすることです。次に、エラーログのその部分は、コードが失敗した行を示します(この場合、MainActivity.Javaの53行目です)。
JavaのNullポインタ例外は、オブジェクト 'A'でメソッドを呼び出そうとしたときですが、そのオブジェクト 'A'は現在null
です。
したがって、このエラーメッセージは、「MainActivity.Javaの53行目で、まだ存在しないオブジェクトのメソッドを呼び出そうとしたため、クラッシュしました」という意味です。
失敗しているメソッドはEditText mText = (EditText) findViewById(R.id.textEt);
です
通常、このタイプの障害は、レイアウトから適切なIDが見つからないことを意味します。 textEt
がこのレイアウト要素の正しいIDであることを再確認してください。
編集:
ビューが表示されない理由はまだわかりませんが、アダプターのエラーに気付きました。 mAdapter
を再定義しているため、2つのコピーがあります。1つはローカルスコープにあり、もう1つはMainActivityのメンバーです。これは間違いなく混乱します。
ここ:
_// Setting the adapter.
CustomRecyclerAdapter mAdapter = new CustomRecyclerAdapter();
recyclerView.setAdapter(mAdapter)
_
mAdapter
をローカルで再定義しています。代わりにこれを行います:
_// Setting the adapter.
mAdapter = new CustomRecyclerAdapter();
recyclerView.setAdapter(mAdapter)
_
addItem(View v)
のビューはボタンのみを参照しています。必要なEditText
オブジェクトはボタン内ではなく、ボタンの親ビュー内にあります。ボタンビューからオブジェクトにアクセスしようとすると、ボタンにオブジェクトがないため、nullになります。代わりに、ボタンの親ビューからオブジェクトにアクセスする必要があります。
// Solution:
public void addItem(View v) {
View parentView = (View) v.getParent();
EditText mText = (EditText) parentView.findViewById(R.id.textEt);
Log.d("LOG", mText.getText().toString()));
}
技術的にはこれが問題のコードを解決しないことを知っています。ただし、問題のコードはエラーを生成したものから変更されているため、実際に問題を生成した元のバグのあるコードは解決されます。元のバグのあるコードは次のように見えたと思います。
// My guess this was the original buggy code
// MainActivity.Java
public void addItem(View v) {
EditText mText = (EditText) v.findViewById(R.id.textEt);
Data dataToAdd = new Data(mText.getText().toString());
mData.add(dataToAdd);
}
// MainActivity.xml
<LinearLayout>
<EditText
Android:id="@+id/textEt"
/>
<Button
Android:text="Add"
Android:onClick="addItem"/>
</LinearLayout>
Public void addItemInRecをpublic void addItemに変更します。 mainActivityにはonClickのメソッドがありません。