Initial commit
This commit is contained in:
@@ -0,0 +1,76 @@
|
||||
import Context from "android.content.Context";
|
||||
import BatteryManager from "android.os.BatteryManager";
|
||||
|
||||
import { GetBatteryInfo, GetBatteryInfoOptions, GetBatteryInfoSuccess, GetBatteryInfoResult, GetBatteryInfoSync } from '../interface.uts'
|
||||
import IntentFilter from 'android.content.IntentFilter';
|
||||
import Intent from 'android.content.Intent';
|
||||
|
||||
import { GetBatteryInfoFailImpl } from '../unierror';
|
||||
|
||||
/**
|
||||
* 异步获取电量
|
||||
*/
|
||||
export const getBatteryInfo : GetBatteryInfo = function (options : GetBatteryInfoOptions) {
|
||||
const context = UTSAndroid.getAppContext();
|
||||
if (context != null) {
|
||||
const manager = context.getSystemService(
|
||||
Context.BATTERY_SERVICE
|
||||
) as BatteryManager;
|
||||
const level = manager.getIntProperty(
|
||||
BatteryManager.BATTERY_PROPERTY_CAPACITY
|
||||
);
|
||||
|
||||
let ifilter = new IntentFilter(Intent.ACTION_BATTERY_CHANGED);
|
||||
let batteryStatus = context.registerReceiver(null, ifilter);
|
||||
let status = batteryStatus?.getIntExtra(BatteryManager.EXTRA_STATUS, -1);
|
||||
let isCharging = status == BatteryManager.BATTERY_STATUS_CHARGING || status == BatteryManager.BATTERY_STATUS_FULL;
|
||||
|
||||
const res : GetBatteryInfoSuccess = {
|
||||
errMsg: 'getBatteryInfo:ok',
|
||||
level,
|
||||
isCharging: isCharging
|
||||
}
|
||||
options.success?.(res)
|
||||
options.complete?.(res)
|
||||
} else {
|
||||
let res = new GetBatteryInfoFailImpl(1001);
|
||||
options.fail?.(res)
|
||||
options.complete?.(res)
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* 同步获取电量
|
||||
*/
|
||||
export const getBatteryInfoSync : GetBatteryInfoSync = function () : GetBatteryInfoResult {
|
||||
const context = UTSAndroid.getAppContext();
|
||||
if (context != null) {
|
||||
const manager = context.getSystemService(
|
||||
Context.BATTERY_SERVICE
|
||||
) as BatteryManager;
|
||||
const level = manager.getIntProperty(
|
||||
BatteryManager.BATTERY_PROPERTY_CAPACITY
|
||||
);
|
||||
|
||||
let ifilter = new IntentFilter(Intent.ACTION_BATTERY_CHANGED);
|
||||
let batteryStatus = context.registerReceiver(null, ifilter);
|
||||
let status = batteryStatus?.getIntExtra(BatteryManager.EXTRA_STATUS, -1);
|
||||
let isCharging = status == BatteryManager.BATTERY_STATUS_CHARGING || status == BatteryManager.BATTERY_STATUS_FULL;
|
||||
|
||||
const res : GetBatteryInfoResult = {
|
||||
level: level,
|
||||
isCharging: isCharging
|
||||
};
|
||||
return res;
|
||||
}
|
||||
else {
|
||||
/**
|
||||
* 无有效上下文
|
||||
*/
|
||||
const res : GetBatteryInfoResult = {
|
||||
level: -1,
|
||||
isCharging: false
|
||||
};
|
||||
return res;
|
||||
}
|
||||
}
|
||||
36
unpackage/dist/dev/.tsc/app-android/uni_modules/uni-getbatteryinfo/utssdk/app-ios/index.uts.ts
vendored
Normal file
36
unpackage/dist/dev/.tsc/app-android/uni_modules/uni-getbatteryinfo/utssdk/app-ios/index.uts.ts
vendored
Normal file
@@ -0,0 +1,36 @@
|
||||
// 引用 iOS 原生平台 api
|
||||
import { UIDevice } from "UIKit";
|
||||
|
||||
import { GetBatteryInfo, GetBatteryInfoSuccess, GetBatteryInfoResult, GetBatteryInfoSync } from '../interface.uts';
|
||||
|
||||
/**
|
||||
* 异步获取电量
|
||||
*/
|
||||
export const getBatteryInfo : GetBatteryInfo = function (options) {
|
||||
// 开启电量检测
|
||||
UIDevice.current.isBatteryMonitoringEnabled = true
|
||||
|
||||
// 返回数据
|
||||
const res : GetBatteryInfoSuccess = {
|
||||
errMsg: "getBatteryInfo:ok",
|
||||
level: Math.abs(Number(UIDevice.current.batteryLevel * 100)),
|
||||
isCharging: UIDevice.current.batteryState == UIDevice.BatteryState.charging,
|
||||
};
|
||||
options.success?.(res);
|
||||
options.complete?.(res);
|
||||
}
|
||||
|
||||
/**
|
||||
* 同步获取电量
|
||||
*/
|
||||
export const getBatteryInfoSync : GetBatteryInfoSync = function () : GetBatteryInfoResult {
|
||||
// 开启电量检测
|
||||
UIDevice.current.isBatteryMonitoringEnabled = true
|
||||
|
||||
// 返回数据
|
||||
const res : GetBatteryInfoResult = {
|
||||
level: Math.abs(Number(UIDevice.current.batteryLevel * 100)),
|
||||
isCharging: UIDevice.current.batteryState == UIDevice.BatteryState.charging,
|
||||
};
|
||||
return res;
|
||||
}
|
||||
43
unpackage/dist/dev/.tsc/app-android/uni_modules/uni-getbatteryinfo/utssdk/index.d.ts
vendored
Normal file
43
unpackage/dist/dev/.tsc/app-android/uni_modules/uni-getbatteryinfo/utssdk/index.d.ts
vendored
Normal file
@@ -0,0 +1,43 @@
|
||||
declare namespace UniNamespace {
|
||||
interface GetBatteryInfoSuccessCallbackResult {
|
||||
/**
|
||||
* 是否正在充电中
|
||||
*/
|
||||
isCharging: boolean;
|
||||
/**
|
||||
* 设备电量,范围 1 - 100
|
||||
*/
|
||||
level: number;
|
||||
errMsg: string;
|
||||
}
|
||||
|
||||
interface GetBatteryInfoOption {
|
||||
/**
|
||||
* 接口调用结束的回调函数(调用成功、失败都会执行)
|
||||
*/
|
||||
complete?: Function
|
||||
/**
|
||||
* 接口调用失败的回调函数
|
||||
*/
|
||||
fail?: Function
|
||||
/**
|
||||
* 接口调用成功的回调函数
|
||||
*/
|
||||
success?: (result: GetBatteryInfoSuccessCallbackResult) => void
|
||||
}
|
||||
}
|
||||
|
||||
declare interface Uni {
|
||||
/**
|
||||
* 获取设备电量
|
||||
*
|
||||
* @tutorial https://uniapp.dcloud.net.cn/api/system/batteryInfo.html
|
||||
*/
|
||||
getBatteryInfo(option?: UniNamespace.GetBatteryInfoOption): void;
|
||||
|
||||
/**
|
||||
* 同步获取电池电量信息
|
||||
* @tutorial https://uniapp.dcloud.net.cn/api/system/batteryInfo.html
|
||||
*/
|
||||
getBatteryInfoSync(): UniNamespace.GetBatteryInfoSuccessCallbackResult;
|
||||
}
|
||||
138
unpackage/dist/dev/.tsc/app-android/uni_modules/uni-getbatteryinfo/utssdk/interface.uts.ts
vendored
Normal file
138
unpackage/dist/dev/.tsc/app-android/uni_modules/uni-getbatteryinfo/utssdk/interface.uts.ts
vendored
Normal file
@@ -0,0 +1,138 @@
|
||||
export type GetBatteryInfoSuccess = {
|
||||
errMsg : string,
|
||||
/**
|
||||
* 设备电量,范围1 - 100
|
||||
*/
|
||||
level : number,
|
||||
/**
|
||||
* 是否正在充电中
|
||||
*/
|
||||
isCharging : boolean
|
||||
}
|
||||
|
||||
export type GetBatteryInfoOptions = {
|
||||
/**
|
||||
* 接口调用结束的回调函数(调用成功、失败都会执行)
|
||||
*/
|
||||
success ?: (res : GetBatteryInfoSuccess) => void
|
||||
/**
|
||||
* 接口调用失败的回调函数
|
||||
*/
|
||||
fail ?: (res : UniError) => void
|
||||
/**
|
||||
* 接口调用成功的回调
|
||||
*/
|
||||
complete ?: (res : any) => void
|
||||
}
|
||||
|
||||
export type GetBatteryInfoResult = {
|
||||
/**
|
||||
* 设备电量,范围1 - 100
|
||||
*/
|
||||
level : number,
|
||||
/**
|
||||
* 是否正在充电中
|
||||
*/
|
||||
isCharging : boolean
|
||||
}
|
||||
|
||||
/**
|
||||
* 错误码
|
||||
* - 1001 getAppContext is null
|
||||
*/
|
||||
export type GetBatteryInfoErrorCode = 1001 ;
|
||||
/**
|
||||
* GetBatteryInfo 的错误回调参数
|
||||
*/
|
||||
export interface GetBatteryInfoFail extends IUniError {
|
||||
errCode : GetBatteryInfoErrorCode
|
||||
};
|
||||
|
||||
/**
|
||||
* 获取电量信息
|
||||
* @param {GetBatteryInfoOptions} options
|
||||
*
|
||||
*
|
||||
* @tutorial https://uniapp.dcloud.net.cn/api/system/batteryInfo.html
|
||||
* @platforms APP-IOS = ^9.0,APP-ANDROID = ^22
|
||||
* @since 3.6.11
|
||||
*
|
||||
* @assert () => success({errCode: 0, errSubject: "uni-getBatteryInfo", errMsg: "getBatteryInfo:ok", level: 60, isCharging: false })
|
||||
* @assert () => fail({errCode: 1001, errSubject: "uni-getBatteryInfo", errMsg: "getBatteryInfo:fail getAppContext is null" })
|
||||
*/
|
||||
export type GetBatteryInfo = (options : GetBatteryInfoOptions) => void
|
||||
|
||||
|
||||
export type GetBatteryInfoSync = () => GetBatteryInfoResult
|
||||
|
||||
interface Uni {
|
||||
|
||||
/**
|
||||
* 获取电池电量信息
|
||||
* @description 获取电池电量信息
|
||||
* @param {GetBatteryInfoOptions} options
|
||||
* @example
|
||||
* ```typescript
|
||||
* uni.getBatteryInfo({
|
||||
* success(res) {
|
||||
* __f__('log','at uni_modules/uni-getbatteryinfo/utssdk/interface.uts:78',res);
|
||||
* }
|
||||
* })
|
||||
* ```
|
||||
* @remark
|
||||
* - 该接口需要同步调用
|
||||
* @uniPlatform {
|
||||
* "app": {
|
||||
* "android": {
|
||||
* "osVer": "4.4.4",
|
||||
* "uniVer": "3.6.11",
|
||||
* "unixVer": "3.9.0"
|
||||
* },
|
||||
* "ios": {
|
||||
* "osVer": "12.0",
|
||||
* "uniVer": "3.6.11",
|
||||
* "unixVer": "4.11"
|
||||
* }
|
||||
* },
|
||||
* "web": {
|
||||
* "uniVer": "3.6.11",
|
||||
* "unixVer": "4.0"
|
||||
* }
|
||||
* }
|
||||
* @uniVueVersion 2,3 //支持的vue版本
|
||||
*
|
||||
*/
|
||||
getBatteryInfo (options : GetBatteryInfoOptions) : void,
|
||||
/**
|
||||
* 同步获取电池电量信息
|
||||
* @description 获取电池电量信息
|
||||
* @example
|
||||
* ```typescript
|
||||
* uni.getBatteryInfo()
|
||||
* ```
|
||||
* @remark
|
||||
* - 该接口需要同步调用
|
||||
* @uniPlatform {
|
||||
* "app": {
|
||||
* "android": {
|
||||
* "osVer": "4.4.4",
|
||||
* "uniVer": "3.6.11",
|
||||
* "unixVer": "3.9.0"
|
||||
* },
|
||||
* "ios": {
|
||||
* "osVer": "12.0",
|
||||
* "uniVer": "3.6.11",
|
||||
* "unixVer": "4.11"
|
||||
* }
|
||||
* },
|
||||
* "web": {
|
||||
* "uniVer": "3.6.11",
|
||||
* "unixVer": "4.0"
|
||||
* }
|
||||
* }
|
||||
* @uniVueVersion 2,3 //支持的vue版本
|
||||
*
|
||||
*/
|
||||
getBatteryInfoSync():GetBatteryInfoResult
|
||||
|
||||
}
|
||||
34
unpackage/dist/dev/.tsc/app-android/uni_modules/uni-getbatteryinfo/utssdk/unierror.uts.ts
vendored
Normal file
34
unpackage/dist/dev/.tsc/app-android/uni_modules/uni-getbatteryinfo/utssdk/unierror.uts.ts
vendored
Normal file
@@ -0,0 +1,34 @@
|
||||
import { GetBatteryInfoErrorCode, GetBatteryInfoFail } from "./interface.uts"
|
||||
/**
|
||||
* 错误主题
|
||||
*/
|
||||
export const UniErrorSubject = 'uni-getBatteryInfo';
|
||||
|
||||
|
||||
/**
|
||||
* 错误信息
|
||||
* @UniError
|
||||
*/
|
||||
export const UniErrors : Map<GetBatteryInfoErrorCode, string> = new Map([
|
||||
/**
|
||||
* 错误码及对应的错误信息
|
||||
*/
|
||||
[1001, 'getBatteryInfo:fail getAppContext is null'],
|
||||
]);
|
||||
|
||||
|
||||
/**
|
||||
* 错误对象实现
|
||||
*/
|
||||
export class GetBatteryInfoFailImpl extends UniError implements GetBatteryInfoFail {
|
||||
|
||||
/**
|
||||
* 错误对象构造函数
|
||||
*/
|
||||
constructor(errCode : GetBatteryInfoErrorCode) {
|
||||
super();
|
||||
this.errSubject = UniErrorSubject;
|
||||
this.errCode = errCode;
|
||||
this.errMsg = UniErrors[errCode] ?? "";
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user