Мое приложение вылетает, когда я добавляю кнопку Bluetooth
Я новичок в студии Android. Я хочу отправлять данные с Arduino на Android через Bluetooth HC-06. Я начинаю свой код с шаблона (Действия с навигационным ящиком) AndroidStudio. Сначала все было хорошо, но начинаются кошмары, когда я хотел добавить в свой код кнопку Bluetooth с помощью SetOnClickListener. 1. Его внешний вид изменился по сравнению с этим введите описание изображения здесь
для этого введите описание изображения здесь. Для наглядности: исчезла панель навигации и другие инструменты, вместо этого появился только домашний фрагмент. 2. При нажатии кнопки Bluetooth на этом фрагменте мое приложение закрывается. Я пытаюсь использовать logcat, но не могу решить проблему.
Пожалуйста, помогите мне советом Best Regard ps Ниже мой файл MainActivity.java
package com.example.myecg2;
import android.content.Intent;
import android.os.Bundle;
import com.google.android.material.floatingactionbutton.FloatingActionButton;
import com.google.android.material.snackbar.Snackbar;
import android.bluetooth.BluetoothAdapter;
import android.bluetooth.BluetoothDevice;
import android.bluetooth.BluetoothSocket;
import android.view.View;
import androidx.annotation.NonNull;
import androidx.annotation.Nullable;
import androidx.lifecycle.Observer;
import androidx.lifecycle.ViewModelProviders;
import androidx.navigation.NavController;
import androidx.navigation.Navigation;
import androidx.navigation.ui.AppBarConfiguration;
import androidx.navigation.ui.NavigationUI;
import com.google.android.material.navigation.NavigationView;
import androidx.drawerlayout.widget.DrawerLayout;
import androidx.appcompat.app.AppCompatActivity;
import androidx.appcompat.widget.Toolbar;
import android.view.Menu;
import android.view.ViewGroup;
import android.widget.Button;
import android.widget.TextView;
import android.widget.Toast;
import java.util.Set;
public class MainActivity extends AppCompatActivity {
private AppBarConfiguration mAppBarConfiguration;
private TextView Tekst;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Toolbar toolbar = findViewById(R.id.toolbar);
setSupportActionBar(toolbar);
FloatingActionButton fab = findViewById(R.id.fab);
fab.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
Snackbar.make(view, "Savollaringiz bo\'lsa Xat yozing", Snackbar.LENGTH_LONG)
.setAction("Action", null).show();
}
});
DrawerLayout drawer = findViewById(R.id.drawer_layout);
NavigationView navigationView = findViewById(R.id.nav_view);
mAppBarConfiguration = new AppBarConfiguration.Builder(
R.id.nav_home, R.id.nav_gallery, R.id.nav_slideshow,
R.id.nav_tools, R.id.nav_share, R.id.nav_send)
.setDrawerLayout(drawer)
.build();
NavController navController = Navigation.findNavController(this, R.id.nav_host_fragment);
NavigationUI.setupActionBarWithNavController(this, navController, mAppBarConfiguration);
NavigationUI.setupWithNavController(navigationView, navController);
final int REQUEST_ENABLE_BT = 1;
setContentView(R.layout.fragment_home);
final BluetoothAdapter btAdapter = BluetoothAdapter.getDefaultAdapter();
Button button =findViewById(R.id.button6);
button.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
if (btAdapter == null) {
Tekst.setText("Bluetooth NOT support");
return;
} else {
if (btAdapter.isEnabled()) {
Tekst.setText("Bluetooth is currently in device discovery process.");
Tekst.append("\nPaired Devices are:");
Set<BluetoothDevice> devices = btAdapter.getBondedDevices();
for (BluetoothDevice device : devices) {
Tekst.append("\nDevice" + device.getName() + "," + device);
}
} else {
Intent enableBtIntent = new Intent(BluetoothAdapter.ACTION_REQUEST_ENABLE);
startActivityForResult(enableBtIntent, REQUEST_ENABLE_BT);
}
}
}
}
);}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.main, menu);
return true;
}
@Override
public boolean onSupportNavigateUp() {
NavController navController = Navigation.findNavController(this, R.id.nav_host_fragment);
return NavigationUI.navigateUp(navController, mAppBarConfiguration)
|| super.onSupportNavigateUp();
}
}
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.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">
<TextView
android:id="@+id/text_home"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginStart="8dp"
android:layout_marginTop="8dp"
android:layout_marginEnd="8dp"
android:textAlignment="center"
android:textSize="20sp"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
<TextView
android:id="@+id/textView8"
android:layout_width="394dp"
android:layout_height="218dp"
android:text="@string/matn"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintTop_toBottomOf="@+id/button6" />
<Button
android:id="@+id/button6"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="116dp"
android:text="@string/LeadI"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintTop_toBottomOf="@+id/text_home"/>
</androidx.constraintlayout.widget.ConstraintLayout>
и ошибки, указанные в LogCat 2019-11-30 02:09:01.342 13088-13088/com.example.myecg2 D/AndroidRuntime: Завершение работы ВМ 2019-11-30 02:09:01.343 13088-13088/com.example.myecg2 E/AndroidRuntime: FATAL EXCEPTION: main Process: com.example.myecg2, PID: 13088 java.lang.NullPointerException: попытка вызвать виртуальный метод void android.widget.TextView.setText(java.lang.CharSequence) для нулевого значения ссылка на объект в com.example.myecg2.MainActivity$2.onClick(MainActivity.java:75) в android.view.View.performClick(View.java:6256) в android.view.View$PerformClick.run(View.java:24701) на android.os.Handler.handleCallback(Handler.java:789) на android.os.Handler.dispatchMessage(Handler.java:98) на android.os.Looper.loop(Looper.java:164) на android.app.ActivityThread.main(ActivityThread.java:6541) в java.lang.reflect.Method.invoke(собственный метод) в com.android.internal.os.Zygote$MethodAndArgsCaller.run(Zygote.java:240) в com.android.internal.os.ZygoteInit.main(ZygoteInit.java:767)
1 ответ
Tekst
имеет значение null, т.е. вы никогда не создаете экземпляр этой переменной.
В вашем журнале это написано прямо здесь:
java.lang.NullPointerException:
Attempt to invoke virtual method 'void android.widget.TextView.setText(java.lang.CharSequence)' on a null object reference
at com.example.myecg2.MainActivity$2.onClick(MainActivity.java:75)
at ...
Он даже говорит, что класс, в котором происходит ошибка, MainActivity
, название метода - это происходит в onClick
и строка ошибки :75
.
Вы не делаете findViewById
создать экземпляр вашего Tekst
переменная, в onCreate
прежде, чем вы попытаетесь получить к нему доступ (т.е. доступ в строке 75).
Примечания:
ты звонишь setContentView
дважды. Вы не должны этого делать. Удалите второй.
Имена переменных в Java и Kotlin должны начинаться с нижнего регистра, чтобы помочь вам отличить их от других вещей. ПереименоватьTekst
к tekst
. Это тоже опечатка? возможно это должно бытьtest
и лучшее имя, которое поможет вам отладить, было бы testTextView
.