当前位置: 首页 > article >正文

OpenHarmony-5.PM 子系统(2)

  • 电池服务组件
  • OpenHarmony-4.1-Release

1.电池服务组件

  Battery Manager 提供了电池信息查询的接口,同时开发者也可以通过公共事件监听电池状态和充放电状态的变化。电池服务组件提供如下功能:

  • 电池信息查询。
  • 充放电状态查询。
  • 关机充电。

  电池服务组件架构图:
在这里插入图片描述

1.1.代码目录:

base/powermgr/battery_manager
├── figures                  	# 架构图
├── frameworks                  # Framework层
│   ├── napi                 	# NAPI
│   └── native                  # Native层
├── interfaces                  # 接口层
│   └── inner_api               # 内部接口
├── sa_profile                  # SA配置文件
├── services                    # 服务层
│   ├── native                  # Native层
│   └── zidl                    # Zidl接口层
├── test                        # 测试用例
│   ├── fuzztest                # Fuzz 测试
│   ├── unittest                # 单元测试
│   ├── systemtest              # 系统测试
│   └── utils                   # 测试工具
└── utils                       # 工具和通用层
base/powermgr/battery_manager
├── figures                  	# 架构图
├── frameworks                  # Framework层
│   ├── napi                 	# NAPI
│   └── native                  # Native层
├── interfaces                  # 接口层
│   └── inner_api               # 内部接口
├── sa_profile                  # SA配置文件
├── services                    # 服务层
│   ├── native                  # Native层
│   └── zidl                    # Zidl接口层
├── test                        # 测试用例
│   ├── fuzztest                # Fuzz 测试
│   ├── unittest                # 单元测试
│   ├── systemtest              # 系统测试
│   └── utils                   # 测试工具
└── utils                       # 工具和通用层

1.2.电池和充电属性接口

  该模块主要提供电池状态和充放电状态的查询接口。batteryInfo类用来描述电池信息。

  • powermgr_battery_manager\interfaces\inner_api\native\include\battery_info.h

在这里插入图片描述
在这里插入图片描述
1.3.Battery Service 服务启动

  Battery Service 服务被打包到 foundation 进程。System Ability 管理模块用于管理系统基础能力,本服务需要向该模块注册,如果没有编写 profile 配置,则 System Ability 管理模块在启动时不会注册该服务。

powermgr_battery_manager\sa_profile\3302.json
注册信息:
  1 {
  2     "process": "foundation",
  3     "systemability": [
  4         {
  5             "name": 3302,
  6             "libpath": "libbatteryservice.z.so",
  7             "run-on-create": true,
  8             "distributed": false,
  9             "dump_level": 1
 10         }
 11     ]
 12 }
  • name:为对应的serviceId必须与代码中注册的serviceId保持一致;电池服务组件的serviceId为3302;
  • libpath:为SystemAbility的加载路径,必配项;
  • run-on-create:true表示进程启动后即向samgr组件注册该SystemAbility;false表示按需启动,即在其他模块访问到该SystemAbility时启动;必配项;
  • distributed:true表示该SystemAbility为分布式SystemAbility,支持跨设备访问;false表示只有本地跨IPC访问;
  • dump-level:表示systemdumper支持的level等级,默认配置1就OK;
  • 注册信息配置文件:/system/profile/foundation.xml

1.3.1.注册代码

powermgr_battery_manager\services\native\src\battery_service.cpp
//调用SystemAbility接口注册BatteryService实例
const bool G_REGISTER_RESULT = SystemAbility::MakeAndRegisterAbility(
    DelayedSpSingleton<BatteryService>::GetInstance().GetRefPtr());
//构建入参为serviceid、runoncreate
BatteryService::BatteryService()
    : SystemAbility(POWER_MANAGER_BATT_SERVICE_ID, true) {}

  System Ability 管理模块调用 BatteryService 的启动函数实现电池服务组件的启动:

