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

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

相关文章

SpringBoot使用Apache Tika检测敏感信息

《SpringBoot使用ApacheTika检测敏感信息》ApacheTika是一个功能强大的内容分析工具,它能够从多种文件格式中提取文本、元数据以及其他结构化信息,下面我们来看看如何使用Ap... 目录Tika 主要特性1. 多格式支持2. 自动文件类型检测3. 文本和元数据提取4. 支持 OCR(光学

java脚本使用不同版本jdk的说明介绍

《java脚本使用不同版本jdk的说明介绍》本文介绍了在Java中执行JavaScript脚本的几种方式,包括使用ScriptEngine、Nashorn和GraalVM,ScriptEngine适用... 目录Java脚本使用不同版本jdk的说明1.使用ScriptEngine执行javascript2.

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

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

使用Python绘制可爱的招财猫

《使用Python绘制可爱的招财猫》招财猫,也被称为“幸运猫”,是一种象征财富和好运的吉祥物,经常出现在亚洲文化的商店、餐厅和家庭中,今天,我将带你用Python和matplotlib库从零开始绘制一... 目录1. 为什么选择用 python 绘制?2. 绘图的基本概念3. 实现代码解析3.1 设置绘图画

无线路由器哪个品牌好用信号强? 口碑最好的三个路由器大比拼

《无线路由器哪个品牌好用信号强?口碑最好的三个路由器大比拼》不同品牌在信号覆盖、稳定性和易用性等方面各有特色,如何在众多选择中找到最适合自己的那款无线路由器呢?今天推荐三款路由器让你的网速起飞... 今天我们来聊聊那些让网速飞起来的路由器。在这个信息爆炸的时代,一个好路由器简直就是家庭网编程络的心脏。无论你

Python绘制土地利用和土地覆盖类型图示例详解

《Python绘制土地利用和土地覆盖类型图示例详解》本文介绍了如何使用Python绘制土地利用和土地覆盖类型图,并提供了详细的代码示例,通过安装所需的库,准备地理数据,使用geopandas和matp... 目录一、所需库的安装二、数据准备三、绘制土地利用和土地覆盖类型图四、代码解释五、其他可视化形式1.

电脑显示hdmi无信号怎么办? 电脑显示器无信号的终极解决指南

《电脑显示hdmi无信号怎么办?电脑显示器无信号的终极解决指南》HDMI无信号的问题却让人头疼不已,遇到这种情况该怎么办?针对这种情况,我们可以采取一系列步骤来逐一排查并解决问题,以下是详细的方法... 无论你是试图为笔记本电脑设置多个显示器还是使用外部显示器,都可能会弹出“无HDMI信号”错误。此消息可能

如何用Python绘制简易动态圣诞树

《如何用Python绘制简易动态圣诞树》这篇文章主要给大家介绍了关于如何用Python绘制简易动态圣诞树,文中讲解了如何通过编写代码来实现特定的效果,包括代码的编写技巧和效果的展示,需要的朋友可以参考... 目录代码:效果:总结 代码:import randomimport timefrom math

2. c#从不同cs的文件调用函数

1.文件目录如下: 2. Program.cs文件的主函数如下 using System;using System.Collections.Generic;using System.Linq;using System.Threading.Tasks;using System.Windows.Forms;namespace datasAnalysis{internal static

综合安防管理平台LntonAIServer视频监控汇聚抖动检测算法优势

LntonAIServer视频质量诊断功能中的抖动检测是一个专门针对视频稳定性进行分析的功能。抖动通常是指视频帧之间的不必要运动,这种运动可能是由于摄像机的移动、传输中的错误或编解码问题导致的。抖动检测对于确保视频内容的平滑性和观看体验至关重要。 优势 1. 提高图像质量 - 清晰度提升:减少抖动,提高图像的清晰度和细节表现力,使得监控画面更加真实可信。 - 细节增强:在低光条件下,抖