添加蓝牙按钮时,我的应用程序崩溃



我是安卓工作室的新手 我想通过蓝牙HC-06将数据从Arduino发送到安卓 我从AndroidStudio的模板(导航抽屉活动(开始我的代码。 起初一切都很好,但是当我想在SetOnClickListener的帮助下将蓝牙按钮添加到我的代码中时,噩梦就开始了。 1.它的外观从这里改变输入图像描述

为此,请在此处输入图像描述。为清楚起见:导航栏和其他工具消失了,只显示主页片段。 2.按下此片段上的蓝牙按钮时,我的应用程序关闭了。 我尝试遵循logcat,但无法解决问题。

请帮我提供建议 最好的问候 附言以下是我的主活动.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();
}
}
以及来自 res/布局的content_main.xml文件

<?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>

和日志猫中给出的错误 2019-11-30 02:09:01.342 13088-13088/com.example.myecg2 D/Android运行时:关闭虚拟机 2019-11-30 02:09:01.343 13088-13088/com.example.myecg2 E/Android运行时:致命 异常:主要 进程: com.example.myecg2, PID: 13088 java.lang.NullPointerException:尝试在空对象引用上调用虚拟方法 'void android.widget.TextView.setText(java.lang.CharSequence(' at com.example.myecg2.MainActivity$2.onClick(MainActivity.java:75( at android.view.View.performClick(View.java:6256( at android.view.View$PerformClick.run(View.java:24701( at android.os.Handler.handleCallback(Handler.java:789( at android.os.Handler.dispatchMessage(Handler.java:98( at android.os.Looper.loop(Looper.java:164( at android.app.ActivityThread.main(ActivityThread.java:6541( at java.lang.reflect.Method.invoke(Native Method( at com.android.internal.os.Zygote$MethodAndArgsCaller.run(Zygote.java:240( at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:767(

Tekst为空,即您永远不会实例化该变量。

您的日志就在这里显示:

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

在尝试访问Tekst变量之前onCreate,您缺少findViewById来实例化变量(即在第 75 行访问(。


旁注:

你给setContentView打了两次电话。你不应该那样做。删除第二个。

Java & Kotlin 中的变量名称应该以小写字母开头,以帮助您将它们与其他变量区分开来。将Tekst重命名为tekst。 这也是错别字吗?也许它应该是test的,并且testTextView更好的名称来帮助您调试。

相关内容

  • 没有找到相关文章

最新更新