Chào các bạn trong bài đăng này mình sẽ hướng dẫn các bạn tạo 1 số hiệu ứng với led đơn giản sử dụng PIC16F877A và trình biên dịch CCS để viết code.
- Ảnh mô phỏng protues.
- Đây là code chương trình.
#include <16f877a.h>
#include <def_877a.h>
#fuses HS,NOLVP,NOWDT,PUT
#use delay(clock=8000000)
void GPIO_init(void);// goi ham xuat nhap
void main (void)
{
GPIO_init(); //
unsigned char a,I,J,CD,D,Y,X;
while(true)
{
// left
PORTB = 0X01;
for(a=0;a<8;a++)
{
delay_ms(200);
PORTB = PORTB<<1;
}
// right
PORTB = 0X80;
for(a=0;a<8;a++)
{
delay_ms(200);
PORTB = PORTB>>1;
}
// left 2
PORTB = 0X03;
for(a=0;a<4;a++)
{
delay_ms(200);
PORTB = PORTB<<2;
}
// right 2
PORTB = 0XC0;
for(a=0;a<4;a++)
{
delay_ms(200);
PORTB = PORTB>>2;
}
// chase left
delay_ms(200);
PORTB = 0X00;
for(a=0;a<9;a++)
{
delay_ms(200);
PORTB = PORTB<<1;
PORTB = PORTB | 0X01;
}
// chase right
delay_ms(200);
PORTB = 0X00;
for(a=0;a<9;a++)
{
delay_ms(200);
PORTB = PORTB>>1;
PORTB = PORTB | 0X80;
}
// sang dan and tat dan
delay_ms(200);
PORTB = 0X00;
for(a=0;a<9;a++)
{
delay_ms(200);
PORTB = PORTB<<1 | 0x01;
}
for(i=0;i<9;i++)
{
delay_ms(100);
PORTB = PORTB<<1;
}
/////////
X=0X00000000;
for(I=0;I<8;I++)
{
X=(X<<1)+0X01;
PORTB = X;
delay_ms(100);
}
for(I=0;I<8;I++)
{
X=(X>>1);
PORTB = X;
delay_ms(100);
}
///////////////
delay_ms(200);
CD=0X00000000;
for ( J=8;J>0;J--)
{
D=0X00000001;
for(I=0;I<J;I++)
{
Y=CD+D;
PORTB = (Y);
delay_ms(100);
D=(D<<1);
}
CD=Y;
}
//////////
delay_ms(200);
CD=0X00000000;
for ( J=4;J>0;J--)
{
D=0X03;
for(I=0;I<J;I++)
{
Y=CD+D;
PORTB = (Y);
delay_ms(100);
D=(D<<2);
}
CD=Y;
}
}
}
void GPIO_init(void)
{
TRISB = 0X00; // cho porta là output
PORTB = 0X00; //
}
- Link download project.
http://adf.ly/11512871/hieu-ung-led-ccs
- Ảnh mô phỏng protues.
- Đây là code chương trình.
#include <16f877a.h>
#include <def_877a.h>
#fuses HS,NOLVP,NOWDT,PUT
#use delay(clock=8000000)
void GPIO_init(void);// goi ham xuat nhap
void main (void)
{
GPIO_init(); //
unsigned char a,I,J,CD,D,Y,X;
while(true)
{
// left
PORTB = 0X01;
for(a=0;a<8;a++)
{
delay_ms(200);
PORTB = PORTB<<1;
}
// right
PORTB = 0X80;
for(a=0;a<8;a++)
{
delay_ms(200);
PORTB = PORTB>>1;
}
// left 2
PORTB = 0X03;
for(a=0;a<4;a++)
{
delay_ms(200);
PORTB = PORTB<<2;
}
// right 2
PORTB = 0XC0;
for(a=0;a<4;a++)
{
delay_ms(200);
PORTB = PORTB>>2;
}
// chase left
delay_ms(200);
PORTB = 0X00;
for(a=0;a<9;a++)
{
delay_ms(200);
PORTB = PORTB<<1;
PORTB = PORTB | 0X01;
}
// chase right
delay_ms(200);
PORTB = 0X00;
for(a=0;a<9;a++)
{
delay_ms(200);
PORTB = PORTB>>1;
PORTB = PORTB | 0X80;
}
// sang dan and tat dan
delay_ms(200);
PORTB = 0X00;
for(a=0;a<9;a++)
{
delay_ms(200);
PORTB = PORTB<<1 | 0x01;
}
for(i=0;i<9;i++)
{
delay_ms(100);
PORTB = PORTB<<1;
}
/////////
X=0X00000000;
for(I=0;I<8;I++)
{
X=(X<<1)+0X01;
PORTB = X;
delay_ms(100);
}
for(I=0;I<8;I++)
{
X=(X>>1);
PORTB = X;
delay_ms(100);
}
///////////////
delay_ms(200);
CD=0X00000000;
for ( J=8;J>0;J--)
{
D=0X00000001;
for(I=0;I<J;I++)
{
Y=CD+D;
PORTB = (Y);
delay_ms(100);
D=(D<<1);
}
CD=Y;
}
//////////
delay_ms(200);
CD=0X00000000;
for ( J=4;J>0;J--)
{
D=0X03;
for(I=0;I<J;I++)
{
Y=CD+D;
PORTB = (Y);
delay_ms(100);
D=(D<<2);
}
CD=Y;
}
}
}
void GPIO_init(void)
{
TRISB = 0X00; // cho porta là output
PORTB = 0X00; //
}
- Link download project.
http://adf.ly/11512871/hieu-ung-led-ccs
EmoticonEmoticon