powermgr_battery_manager\services\native\src\battery_service.cpp
void BatteryService::OnStart()
{
    //如果已启动则返回(BatteryService是单实例服务,只会启动一个)
    if (ready_) {
        BATTERY_HILOGD(COMP_SVC, "Service is ready, nothing to do");
        return;
    }
    //创建BatterysrvEventHandler实例
    //等待CommonEventService服务启动完成之后初始化完成
    if (!(Init())) {         //调用BatteryService::Init
        BATTERY_HILOGE(COMP_SVC, "Call init failed");
        return;
    }
    //向OHOS::HDI::ServiceManager 注册状态监听
    RegisterHdiStatusListener();
   //BatteryService服务发布到System Ability管理模块
    if (!Publish(this)) {
        BATTERY_HILOGE(COMP_SVC, "Register to system ability manager failed");
        return;
    }
    // 对指定SA,MISCDEVICE_SERVICE_ABILITY_ID 的监听,当监听的该SA已被publish到SAmgr后,就会触发OnAddSystemAbility
    AddSystemAbilityListener(MISCDEVICE_SERVICE_ABILITY_ID);
    ready_ = true;
}

  重点分析:

  • BatteryService::Init
bool BatteryService::Init()
{
    InitConfig();        //解析battery_config.json
    if (!batteryNotify_) {
        batteryNotify_ = std::make_unique<BatteryNotify>();
    }
    VibratorInit();     //解析battery_vibrator.json
    RegisterBootCompletedCallback();
    return true;
}
  • RegisterHdiStatusListener();
 ->RegisterBatteryHdiCallback();
   ->ErrCode ret = iBatteryInterface_->Register(callback); 
        //drivers_peripheral\battery\interfaces\hdi_service\src\battery_interface_impl.cpp
   		(即 BatteryInterfaceImpl::Register(const sptr<IBatteryCallback>& callback)) 

1.3.2.BatteryInterfaceDriver 启动

  BatteryInterfaceDriver 是 HDI(即驱动接口)层服务,打包在 power_host 进程。本文主要分析 batteryd 的实现。

  device_info.hcs 节点配置:

/vendor/hihope/rk3568/hdf_config/uhdf/device_info.hcs
140         power :: host {
141             hostName = "power_host";
142             priority = 50;
143             uid = "power_host";
144             gid = ["power_host", "system", "log"];
145             caps = ["BLOCK_SUSPEND"];
146             power_device :: device {
147                 device0 :: deviceNode {
148                     policy = 2;
149                     priority = 100;
150                     moduleName = "libpower_driver.z.so";
151                     serviceName = "power_interface_service";
152                 }
153             }
154             battery_device :: device {
155                 device0 :: deviceNode {
156                     policy = 2;
157                     priority = 100;
158                     moduleName = "libbattery_driver.z.so";
159                     serviceName = "battery_interface_service";
160                 }
161             }
162             thermal_device :: device {
163                 device0 :: deviceNode {
164                     policy = 2;
165                     priority = 100;
166                     moduleName = "libthermal_driver.z.so";
167                     serviceName = "thermal_interface_service";
168                 }
169             }
170         }

  驱动程序 (Driver Entry)入口中的三个主要接口:

  • Bind 接口:实现驱动接口实例化绑定,如果需要发布驱动接口,会在驱动加载过程中被调用,实例化该接口的驱动服务并和 DeviceObject 绑定。
  • Init 接口:实现驱动的初始化,返回错误将中止驱动加载流程。
  • Release 接口:实现驱动的卸载,在该接口中释放驱动实例的软硬件资源。

  batteryd 驱动程序初始化接口:

drivers_peripheral\battery\interfaces\hdi_service\src\battery_interface_driver.cpp
static struct HdfDriverEntry g_batteryInterfaceDriverEntry = {
    .moduleVersion = 1,
    .moduleName = "battery_interface_service",
    .Bind = HdfBatteryInterfaceDriverBind,
    .Init = HdfBatteryInterfaceDriverInit,
    .Release = HdfBatteryInterfaceDriverRelease,
};


