#clavier matrice 4 X 4 donc 16 touches
import RPi.GPIO as GPIO
import time
 
class keypad():
    # CONSTANTS   
    KEYPAD = [
    [1,2,3,"A"],
    [4,5,6,"B"],
    [7,8,9,"C"],
    ["*",0,"#","D"]
    ]
     
    ROW         = [37,36,33,32] # du livre [11,12,13,15]
    COLUMN      = [26,24,31,29] # du livre [16,18,22,7]
     
    def __init__(self):
        GPIO.setmode(GPIO.BOARD) #définie GPIO par numéro de pin
     
    def getKey(self):
         
        # Place les pins colone en sortie et à 0
        for j in range(len(self.COLUMN)):
            GPIO.setup(self.COLUMN[j], GPIO.OUT) 
            GPIO.output(self.COLUMN[j], GPIO.LOW)
         
        # Place les pins rangé en entrée
        for i in range(len(self.ROW)):
            GPIO.setup(self.ROW[i], GPIO.IN, pull_up_down=GPIO.PUD_UP)
         
        # Scan rangé pour voir si une touche est enfoncée
        # une touche enfoncé valide donnera un valeur "rowVal"  entre 0 et 3.
        rowVal = -1
        for i in range(len(self.ROW)):
            tmpRead = GPIO.input(self.ROW[i])
            if tmpRead == 0:
                rowVal = i
                 
        # if rowVal is not 0 thru 3 then no button was pressed and we can exit
        if rowVal < 0 or rowVal > 3:
            self.exit()
            return
         
        # Convert columns to input
        for j in range(len(self.COLUMN)):
            GPIO.setup(self.COLUMN[j], GPIO.IN, pull_up_down=GPIO.PUD_DOWN)
         
        # Switch the i-th row found from scan to output
        GPIO.setup(self.ROW[rowVal], GPIO.OUT)
        GPIO.output(self.ROW[rowVal], GPIO.HIGH)
 
        # Scan columns for still-pushed key/button
        # A valid key press should set "colVal"  between 0 and 2.
        colVal = -1
        for j in range(len(self.COLUMN)):
            tmpRead = GPIO.input(self.COLUMN[j])
            if tmpRead == 1:
                colVal=j
                 
        # if colVal is not 0 thru 2 then no button was pressed and we can exit
        if colVal < 0 or colVal > 3:
            self.exit()
            return
 
        # Return the value of the key pressed
        self.exit()
        return self.KEYPAD[rowVal][colVal]
         
    def exit(self):
        # Reinitialize all rows and columns as input at exit
        for i in range(len(self.ROW)):
                GPIO.setup(self.ROW[i], GPIO.IN, pull_up_down=GPIO.PUD_UP) 
        for j in range(len(self.COLUMN)):
                GPIO.setup(self.COLUMN[j], GPIO.IN, pull_up_down=GPIO.PUD_UP)

def loop():
        # Initialise la class keypad()
        kp = keypad()
        # fait toujour cette boucle pour afficher si une touche a été enfoncé
        while True:
            digit = None
            while digit == None:
                digit = kp.getKey()    
            # affiche le résultat
            print (digit)
            time.sleep(0.5) # delais de 0.5 seconde
        

def destroy():   #Arrêt du programme
         GPIO.cleanup()                     # relache la ressource GPIO
	

if __name__ == '__main__': # Le programme commence ici
    try:  
            loop()    
    except KeyboardInterrupt:    
            destroy()
    
