您的位置:首页 > 房产 > 建筑 > 网站设计的公司怎么样_新开传奇网站发布网单_吉林seo网络推广_短期职业技能培训班

网站设计的公司怎么样_新开传奇网站发布网单_吉林seo网络推广_短期职业技能培训班

2025/1/6 19:24:31 来源:https://blog.csdn.net/weixin_41028621/article/details/144737072  浏览:    关键词:网站设计的公司怎么样_新开传奇网站发布网单_吉林seo网络推广_短期职业技能培训班
网站设计的公司怎么样_新开传奇网站发布网单_吉林seo网络推广_短期职业技能培训班
  • 电池服务组件
  • 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": 110         }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::InitBATTERY_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后,就会触发OnAddSystemAbilityAddSystemAbilityListener(MISCDEVICE_SERVICE_ABILITY_ID);ready_ = true;
}

  重点分析:

  • BatteryService::Init
bool BatteryService::Init()
{InitConfig();        //解析battery_config.jsonif (!batteryNotify_) {batteryNotify_ = std::make_unique<BatteryNotify>();}VibratorInit();     //解析battery_vibrator.jsonRegisterBootCompletedCallback();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::Initdelete 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::StartThreadreturn 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的系统文件读取当前设备剩余电池容量中至bufint32_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, 并且注册回调函数UeventCallbackreturn 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 separatormsg[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;}// 从系统文件中读取信息到batteryInfoprovider_->UpdateInfoByReadSysFile(batteryInfo.get());//将batteryInfo 赋值eventevent.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)为HandleBatteryCallbackEventBatteryCallback::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

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com