static int32_t HdfBatteryInterfaceDriverBind(struct HdfDeviceObject *deviceObject)
{
    auto *hdfBatteryInterfaceHost = new (std::nothrow) HdfBatteryInterfaceHost;

    //绑定BatteryInterfaceDriverDispatch作为消息处理函数。
    hdfBatteryInterfaceHost->ioService.Dispatch = BatteryInterfaceDriverDispatch;
    hdfBatteryInterfaceHost->ioService.Open = nullptr;
    hdfBatteryInterfaceHost->ioService.Release = nullptr;

    auto serviceImpl = IBatteryInterface::Get(true);

    hdfBatteryInterfaceHost->stub = OHOS::HDI::ObjectCollector::GetInstance().GetOrNewObject(serviceImpl,
        IBatteryInterface::GetDescriptor());

    //IO Service 完成 IPC 通信的客户端消息请求封装,IO Dispatcher 完成驱动服务端消息请求封装
    //客户端消息通过 IPC 通信到达服务端并分发给 IO Dispatcher 处理。
    deviceObject->service = &hdfBatteryInterfaceHost->ioService;
    return HDF_SUCCESS;
}

  BatteryInterfaceImpl接口:

  通过调用BatteryInterfaceImplGetInstance接口实例BatteryInterfaceImpl对象,并且调用调用BatteryInterfaceImpl::Init进行初始化。

  • 初始化电池信息路径;
  • 调用调用BatteryThread::StartThread.
drivers_peripheral\battery\interfaces\hdi_service\src\battery_interface_impl.cpp
extern "C" IBatteryInterface *BatteryInterfaceImplGetInstance(void)
{
    using OHOS::HDI::Battery::V2_0::BatteryInterfaceImpl;
    BatteryInterfaceImpl *service = new (std::nothrow) BatteryInterfaceImpl();

    if (service->Init() != HDF_SUCCESS) {  //调用BatteryInterfaceImpl::Init
        delete service;
        return nullptr;
    }

    return service;
}

int32_t BatteryInterfaceImpl::Init()
{
    powerSupplyProvider_ = std::make_unique<OHOS::HDI::Battery::V2_0::PowerSupplyProvider>();

    powerSupplyProvider_->InitBatteryPath();
    powerSupplyProvider_->InitPowerSupplySysfs();

    auto& batteryConfig = BatteryConfig::GetInstance();

    batteryConfig.ParseConfig();

    loop_ = std::make_unique<OHOS::HDI::Battery::V2_0::BatteryThread>();

    if (batteryCallback_ != nullptr) {
        loop_->InitCallback(batteryCallback_);
    } else {
        BATTERY_HILOGW(COMP_HDI, "batteryCallback_ is nullptr");
    }
    loop_->StartThread(this);  //调用BatteryThread::StartThread

    return HDF_SUCCESS;
}

drivers_peripheral\battery\interfaces\hdi_service\src\battery_thread.cpp
//在BatteryInterfaceImpl::Init() 启动初始化阶段启动本线程,用于处理kernel发来的消息
void BatteryThread::StartThread(void* service)
{
    Init(service);
    Run(service);
}

1.3.3.电池 batteryInfo 信息查询流程

  采用NAPI (Native API)获取电池信息,NAPI 组件是一套对外接口基于Node.js N-API规范开发的原生模块扩展开发框架。NAPI组件架构图:

在这里插入图片描述
  NAPI适合封装IO、CPU密集型、OS底层等能力并对外暴露JS接口,通过NAPI可以实现JS与C/C++代码互相访问。我们可以通过NAPI接口构建例如网络通信、串口访问、多媒体解码、传感器数据收集等模块。接口实现详见:foundation/arkui/napi。

powermgr_battery_manager\frameworks\napi\battery_info.cpp:
static napi_module g_module = {.nm_version = 1,
    .nm_flags = 0,
    .nm_filename = "batteryInfo",
    .nm_register_func = BatteryInit,
    .nm_modname = "batteryInfo",
    .nm_priv = ((void*)0),
    .reserved = {0}};

