Chào các bạn trong bài đăng trước mình đã hướng dẫn các bạn giao tiếp với LED 7 SEG cụ thể là đếm từ 0 đến 99 còn trong bài đăng này mình sẽ hướng dẫn các bạn đếm từ 0 – 9999 sử dụng PIC16F877A và trình biên dịch MPLAB XC8 để viết code.
Đếm từ 0 - 99 thì chỉ có 1 LED còn đếm từ 0 - 9999 thì có 4 LED nên trong cùng 1 thời điểm PORTX của con PIC không thể xuất dữ liệu ra 4 LED được nên buộc chúng ta phải sử dụng 4 chân của LED để bật, tắt phù hợp để dữ liệu có thể xuất ra 4 LED của chúng ta.
Và giải thuật được viết như sau :
output_c(maled[nghin]);
ra0=0;
delay_ms(10);
ra0=1;
output_c(maled[tram]);
ra1=0;
delay_ms(10);
ra1=1;
output_c(maled[chuc]);
ra2=0;
delay_ms(10);
ra2=1;
output_c(maled[donvi]);
ra3=0;
delay_ms(10);
ra3=1;
ra0=0;
delay_ms(10);
ra0=1;
output_c(maled[tram]);
ra1=0;
delay_ms(10);
ra1=1;
output_c(maled[chuc]);
ra2=0;
delay_ms(10);
ra2=1;
output_c(maled[donvi]);
ra3=0;
delay_ms(10);
ra3=1;
Và khi đếm chúng ta phải xác định LED nào là LED hàng nghin,tram,chuc,donvi và chúng ta có công thức tính như sau :
Hai phần mình nói ở trên cũng chính là 2 phần quan trọng để các bạn làm được bài này và các bạn có thể phát triển PROJECT của mình lên từ 2 LED có thể lên 6 hoặc 8 LED.
nghin = dem/1000;
tram = (dem - nghin*1000)/100;
chuc = (dem - nghin*1000 - tram*100)/10;
donvi = dem - nghin*1000 - tram*100 - chuc*10;
tram = (dem - nghin*1000)/100;
chuc = (dem - nghin*1000 - tram*100)/10;
donvi = dem - nghin*1000 - tram*100 - chuc*10;
- Đây là code chương trình.
#include <16f877a.h>
#fuses NOLVP,NOWDT,PUT,XT
#use delay(clock=8000000)
#byte porta=0x05
#bit ra0=0x05.0
#bit ra1=0x05.1
#bit ra2=0x05.2
#bit ra3=0x05.3
const unsigned char maled[10]={0xC0, 0xF9, 0xA4, 0xB0, 0x99, 0x92, 0x82,0xF8, 0x80, 0x90};
int16 dem,chuc,donvi,nghin,tram;
void main (void)
{
set_tris_c(0x00);
set_tris_a(0x00);
output_c(0);
while(true)
{
nghin=dem/1000;
tram = (dem - nghin*1000)/100;
chuc=(dem - nghin*1000 - tram*100)/10;
donvi=dem - nghin*1000 - tram*100 - chuc*10;
//----phan tach so----\\
output_c(maled[nghin]);
ra0=0;
delay_ms(10);
ra0=1;
//-----------hien thi so hang nghin------\\
output_c(maled[tram]);
ra1=0;
delay_ms(10);
ra1=1;
//---------hien thi so hang tram---------\\
output_c(maled[chuc]);
ra2=0;
delay_ms(10);
ra2=1;
//---------hien thi so hang chuc---------\\
output_c(maled[donvi]);
ra3=0;
delay_ms(10);
ra3=1;
//---------hien thi so hang donvi---------\\
dem++;
if(dem==1500)
{
dem=0;
}
}
}
- Link download project Click here#fuses NOLVP,NOWDT,PUT,XT
#use delay(clock=8000000)
#byte porta=0x05
#bit ra0=0x05.0
#bit ra1=0x05.1
#bit ra2=0x05.2
#bit ra3=0x05.3
const unsigned char maled[10]={0xC0, 0xF9, 0xA4, 0xB0, 0x99, 0x92, 0x82,0xF8, 0x80, 0x90};
int16 dem,chuc,donvi,nghin,tram;
void main (void)
{
set_tris_c(0x00);
set_tris_a(0x00);
output_c(0);
while(true)
{
nghin=dem/1000;
tram = (dem - nghin*1000)/100;
chuc=(dem - nghin*1000 - tram*100)/10;
donvi=dem - nghin*1000 - tram*100 - chuc*10;
//----phan tach so----\\
output_c(maled[nghin]);
ra0=0;
delay_ms(10);
ra0=1;
//-----------hien thi so hang nghin------\\
output_c(maled[tram]);
ra1=0;
delay_ms(10);
ra1=1;
//---------hien thi so hang tram---------\\
output_c(maled[chuc]);
ra2=0;
delay_ms(10);
ra2=1;
//---------hien thi so hang chuc---------\\
output_c(maled[donvi]);
ra3=0;
delay_ms(10);
ra3=1;
//---------hien thi so hang donvi---------\\
dem++;
if(dem==1500)
{
dem=0;
}
}
}
EmoticonEmoticon