|
在昨天我已經(jīng)用寄存器初始化了GPIO,大家只要按照這個(gè)套路來(lái)基本上不會(huì)有問(wèn)題。這里我總結(jié)一下幾點(diǎn)。
1)以LED這個(gè)元件來(lái)看。我們?cè)诰帉戇@個(gè)程序的時(shí)候,GPIO一定是作為輸出模式。在LED.h文件中我們可以宏定義,#define LED_ON GPIOx->ODR |=();
關(guān)閉的時(shí)候定義#define LED_OFF GPIOx->ODR &= ~();LED閃爍的時(shí)候 #define LED_FZ GPIOx->ODR ^= ();這樣我們?cè)诤瘮?shù)調(diào)用這些宏可以一目了然的知道程序的意思。這宏定義在LED,BEEP,DHT11,IIC,SMG等會(huì)經(jīng)常用到。
2)在多個(gè)引腳輸出不同的電平來(lái)控制器件的工作狀態(tài)的時(shí)候。一個(gè)一個(gè)宏定義比較麻煩,比如8個(gè)LED。我們可以這樣做,將不同時(shí)刻的電平狀態(tài)封裝成一個(gè)數(shù)組,比如共陰/陽(yáng)極數(shù)碼管,還有步進(jìn)電機(jī)的電平狀態(tài)。我這用數(shù)碼管為例,unsigned char table[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};這里有0,1,2,.......9,a,b,c,d,e,f.16中狀態(tài)
代碼如下
for(i=0;i<16;i++)
{
GPIOA->ODR &=~(table[ i]<<n);//每次都要清除上一次保留的值,防止下一次往里面寫,造成數(shù)據(jù)錯(cuò)誤
GPIOA->ODR |= (table[ i]<<n);
delayms(120);
}
//3相步進(jìn)電機(jī)為例。
unsigned char FFW[8]={0xf1,0xf3,0xf2,0xf6,0xf4,0xfc,0xf8,0xf9}; //正轉(zhuǎn)
unsigned char FFZ[8]={0xf9,0xf8,0xfc,0xf4,0xf6,0xf2,0xf3,0xf1}; //反轉(zhuǎn)
//這單雙八拍:A-AB-B-BC-C-CD-D-DA,其他的狀態(tài)大家模仿來(lái)做,這就是我上面說(shuō)的把不同電平狀態(tài)封裝成一個(gè)數(shù)組。
PB15 PB14 PB13 PB120 0 0 1 相位值0 0 1 10 0 1 00 1 1 00 1 0 01 1 0 01 0 0 01 0 0 1
/************************************************
函數(shù)功能:控制電機(jī)運(yùn)行的轉(zhuǎn)長(zhǎng),速度,和方向
參數(shù):circle:電機(jī)的圈數(shù),speed:電機(jī)速度,p:電機(jī)方向。
返回值:無(wú)。
*************************************************/
void Moter_Single_Beat(u32 circle,u32 speed,u8 *p)
{
u32 i,j;
for(i=0;i<=circle;i++)
{
for (j=0; j<8; j++)
{
GPIOG->ODR&=~(0xf<<2);
GPIOG->ODR|=((p[j]&0xf)<<2); //我這里取得是低4位,GPIOG2-5
SysTick_Delayms(speed);
}
SysTick_Delayms(speed);
}
}
如果大家對(duì)位操作不了解的話,可以留言我可以講講位操作。對(duì)寄存器操作就是位操作
|
評(píng)分
-
查看全部評(píng)分
|