mirror of
https://github.com/esphome/esphome.git
synced 2024-11-10 01:07:45 +01:00
MCP3204 4-channel 12-bit ADC component (#2895)
Co-authored-by: Jesse Hills <3060199+jesserockz@users.noreply.github.com>
This commit is contained in:
parent
5844c1767b
commit
a4431abea8
8 changed files with 182 additions and 0 deletions
|
@ -97,6 +97,7 @@ esphome/components/mcp23x08_base/* @jesserockz
|
||||||
esphome/components/mcp23x17_base/* @jesserockz
|
esphome/components/mcp23x17_base/* @jesserockz
|
||||||
esphome/components/mcp23xxx_base/* @jesserockz
|
esphome/components/mcp23xxx_base/* @jesserockz
|
||||||
esphome/components/mcp2515/* @danielschramm @mvturnho
|
esphome/components/mcp2515/* @danielschramm @mvturnho
|
||||||
|
esphome/components/mcp3204/* @rsumner
|
||||||
esphome/components/mcp47a1/* @jesserockz
|
esphome/components/mcp47a1/* @jesserockz
|
||||||
esphome/components/mcp9808/* @k7hpn
|
esphome/components/mcp9808/* @k7hpn
|
||||||
esphome/components/md5/* @esphome/core
|
esphome/components/md5/* @esphome/core
|
||||||
|
|
27
esphome/components/mcp3204/__init__.py
Normal file
27
esphome/components/mcp3204/__init__.py
Normal file
|
@ -0,0 +1,27 @@
|
||||||
|
import esphome.codegen as cg
|
||||||
|
import esphome.config_validation as cv
|
||||||
|
from esphome.components import spi
|
||||||
|
from esphome.const import CONF_ID
|
||||||
|
|
||||||
|
DEPENDENCIES = ["spi"]
|
||||||
|
MULTI_CONF = True
|
||||||
|
CODEOWNERS = ["@rsumner"]
|
||||||
|
|
||||||
|
mcp3204_ns = cg.esphome_ns.namespace("mcp3204")
|
||||||
|
MCP3204 = mcp3204_ns.class_("MCP3204", cg.Component, spi.SPIDevice)
|
||||||
|
|
||||||
|
CONF_REFERENCE_VOLTAGE = "reference_voltage"
|
||||||
|
|
||||||
|
CONFIG_SCHEMA = cv.Schema(
|
||||||
|
{
|
||||||
|
cv.GenerateID(): cv.declare_id(MCP3204),
|
||||||
|
cv.Optional(CONF_REFERENCE_VOLTAGE, default="3.3V"): cv.voltage,
|
||||||
|
}
|
||||||
|
).extend(spi.spi_device_schema(cs_pin_required=True))
|
||||||
|
|
||||||
|
|
||||||
|
async def to_code(config):
|
||||||
|
var = cg.new_Pvariable(config[CONF_ID])
|
||||||
|
cg.add(var.set_reference_voltage(config[CONF_REFERENCE_VOLTAGE]))
|
||||||
|
await cg.register_component(var, config)
|
||||||
|
await spi.register_spi_device(var, config)
|
35
esphome/components/mcp3204/mcp3204.cpp
Normal file
35
esphome/components/mcp3204/mcp3204.cpp
Normal file
|
@ -0,0 +1,35 @@
|
||||||
|
#include "mcp3204.h"
|
||||||
|
#include "esphome/core/log.h"
|
||||||
|
|
||||||
|
namespace esphome {
|
||||||
|
namespace mcp3204 {
|
||||||
|
|
||||||
|
static const char *const TAG = "mcp3204";
|
||||||
|
|
||||||
|
float MCP3204::get_setup_priority() const { return setup_priority::HARDWARE; }
|
||||||
|
|
||||||
|
void MCP3204::setup() {
|
||||||
|
ESP_LOGCONFIG(TAG, "Setting up mcp3204");
|
||||||
|
this->spi_setup();
|
||||||
|
}
|
||||||
|
|
||||||
|
void MCP3204::dump_config() {
|
||||||
|
ESP_LOGCONFIG(TAG, "MCP3204:");
|
||||||
|
LOG_PIN(" CS Pin:", this->cs_);
|
||||||
|
ESP_LOGCONFIG(TAG, " Reference Voltage: %.2fV", this->reference_voltage_);
|
||||||
|
}
|
||||||
|
|
||||||
|
float MCP3204::read_data(uint8_t pin) {
|
||||||
|
uint8_t adc_primary_config = 0b00000110 & 0b00000111;
|
||||||
|
uint8_t adc_secondary_config = pin << 6;
|
||||||
|
this->enable();
|
||||||
|
this->transfer_byte(adc_primary_config);
|
||||||
|
uint8_t adc_primary_byte = this->transfer_byte(adc_secondary_config);
|
||||||
|
uint8_t adc_secondary_byte = this->transfer_byte(0x00);
|
||||||
|
this->disable();
|
||||||
|
uint16_t digital_value = (adc_primary_byte << 8 | adc_secondary_byte) & 0b111111111111;
|
||||||
|
return float(digital_value) / 4096.000 * this->reference_voltage_;
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace mcp3204
|
||||||
|
} // namespace esphome
|
28
esphome/components/mcp3204/mcp3204.h
Normal file
28
esphome/components/mcp3204/mcp3204.h
Normal file
|
@ -0,0 +1,28 @@
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include "esphome/core/component.h"
|
||||||
|
#include "esphome/core/hal.h"
|
||||||
|
#include "esphome/components/spi/spi.h"
|
||||||
|
|
||||||
|
namespace esphome {
|
||||||
|
namespace mcp3204 {
|
||||||
|
|
||||||
|
class MCP3204 : public Component,
|
||||||
|
public spi::SPIDevice<spi::BIT_ORDER_MSB_FIRST, spi::CLOCK_POLARITY_LOW, spi::CLOCK_PHASE_LEADING,
|
||||||
|
spi::DATA_RATE_1MHZ> {
|
||||||
|
public:
|
||||||
|
MCP3204() = default;
|
||||||
|
|
||||||
|
void set_reference_voltage(float reference_voltage) { this->reference_voltage_ = reference_voltage; }
|
||||||
|
|
||||||
|
void setup() override;
|
||||||
|
void dump_config() override;
|
||||||
|
float get_setup_priority() const override;
|
||||||
|
float read_data(uint8_t pin);
|
||||||
|
|
||||||
|
protected:
|
||||||
|
float reference_voltage_;
|
||||||
|
};
|
||||||
|
|
||||||
|
} // namespace mcp3204
|
||||||
|
} // namespace esphome
|
32
esphome/components/mcp3204/sensor/__init__.py
Normal file
32
esphome/components/mcp3204/sensor/__init__.py
Normal file
|
@ -0,0 +1,32 @@
|
||||||
|
import esphome.codegen as cg
|
||||||
|
import esphome.config_validation as cv
|
||||||
|
from esphome.components import sensor, voltage_sampler
|
||||||
|
from esphome.const import CONF_ID, CONF_NUMBER
|
||||||
|
from .. import mcp3204_ns, MCP3204
|
||||||
|
|
||||||
|
AUTO_LOAD = ["voltage_sampler"]
|
||||||
|
|
||||||
|
DEPENDENCIES = ["mcp3204"]
|
||||||
|
|
||||||
|
MCP3204Sensor = mcp3204_ns.class_(
|
||||||
|
"MCP3204Sensor", sensor.Sensor, cg.PollingComponent, voltage_sampler.VoltageSampler
|
||||||
|
)
|
||||||
|
CONF_MCP3204_ID = "mcp3204_id"
|
||||||
|
|
||||||
|
CONFIG_SCHEMA = sensor.SENSOR_SCHEMA.extend(
|
||||||
|
{
|
||||||
|
cv.GenerateID(): cv.declare_id(MCP3204Sensor),
|
||||||
|
cv.GenerateID(CONF_MCP3204_ID): cv.use_id(MCP3204),
|
||||||
|
cv.Required(CONF_NUMBER): cv.int_range(min=0, max=3),
|
||||||
|
}
|
||||||
|
).extend(cv.polling_component_schema("60s"))
|
||||||
|
|
||||||
|
|
||||||
|
async def to_code(config):
|
||||||
|
var = cg.new_Pvariable(
|
||||||
|
config[CONF_ID],
|
||||||
|
config[CONF_NUMBER],
|
||||||
|
)
|
||||||
|
await cg.register_parented(var, config[CONF_MCP3204_ID])
|
||||||
|
await cg.register_component(var, config)
|
||||||
|
await sensor.register_sensor(var, config)
|
23
esphome/components/mcp3204/sensor/mcp3204_sensor.cpp
Normal file
23
esphome/components/mcp3204/sensor/mcp3204_sensor.cpp
Normal file
|
@ -0,0 +1,23 @@
|
||||||
|
#include "mcp3204_sensor.h"
|
||||||
|
|
||||||
|
#include "esphome/core/log.h"
|
||||||
|
|
||||||
|
namespace esphome {
|
||||||
|
namespace mcp3204 {
|
||||||
|
|
||||||
|
static const char *const TAG = "mcp3204.sensor";
|
||||||
|
|
||||||
|
MCP3204Sensor::MCP3204Sensor(uint8_t pin) : pin_(pin) {}
|
||||||
|
|
||||||
|
float MCP3204Sensor::get_setup_priority() const { return setup_priority::DATA; }
|
||||||
|
|
||||||
|
void MCP3204Sensor::dump_config() {
|
||||||
|
LOG_SENSOR("", "MCP3204 Sensor", this);
|
||||||
|
ESP_LOGCONFIG(TAG, " Pin: %u", this->pin_);
|
||||||
|
LOG_UPDATE_INTERVAL(this);
|
||||||
|
}
|
||||||
|
float MCP3204Sensor::sample() { return this->parent_->read_data(this->pin_); }
|
||||||
|
void MCP3204Sensor::update() { this->publish_state(this->sample()); }
|
||||||
|
|
||||||
|
} // namespace mcp3204
|
||||||
|
} // namespace esphome
|
30
esphome/components/mcp3204/sensor/mcp3204_sensor.h
Normal file
30
esphome/components/mcp3204/sensor/mcp3204_sensor.h
Normal file
|
@ -0,0 +1,30 @@
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include "esphome/components/sensor/sensor.h"
|
||||||
|
#include "esphome/components/voltage_sampler/voltage_sampler.h"
|
||||||
|
#include "esphome/core/component.h"
|
||||||
|
#include "esphome/core/hal.h"
|
||||||
|
|
||||||
|
#include "../mcp3204.h"
|
||||||
|
|
||||||
|
namespace esphome {
|
||||||
|
namespace mcp3204 {
|
||||||
|
|
||||||
|
class MCP3204Sensor : public PollingComponent,
|
||||||
|
public Parented<MCP3204>,
|
||||||
|
public sensor::Sensor,
|
||||||
|
public voltage_sampler::VoltageSampler {
|
||||||
|
public:
|
||||||
|
MCP3204Sensor(uint8_t pin);
|
||||||
|
|
||||||
|
void update() override;
|
||||||
|
void dump_config() override;
|
||||||
|
float get_setup_priority() const override;
|
||||||
|
float sample() override;
|
||||||
|
|
||||||
|
protected:
|
||||||
|
uint8_t pin_;
|
||||||
|
};
|
||||||
|
|
||||||
|
} // namespace mcp3204
|
||||||
|
} // namespace esphome
|
|
@ -65,6 +65,9 @@ sx1509:
|
||||||
- id: sx1509_hub
|
- id: sx1509_hub
|
||||||
address: 0x3E
|
address: 0x3E
|
||||||
|
|
||||||
|
mcp3204:
|
||||||
|
cs_pin: GPIO23
|
||||||
|
|
||||||
sensor:
|
sensor:
|
||||||
- platform: homeassistant
|
- platform: homeassistant
|
||||||
entity_id: sensor.hello_world
|
entity_id: sensor.hello_world
|
||||||
|
@ -215,6 +218,9 @@ sensor:
|
||||||
- or:
|
- or:
|
||||||
- throttle: "20min"
|
- throttle: "20min"
|
||||||
- delta: 0.02
|
- delta: 0.02
|
||||||
|
- platform: mcp3204
|
||||||
|
name: "MCP3204 Pin 1"
|
||||||
|
number: 1
|
||||||
|
|
||||||
#
|
#
|
||||||
# platform sensor.apds9960 requires component apds9960
|
# platform sensor.apds9960 requires component apds9960
|
||||||
|
|
Loading…
Reference in a new issue