X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Flibr2c2%2Fsensor.cpp;h=c31c795f12986e32fbd4f23e95c885e03d1aff2f;hb=b5e23ed067e75f17419dc04be872d2162eac01e9;hp=1b7e8cc10c08881a49a22743684046b64683a9fe;hpb=59bae8acd679127602cf35d22bcd37e316a5a056;p=r2c2.git diff --git a/source/libr2c2/sensor.cpp b/source/libr2c2/sensor.cpp index 1b7e8cc..c31c795 100644 --- a/source/libr2c2/sensor.cpp +++ b/source/libr2c2/sensor.cpp @@ -9,17 +9,25 @@ namespace R2C2 { Sensor::Sensor(Layout &l): layout(l), address(0), + invert(false), state(INACTIVE) { if(layout.has_driver()) layout.get_driver().signal_sensor.connect(sigc::mem_fun(this, &Sensor::event)); - layout.add_sensor(*this); + layout.add(*this); } Sensor::~Sensor() { - layout.remove_sensor(*this); + layout.remove(*this); +} + +void Sensor::set_address(unsigned a) +{ + address = a; + if(layout.has_driver()) + layout.get_driver().add_sensor(address); } void Sensor::tick(const Time::TimeDelta &dt) @@ -43,13 +51,13 @@ void Sensor::event(unsigned a, bool s) { if(a==address) { - if(s && stateMAYBE_INACTIVE) + else if(s==invert && state>MAYBE_INACTIVE) { state = MAYBE_INACTIVE; state_confirm_timeout = 700*Time::msec;