extern "C" __attribute__((constructor)) void RegisterModule(void)
{
    napi_module_register(&g_module);
}
  • BatteryInit
static napi_value BatteryInit(napi_env env, napi_value exports)
{
    BATTERY_HILOGD(COMP_FWK, "Enter");

    napi_property_descriptor desc[] = {
        DECLARE_NAPI_GETTER("batterySOC", BatterySOC),
        DECLARE_NAPI_GETTER("chargingStatus", GetChargingState),
        DECLARE_NAPI_GETTER("healthStatus", GetHealthState),
        DECLARE_NAPI_GETTER("pluggedType", GetPluggedType),
        DECLARE_NAPI_GETTER("voltage", GetVoltage),
        DECLARE_NAPI_GETTER("technology", GetTechnology),
        DECLARE_NAPI_GETTER("batteryTemperature", GetBatteryTemperature),
        DECLARE_NAPI_GETTER("isBatteryPresent", GetBatteryPresent),
        DECLARE_NAPI_GETTER("batteryCapacityLevel", GetCapacityLevel),
        DECLARE_NAPI_GETTER("estimatedRemainingChargeTime", GetRemainingChargeTime),
        DECLARE_NAPI_GETTER("nowCurrent", GetBatteryNowCurrent),
        DECLARE_NAPI_GETTER("remainingEnergy", GetBatteryRemainEnergy),
        DECLARE_NAPI_GETTER("totalEnergy", GetTotalEnergy),
        DECLARE_NAPI_FUNCTION("setBatteryConfig", SetBatteryConfig),
        DECLARE_NAPI_FUNCTION("getBatteryConfig", GetBatteryConfig),
        DECLARE_NAPI_FUNCTION("isBatteryConfigSupported", IsBatteryConfigSupported),
    };
    NAPI_CALL(env, napi_define_properties(env, exports, sizeof(desc) / sizeof(desc[0]), desc));

    CreateEnumPluggedType(env, exports);
    CreateEnumChargeState(env, exports);
    CreateEnumHealthState(env, exports);
    CreateEnumLevelState(env, exports);
    CreateEventBatteryChangedKey(env, exports);
    CreateEventBatteryChangedCode(env, exports);

    BATTERY_HILOGD(COMP_FWK, "Success");

    return exports;
}

  应用调用接口获取当前设备剩余电池容量(batterySOC)为例:

applications/standard/app_samples/code/SystemFeature/DeviceManagement/DeviceManagementCollection/feature/capabilities/src/main/ets/util/
//导入模块
import batteryInfo from '@ohos.batteryInfo';

60   /**
61    * 获取当前设备剩余电池电量百分比
62    */
63   public getBatterySOC(): string {
64     let soc: number = this.disposeBatterySOC(batteryInfo.batterySOC)   //调用batterySOC查询接口
65     logger.info(`${this.TAG} getChargingStatus: ${soc}`)
66     return soc.toString()
67   }
68 

  NAPI 接口实现BatterySOC,BatterySOC调用流程:

g_battClient.GetCapacity()->BatterySrvClient::GetCapacity()
   ->BatteryService::GetCapacity()
   	 ->BatteryInterface::GetCapacity(capacity)
   	 	-> PowerSupplyProvider::ParseCapacity
   	 	   ->PowerSupplyProvider::ReadBatterySysfsToBuff
   	 	   	 ->open

  详细分析:

powermgr_battery_manager\frameworks\napi\battery_info.cpp
thread_local static BatterySrvClient& g_battClient = BatterySrvClient::GetInstance();
//注册在动态库中的BatterySOC接口,实现了电池容量的查询
static napi_value BatterySOC(napi_env env, napi_callback_info info)
{
    napi_value napiValue = nullptr;
    int32_t capacity = g_battClient.GetCapacity();

    NAPI_CALL(env, napi_create_int32(env, capacity, &napiValue));

    BATTERY_HILOGD(FEATURE_BATT_INFO, "capacity %{public}d", capacity);
    return napiValue;
}

