On the TERRA Board the GPIO lines are available on the Daisy connectors (see the Terra pinout).
It is possible to access directly the GPIO lines using for example the DAISY-12 protoboard and set the GPIO line using the on() and off() methods of Pin class:
from ablib import Pin led = Pin('D11.2','OUTPUT') led.on() led.off()
to read the line state it is possible to follow two methods:
This mode consists to check the actual state of the line calling the get_value() method.
from ablib import Pin PB=Pin('D11.3','INPUT') #Never ending loop while True: if (PB.digitalRead()==0): print "Pressed" while PB.digitalRead()==0: pass
This mode consists to register a callback function with the set_edge() method that will call when the GPIO lines changes its state.
from ablib import Pin from time import sleep def pressed(): print "Pressed" PB=Pin('D11.3','INPUT') PB.set_edge("falling",pressed) #Never ending loop i=0 while True: print i i=i+1 sleep(0.5)
If you are using a Daisy module with leds, relays or other output devices you can use directly the name of the devices written on the PCB silk screen.
Following is an example to turn on a led on the DAISY-11 eight leds module:
from ablib import Daisy11 led = Daisy11('D11','L1') led.on() led.off()
This is an example with a Daisy-8 relay board plugged on D12 connector
from ablib import Daisy8 relay = Daisy8('D12','first','RL0') relay.on() relay.off()
The 'first' parms indicated that the Daisy8 used is plugged as first board on the flat cable. Up to board can be wired on the same daisy cable: 'first' and 'second'.