nanoFramework.Iot.Device.Bq2579x
1.0.333
Prefix Reserved
dotnet add package nanoFramework.Iot.Device.Bq2579x --version 1.0.333
NuGet\Install-Package nanoFramework.Iot.Device.Bq2579x -Version 1.0.333
<PackageReference Include="nanoFramework.Iot.Device.Bq2579x" Version="1.0.333" />
paket add nanoFramework.Iot.Device.Bq2579x --version 1.0.333
#r "nuget: nanoFramework.Iot.Device.Bq2579x, 1.0.333"
// Install nanoFramework.Iot.Device.Bq2579x as a Cake Addin #addin nuget:?package=nanoFramework.Iot.Device.Bq2579x&version=1.0.333 // Install nanoFramework.Iot.Device.Bq2579x as a Cake Tool #tool nuget:?package=nanoFramework.Iot.Device.Bq2579x&version=1.0.333
BQ2579x/BQ25792/BQ25798 - Buck-boost battery charger
This library supports several Bq2579x devices, namely:
- The BQ25798 is an I²C controlled, 1-4-cell, 5-A buck-boost solar battery charger with dual-input selector and MPPT.
- The BQ25792 is an I²C controlled, 5-A, 1-4 cell buck-boost charger with dual-input selector and USB PD 3.0 OTG output.
Documentation
Device & EVM
VQFN 29 pins chip package |
Simplified schematic |
Evaluation Module |
Usage
Warning: If using an ESP32, make sure to properly setup the I2C pins before creating the
I2cDevice
. Add a reference tonanoFramework.Hardware.ESP32
NuGet package and add the following code lines:
//////////////////////////////////////////////////////////////////////
// when connecting to an ESP32 device, need to configure the I2C GPIOs
// used for the bus
Configuration.SetPinFunction(21, DeviceFunction.I2C1_DATA);
Configuration.SetPinFunction(22, DeviceFunction.I2C1_CLOCK);
For other devices like STM32, please make sure you're using the preset pins for the I2C bus you want to use.
Hardware Required
- BQ25798 EVM
- Male/Female Jumper Wires
Circuit
- SCL - SCL
- SDA - SDA
- VCC - 5V
- GND - GND
Code
The following code creates an I2C configuration and instantiates a Bq25798 object. Then it prints the Minimum System Voltage detected by the device at boot. Last it enters a loop where it prints the current Vbus voltage each second.
I2cConnectionSettings settings = new I2cConnectionSettings(1, Bq25798.DefaultI2cAddress);
I2cDevice device = I2cDevice.Create(settings);
using (Bq25798 charger = new Bq25798(device))
{
Debug.WriteLine("");
Debug.WriteLine($"BQ25798 connected to I2C{device.ConnectionSettings.BusId}");
Debug.WriteLine("");
Debug.WriteLine($"Minimum System Voltage is config @ {charger.MinimalSystemVoltage.VoltsDc:N3}V");
while (true)
{
Debug.WriteLine($"Current Vbus: {charger.Vbus.VoltsDc:N3}V");
Debug.WriteLine("");
Thread.Sleep(1000);
}
}
Acknowledgments
The development of this library was kindly sponsored by OrgPal.IoT!
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET Framework | net is compatible. |
-
- nanoFramework.CoreLibrary (>= 1.15.5)
- nanoFramework.System.Device.I2c (>= 1.1.16)
- nanoFramework.System.Device.Model (>= 1.2.693)
- UnitsNet.nanoFramework.ElectricCurrent (>= 5.61.0)
- UnitsNet.nanoFramework.ElectricPotentialDc (>= 5.61.0)
- UnitsNet.nanoFramework.Temperature (>= 5.61.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
1.0.333 | 74 | 12/16/2024 |
1.0.310 | 93 | 10/23/2024 |
1.0.293 | 83 | 10/3/2024 |
1.0.279 | 107 | 9/10/2024 |
1.0.276 | 100 | 9/6/2024 |
1.0.268 | 90 | 8/28/2024 |
1.0.250 | 108 | 8/9/2024 |
1.0.238 | 76 | 7/26/2024 |
1.0.227 | 98 | 7/17/2024 |
1.0.210 | 108 | 6/19/2024 |
1.0.207 | 103 | 6/14/2024 |
1.0.173 | 122 | 4/15/2024 |
1.0.151 | 125 | 3/22/2024 |
1.0.131 | 118 | 2/28/2024 |
1.0.111 | 131 | 1/24/2024 |
1.0.99 | 172 | 1/5/2024 |
1.0.95 | 143 | 12/20/2023 |
1.0.73 | 157 | 11/10/2023 |
1.0.53 | 117 | 11/8/2023 |
1.0.40 | 143 | 10/6/2023 |
1.0.33 | 135 | 9/27/2023 |
1.0.21 | 158 | 9/6/2023 |
1.0.15 | 180 | 8/16/2023 |
1.0.8 | 172 | 8/2/2023 |
1.0.6 | 178 | 8/2/2023 |
1.0.1 | 176 | 7/31/2023 |