用STC ISP下載程序到單片機時,先點擊"Download/下載"按鈕,然后單片機電源慢慢開到on,如果開太快,可能下載不進去。
把單片機正放身前,左下是USB轉串口,右上是數碼管,LED。
看板子個的LED,從右到左分別是LED2-LED9, 然后看51開發板原理圖,LED2-LED9分別通到DB0-DB7。再查DB0-DB7對應的IO口,分別是P0.0到 P0.7. 要點亮LED2,也就是右邊第一個LED,一般情況代碼如下:
#include <reg52.h>
sbit LED0 = P0^0;
void turnLED()
{
while(1)
{
LED0 = 0;
}
}
int main(void)
{
turnLED();
return 0;
}
但是此開發板因為IO緊張,用74HC138進行了端口復用。必須先設置74HC138,切換到LED2-LED9才能點亮所需LED。
再次查看原理圖,8個LED的共陽極和PNP三極管的集電極連接,三極管的基極接到LEDS6,只有LEDS6是低電平時,三極管電路才會導通。查看74HC138的電路,LEDS6對應于74HC138的Y6.
查看74HC138的手冊,要Y0-Y7要輸出低電平,必須G1=H, G2=L, 要Y6輸出低電平,必須C=H, B=H,A=L. 發現此表很有規律,CBA組成三位二進制數,C高位,H表示1. HHL也就是二進制的6, 所以Y6輸出低電平。
接下來要找到51單片機開發板上,74HC138和開發板上的IO的對應關系。還是查開發板原理圖。
G1=ADDR3=P1.3
G2=ENLED=P1.4
C=ADDR2=P1.2
B=ADDR1=P1.1
A=ADDR0=P1.0
于是我們可以寫出下面函數讓LEDS6輸出低電平(如果你的板子沒有用到138譯碼器,下面代碼可以略過):
sbit enableG1 = P1^3;
sbit enableG2 = P1^4;
sbit selectC = P1^2;
sbit selectB = P1^1;
sbit selectA = P1^0;
void hc138()
{
enableG1 = 1;
enableG2 = 0;
selectC = 1;
selectB = 1;
selectA = 0;
}
現在,點亮LED2的完整代碼如下:
#include <reg52.h>
sbit enableG1 = P1^3;
sbit enableG2 = P1^4;
sbit selectC = P1^2;
sbit selectB = P1^1;
sbit selectA = P1^0;
//74HC138譯碼器
void hc138()
{
enableG1 = 1;
enableG2 = 0;
selectC = 1;
selectB = 1;
selectA = 0;
}
//點亮LED
void turnLED()
{
while(1)
{
P0 = 254;
}
}
int main(void)
{
hc138();
turnLED();
return 0;
}
注意,點亮LED2的代碼我們寫成了P0=254, 這是一次設置1 byte的方法。1 byte最大的數字是255,第1位變成0,就是254了。用16進制賦值更簡單: P0 = 0xFE
下面變換些花樣,我只給出turnLED函數,其他代碼同前:
typedef unsigned char uint8;
typedef unsigned int uint16;
//6種單片機LED流水燈跑馬燈示例代碼
void turnLED()
{
uint8 i = 0;
uint16 j = 0;
while(1)
{
//P0 = 1 << i++; //一熄滅燈從右到左
//P0 = ~(1 << i++); //一燈從右到左
//P0 = ~(0x80 >> i++); //一燈從左到右
//P0 = ~(0xC0 >> i++); //二燈從左到右
//左右來回振蕩
/*
P0 = ~(0x80 >> i++); //一燈從左到右
for(j = 0; j < 33000; j++); //延時不要太短,以看得更清楚
if( i == 8 )
{
i -= 2;
while(i > 0)
{
P0 = ~(0x80 >> i--);
for(j = 0; j < 33000; j++); //延時不要太短,以看得更清楚
}
}
*/
P0 = ~(0x80 >> i++); //一燈從左到右
for(j = 0; j < 33000; j++); //延時不要太短,以看得更清楚
i %= 8;
}
}
|