powermgr_battery_manager\frameworks\native\src\battery_srv_client.cpp
int32_t BatterySrvClient::GetCapacity()
{
    auto proxy = Connect();
    
    //查找到到POWER_MANAGER_BATT_SERVICE_ID(即BatteryService)服务并赋值给proxy_
    //需要了解SystemAbility IPC机制,xxClient-->xxProxy-->xxStub-->xxService。
    RETURN_IF_WITH_RET(proxy == nullptr, INVALID_BATT_INT_VALUE);
    //调用BatteryService::GetCapacity()
    return proxy->GetCapacity();
}

powermgr_battery_manager\services\native\src\battery_service.cpp
int32_t BatteryService::GetCapacity()
{
    if (isMockCapacity_) {
        BATTERY_HILOGD(FEATURE_BATT_INFO, "Return mock battery capacity");
        return batteryInfo_.GetCapacity();
    }
    std::shared_lock<std::shared_mutex> lock(mutex_);
    if (iBatteryInterface_ == nullptr) {
        BATTERY_HILOGE(FEATURE_BATT_INFO, "iBatteryInterface_ is nullptr");
        return ERR_NO_INIT;
    }
    int32_t capacity = BATTERY_FULL_CAPACITY;
    //调用 BatteryInterface::GetCapacity(capacity)
    iBatteryInterface_->GetCapacity(capacity);
    return capacity;
}

drivers_peripheral\battery\interfaces\hdi_service\src\battery_interface_impl.cpp
// BatteryInterfaceImpl 实现IBatteryInterface的纯虚函数
int32_t BatteryInterfaceImpl::GetCapacity(int32_t& capacity)
{
   // 调用 PowerSupplyProvider::ParseCapacity(...)
    return powerSupplyProvider_->ParseCapacity(&capacity);
}

drivers_peripheral\battery\interfaces\hdi_service\src\power_supply_provider.cpp
int32_t PowerSupplyProvider::ParseCapacity(int32_t* capacity) const
{
    char buf[MAX_BUFF_SIZE] = {0};
    // 从capacity的系统文件读取当前设备剩余电池容量中至buf
    int32_t ret = ReadBatterySysfsToBuff(batterySysfsInfo_.capacityPath.c_str(), buf, sizeof(buf));
    if (ret != HDF_SUCCESS) {
        return ret;
    }
     // 转换为十进制
    int32_t value = ParseInt(buf);
    *capacity = value;

    return HDF_SUCCESS;
}

int32_t PowerSupplyProvider::ReadBatterySysfsToBuff(const char* path, char* buf, size_t size) const
{  
    // ReadSysfsFile 
    int32_t ret = ReadSysfsFile(path, buf, size);
    return HDF_SUCCESS;
}

int32_t PowerSupplyProvider::ReadSysfsFile(const char* path, char* buf, size_t size) const
{
    int32_t fd = open(path, O_RDONLY, S_IRUSR | S_IRGRP | S_IROTH);

    size_t readSize = read(fd, buf, size - 1);
    buf[readSize] = '\0';
    Trim(buf);
    close(fd);

    return HDF_SUCCESS;
}

1.3.4.电池 batteryinfo 信息变更发布流程

  BatteryThread接口:

drivers_peripheral\battery\interfaces\hdi_service\src\battery_thread.cpp
int32_t BatteryThread::Init([[maybe_unused]] void* service)
{
    provider_ = std::make_unique<PowerSupplyProvider>();
    if (provider_ != nullptr) {
        provider_->InitBatteryPath();
        provider_->InitPowerSupplySysfs();
    }
    epFd_ = epoll_create1(EPOLL_CLOEXEC);  //创建epoll 实例,用于异步事件通知
    InitUevent();      //初始化uevent, 并且注册回调函数UeventCallback
    return HDF_SUCCESS;
}

