蓝宙TSL1401设计巡线

2019-08-14 02:03发布

在ADC库函数的例子里面加了下面这个函数来实现在白纸上寻找黑线位置,CCD总是有问题找不到,劳烦各路大神帮忙看一下
u16 CCD_Find(void)
{
u16 ao_d[128];
u16 n,max,min,mid,find=0,bla=0;
GPIO_SetBits(GPIOB,GPIO_Pin_13);
delay_us(50);
GPIO_SetBits(GPIOB,GPIO_Pin_14);
    delay_us(50);
GPIO_ResetBits(GPIOB,GPIO_Pin_13);
delay_us(50);
for(n=0;n<129;n++)
{
GPIO_ResetBits(GPIOB,GPIO_Pin_14);
   delay_us(50);
GPIO_SetBits(GPIOB,GPIO_Pin_14);
        delay_us(50);
}
GPIO_ResetBits(GPIOB,GPIO_Pin_14);
delay_us(50);
GPIO_SetBits(GPIOB,GPIO_Pin_13);
delay_us(50);
GPIO_SetBits(GPIOB,GPIO_Pin_14);
    delay_us(50);
GPIO_ResetBits(GPIOB,GPIO_Pin_13);
delay_us(50);
for(n=0;n<128;n++)
{
ao_d[n]=Get_Adc_Average(ADC_Channel_1,10);
UART0_TX_Oscilloscope(ao_d[n]/10,0);
GPIO_ResetBits(GPIOB,GPIO_Pin_14);
   delay_us(50);
GPIO_SetBits(GPIOB,GPIO_Pin_14);
        delay_us(50);
}
GPIO_ResetBits(GPIOB,GPIO_Pin_14);
delay_us(50);
GPIO_SetBits(GPIOB,GPIO_Pin_14);
max=0;
for(n=0;n<128;n++)
{
if(max<ao_d[n])
   max=ao_d[n];
}
min=max;
for(n=0;n<128;n++)
{
if(min>ao_d[n])    
   min=ao_d[n];
}
mid=(max+min)/2;
for(n=128;n>0;n--)
{
if(ao_d[n-1]<mid)
{
 find=n;
 bla++;
}
}
bla=bla/2;
find=find+bla;
return find;
}
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
46条回答
byond03
1楼-- · 2019-08-19 13:36
回复【43楼】彩笔:
---------------------------------
恩,好的,我知道了。我试试看吧
yutuo
2楼-- · 2019-08-19 16:10
谢谢, 学习
wuguandong
3楼-- · 2019-08-19 17:50
请问有没有miniSTM32用的版本?
wuguandong
4楼-- · 2019-08-19 20:20
彩笔 发表于 2014-7-17 09:32
忘了说了,CCD用的是蓝宙的TSL1401,我那个程序把SI接在PB13,CLK接在PB14,AO输出到PA1,VCC接板子上的3.3 ...

看了下代码,好像SI接在PB12,CLK接在PB10上

一周热门 更多>