-
Notifications
You must be signed in to change notification settings - Fork 151
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Enable reporting of individual pins #68
Comments
It may be useful to make this message work for both analog and digital pins since the current report analog pin message (0xC0) is limited to 16 pins, while some boards have more than 16 analog pins. A version that works for both analog and digital could look like this:
or
|
Can't we infer the pin type from the pin number? (I don't remember exactly if an analog pin can be used as digital, and how relevant this would be.) |
Do you receive any email notifications from the comments? I always have to check the page. |
Generally, but not always. There are some boards (such as some of the Teensy boards) that have a few analog only pins. The analog to digital pin mapping is not always straight forward either (if you look at Leonardo for example) so having a way to specify analog vs digital is useful in reducing chance of user (or even library author) error.
Make sure you set the status at the top of the page to "Watching" (next to where you can Star and Fork) and then I think you should get emails whenever a new comment is posted. |
There is also a Notifications button on bottom of the right hand column of this page so that may be another way to ensure you are notified of updates to a thread. |
I guess the pinType could be inferred from the pinMode since the user should set the pinMode before they enable a pin (these two steps could be combined in a client library). The only risk there is enforcing the order, but I guess we could assume Digital if no pinMode is specified for a pin when the |
I solved the notification issue, thanks (the "Watching" status is useful, curiously the Notifications at the bottom of the page was set, but with no effect. I set also some options in my GitHub profile.) |
My latest thoughts on this are that we should use my initial proposal:
Then add a separate |
Makes sense, since there is already a REPORT_ANALOG with one data byte for the pin. It may seem a bit inconsequent to have REPORT_ANALOG for a pin, REPORT_DIGITAL for a port and REPORT_DIGITAL_PIN for a pin, though. |
I'll rename REPORT_DIGITAL to REPORT_DIGITAL_PORT when these changes are made in order to make that distinction clear. |
Thanks ;) |
|
Hi all. First, thanks for the amazing work on firmata, really incredible how this enable so many other projects. I've been developing a plant monitoring system and that includes moisture sensors. For those, I really don't want to have them connected to Vcc all the time as the current drawn will increase corrosion (see this Soil Moisture Sensor Hookup Guide). To cope with this, I need two changes to the way analog readings are done: My idea is to implement the individual reporting per pin using the planned Do you think this makes sense? Can I go ahead and open the PR? Do you have any ideas for number 2? Possibly another SYSEX command that links a power ping to an analog pin. This is also good for thermistors, as you usually don't want them burning power and heating up as a consequence of being powered on all the time. Waiting for your feedback. Cheers. |
@mdlima Please file 2 separate issues here. They are not related to this particular thread. |
Note that the value of |
In order to support a change from defaulting all pins to OUTPUT on startup, to defaulting to INPUT, we will need the ability to enable individual digital pins rather than entire digital ports.
Once this is in place, digital port reporting (0xD0) should be deprecated. The reason is that when the pin mode is set to INPUT (electrically much safer and should also fix issues users have with relays) rather than OUTPUT by default, non grounded pins (or pins without pull-ups enabled) will report stray voltages and
DIGITAL_MESSAGE
would report these as pin changes. WhenREPORT_DIGITAL_PIN
is added, Firmata should not report a pin value for any pin that is not enabled (much like how analog pin reporting currently works). This will prevent reporting stray voltages as input pin state changes.The text was updated successfully, but these errors were encountered: