检测周边蓝牙设备信号,并绘制半径不同的圆表示信号强弱

2024-03-13 18:32

本文主要是介绍检测周边蓝牙设备信号,并绘制半径不同的圆表示信号强弱,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

周边蓝牙强弱搜索/AndroidManifest.xml












    +<?xml version="1.0" encoding="utf-8"?>
    +<manifestxmlns:android="http://schemas.android.com/apk/res/android"
    +package="com.example.bt_dir"
    +android:versionCode="1"
    +android:versionName="1.0" >
    +
    + <uses-sdk
    +android:minSdkVersion="8"
    +android:targetSdkVersion="19" />
    +
    + <uses-permissionandroid:name="android.permission.BLUETOOTH_ADMIN" />
    + <uses-permissionandroid:name="android.permission.BLUETOOTH" />
    +
    + <application
    +android:allowBackup="true"
    +android:icon="@drawable/ic_launcher"
    +android:label="@string/app_name"
    +android:theme="@style/AppTheme" >
    + <activity
    +android:name=".MainActivity"
    +android:label="@string/app_name" >
    + <intent-filter>
    + <actionandroid:name="android.intent.action.MAIN" />
    +
    + <categoryandroid:name="android.intent.category.LAUNCHER" />
    + </intent-filter>
    + </activity>
    + </application>
    +
    +</manifest>



周边蓝牙强弱搜索/res/layout/activity_main.xml
    +<LinearLayoutxmlns:android="http://schemas.android.com/apk/res/android"
    +xmlns:tools="http://schemas.android.com/tools"
    +android:id="@+id/LinearLayout1"
    +android:layout_width="fill_parent"
    +android:layout_height="fill_parent"
    +android:orientation="vertical"
    +tools:context="com.example.bt_dir.MainActivity" >
    +
    + <SurfaceView
    +android:id="@+id/surface"
    + android:layout_width="fill_parent"
    + android:layout_height="fill_parent" />
    +</LinearLayout> 
周边蓝牙强弱搜索/res/menu/main.xml

周边蓝牙强弱搜索/res/menu/main.xml

Vie
   
