aboutsummaryrefslogtreecommitdiff
path: root/libraries/Robot_Control/Multiplexer.cpp
diff options
context:
space:
mode:
authorCristian Maglie <c.maglie@bug.st>2013-06-01 23:16:02 +0200
committerCristian Maglie <c.maglie@bug.st>2013-06-01 23:16:02 +0200
commit177ad96f866714a4962be57f69cd3d5a6334cde1 (patch)
tree1072239986340d6a239adac924eddf2e1d1ca566 /libraries/Robot_Control/Multiplexer.cpp
parent6cff36ac5e85c74bcb45cc53491ad69d64520b36 (diff)
parentd90fcca5839d13d57ed527d4009b78d22dafbde7 (diff)
Merge branch 'merge-1.0.5' into ide-1.5.x-discovery
Diffstat (limited to 'libraries/Robot_Control/Multiplexer.cpp')
-rw-r--r--libraries/Robot_Control/Multiplexer.cpp37
1 files changed, 37 insertions, 0 deletions
diff --git a/libraries/Robot_Control/Multiplexer.cpp b/libraries/Robot_Control/Multiplexer.cpp
new file mode 100644
index 0000000..8f7d30e
--- /dev/null
+++ b/libraries/Robot_Control/Multiplexer.cpp
@@ -0,0 +1,37 @@
+#include "Multiplexer.h"
+
+void Multiplexer::begin(uint8_t* selectors, uint8_t Z, uint8_t length){
+ for(uint8_t i=0;i<length;i++){
+ this->selectors[i]=selectors[i];
+ pinMode(selectors[i],OUTPUT);
+ }
+ this->length=length;
+ this->pin_Z=Z;
+ pinMode(pin_Z,INPUT);
+}
+
+void Multiplexer::selectPin(uint8_t num){
+ for(uint8_t i=0;i<length;i++){
+ //Serial.print(bitRead(num,i));
+ digitalWrite(selectors[i],bitRead(num,i));
+ }
+ //Serial.println("");
+}
+
+int Multiplexer::getAnalogValue(){
+ return analogRead(pin_Z);
+}
+
+bool Multiplexer::getDigitalValue(){
+ return digitalRead(pin_Z);
+}
+
+int Multiplexer::getAnalogValueAt(uint8_t num){
+ selectPin(num);
+ return getAnalogValue();
+}
+
+bool Multiplexer::getDigitalValueAt(uint8_t num){
+ selectPin(num);
+ return getDigitalValue();
+}