void BatteryThread::Run(void* service)
{
    batteryThread_ = std::make_unique<std::thread>([this, service] { this->LoopingThreadEntry(service); });
    pthread_setname_np(batteryThread_->native_handle(), "battery_thread");
}

void BatteryThread::LoopingThreadEntry(void* arg)
{
    int32_t nevents = 0;
    size_t size = callbacks_.size();
    struct epoll_event events[size];

    while (isRunning_) {
        if (!nevents) {
            CycleMatters();
        }

        HandleStates();

        int32_t timeout = epollInterval_;
        int32_t waitTimeout = UpdateWaitInterval();
        if ((timeout < 0) || (waitTimeout > 0 && waitTimeout < timeout)) {
            timeout = waitTimeout;
        }
        // 等待监听的所有的fd相应的事件的产生
        nevents = epoll_wait(epFd_, events, static_cast<int32_t>(size), timeout);
        if (nevents <= 0) {
            continue;
        }
       // 在callbacks_中,根据ueventFd_, 调用void BatteryThread::UeventCallback(void* service) 
        for (int32_t n = 0; n < nevents; ++n) {
            if (events[n].data.ptr) {
                auto* func = const_cast<BatteryThread*>(this);
                (callbacks_.find(events[n].data.fd)->second)(func, arg);
            }
        }
    }
}

//当监听到异步事件之后,调用该函数处理
void BatteryThread::UeventCallback(void* service)
{
    char msg[UEVENT_MSG_LEN + UEVENT_RESERVED_SIZE] = { 0 };

    ssize_t len = recv(ueventFd_, msg, UEVENT_MSG_LEN, 0);
    if (len < 0 || len >= UEVENT_MSG_LEN) {
        BATTERY_HILOGI(COMP_HDI, "recv return msg is invalid, len: %{public}zd", len);
        return;
    }

    // msg separator
    msg[len] = '\0';
    msg[len + 1] = '\0';
    std::string powerUevent;
    if (!MatchPowerUevent(msg, powerUevent)) {
        return;
    }
    BATTERY_HILOGD(FEATURE_BATT_INFO, "PowerUevent msg:%{public}s", powerUevent.c_str());
    UpdateBatteryInfo(service, powerUevent);
}

//更新电池信息
void BatteryThread::UpdateBatteryInfo(void* service, const std::string& powerUevent)
{
    BatteryInfo event = {};
    std::unique_ptr<BatterydInfo> batteryInfo = std::make_unique<BatterydInfo>();
    if (batteryInfo == nullptr) {
        BATTERY_HILOGE(FEATURE_BATT_INFO, "make_unique BatterydInfo error");
        return;
    }
    // 从系统文件中读取信息到batteryInfo
    provider_->UpdateInfoByReadSysFile(batteryInfo.get());
    //将batteryInfo 赋值event
    event.capacity = batteryInfo->capacity_;
    event.voltage= batteryInfo->voltage_;
    event.temperature = batteryInfo->temperature_;
    event.healthState = batteryInfo->healthState_;
    event.pluggedType = batteryInfo->pluggedType_;
    event.pluggedMaxCurrent = batteryInfo->pluggedMaxCurrent_;
    event.pluggedMaxVoltage = batteryInfo->pluggedMaxVoltage_;
    event.chargeState = batteryInfo->chargeState_;
    event.chargeCounter = batteryInfo->chargeCounter_;
    event.present = batteryInfo->present_;
    event.technology = batteryInfo->technology_;
    event.curNow = batteryInfo->curNow_;
    event.remainEnergy = batteryInfo->remainEnergy_;
    event.totalEnergy = batteryInfo->totalEnergy_;
    event.uevent = powerUevent;

    if (g_callback != nullptr) {
        g_callback->Update(event);   // 向注册的 Callback or Subscriber发送电池状态变更消息
    } else {
        BATTERY_HILOGI(FEATURE_BATT_INFO, "g_callback is nullptr");
    }
}

  framework service端接口:

