Я написал простое приложение с TextView внутри макета. Дизайн на XML:
Я попробовал 2 метода, чтобы добавить событие щелчка в этот TextView:
Метод 1. Добавьте свойство onClick в тег TextView => Этот метод работает нормально.
Файл 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">
<TextView
android:id = "@+id/txtMsg"
android:layout_width = "wrap_content"
android:layout_height = "wrap_content"
android:text = "Hello World!"
app:layout_constraintBottom_toBottomOf = "parent"
app:layout_constraintLeft_toLeftOf = "parent"
app:layout_constraintRight_toRightOf = "parent"
app:layout_constraintTop_toTopOf = "parent"
android:onClick = "msgOnClick"/>
</android.support.constraint.ConstraintLayout>
и файл Java:
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.LinearLayout;
import android.widget.TextView;
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
TextView txtMsg = findViewById(R.id.txtMsg);
setContentView(R.layout.activity_main);
}
public void msgOnClick(View view) {
}
}
Метод 2. Я использую вышеуказанный дизайн (без свойства onclick) и использую setOnClickListener следующим образом:
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">
<TextView
android:id = "@+id/txtMsg"
android:layout_width = "wrap_content"
android:layout_height = "wrap_content"
android:text = "Hello World!"
app:layout_constraintBottom_toBottomOf = "parent"
app:layout_constraintLeft_toLeftOf = "parent"
app:layout_constraintRight_toRightOf = "parent"
app:layout_constraintTop_toTopOf = "parent"/>
</android.support.constraint.ConstraintLayout>
Код Java:
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.LinearLayout;
import android.widget.TextView;
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
TextView txtMsg = findViewById(R.id.txtMsg);
txtMsg.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
}
});
setContentView(R.layout.activity_main);
}
}
Этот способ 2 не работает. Хотя ошибки нет, но когда я запускаю приложение в симуляторе / устройстве, программа останавливается.
В чем тут проблема? Я точно знаю, что причина вызвана setOnClickListener. Если я использую элемент, созданный с помощью XML of Activity, я не могу использовать метод setOnClickListener. Похоже, что Android-студия создала некоторую конфигурацию для создания метода setOnClickListener, и мы просто добавляем это свойство в тег компонента. Это правильно? Заранее спасибо !
Отслеживание здесь
E/AndroidRuntime: FATAL EXCEPTION: main Process: localglobal, PID: 8342 java.lang.RuntimeException: Unable to start activity ComponentInfo{localglobal/MainActivity}: java.lang.NullPointerException: Attempt to invoke virtual method 'void android.widget.TextView.setOnClickListener(android.view.View$OnClickListener)' on a null object reference at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2298) at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2360) at android.app.ActivityThread.access$800(ActivityThread.java:144) at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1278) at android.os.Handler.dispatchMessage(Handler.java:102) 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 'void android.widget.TextView.setOnClickListener(android.view.View$OnClickListener)' on a null object reference at localglobal.MainActivity.onCreate(MainActivity.java:15) at android.app.Activity.performCreate(Activity.java:5937) at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1105) at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2251)




Вам необходимо настроить просмотр содержимого.
setContentView(R.layout.activity_main);
Перед findViewById
У вас есть исключение NullPointerException, потому что textview не инициализирован. Вы найдете идентификатор textview перед setContentView. Итак, сделайте так:
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.LinearLayout;
import android.widget.TextView;
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
TextView txtMsg = findViewById(R.id.txtMsg);
txtMsg.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
}
});
}
}
Инициализация txtMsg выполняется перед макетом setcontentView, поэтому начинайте писать код после настройки макета. Надеюсь, это поможет