周边蓝牙强弱搜索/res/layout/activity_main.xml



    +<menuxmlns:android="http://schemas.android.com/apk/res/android"
    +xmlns:app="http://schemas.android.com/apk/res-auto"
    +xmlns:tools="http://schemas.android.com/tools"
    +tools:context="com.example.bt_dir.MainActivity" >
    +
    + <item
    +android:id="@+id/action_settings"
    +android:orderInCategory="100"
    +android:title="@string/action_settings"
    +app:showAsAction="never"/>
    +
    +</menu>
    周边蓝牙强弱搜索/src/com/example/bt_dir/MainActivity.java+packagecom.example.bt_dir;
    +
    +importjava.util.Vector;
    +
    +importandroid.support.v7.app.ActionBarActivity;
    +importandroid.bluetooth.BluetoothAdapter;
    +importandroid.bluetooth.BluetoothDevice;
    +importandroid.content.BroadcastReceiver;
    +importandroid.content.Context;
    +importandroid.content.Intent;
    +importandroid.content.IntentFilter;
    +importandroid.graphics.Canvas;
    +importandroid.graphics.Color;
    +importandroid.graphics.Paint;
    +importandroid.graphics.Paint.Style;
    +importandroid.os.Bundle;
    +importandroid.os.Handler;
    +importandroid.os.Message;
    +importandroid.util.Log;
    +importandroid.view.Menu;
    +importandroid.view.MenuItem;
    +importandroid.view.SurfaceHolder;
    +importandroid.view.SurfaceHolder.Callback;
    +importandroid.view.SurfaceView;
    +
    +publicclass MainActivity extendsActionBarActivity implements Callback {
    +
    +private SurfaceView mSurface;
    +private SurfaceHolder mHolder;
    +private BluetoothAdapter mBtAdapter;
    +//private Message msg ;
    +//private Bundle bundle;
    +
    +private Vector<String> mDevicesVector;
    +private Vector<Short> mRSSIVector;
    +private Vector<Paint> mPaint;
    +//消息句柄(线程里无法进行界面更新,所以要把消息从线程里发送出来在消息句柄里进行处理)
    +public Handler myHandler =new Handler() {
    +@Override
    +public void handleMessage(Messagemsg)
    + {
    +Bundle bundle = msg.getData();
    +short now = bundle.getShort("msg");
    +Log.d("onGet",String.valueOf(now));
    +if (msg.what== 0x01)
    + {
    + draw();
    + }
    + doDiscovery();
    + }
    +//画图像
    +private void draw() {
    +Canvas canvas = mHolder.lockCanvas();
    + canvas.drawRGB(0,0, 0);
    +
    +for(int i=mRSSIVector.size()-1;i>=0;i--)
    + {
    + canvas.drawText(i+":"+mDevicesVector.get(i),5, i*10+12, mPaint.get(i));
    + canvas.drawCircle(canvas.getWidth()/2, canvas.getHeight()/2,150+mRSSIVector.get(i), mPaint.get(i)); //画圆圈
    + }
    + mHolder.unlockCanvasAndPost(canvas);// 更新屏幕显示内容
    + mRSSIVector.clear();
    + mDevicesVector.clear();
    + }
    + };
    +
    +@Override
    +protected void onCreate(BundlesavedInstanceState) {
    +super.onCreate(savedInstanceState);
    + setContentView(R.layout.activity_main);
    +
    +//msg = new Message();//消息
    +///bundle = new Bundle();
    +
    + mDevicesVector=newVector<String>();//向量
    + mRSSIVector=newVector<Short>();
    + mPaint=newVector<Paint>();
    +Paint paint0 = new Paint();
    + paint0.setAntiAlias(true);
    + paint0.setStyle(Style.STROKE);
    + paint0.setColor(Color.RED);
    + mPaint.add(paint0);
    +Paint paint1 = new Paint();
    + paint1.setAntiAlias(true);
    + paint1.setStyle(Style.STROKE);
    + paint1.setColor(Color.GREEN);
    + mPaint.add(paint1);
    +Paint paint2 = new Paint();
    + paint2.setAntiAlias(true);
    + paint2.setStyle(Style.STROKE);
    + paint2.setColor(Color.BLUE);
    + mPaint.add(paint2);
    +Paint paint3 = new Paint();
    + paint3.setAntiAlias(true);
    + paint3.setStyle(Style.STROKE);
    + paint3.setColor(Color.YELLOW);
    + mPaint.add(paint3);
    +Paint paint4 = new Paint();
    + paint4.setAntiAlias(true);
    + paint4.setStyle(Style.STROKE);
    + paint4.setColor(Color.WHITE);
    + mPaint.add(paint4);
    +Paint paint5 = new Paint();
    + paint5.setAntiAlias(true);
    + paint5.setStyle(Style.STROKE);
    + paint5.setColor(Color.LTGRAY);
    + mPaint.add(paint5);
    +Paint paint6 = new Paint();
    + paint6.setAntiAlias(true);
    + paint6.setStyle(Style.STROKE);
    + paint6.setColor(Color.CYAN);
    + mPaint.add(paint6);
    +
    + mSurface=(SurfaceView)findViewById(R.id.surface);
    + mHolder= mSurface.getHolder();
    + mHolder.addCallback(this);
    +
    +// Register for broadcasts when a device is discovered
    +IntentFilter filter = new IntentFilter(BluetoothDevice.ACTION_FOUND);
    +this.registerReceiver(mReceiver, filter);
    +// Register for broadcasts when discovery has finished
    + filter= new IntentFilter(BluetoothAdapter.ACTION_DISCOVERY_FINISHED);
    +this.registerReceiver(mReceiver, filter);
    +
    +// Get the local Bluetooth adapter
    + mBtAdapter= BluetoothAdapter.getDefaultAdapter();
    + }
    +
    +// Start device discover with the BluetoothAdapter
    +private void doDiscovery() {
    +// Indicate scanning in the title
    + setProgressBarIndeterminateVisibility(true);
    +
    +// If we're already discovering, stop it
    +if (mBtAdapter.isDiscovering()) {
    + mBtAdapter.cancelDiscovery();
    + }
    +// Request discover from BluetoothAdapter
    + mBtAdapter.startDiscovery();
    + }
    +
    +// The BroadcastReceiver that listens for discovered devices and
    +// changes the title when discovery is finished
    +//【查找蓝牙设备】
    +private final BroadcastReceiver mReceiver = new BroadcastReceiver() {
    +@Override
    +public void onReceive(Contextcontext, Intent intent) {
    +Log.d("onReceive","OK");
    +String action = intent.getAction();
    +// When discovery finds a device
    +if (BluetoothDevice.ACTION_FOUND.equals(action)) {
    +// Get the BluetoothDevice object from the Intent
    +BluetoothDevice device = intent.getParcelableExtra(BluetoothDevice.EXTRA_DEVICE);
    + mDevicesVector.add(device.getName()+ "\n"+ device.getAddress());
    +short rssi = intent.getExtras().getShort(BluetoothDevice.EXTRA_RSSI);
    + mRSSIVector.add(rssi);
    +Log.d("RSSI",device.getName()+""+String.valueOf(rssi));
    +// When discovery is finished, change the Activity title
    + }else if (BluetoothAdapter.ACTION_DISCOVERY_FINISHED.equals(action)) {
    + setProgressBarIndeterminateVisibility(false);
    +if (mDevicesVector.size()!= 0) {
    +Message msg = new Message();//消息
    +Bundle bundle = new Bundle();
    + bundle.clear();Log.d("onReceive","1");
    + msg.what= 0x01;//消息类别
    + bundle.putShort("msg",(short)0);Log.d("onReceive","2");
    + msg.setData(bundle);Log.d("onReceive","3");
    + myHandler.sendMessage(msg);Log.d("onReceive","4");
    + }
    + }
    + }
    + };
    +
    +@Override
    +public boolean onCreateOptionsMenu(Menumenu) {
    +// 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 onOptionsItemSelected(MenuItemitem) {
    +// 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) {
    + doDiscovery();
    +return true;
    + }
    +return false;
    + }
    +
    +@Override
    +public void surfaceCreated(SurfaceHolderholder) {
    +// TODO Auto-generated method stub
    +
    + }
    +
    +@Override
    +public void surfaceChanged(SurfaceHolderholder, int format, int width,
    +int height) {
    +// TODO Auto-generated method stub
    +
    + }
    +
    +@Override
    +public void surfaceDestroyed(SurfaceHolderholder) {
    +// TODO Auto-generated method stub
    +
    + }
    +}