powermgr_battery_manager\services\native\src\battery_service.cpp
bool BatteryService::RegisterBatteryHdiCallback()
{
    std::lock_guard<std::shared_mutex> lock(mutex_);
    if (iBatteryInterface_ == nullptr) {
        iBatteryInterface_ = V2_0::IBatteryInterface::Get();
        BATTERY_HILOGE(COMP_SVC, "failed to get battery hdi interface");
        RETURN_IF_WITH_RET(iBatteryInterface_ == nullptr, false);
    }
    // 向BatteryInterface 注册一个 BatteryCallback,
    sptr<V2_0::IBatteryCallback> callback = new BatteryCallback();
    ErrCode ret = iBatteryInterface_->Register(callback);
    if (ret < 0) {
        BATTERY_HILOGE(COMP_SVC, "register callback failed");
        return false;
    }
     // 调用 BatteryCallback::RegisterBatteryEvent 更新回调处理函数(static)为HandleBatteryCallbackEvent
    BatteryCallback::BatteryEventCallback eventCb =
        std::bind(&BatteryService::HandleBatteryCallbackEvent, this, std::placeholders::_1);
    BatteryCallback::RegisterBatteryEvent(eventCb);
    return true;
}


int32_t BatteryService::HandleBatteryCallbackEvent(const V2_0::BatteryInfo& event)
{
    if (isMockUnplugged_ || isMockCapacity_) {
        return ERR_OK;
    }

    ConvertingEvent(event);
    RETURN_IF_WITH_RET(lastBatteryInfo_ == batteryInfo_, ERR_OK);
    HandleBatteryInfo();
    return ERR_OK;
}

//根据event事件,更新batteryInfo_
void BatteryService::ConvertingEvent(const V1_2::BatteryInfo& event)
{
    if (!isMockCapacity_) {
        batteryInfo_.SetCapacity(event.capacity);
    }
    if (!isMockUnplugged_) {
        batteryInfo_.SetPluggedType(BatteryPluggedType(event.pluggedType));
        batteryInfo_.SetPluggedMaxCurrent(event.pluggedMaxCurrent);
        batteryInfo_.SetPluggedMaxVoltage(event.pluggedMaxVoltage);
        batteryInfo_.SetChargeState(BatteryChargeState(event.chargeState));
    }
    batteryInfo_.SetVoltage(event.voltage);
    batteryInfo_.SetTemperature(event.temperature);
    batteryInfo_.SetHealthState(BatteryHealthState(event.healthState));
    batteryInfo_.SetChargeCounter(event.chargeCounter);
    batteryInfo_.SetTotalEnergy(event.totalEnergy);
    batteryInfo_.SetCurAverage(event.curAverage);
    batteryInfo_.SetRemainEnergy(event.remainEnergy);
    batteryInfo_.SetPresent(event.present);
    batteryInfo_.SetTechnology(event.technology);
    batteryInfo_.SetNowCurrent(event.curNow);
    batteryInfo_.SetChargeType(GetChargeType());
}

void BatteryService::HandleBatteryInfo()
{
    batteryLight_.UpdateColor(batteryInfo_.GetChargeState(), batteryInfo_.GetCapacity());
    // 若有外接电源插入/拔出,则唤醒设备
    WakeupDevice(batteryInfo_.GetPluggedType());
     // 根据batteryInfo_,更新 
    CalculateRemainingChargeTime(batteryInfo_.GetCapacity(), batteryInfo_.GetChargeState());
    // BatteryNotify 发布电池信息更新事件
    batteryNotify_->PublishEvents(batteryInfo_);
    //其他信息更新
    HandleTemperature(batteryInfo_.GetTemperature());
    HandleCapacity(batteryInfo_.GetCapacity(), batteryInfo_.GetChargeState());
    lastBatteryInfo_ = batteryInfo_;
}

