提交 bbea88dd 编写于 作者: 杜庆泉's avatar 杜庆泉

优化onConnectWifi 函数

上级 926786d9
import Context from "android.content.Context"; import Context from "android.content.Context";
import { getAppContext,getUniActivity } from "io.dcloud.uts.android"; import { getAppContext, getUniActivity } from "io.dcloud.uts.android";
import WifiManager from "android.net.wifi.WifiManager"; import WifiManager from "android.net.wifi.WifiManager";
import WifiInfo from "android.net.wifi.WifiInfo"; import WifiInfo from "android.net.wifi.WifiInfo";
import ConnectivityManager from "android.net.ConnectivityManager";
import Manifest from "android.Manifest"; import Manifest from "android.Manifest";
import PackageManager from "android.content.pm.PackageManager"; import PackageManager from "android.content.pm.PackageManager";
import ScanResult from "android.net.wifi.ScanResult"; import ScanResult from "android.net.wifi.ScanResult";
...@@ -24,20 +22,33 @@ type WifiOption = { ...@@ -24,20 +22,33 @@ type WifiOption = {
complete?: (res: object) => void; complete?: (res: object) => void;
}; };
/**
* Wifi 链接参数封装
*/
type WifiConnectOption = {
SSID:string;
BSSID:string;
password:string;
maunal:boolean;
partialInfo:boolean;
success?: (res: object) => void;
fail?: (res: object) => void;
complete?: (res: object) => void;
}
/** /**
* Wifi信息统一数据结构 * Wifi信息统一数据结构
*/ */
class UniWifiInfo { class UniWifiInfo {
SSID:String = ""; SSID: String = "";
BSSID:String = ""; BSSID: String = "";
secure:boolean = false; secure: boolean = false;
signalStrength:Number = 0; signalStrength: Number = 0;
frequency:Number = 0; frequency: Number = 0;
constructor(scanResult?:ScanResult){ constructor(scanResult?: ScanResult) {
if(scanResult != null){ if (scanResult != null) {
// 如果是通过扫描列表得到的数据,进行封装 // 如果是通过扫描列表得到的数据,进行封装
this.BSSID = scanResult.BSSID; this.BSSID = scanResult.BSSID;
this.SSID = scanResult.SSID; this.SSID = scanResult.SSID;
...@@ -50,7 +61,7 @@ class UniWifiInfo { ...@@ -50,7 +61,7 @@ class UniWifiInfo {
let capabilities = scanResult.capabilities.trim(); let capabilities = scanResult.capabilities.trim();
if (capabilities != null && (capabilities.equals(Global.WIFI_AUTH_OPEN) || capabilities.equals(Global.WIFI_AUTH_ROAM))) { if (capabilities != null && (capabilities.equals(Global.WIFI_AUTH_OPEN) || capabilities.equals(Global.WIFI_AUTH_ROAM))) {
this.secure = false; this.secure = false;
}else{ } else {
this.secure = true; this.secure = true;
} }
} }
...@@ -59,14 +70,14 @@ class UniWifiInfo { ...@@ -59,14 +70,14 @@ class UniWifiInfo {
/** /**
* 根据connectInfo 链接信息对wifi数据结构进行初始化 * 根据connectInfo 链接信息对wifi数据结构进行初始化
*/ */
wrapConnectInfo(connectInfo:WifiInfo):void{ wrapConnectInfo(connectInfo: WifiInfo): void {
console.log(connectInfo.getSSID()); console.log(connectInfo.getSSID());
console.log(connectInfo.getBSSID()); console.log(connectInfo.getBSSID());
if(connectInfo.getBSSID() == null){ if (connectInfo.getBSSID() == null) {
return return
} }
if (connectInfo != null) { if (connectInfo != null) {
if(connectInfo.getSSID() != null){ if (connectInfo.getSSID() != null) {
let s = connectInfo.getSSID(); let s = connectInfo.getSSID();
// 微信不带,这里需要去掉引号 // 微信不带,这里需要去掉引号
if (s.length > 2 && s.charAt(0) == '"' && s.charAt(s.length - 1) == '"') { if (s.length > 2 && s.charAt(0) == '"' && s.charAt(s.length - 1) == '"') {
...@@ -76,9 +87,9 @@ class UniWifiInfo { ...@@ -76,9 +87,9 @@ class UniWifiInfo {
} }
this.BSSID = connectInfo.getBSSID(); this.BSSID = connectInfo.getBSSID();
this.signalStrength = connectInfo.getRssi()+100; //Android返回的值是-100~0,而微信API规范是0~100,值越大信号越好,需要+100拉齐 //Android返回的值是-100~0,而微信API规范是0~100,值越大信号越好,需要+100拉齐
this.signalStrength = connectInfo.getRssi() + 100;
this.frequency = connectInfo.getFrequency(); this.frequency = connectInfo.getFrequency();
// WifiInfo.macAddress = winfo.getMacAddress(); //注意此代码涉及隐私,首先需要配置权限,没有权限会返回"02:00:00:00:00:00";然后需要在隐私协议中声明用途。如不需要,可注释掉本行
} }
} }
...@@ -90,7 +101,7 @@ class UniWifiInfo { ...@@ -90,7 +101,7 @@ class UniWifiInfo {
* 获取当前链接的wifi信息 * 获取当前链接的wifi信息
*/ */
type GetConnectedWifiOptions = { type GetConnectedWifiOptions = {
partialInfo?:boolean partialInfo?: boolean
success?: (res: UTSJSONObject) => void success?: (res: UTSJSONObject) => void
fail?: (res: UTSJSONObject) => void fail?: (res: UTSJSONObject) => void
complete?: (res: UTSJSONObject) => void complete?: (res: UTSJSONObject) => void
...@@ -101,29 +112,29 @@ type GetConnectedWifiOptions = { ...@@ -101,29 +112,29 @@ type GetConnectedWifiOptions = {
/** /**
* 全局数据储存 * 全局数据储存
*/ */
class Global{ class Global {
static mReceiver?:CustomBroadcastReceiver = null; static mReceiver?: CustomBroadcastReceiver = null;
static scanList:UniWifiInfo[] = [] static scanList: UniWifiInfo[] = []
static WIFI_AUTH_OPEN:String = ""; static WIFI_AUTH_OPEN: String = "";
static WIFI_AUTH_ROAM:String = "[ESS]"; static WIFI_AUTH_ROAM: String = "[ESS]";
static getWifiListCallbackList:UTSCallback[] = [] static getWifiListCallbackList: UTSCallback[] = []
static onWifiConnectCallbackList:UTSCallback[] = [] static onWifiConnectCallbackList: UTSCallback[] = []
} }
/** /**
* 自定义wifi变化广播监听器 * 自定义wifi变化广播监听器
*/ */
class CustomBroadcastReceiver extends BroadcastReceiver{ class CustomBroadcastReceiver extends BroadcastReceiver {
mWifiManager?:WifiManager = null; mWifiManager?: WifiManager = null;
constructor(wifiManager: WifiManager){ constructor(wifiManager: WifiManager) {
super(); super();
this.mWifiManager = wifiManager; this.mWifiManager = wifiManager;
} }
override onReceive(context: Context, intent: Intent) :void { override onReceive(_context: Context, intent: Intent): void {
if (intent.action == WifiManager.WIFI_STATE_CHANGED_ACTION) { if (intent.action == WifiManager.WIFI_STATE_CHANGED_ACTION) {
...@@ -132,13 +143,16 @@ class CustomBroadcastReceiver extends BroadcastReceiver{ ...@@ -132,13 +143,16 @@ class CustomBroadcastReceiver extends BroadcastReceiver{
if (state == WifiManager.WIFI_STATE_ENABLED) { if (state == WifiManager.WIFI_STATE_ENABLED) {
// 获取当前的connectInfo 并且进行数据封装 // 获取当前的connectInfo 并且进行数据封装
let uniWifiInfo = new UniWifiInfo(null) let uniWifiInfo = new UniWifiInfo(null)
//做一些异步操作
setTimeout(function() {
// BroadcastReceiver 中不能执行耗时任务,需要使用setTimeout
console.log(Thread.currentThread().getName())
let winfo = this.mWifiManager!.getConnectionInfo(); let winfo = this.mWifiManager!.getConnectionInfo();
while(winfo.bssid == null){ while (winfo.bssid == null) {
Thread.sleep(1000) Thread.sleep(1000)
winfo = this.mWifiManager!!.getConnectionInfo(); winfo = this.mWifiManager!!.getConnectionInfo();
} }
console.log(winfo)
// 封装成数据对象 // 封装成数据对象
uniWifiInfo.wrapConnectInfo(winfo) uniWifiInfo.wrapConnectInfo(winfo)
let res = { let res = {
...@@ -148,10 +162,13 @@ class CustomBroadcastReceiver extends BroadcastReceiver{ ...@@ -148,10 +162,13 @@ class CustomBroadcastReceiver extends BroadcastReceiver{
} }
console.log("Global.onWifiConnectCallbackList == " + Global.onWifiConnectCallbackList.length); console.log("Global.onWifiConnectCallbackList == " + Global.onWifiConnectCallbackList.length);
// wifi状态可用了,分发当前的链接状态给已注册的监听集合 // wifi状态可用了,分发当前的链接状态给已注册的监听集合
for(let perCallback in Global.onWifiConnectCallbackList){ for (let perCallback in Global.onWifiConnectCallbackList) {
perCallback(res); perCallback(res);
} }
}, 100);
} }
} }
...@@ -161,15 +178,15 @@ class CustomBroadcastReceiver extends BroadcastReceiver{ ...@@ -161,15 +178,15 @@ class CustomBroadcastReceiver extends BroadcastReceiver{
if (results != null) { if (results != null) {
Global.scanList = [] Global.scanList = []
for(let scanResult in results){ for (let scanResult in results) {
if(scanResult.SSID == null){ if (scanResult.SSID == null) {
continue; continue;
} }
Global.scanList.push(new UniWifiInfo(scanResult)); Global.scanList.push(new UniWifiInfo(scanResult));
} }
// 挨个通知,所有的监听器 // 挨个通知,所有的监听器
for(let perCallback in Global.getWifiListCallbackList){ for (let perCallback in Global.getWifiListCallbackList) {
const data = new JSONObject(); const data = new JSONObject();
let mainJsonStr = Gson().toJson(Global.scanList); let mainJsonStr = Gson().toJson(Global.scanList);
...@@ -189,15 +206,15 @@ class CustomBroadcastReceiver extends BroadcastReceiver{ ...@@ -189,15 +206,15 @@ class CustomBroadcastReceiver extends BroadcastReceiver{
/** /**
* 获取wifi列表 * 获取wifi列表
*/ */
export function getWifiList(option:WifiOption) { export function getWifiList(option: WifiOption) {
let wifiManager: WifiManager = let wifiManager: WifiManager =
getAppContext()!.getSystemService(Context.WIFI_SERVICE) as WifiManager getAppContext()!.getSystemService(Context.WIFI_SERVICE) as WifiManager
wifiManager.startScan() wifiManager.startScan()
let ret = { let ret = {
errNo:0, errNo: 0,
errCode:0, errCode: 0,
errMsg:"getWifiList:ok" errMsg: "getWifiList:ok"
} }
option?.success?.(ret) option?.success?.(ret)
option?.complete?.(ret) option?.complete?.(ret)
...@@ -217,7 +234,7 @@ export function onWifiConnected(callback: UTSCallback) { ...@@ -217,7 +234,7 @@ export function onWifiConnected(callback: UTSCallback) {
*/ */
export function offWifiConnected(callback: UTSCallback) { export function offWifiConnected(callback: UTSCallback) {
let callbackIndex = Global.onWifiConnectCallbackList.indexOf(callback) let callbackIndex = Global.onWifiConnectCallbackList.indexOf(callback)
if(callbackIndex > 0){ if (callbackIndex > 0) {
Global.onWifiConnectCallbackList.splice(callbackIndex, 1); Global.onWifiConnectCallbackList.splice(callbackIndex, 1);
} }
} }
...@@ -234,28 +251,32 @@ export function onGetWifiList(callback: UTSCallback) { ...@@ -234,28 +251,32 @@ export function onGetWifiList(callback: UTSCallback) {
*/ */
export function offGetWifiList(callback: UTSCallback) { export function offGetWifiList(callback: UTSCallback) {
let callbackIndex = Global.getWifiListCallbackList.indexOf(callback) let callbackIndex = Global.getWifiListCallbackList.indexOf(callback)
if(callbackIndex > 0){ if (callbackIndex > 0) {
Global.getWifiListCallbackList.splice(callbackIndex, 1); Global.getWifiListCallbackList.splice(callbackIndex, 1);
} }
} }
export function connectWifi(option: WifiOption) {
}
/** /**
* 开启wifi * 开启wifi
*/ */
export function startWifi(option:WifiOption) { export function startWifi(option: WifiOption) {
// 需要先开启wifi,才能使用后续的功能 // 需要先开启wifi,才能使用后续的功能
let requestCode = 1001; let requestCode = 1001;
let permissionWifi = arrayOf("android.permission.ACCESS_FINE_LOCATION"); let permissionWifi = arrayOf("android.permission.ACCESS_FINE_LOCATION");
// 检查权限 // 检查权限
if (ActivityCompat.checkSelfPermission(getUniActivity()!, Manifest.permission.ACCESS_FINE_LOCATION)!= PackageManager.PERMISSION_GRANTED) { if (ActivityCompat.checkSelfPermission(getUniActivity()!, Manifest.permission.ACCESS_FINE_LOCATION) != PackageManager.PERMISSION_GRANTED) {
ActivityCompat.requestPermissions(getUniActivity()!, permissionWifi, requestCode) ActivityCompat.requestPermissions(getUniActivity()!, permissionWifi, requestCode)
// 尚不具备权限,返回错误 // 尚不具备权限,返回错误
var result = { var result = {
errNo:0, errNo: 0,
errCode:0, errCode: 0,
errMsg:"startWifi:premission loss" errMsg: "startWifi:premission loss"
} }
option.fail?.(result) option.fail?.(result)
option.complete?.(result) option.complete?.(result)
...@@ -279,9 +300,9 @@ export function startWifi(option:WifiOption) { ...@@ -279,9 +300,9 @@ export function startWifi(option:WifiOption) {
getUniActivity()!.registerReceiver(Global.mReceiver, filter) getUniActivity()!.registerReceiver(Global.mReceiver, filter)
wifiManager.startScan() wifiManager.startScan()
var result = { var result = {
errNo:0, errNo: 0,
errCode:0, errCode: 0,
errMsg:"startWifi:ok" errMsg: "startWifi:ok"
} }
option.success?.(result) option.success?.(result)
option.complete?.(result) option.complete?.(result)
...@@ -292,13 +313,13 @@ export function startWifi(option:WifiOption) { ...@@ -292,13 +313,13 @@ export function startWifi(option:WifiOption) {
/** /**
* 关闭wifi * 关闭wifi
*/ */
export function stopWifi(option:WifiOption) { export function stopWifi(option: WifiOption) {
// 需要先开启wifi,才能使用后续的功能 // 需要先开启wifi,才能使用后续的功能
if (Global.mReceiver == null) { if (Global.mReceiver == null) {
var result = { var result = {
errNo:12000, errNo: 12000,
errCode:12000, errCode: 12000,
errMsg:"stopWifi:not init" errMsg: "stopWifi:not init"
} }
option.fail?.(result) option.fail?.(result)
option.complete?.(result) option.complete?.(result)
...@@ -308,9 +329,9 @@ export function stopWifi(option:WifiOption) { ...@@ -308,9 +329,9 @@ export function stopWifi(option:WifiOption) {
getUniActivity()!.unregisterReceiver(Global.mReceiver) getUniActivity()!.unregisterReceiver(Global.mReceiver)
var result = { var result = {
errNo:0, errNo: 0,
errCode:0, errCode: 0,
errMsg:"stopWifi:ok" errMsg: "stopWifi:ok"
} }
option.success?.(result) option.success?.(result)
option.complete?.(result) option.complete?.(result)
...@@ -333,7 +354,7 @@ export function getConnectedWifi(option: GetConnectedWifiOptions) { ...@@ -333,7 +354,7 @@ export function getConnectedWifi(option: GetConnectedWifiOptions) {
} }
if (ActivityCompat.checkSelfPermission(getUniActivity()!, Manifest.permission.ACCESS_FINE_LOCATION)!= PackageManager.PERMISSION_GRANTED) { if (ActivityCompat.checkSelfPermission(getUniActivity()!, Manifest.permission.ACCESS_FINE_LOCATION) != PackageManager.PERMISSION_GRANTED) {
// 尚不具备权限,返回错误 // 尚不具备权限,返回错误
option.fail?.(res) option.fail?.(res)
option.complete?.(res) option.complete?.(res)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册