这篇关于检测周边蓝牙设备信号,并绘制半径不同的圆表示信号强弱的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

C#自动化实现检测并删除PDF文件中的空白页面

《C#自动化实现检测并删除PDF文件中的空白页面》PDF文档在日常工作和生活中扮演着重要的角色,本文将深入探讨如何使用C#编程语言,结合强大的PDF处理库,自动化地检测并删除PDF文件中的空白页面,感... 目录理解PDF空白页的定义与挑战引入Spire.PDF for .NET库核心实现:检测并删除空白页

Python绘制TSP、VRP问题求解结果图全过程

《Python绘制TSP、VRP问题求解结果图全过程》本文介绍用Python绘制TSP和VRP问题的静态与动态结果图,静态图展示路径,动态图通过matplotlib.animation模块实现动画效果... 目录一、静态图二、动态图总结【代码】python绘制TSP、VRP问题求解结果图(包含静态图与动态图

录音功能在哪里? 电脑手机等设备打开录音功能的技巧

《录音功能在哪里?电脑手机等设备打开录音功能的技巧》很多时候我们需要使用录音功能,电脑和手机这些常用设备怎么使用录音功能呢?下面我们就来看看详细的教程... 我们在会议讨论、采访记录、课堂学习、灵感创作、法律取证、重要对话时,都可能有录音需求,便于留存关键信息。下面分享一下如何在电脑端和手机端上找到录音功能

SpringBoot实现不同接口指定上传文件大小的具体步骤

《SpringBoot实现不同接口指定上传文件大小的具体步骤》:本文主要介绍在SpringBoot中通过自定义注解、AOP拦截和配置文件实现不同接口上传文件大小限制的方法,强调需设置全局阈值远大于... 目录一  springboot实现不同接口指定文件大小1.1 思路说明1.2 工程启动说明二 具体实施2

Python脚本轻松实现检测麦克风功能

《Python脚本轻松实现检测麦克风功能》在进行音频处理或开发需要使用麦克风的应用程序时,确保麦克风功能正常是非常重要的,本文将介绍一个简单的Python脚本,能够帮助我们检测本地麦克风的功能,需要的... 目录轻松检测麦克风功能脚本介绍一、python环境准备二、代码解析三、使用方法四、知识扩展轻松检测麦

Python Flask实现定时任务的不同方法详解

《PythonFlask实现定时任务的不同方法详解》在Flask中实现定时任务,最常用的方法是使用APScheduler库,本文将提供一个完整的解决方案,有需要的小伙伴可以跟随小编一起学习一下... 目录完js整实现方案代码解释1. 依赖安装2. 核心组件3. 任务类型4. 任务管理5. 持久化存储生产环境

Linux之platform平台设备驱动详解

《Linux之platform平台设备驱动详解》Linux设备驱动模型中,Platform总线作为虚拟总线统一管理无物理总线依赖的嵌入式设备,通过platform_driver和platform_de... 目录platform驱动注册platform设备注册设备树Platform驱动和设备的关系总结在 l

Linux系统性能检测命令详解

《Linux系统性能检测命令详解》本文介绍了Linux系统常用的监控命令(如top、vmstat、iostat、htop等)及其参数功能,涵盖进程状态、内存使用、磁盘I/O、系统负载等多维度资源监控,... 目录toppsuptimevmstatIOStatiotopslabtophtopdstatnmon

使用Python绘制3D堆叠条形图全解析

《使用Python绘制3D堆叠条形图全解析》在数据可视化的工具箱里,3D图表总能带来眼前一亮的效果,本文就来和大家聊聊如何使用Python实现绘制3D堆叠条形图,感兴趣的小伙伴可以了解下... 目录为什么选择 3D 堆叠条形图代码实现:从数据到 3D 世界的搭建核心代码逐行解析细节优化应用场景:3D 堆叠图

C++ 检测文件大小和文件传输的方法示例详解

《C++检测文件大小和文件传输的方法示例详解》文章介绍了在C/C++中获取文件大小的三种方法,推荐使用stat()函数,并详细说明了如何设计一次性发送压缩包的结构体及传输流程,包含CRC校验和自动解... 目录检测文件的大小✅ 方法一:使用 stat() 函数(推荐)✅ 用法示例:✅ 方法二:使用 fsee