2.电量等级定制开发

 &加粗样式ensp;OpenHarmony默认提供了电量等级,根据当前的电量来定义系统统一的电量等级,如满电量、高电量、低电量、极低电量等。系统可以根据当前的电量等级对用户进行提示或处理相关业务。但是电量等级对应的电量值在不同的产品上规格是不同的,产品希望根据产品的设计规格来定制此特性。为此OpenHarmony提供了电量等级的定制方式,产品定制开发者可根据设计规格来定制此特性。battery_config.cpp(drivers_peripheral\battery\interfaces\hdi_service\src\)解析配置文件battery_config.json。

drivers/peripheral/battery/interfaces/hdi_service/profile/battery_config.json:
1 {
2     "light": {
3         "low": {
4             "soc": [0, 10],
5             "rgb": [255, 0, 0]
6         },
7         "normal": {
8             "soc": [10, 90],
9             "rgb": [255, 255, 0]
10         },
11         "high": {
12             "soc": [90, 100],
13             "rgb": [0, 255, 0]
14         }
15     },
16     "boot_actions": {
17         "sendcommonevent": [{
18             "event_name": "usual.event.BATTERY_CHANGED",
19             "scene_config": {
20                 "name" : "wireless",
21                 "not_equal" : "0"
22             },
23             "uevent": "battery common event"
24         }]
25     },
26     "temperature": {
27         "high": 680,
28         "low": -500
29     },
30     "soc": {
31         "shutdown": 5,
32         "critical": 10,
33         "warning": 15,
34         "low": 30,
35         "normal": 60,
36         "high": 90,
37         "full": 100
38     },
39     "charger": {
40         "current_limit":{
41             "path": "/data/service/el0/battery/current_limit"
42         },
43         "voltage_limit":{
44             "path": "/data/service/el0/battery/voltage_limit"
45         },
46         "type": {
47             "path": "/data/service/el0/battery/charger_type"
48         }
49     }
50 }

  电量等级配置说明:
在这里插入图片描述

refer to

  • https://gitee.com/openharmony/powermgr_battery_manager
  • https://gitee.com/openharmony/ace_napi/tree/master
  • https://forums.openharmony.cn/forum.php?mod=viewthread&tid=616
  • http://test.openharmony.cn:7780/pages/v4.1/zh-cn/device-dev/subsystems/subsys-power-battery-level-customization.md

http://www.kler.cn/a/457403.html

相关文章:

  • spring mvc源码学习笔记之五
  • 启航数据结构算法之雅舟,悠游C++智慧之旅——线性艺术:顺序表之细腻探索
  • Java 数据库连接 - Sqlite
  • 机场安全项目|基于改进 YOLOv8 的机场飞鸟实时目标检测方法
  • ASA第六天笔记
  • 学习C++:数组
  • 【人工智能】基于Python和OpenCV实现实时人脸识别系统:从基础到应用
  • PyPika:Python SQL 查询构建器
  • Java删除文件夹
  • 【微服务】SpringBoot 自定义消息转换器使用详解
  • java 加密算法
  • ubuntu linux 更新软件源、在线下载软件、离线安装软件
  • 【Spring】 Bean 注入 HttpServletRequest 能保证线程安全的原理
  • Huggingface数据集采样之后得到的arrow文件无法用Dataset.load_from_disk加载解决方法
  • 第3关:简单通讯录管理系统之删除用户
  • .NetCore WebAPI 导入、导出Excel文件
  • html+css+js网页设计 美食 家美食1个页面
  • Day32 # 和 ## 运算符
  • 云计算学习架构篇之HTTP协议、Nginx常用模块与Nginx服务实战
  • 探索 Java 权限修饰符的奥秘
  • C#中相等比较 == 和 Equal函数 对比
  • 在Ubuntu下通过Docker部署Cloudflared Tunnel服务器
  • SpringBoot整合springmvc
  • 遗传算法——附python实现与各方法的作用与修改
  • 【强化学习】深度确定性策略梯度算法(DDPG)详解(附代码)
  • 碰一碰发视频矩阵系统源码搭建,支持OEM