Subversion Repositories svnkaklik

Rev

Rev 154 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log

Rev Author Line No. Line
141 kakl 1
#include ".\camerus.h"
136 kakl 2
 
154 kakl 3
#USE FAST_IO (C)     // Brana C je ve FAST_IO modu, aby slo rychle cteni z kamery
136 kakl 4
 
150 kakl 5
// kroutitka
153 kakl 6
#define  CERVENA  3  // AN3/RA3
7
#define  CERNA    2  // AN2/RA2
8
#define  ZELENA   1  // AN1/RA0
9
#define  MODRA    0  // AN0/RA1
150 kakl 10
 
11
// I/O
154 kakl 12
#define LED    PIN_C0      // LED signalizujici start programu
13
#define HREF   PIN_C5      // Signal HREF z kamery (v H po celou dobu radku)
14
#define PIX    PIN_C6      // Vstup pro body z kamery (za trivstupim hradlem OR (dig. komparator))
176 kakl 15
#define SERVO  PIN_B4      // Vystup na servo (1 az 2ms po cca 20ms (synchronizovano snimkovym kmitoctem))
154 kakl 16
#define MOT_L  PIN_B5      // Smer otaceni leveho motoru; druhy pol je RC2
17
#define MOT_R  PIN_B6      // Smer otaceni praveho motoru; druhy pol je RC1
136 kakl 18
 
176 kakl 19
#define DATA   PIN_B2
20
#define CP     PIN_B1
21
 
22
void disp(int8 x)
23
{
24
   int n;
25
 
26
   x=~x;
27
   for(n=0;n<=7;n++)
28
   {
29
      if (x & 1 == 1) output_high(DATA); else output_low(DATA);
30
      output_high(CP);
31
      x>>=1;
32
      output_low(CP);
33
   }
34
}
35
 
36
void NightRider(int x)
37
{
38
   int n,i,j;
39
 
40
   for(j=0;j<x;j++)
41
   {
42
      i=0x01;
43
      for(n=0;n<7;n++)
44
      {
45
         disp(i);
46
         rotate_left(&i, 1);
47
         delay_ms(100);
48
      }
49
      for(n=0;n<7;n++)
50
      {
51
         disp(i);
52
         rotate_right(&i, 1);
53
         delay_ms(100);
54
      }
55
   }
56
   disp(i);
57
   delay_ms(100);
58
   i=0;
59
   disp(i);
60
}
61
 
