- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我开发了一个应用程序,它使用特定的蓝牙模块(HC-06)与其通信,但首先它需要与之配对,它使用以下代码来实现……
BluetoothAdapter mBluetoothAdapter = BluetoothAdapter.getDefaultAdapter();
ListView lView;
ArrayList<String> devNameList, devAddressList;
private ListAdapter arrayAdapter;
private ConnectThread mConnectThread;
private BluetoothSocket mmSocket = null;
private static final UUID MY_UUID = UUID.fromString("00001101-0000-1000-8000-00805F9B34FB");
private final static int REQUEST_ID = 2;
// Create a BroadcastReceiver for ACTION_FOUND.
private final BroadcastReceiver mReceiver = new BroadcastReceiver() {
public void onReceive(Context context, Intent intent) {
String action = intent.getAction();
if (BluetoothDevice.ACTION_FOUND.equals(action)) {
// Discovery has found a device. Get the BluetoothDevice
// object and its info from the Intent.
BluetoothDevice device = intent.getParcelableExtra(BluetoothDevice.EXTRA_DEVICE);
String devName = device.getName();
String devAddress = device.getAddress();
devAddressList.add(devAddress);
if (devName == null){
devName = device.getAddress();
}
devNameList.add(devName);
lView.setAdapter(arrayAdapter);
}
}
};
private class ConnectThread extends Thread {
ConnectThread(BluetoothDevice device) {
BluetoothSocket tmp = null;
try {
// Get a BluetoothSocket to connect with the given BluetoothDevice.
// MY_UUID is the app's UUID string, also used in the server code.
tmp = device.createRfcommSocketToServiceRecord(MY_UUID);
} catch (IOException e) {
Toast.makeText(getBaseContext(), "ERROR: Socket's create() method failed", Toast.LENGTH_SHORT).show();
}
mmSocket = tmp;
}
public void run() {
try {
// Connect to the remote device through the socket. This call blocks
// until it succeeds or throws an exception.
mmSocket.connect();
} catch (IOException connectException) {
// Unable to connect; close the socket and return.
try {
mmSocket.close();
} catch (IOException closeException) {
Toast.makeText(getBaseContext(), "ERROR: Could not close the client socket",
Toast.LENGTH_SHORT).show();
}
return;
}
// The connection attempt succeeded. Perform work associated with
// the connection in a separate thread.
manageMyConnectedSocket();
}
// Closes the client socket and causes the thread to finish.
void cancel() {
try {
mmSocket.close();
} catch (IOException e) {
Toast.makeText(getBaseContext(), "ERROR: Could not close the client socket",
Toast.LENGTH_SHORT).show();
}
}
}
@Override
protected void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_add_new_device);
requestPermissions();
lView = findViewById(R.id.discList);
devNameList = new ArrayList<>();
devAddressList = new ArrayList<>();
arrayAdapter = new ArrayAdapter<>(this, android.R.layout.simple_list_item_1, devNameList);
if (mBluetoothAdapter.isDiscovering()){
mBluetoothAdapter.cancelDiscovery();
}
// Register for broadcasts when a device is discovered.
IntentFilter filter = new IntentFilter(BluetoothDevice.ACTION_FOUND);
registerReceiver(mReceiver, filter);
mBluetoothAdapter.startDiscovery();
lView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
String devName = devNameList.get(position);
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) {
if((Objects.equals(devName, "HC-06"))|| (Objects.equals(devName, "00:21:13:00:97:6A"))){
Toast.makeText(AddNewDevice.this, "Please wait...", Toast.LENGTH_SHORT).show();
mBluetoothAdapter.cancelDiscovery();
String address = devAddressList.get(position);
BluetoothDevice device = mBluetoothAdapter.getRemoteDevice(address);
mConnectThread = new ConnectThread(device);
mConnectThread.run();
}
else{
Toast.makeText(AddNewDevice.this, "Please connect to an HC-06 device.", Toast.LENGTH_SHORT).show();
}
}
else {
if("HC-06".equals(devName) || "00:21:13:00:97:6A".equals(devName)){
Toast.makeText(AddNewDevice.this, "Please wait...", Toast.LENGTH_SHORT).show();
mBluetoothAdapter.cancelDiscovery();
String address = devAddressList.get(position);
BluetoothDevice device = mBluetoothAdapter.getRemoteDevice(address);
mConnectThread = new ConnectThread(device);
mConnectThread.run();
}
else{
Toast.makeText(AddNewDevice.this, "Please connect to an HC-06 device.", Toast.LENGTH_SHORT).show();
}
}
}
});
}
private void requestPermissions(){
int androidVersion = Build.VERSION.SDK_INT;
if (androidVersion >= 23){
ActivityCompat.requestPermissions(this,
new String[]{Manifest.permission.ACCESS_FINE_LOCATION,
Manifest.permission.ACCESS_COARSE_LOCATION,
}, REQUEST_ID);
}
}
@Override
protected void onDestroy() {
super.onDestroy();
unregisterReceiver(mReceiver);
mBluetoothAdapter.cancelDiscovery();
}
private void manageMyConnectedSocket() {
mConnectThread.cancel();
finish();
}
该代码在运行 API 17 (Android 4.2.2) 的设备上运行良好,但在 API 23 (android 6.0) 设备上它有点故障:
首先,它有时会找到设备名称,有时却找不到(这就是为什么我在第 50 行和第 51 行 [如果您复制了代码]、第 23 行和24 没有导入 header )
其次,我注意到当它没有获得设备名称并且我尝试连接时,它很难配对/连接到设备(在我的蓝牙设置中它永远显示“正在配对...”)但是当它确实获得了正确配对的设备名称。
谁能帮我解决这个问题?
最佳答案
几天前我回答了这个问题。链接如下。您在使用较新版本的 Android 时遇到的问题是,它需要粗略和精细位置权限才能使用较新版本的 android 进行发现。包含这些权限后,查找设备然后与它们配对应该就可以了。
链接:Can not discover available Bluetooth devices
来自上面链接的我的帖子:
尝试同时添加粗略定位权限。我的应用程序有 Fine 和 Coarse,它适用于 API 19 (Kit Kat)、API 21 (Lollipop)、API 23 (Marshmallow) 和 API 24 (Nougat)。
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
另外,请确保您在到达应用程序的这一点之前请求了许可。因此在 onCreate 中添加以下方法以确保在更高版本的 Android 上请求您的权限。我知道我还需要添加此代码才能使其正常工作。您可以为 REQUEST_ID 使用您自己定义的 int。当您为更高版本的 android 加载应用程序时,它会弹出提示给用户。
private int androidVersion; //define at top of code as a variable
private void requestPermissions(){
androidVersion = Build.VERSION.SDK_INT;
if (androidVersion >= 23){
ActivityCompat.requestPermissions(this,
new String[]{Manifest.permission.ACCESS_FINE_LOCATION,
Manifest.permission.ACCESS_COARSE_LOCATION,
}, REQUEST_ID);
}
}
关于安卓工作室 : Discovered Bluetooth device name not found and struggling to pair to device,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47779875/
我想将 EditText 始终设置为 LTR,我该怎么做?android:textDirection 似乎确实是答案,我无法让项目使用该指令进行编译 最佳答案 为 editText 使用引力 andr
我希望我的应用在每次打开时都显示登录屏幕。使用 android:clearTaskOnLaunch="true" 一切正常。但是有一个错误,只有在手机关机并且应用程序首先使用小部件启动时才会发生。 I
实际上我的要求是我想将动态文件加载到像图像一样的网页中。视频,音频等,它来自 Assets 或应用程序自己的文件目录,这不是问题。 我尝试使用以下两种方式。 方式一 这是我的 html 文件在 ass
我正在触发一个 DatePickerDialog,在 api 22 (Android 5.1) 之前它一直在工作并显示良好,我在上面设置混合和最大日期(最小 = 当前日期,最大 = 从当前日期开始的
我有一个 ListView ,我在其中将标题 View 添加到该列表。一切都很好,但是当滚动列表 headerview 也随着列表移动时,所以我想避免 headerview 滚动,我的意思是当我列表到
虽然我在android上做过一些app,但我还是一头雾水。是否可以使用 SDK 4.0 中的功能,并在 android 2.1 或更低版本上运行该应用程序? 我尝试了你们提到的方法,但出现错误 - F
您好,我正在开发小型 android 应用程序,我想在其中显示带有一些元素的简单 gridview。它工作正常。唯一的问题是即使有空间,它也总是只显示两列。它平均将屏幕分成 2 列并仅显示两个元素。如
我正在使用 Android 2.3.3 API 构建一个应用程序。我需要识别方向的变化并执行一些操作。所以我在 Android Manifest 中添加了以下内容, android:configCha
我正在尝试在“点击”包含特定 MIME 类型的 nfc 标签时开始一项 Activity 。我制作了一个 mime 类型为“text/plain”的标签,并将其添加到 list 中:
我可以将一些数据保存到文件中 val byteArrayOutputStream = ByteArrayOutputStream() byteArrayOutputStream.wri
我正在尝试解析一个包含复杂阿拉伯字母的 XML 文件.. 当我在 android 2.3.7 上测试时,并不是所有的阿拉伯字母都被支持,仍然有一些复杂的显示为方 block .. 但是在 androi
我需要编写一个方法来确定设备是平板电脑还是手机。我不需要根据这个显示不同的用户界面。我只需要有关设备的信息,以便将来我可以将其发送到指标。 在互联网上,我找到了很多方法来确定设备是否是平板电脑。我已经
我正在玩文字转语音,让我的测试应用程序更有趣。它适用于模拟器,但不适用于我的手机,因为我的默认语言环境不是英语。 但是,文本是英文的,所以 tts 当然应该使用英文。据我所知,我可以实现一个自动安装,
我正在使用 MVVM 和整洁的架构编写应用程序。在其中一个屏幕上,我需要使用 pagination 实现 RecyclerView。我将使用库 Paging3。 Android 开发者推荐在存储库层使
这个问题在这里已经有了答案: I lost my .keystore file? (12 个回答) 4年前关闭。 当我以前的操作系统损坏并安装新的(7 月 3 日)时,以前的 android_key_
我正在使用 MVVM 和整洁的架构编写应用程序。在其中一个屏幕上,我需要使用 pagination 实现 RecyclerView。我将使用库 Paging3。 Android 开发者推荐在存储库层使
在我的 v27\style.xml 中,我有以下代码来设置白色导航栏: @color/colorPrimary @color/colorPrimaryDark @color/
我想通过发送电子邮件 startActivity(Intent.createChooser(new Intent(android.content.Intent.ACTION_SEND))) 我知道要将
我实现了一个自定义 ListView ,它看起来像 Twitter 时间线。 adapter = new MyClickableListAdapter(this, R.layout.timeline,
我有一个显示启动画面的自定义对话框; mSplashDialog = new Dialog(MyActivity.this,R.layout.splash); mSplashDialog.setCon
我是一名优秀的程序员,十分优秀!