Bluetooth控件的使用

2024-06-20 18:38
文章标签 使用 控件 bluetooth

本文主要是介绍Bluetooth控件的使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

大家可以使用BlueSoleil这个软件模拟在台式机的蓝牙的功能

主要只用代码实现我们手机中的蓝牙的基本的功能:

(1)查看已经配对的蓝牙设备的情况

(2)启动蓝牙让其他蓝牙设备可以扫描的到

(3)扫描其他的蓝牙设备,并且显示

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" >


    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/matched_bluetooth" />
    
    <Button 
        android:id="@+id/scanButton"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text="@string/scan_bluetooth"
       %3@ />
</LinearLayout>

package com.example.buletooth;


import java.util.Set;


import android.support.v7.app.ActionBarActivity;
import android.bluetooth.BluetoothAdapter;
import android.bluetooth.BluetoothDevice;
import android.content.Intent;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;


/*
 * 这个Activity的主要的功能就是查看本地已经配对的蓝牙设备
 * 
 * */
public class BluetoothActivity extends ActionBarActivity {



private Button BluetoothButton;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_bluetooth);
BluetoothButton=(Button)findViewById(R.id.scanButton);
BluetoothButton.setOnClickListener(new BluetoothButtonListener());
}

class BluetoothButtonListener implements OnClickListener{


@Override
public void onClick(View view) {

//创建蓝牙Adapter
BluetoothAdapter adapter=BluetoothAdapter.getDefaultAdapter();
if(adapter!=null){
System.out.println("本地有可用的蓝牙设备");
//如果蓝牙设备不可用 就弹出Activity 询问用户是否打开设备
if(!adapter.enable()){
Intent intent=new Intent();
intent.setAction(BluetoothAdapter.ACTION_REQUEST_ENABLE);
startActivity(intent);
}
//获取已经跟这个机器配对的设备
Set<BluetoothDevice> devices=adapter.getBondedDevices();
//循环遍历所有蓝牙设备的名字和mac地址
for(BluetoothDevice device:devices){
System.out.println(device.getName()+"  "+device.getAddress());
}

}else{
System.out.println("本地没有可用的蓝牙设备");
}
}


}


@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.bluetooth, menu);
return true;
}


@Override
public boolean onOptionsItemSelected(MenuItem item) {
// Handle action bar item clicks here. The action bar will
// automatically handle clicks on the Home/Up button, so long
// as you specify a parent activity in AndroidManifest.xml.
int id = item.getItemId();
if (id == R.id.action_settings) {
return true;
}
return super.onOptionsItemSelected(item);
}
}


-------------------------------------------------------------------------------------------------------------

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" >
    


    <Button 
        android:id="@+id/discoveryenable"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text="@string/discoverty_bluetooth"
        />
    
    <Button 
        android:id="@+id/scanaround"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text="@string/scan_around_bluetooth"
        /> 
</LinearLayout>


package com.example.buletooth;


import android.app.Activity;
import android.bluetooth.BluetoothAdapter;
import android.bluetooth.BluetoothDevice;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.content.IntentFilter;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;




/*
 * 这个Activity的主要的功能就是
 * (1)将本地的蓝牙设备设置为可见的状态,并且设置可见的时间
 * (2)扫描周围的蓝牙设备 并且利用广播接收周围的设备,并且显示
 * 
 * 
 * */
public class ScanAroundBluetooth extends Activity {



private Button  discoveryButton;
private Button  scanAroundButton;
private BluetoothAdapter  adapter;
private BluetoothReceiver receiver;


@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.scanaroundblurtooth);
discoveryButton=(Button)findViewById(R.id.discoveryenable);
scanAroundButton=(Button)findViewById(R.id.scanaround);
adapter=BluetoothAdapter.getDefaultAdapter();
IntentFilter intentFilter=new IntentFilter(BluetoothDevice.ACTION_FOUND);
receiver=new BluetoothReceiver();
registerReceiver(receiver, intentFilter);//注册接收广播的接收者
discoveryButton.setOnClickListener(new DiscoveryButtonListener());
scanAroundButton.setOnClickListener(new ScanAroundButtonListener());
}

class DiscoveryButtonListener implements OnClickListener{


@Override
public void onClick(View view) {
//创建INtent对象
Intent intent=new Intent();
//设置本地的蓝牙设备可以扫描
intent.setAction(BluetoothAdapter.ACTION_REQUEST_DISCOVERABLE);
//设置本地蓝牙被扫描的时间最多是300秒
intent.putExtra(BluetoothAdapter.EXTRA_DISCOVERABLE_DURATION, 300);
//启动Activity
startActivity(intent);
}

}


class ScanAroundButtonListener implements OnClickListener{


@Override
public void onClick(View view) {
//扫描周围的蓝牙设备,如果扫描到,就会发送广播,我们需要接收广播
adapter.startDiscovery();
}

}


