AVR單片機595驅動8位數碼管的顯示的電路實現
主程序代碼
#include
#include //GCC中的延時函數頭文件
#include “hc595.h”
//unsigned char Led_Disbuf[10]={0x3F,0x06,0x5B,0x4F,0x66,0x6D,0x7D,0x07,0x7F,0x6F}; //共陰極
unsigned char Led_Disbuf[10]={0xC0,0xF9,0xA4,0xB0,0x99,0x92,0x82,0xF8,0x80,0x90}; //共陽極
unsigned char ComBuf[8] = {0x01,0x02,0x04,0x08,0x10,0x20,0x40,0x80};
//函數聲明
extern void Delayus(unsigned int lus); //us延時函數
extern void Delayms(unsigned int lms); //ms延時函數
int main(void) //GCC中main文件必須為返回整形值的函數,沒有參數
{
unsigned char i;
PORTB = 0xff; //PORTB輸出低電平,使LED熄滅
HC595_port_init();
while(1)
{
for(i = 0; i < 8;i++)
{
PORTB = Led_Disbuf; //送段碼
HC595_Send_Data(ComBuf); //選通位選端口
Delayus(70); //延時
HC595_Send_Data(0x00); //位選通關閉
}
}
}
//us級別的延時函數
void Delayus(unsigned int lus)
{
while(lus--)
{
_delay_loop_2(4); //_delay_loop_2(1)是延時4個時鐘周期,參數為4則延時16
//個時鐘周期,本實驗用16M晶體,則16個時鐘周期為16/16=1us
}
}
//ms級別的延時函數
void Delayms(unsigned int lms)
{
while(lms--)
{
Delayus(1000); //延時1ms
}
}
模塊化程序設計的.h文件
下面是本實例中模塊化程序設計的.h文件
/*****************************
74hc595.h
***********************************/
/*74hc595與單片機的引腳連接
/MR(10腳) VCC 低點平時將移位寄存器的數據清零。通常將它接Vcc
/OE(13腳) PG4 高電平時禁止輸出(高阻態)。
如果單片機的引腳不緊張,用一個引腳控制它,
可以方便地產生閃爍和熄滅效果。比通過數據端移位控制要省時省力。
ST_CP(12腳) PG1 上升沿時移位寄存器的數據進入數據存儲寄存器,
下降沿時存儲寄存器數據不變。通常將RCK置為低電平,
當移位結束后,在RCK端產生一個正脈沖(5V時,大于幾十納秒就行了。
通常都選微秒級),更新顯示數據。
SH_CP(11腳) PG0 上升沿時數據寄存器的數據移位。QA-->QB-->QC-->。。。-->QH;
下降沿移位寄存器數據不變。(脈沖寬度:5V時,大于幾十納秒就行了。
通常都選微秒級)
DS(14) PG2 串行數據輸入端。
*/
#ifndef __HC595_H__
#define __HC595_H__
#include //io端口寄存器配置文件,必須包含
#include //GCC中的延時函數頭文件
#define HC595_latch (1 << PG1) //上升沿數據打入8位鎖存器,下降沿鎖存器數據不變
#define HC595_sclk (1 << PG0) //上升沿數據移位,下降沿數據不變
#define HC595_oe (1 << PG4) //低電平,8位數據鎖存器輸出,高電平輸出高組態
#define HC595_data (1 << PG2) //串行數據輸入端
#define SET_HC595_latch (PORTG |= (1 << PG1))
#define CLR_HC595_latch (PORTG &= ~(1 << PG1))
#define SET_HC595_sclk (PORTG |= (1 << PG0))
#define CLR_HC595_sclk (PORTG &= ~(1 << PG0))
#define SET_HC595_data (PORTG |= (1 << PG2))
#define CLR_HC595_data (PORTG &= ~(1 << PG2))
#define SET_HC595_oe (PORTG |= (1 << PG4))
#define CLR_HC595_oe (PORTG &= ~(1 << PG4))
void HC595_port_init(void); //595端口初始化
void HC595_Send_Data(unsigned char byte); //發送一個字節
void HC595_Output_Data(unsigned char data); //發送字符串
#endif
同時我們將與74HC595相關的函數定義部分放在74HC595.c文件中,如下
/********************************
74hc595.c
**************************************/
#include “hc595.h”
//595端口初始化
void HC595_port_init(void)
{
PORTG = 0x00;
DDRG |= (1 << PG0) | (1 << PG1) | (1 << PG2) | (1 << PG4);
}
//發送一個字節
void HC595_Send_Data(unsigned char byte)
{
unsigned char i;
//CLR_HC595_latch;
for(i = 0;i < 8;i++)
{
if(byte & 0x80)
{
SET_HC595_data;
}
else
{
CLR_HC595_data;
}
byte <<=1;
SET_HC595_sclk; //上升沿數據移位
CLR_HC595_sclk;
}
SET_HC595_latch;
CLR_HC595_latch;
}
//發送字符串
void HC595_Output_Data(unsigned char data)
{
CLR_HC595_latch; //下降沿鎖存器數據不變
HC595_Send_Data(data);
SET_HC595_latch; //上升沿數據打入8位鎖存器
}
評論