Blame view

Robot/deplacement.c 1.28 KB
d2f14e3c   pfrison   Debut programme a...
1
2
3
4
5
6
7
8
  #include <avr/io.h>
  #include <util/delay.h>
  
  #define STEP_GAUCHE 0x10 // pin 7
  #define DIR_GAUCHE 0x08 // pin 6
  #define STEP_DROIT 0x20 // pin 12
  #define DIR_DROIT 0x10 // pin 11
  
9a371461   pfrison   Programme robot
9
  // valeurs a remplacer par ceux donne par PercTeacher
d2f14e3c   pfrison   Debut programme a...
10
11
12
13
  const uint8_t deltaL[] = {};
  const uint8_t delaiL[] = {};
  const uint8_t deltaR[] = {};
  const uint8_t delaiR[] = {};
9a371461   pfrison   Programme robot
14
  #define N_DEPLACEMENT 0
d2f14e3c   pfrison   Debut programme a...
15
16
17
18
19
20
  
  void init_deplacements(void){
      DDRH |= STEP_GAUCHE | DIR_GAUCHE;
      DDRB |= STEP_DROIT | DIR_DROIT;
  }
  
9a371461   pfrison   Programme robot
21
  static uint16_t* deplacement_commande_suivante(uint16_t num){
d2f14e3c   pfrison   Debut programme a...
22
23
24
      return {deltaL[num], delaiL[num], deltaR[num], delaiR[num]};
  }
  
9a371461   pfrison   Programme robot
25
26
27
28
29
30
31
32
33
34
35
  void deplacement(uint8_t mot){
  	int i;
  	for(i=0; i<N_DEPLACEMENT; i++){
  		uint16_t *commande = deplacement_commande_suivante(i);
  		if(mot == GAUCHE)
  			deplacement_moteur(mot, commande[0], commande[1]);
  		else
  			deplacement_moteur(mot, commande[2], commande[3]);
  	}
  }
  
d2f14e3c   pfrison   Debut programme a...
36
  static void deplacement_moteur(uint8_t mot, uint16_t delta, uint16_t delai){
9a371461   pfrison   Programme robot
37
38
  	uint16_t i;
      for(i=0; i<delta; i++){
d2f14e3c   pfrison   Debut programme a...
39
40
41
42
43
44
45
46
47
48
49
50
          if (mot == GAUCHE)
              PORTH |= STEP_GAUCHE;
          else if (mot == DROIT)
              PORTB |= STEP_DROIT;
          _delay_ms(delai);
          if (mot == GAUCHE)
              PORTH &= ~STEP_GAUCHE;
          else if (mot == DROIT)
              PORTB &= ~STEP_DROIT;
          _delay_ms(delai);
      }
  }