/*
* 这个是BluetoothDevice.ACTION_FOUND事件的广播接收器
* */
class BluetoothReceiver extends BroadcastReceiver{


@Override
public void onReceive(Context arg0, Intent intent) {
String action=intent.getAction();
if(action.equalsIgnoreCase(BluetoothDevice.ACTION_FOUND)){
//获取远程的设备
BluetoothDevice device=intent.getParcelableExtra(BluetoothDevice.EXTRA_DEVICE);
System.out.println(device.getAddress()+"  "+device.getName());
}
}

}

@Override
protected void onDestroy() {
//撤销注册
unregisterReceiver(receiver);
super.onDestroy();
}



}

这篇关于Bluetooth控件的使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1078943

相关文章

使用Java解析JSON数据并提取特定字段的实现步骤(以提取mailNo为例)

《使用Java解析JSON数据并提取特定字段的实现步骤(以提取mailNo为例)》在现代软件开发中,处理JSON数据是一项非常常见的任务,无论是从API接口获取数据,还是将数据存储为JSON格式,解析... 目录1. 背景介绍1.1 jsON简介1.2 实际案例2. 准备工作2.1 环境搭建2.1.1 添加

如何使用celery进行异步处理和定时任务(django)

《如何使用celery进行异步处理和定时任务(django)》文章介绍了Celery的基本概念、安装方法、如何使用Celery进行异步任务处理以及如何设置定时任务,通过Celery,可以在Web应用中... 目录一、celery的作用二、安装celery三、使用celery 异步执行任务四、使用celery

使用Python绘制蛇年春节祝福艺术图

《使用Python绘制蛇年春节祝福艺术图》:本文主要介绍如何使用Python的Matplotlib库绘制一幅富有创意的“蛇年有福”艺术图,这幅图结合了数字,蛇形,花朵等装饰,需要的可以参考下... 目录1. 绘图的基本概念2. 准备工作3. 实现代码解析3.1 设置绘图画布3.2 绘制数字“2025”3.3

Jsoncpp的安装与使用方式

《Jsoncpp的安装与使用方式》JsonCpp是一个用于解析和生成JSON数据的C++库,它支持解析JSON文件或字符串到C++对象,以及将C++对象序列化回JSON格式,安装JsonCpp可以通过... 目录安装jsoncppJsoncpp的使用Value类构造函数检测保存的数据类型提取数据对json数

python使用watchdog实现文件资源监控

《python使用watchdog实现文件资源监控》watchdog支持跨平台文件资源监控,可以检测指定文件夹下文件及文件夹变动,下面我们来看看Python如何使用watchdog实现文件资源监控吧... python文件监控库watchdogs简介随着Python在各种应用领域中的广泛使用,其生态环境也

Python中构建终端应用界面利器Blessed模块的使用

《Python中构建终端应用界面利器Blessed模块的使用》Blessed库作为一个轻量级且功能强大的解决方案,开始在开发者中赢得口碑,今天,我们就一起来探索一下它是如何让终端UI开发变得轻松而高... 目录一、安装与配置:简单、快速、无障碍二、基本功能:从彩色文本到动态交互1. 显示基本内容2. 创建链

springboot整合 xxl-job及使用步骤

《springboot整合xxl-job及使用步骤》XXL-JOB是一个分布式任务调度平台,用于解决分布式系统中的任务调度和管理问题,文章详细介绍了XXL-JOB的架构,包括调度中心、执行器和Web... 目录一、xxl-job是什么二、使用步骤1. 下载并运行管理端代码2. 访问管理页面,确认是否启动成功

使用Nginx来共享文件的详细教程

《使用Nginx来共享文件的详细教程》有时我们想共享电脑上的某些文件,一个比较方便的做法是,开一个HTTP服务,指向文件所在的目录,这次我们用nginx来实现这个需求,本文将通过代码示例一步步教你使用... 在本教程中,我们将向您展示如何使用开源 Web 服务器 Nginx 设置文件共享服务器步骤 0 —

Java中switch-case结构的使用方法举例详解

《Java中switch-case结构的使用方法举例详解》:本文主要介绍Java中switch-case结构使用的相关资料,switch-case结构是Java中处理多个分支条件的一种有效方式,它... 目录前言一、switch-case结构的基本语法二、使用示例三、注意事项四、总结前言对于Java初学者

Golang使用minio替代文件系统的实战教程

《Golang使用minio替代文件系统的实战教程》本文讨论项目开发中直接文件系统的限制或不足,接着介绍Minio对象存储的优势,同时给出Golang的实际示例代码,包括初始化客户端、读取minio对... 目录文件系统 vs Minio文件系统不足:对象存储:miniogolang连接Minio配置Min