parent
bc6f6402eb
commit
f0a839667d
@ -12,8 +12,8 @@ CONF_NIMBLE_ID = "esp32_nimble_mqtt_room"
|
|||||||
|
|
||||||
CONF_ROOM_KEY = 'room'
|
CONF_ROOM_KEY = 'room'
|
||||||
CONF_BASE_TOPIC_KEY = 'base_topic'
|
CONF_BASE_TOPIC_KEY = 'base_topic'
|
||||||
# CONF_MY_OPTIONAL_KEY = 'my_optional_key'
|
|
||||||
CONF_MAC_KEY = 'mac_addr'
|
CONF_MAC_KEY = 'mac_addr'
|
||||||
|
CONF_MAX_DISTANCE = 'max_distance'
|
||||||
|
|
||||||
esp32_nimble_tracker_ns = cg.esphome_ns.namespace("esp32_nimble_mqtt_room")
|
esp32_nimble_tracker_ns = cg.esphome_ns.namespace("esp32_nimble_mqtt_room")
|
||||||
ESP32NimbleMQTTRoom = esp32_nimble_tracker_ns.class_(
|
ESP32NimbleMQTTRoom = esp32_nimble_tracker_ns.class_(
|
||||||
@ -24,6 +24,7 @@ CONFIG_SCHEMA = cv.Schema({
|
|||||||
cv.GenerateID(): cv.declare_id(ESP32NimbleMQTTRoom),
|
cv.GenerateID(): cv.declare_id(ESP32NimbleMQTTRoom),
|
||||||
cv.Required(CONF_ROOM_KEY): cv.string,
|
cv.Required(CONF_ROOM_KEY): cv.string,
|
||||||
cv.Required(CONF_MAC_KEY): cv.All(cv.ensure_list(cv.string)),
|
cv.Required(CONF_MAC_KEY): cv.All(cv.ensure_list(cv.string)),
|
||||||
|
cv.Optional(CONF_MAX_DISTANCE, default=16.0): cv.float_,
|
||||||
cv.Optional(CONF_BASE_TOPIC_KEY, default="esphome_presense"): cv.string,
|
cv.Optional(CONF_BASE_TOPIC_KEY, default="esphome_presense"): cv.string,
|
||||||
}).extend(cv.COMPONENT_SCHEMA).extend(nimble_tracker.NIMBLE_DEVICE_LISTENER_SCHEMA)
|
}).extend(cv.COMPONENT_SCHEMA).extend(nimble_tracker.NIMBLE_DEVICE_LISTENER_SCHEMA)
|
||||||
|
|
||||||
@ -34,6 +35,7 @@ async def to_code(config):
|
|||||||
cg.add(var.set_room(config[CONF_ROOM_KEY]))
|
cg.add(var.set_room(config[CONF_ROOM_KEY]))
|
||||||
cg.add(var.set_base_topic(config[CONF_BASE_TOPIC_KEY]))
|
cg.add(var.set_base_topic(config[CONF_BASE_TOPIC_KEY]))
|
||||||
cg.add(var.set_addresses(config[CONF_MAC_KEY]))
|
cg.add(var.set_addresses(config[CONF_MAC_KEY]))
|
||||||
|
cg.add(var.set_max_distance(config[CONF_MAX_DISTANCE]))
|
||||||
|
|
||||||
await nimble_tracker.device_listener_to_code(var, config)
|
await nimble_tracker.device_listener_to_code(var, config)
|
||||||
await nimble_tracker.register_ble_device(var, config)
|
await nimble_tracker.register_ble_device(var, config)
|
@ -1,30 +0,0 @@
|
|||||||
import esphome.config_validation as cv
|
|
||||||
import esphome.codegen as cg
|
|
||||||
from esphome.const import (
|
|
||||||
CONF_ID,
|
|
||||||
)
|
|
||||||
|
|
||||||
DEPENDENCIES = ["esp32"]
|
|
||||||
|
|
||||||
# CONF_NIMBLE_ID = "esp32_nimble_tracker"
|
|
||||||
|
|
||||||
CONF_MY_REQUIRED_KEY = 'my_required_key'
|
|
||||||
CONF_MY_OPTIONAL_KEY = 'my_optional_key'
|
|
||||||
|
|
||||||
esp32_nimble_tracker_ns = cg.esphome_ns.namespace("esp32_nimble_tracker")
|
|
||||||
ESP32NimbleTracker = esp32_nimble_tracker_ns.class_(
|
|
||||||
"ESP32NimbleTracker", cg.Component
|
|
||||||
)
|
|
||||||
|
|
||||||
CONFIG_SCHEMA = cv.Schema({
|
|
||||||
cv.GenerateID(): cv.declare_id(ESP32NimbleTracker),
|
|
||||||
cv.Required(CONF_MY_REQUIRED_KEY): cv.string,
|
|
||||||
cv.Optional(CONF_MY_OPTIONAL_KEY, default=10): cv.int_,
|
|
||||||
}).extend(cv.COMPONENT_SCHEMA)
|
|
||||||
|
|
||||||
def to_code(config):
|
|
||||||
var = cg.new_Pvariable(config[CONF_ID])
|
|
||||||
yield cg.register_component(var, config)
|
|
||||||
|
|
||||||
await nimble_tracker.device_listener_to_code(var, config)
|
|
||||||
await nimble_tracker.register_ble_device(var, config)
|
|
@ -1,12 +0,0 @@
|
|||||||
#pragma once
|
|
||||||
|
|
||||||
#include "esphome/core/component.h"
|
|
||||||
#include "esphome/components/sensor/sensor.h"
|
|
||||||
|
|
||||||
namespace esphome
|
|
||||||
{
|
|
||||||
namespace esp32_nimble_tracker
|
|
||||||
{
|
|
||||||
class ESP32NimbleTracker : public Component {};
|
|
||||||
} // namespace esp32_nimble_tracker
|
|
||||||
} // namespace esphome
|
|
@ -39,6 +39,11 @@ namespace esphome
|
|||||||
this->filter_ = new Filter(ONE_EURO_FCMIN, ONE_EURO_BETA, ONE_EURO_DCUTOFF);
|
this->filter_ = new Filter(ONE_EURO_FCMIN, ONE_EURO_BETA, ONE_EURO_DCUTOFF);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void NimbleDistanceCustomComponent::set_max_distance(float max_distance) {
|
||||||
|
this->max_distance_ = max_distance;
|
||||||
|
}
|
||||||
|
|
||||||
// Defined distance formula using
|
// Defined distance formula using
|
||||||
// https://medium.com/beingcoders/convert-rssi-value-of-the-ble-bluetooth-low-energy-beacons-to-meters-63259f307283
|
// https://medium.com/beingcoders/convert-rssi-value-of-the-ble-bluetooth-low-energy-beacons-to-meters-63259f307283
|
||||||
// and copied a lot of code from
|
// and copied a lot of code from
|
||||||
@ -59,8 +64,7 @@ namespace esphome
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
auto max_distance = 16.0f;
|
if (this->max_distance_ > 0 && this->filter_->output.value.position > this->max_distance_)
|
||||||
if (max_distance > 0 && this->filter_->output.value.position > max_distance)
|
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
auto skip_distance = 0.5f;
|
auto skip_distance = 0.5f;
|
||||||
|
@ -49,6 +49,7 @@ namespace esphome
|
|||||||
public:
|
public:
|
||||||
void setup() override;
|
void setup() override;
|
||||||
int get_1m_rssi(nimble_tracker::NimbleTrackerEvent *tracker_event);
|
int get_1m_rssi(nimble_tracker::NimbleTrackerEvent *tracker_event);
|
||||||
|
void set_max_distance(float);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
bool update_state(nimble_tracker::NimbleTrackerEvent *tracker_event) override;
|
bool update_state(nimble_tracker::NimbleTrackerEvent *tracker_event) override;
|
||||||
@ -60,6 +61,8 @@ namespace esphome
|
|||||||
float absorption_ = 3.5f;
|
float absorption_ = 3.5f;
|
||||||
float last_reported_position_ = 0;
|
float last_reported_position_ = 0;
|
||||||
int64_t last_reported_micro_seconds_ = 0;
|
int64_t last_reported_micro_seconds_ = 0;
|
||||||
|
|
||||||
|
float max_distance_ = 16.0;
|
||||||
};
|
};
|
||||||
} // namespace nimble_distance
|
} // namespace nimble_distance
|
||||||
} // namespace esphome
|
} // namespace esphome
|
Loading…
Reference in New Issue
Block a user