136 kakl 62
void main()
63
{
154 kakl 64
   int8 cas;      // Cas hrany bila/cerna v radce
65
   int8 offset;   // Promena pro ulozeni ovsetu
66
   int8 rr;       // Promenna na ulozeni Rozumne rychlost
67
   int8 r1;       // Rychlost motoru 1
68
   int8 r2;       // Rychlost motoru 2
136 kakl 69
 
154 kakl 70
   int16 ble;     // Prodleva do rozjezdu
71
 
72
   setup_adc_ports(ALL_ANALOG);              // Zapnuti A/D prevodniku pro cteni kroutitek
136 kakl 73
   setup_adc(ADC_CLOCK_INTERNAL);
154 kakl 74
   setup_timer_0(RTCC_INTERNAL|RTCC_DIV_1);  // Casovac pro mereni casu hrany W/B v radce
136 kakl 75
   setup_timer_1(T1_DISABLED);
154 kakl 76
   setup_timer_2(T2_DIV_BY_16,255,1);        // Casovac PWM motoru
77
   setup_ccp1(CCP_PWM); // RC1               // PWM pro motory
136 kakl 78
   setup_ccp2(CCP_PWM); // RC2
176 kakl 79
   setup_comparator(NC_NC_NC_NC);
136 kakl 80
   setup_vref(FALSE);
81
 
154 kakl 82
   set_tris_c(0b11111000);     // Nastaveni vstup/vystup pro branu C, protoze se nedela automaticky
176 kakl 83
 
153 kakl 84
   set_pwm1_duty(0);   // Zastav motory
85
   set_pwm2_duty(0);
86
   output_low(MOT_L);
87
   output_low(MOT_R);
88
 
176 kakl 89
   NightRider(1);    // Aby se poznalo, ze byl RESET
90
                     // Musi se pockat, nez se rozjede kamera, nez se do ni zacnou posilat prikazy
136 kakl 91
 
176 kakl 92
   //... Nastaveni kamery ...
154 kakl 93
   i2c_start();      // Soft RESET kamery
94
   i2c_write(0xC0);        // Pro single slave musi mit vsechny zapisy adresu C0h
95
   i2c_write(0x12);        // Adresa registru COMH
96
   i2c_write(0x80 | 0x24); // Zapis ridiciho slova
136 kakl 97
   i2c_stop();
98
 
99
   i2c_start();      // BW
100
   i2c_write(0xC0);
101
   i2c_write(0x28);
102
   i2c_write(0b01000001);
103
   i2c_stop();
104
 
176 kakl 105
/*
136 kakl 106
   i2c_start();      // Contrast
107
   i2c_write(0xC0);
108
   i2c_write(0x05);
176 kakl 109
   i2c_write(0xA0);  // 48h
136 kakl 110
   i2c_stop();
176 kakl 111
*/
136 kakl 112
   i2c_start();      // Brightness
113
   i2c_write(0xC0);
114
   i2c_write(0x06);
176 kakl 115
   i2c_write(0x90);  // 80h
136 kakl 116
   i2c_stop();
117
 
176 kakl 118
/*
136 kakl 119
   i2c_start();      // Band Filter
120
   i2c_write(0xC0);
121
   i2c_write(0x2D);
122
   i2c_write(0x04 | 0x03);
123
   i2c_stop();
124
*/
125
   i2c_start();      // VSTRT
126
   i2c_write(0xC0);
127
   i2c_write(0x19);
128
   i2c_write(45);
129
   i2c_stop();
130
 
131
   i2c_start();      // VEND
132
   i2c_write(0xC0);
133
   i2c_write(0x1A);
134
   i2c_write(45);
135
   i2c_stop();
136
 
176 kakl 137
   NightRider(1);    // Aby se poznalo, ze byl RESET
152 kakl 138
 
154 kakl 139
   cas=128;  // Inicializace promenych, aby neslo servo za roh a aby se to rozjelo jeste dneska
140
   ble=0;
136 kakl 141
 
176 kakl 142
/*
143
while(true)
144
{
145
disp(ble);
146
   i2c_start();      
147
   i2c_write(0xC0);
148
   i2c_write(0x06);
149
   i2c_write(ble); 
150
   i2c_stop();
151
delay_ms(1000);
152
ble+=0x10;
153
};
154
*/
155
 
154 kakl 156
   // ... Hlavni smycka ...
136 kakl 157
   while(true)
158
   {
154 kakl 159
      while(!input(HREF));    // Cekej nez se zacnou posilat pixely z radky
160
      set_timer0(0);          // Vynuluj pocitadlo casu
161
      while(input(HREF))      // Po dobu vysilani radky cekej na hranu W/B
149 kakl 162
      {
176 kakl 163
// Dodelat rozpoznani cerne cary napric pro zastaveni
164
// Pockat na shozeni signalu HREF
154 kakl 165
         if(!input(PIX))   // Pokud se dvakrat za sebou precetla CERNA
152 kakl 166
         if(!input(PIX))
176 kakl 167
         if(!input(PIX))
152 kakl 168
         {
176 kakl 169
            int8 pom;
170
 
171
            pom=get_timer0();    // Precti cas z citace casu hrany
172
//            cas=255-cas;         // Vlevo je vpravo
173
            if(pom<0b11000000) cas=pom;
152 kakl 174
            break;
175
         };
149 kakl 176
      };
150 kakl 177
 
154 kakl 178
      set_adc_channel(MODRA);    // Kroutitko na vystredeni predniho kolecka
150 kakl 179
      Delay_ms(1);
180
      offset=read_adc();
176 kakl 181
 
154 kakl 182
      output_high(SERVO);        // Odvysilani impuzu 1 az 2ms pro servo
152 kakl 183
      delay_us(1000);
150 kakl 184
      delay_us(offset);
152 kakl 185
      delay_us(offset);
149 kakl 186
      delay_us(cas);
187
      delay_us(cas);
152 kakl 188
      output_low(SERVO);
154 kakl 189
 
190
      ble++;                     // Casovac pro odlozeni rozjezdu po zapnuti napajeni
191
      set_adc_channel(ZELENA);   // Kroutitka pro vykon motoru (!!! to bude chtit jeste predelat !!!)
153 kakl 192
      Delay_ms(1);
193
      offset=read_adc();
194
      set_adc_channel(CERNA);
195
      Delay_ms(1);
196
      rr=read_adc();
176 kakl 197
 
198
disp(cas);
199
 
154 kakl 200
      r1=cas>>1;                 // Elektronicky diferencial
153 kakl 201
      r2=255-offset-(cas>>1);
154 kakl 202
 
203
      if (ble==99)               // Rozjezd na Rozumnou rychlost
153 kakl 204
      {
205
         set_pwm1_duty(rr);
154 kakl 206
         set_pwm2_duty(rr);
153 kakl 207
      };
154 kakl 208
      if ((ble>100)&&(ble<60000))      // Jizda
209
      {
153 kakl 210
         if (r1<=rr) set_pwm1_duty(r1);
211
         if (r2<=rr) set_pwm2_duty(r2);
212
      }
213
      else
214
      {
154 kakl 215
         set_pwm1_duty(0);       // Zastaveni
153 kakl 216
         set_pwm2_duty(0);
217
      }
136 kakl 218
   };
219
}