之前写过用内部pwm直接产生脉冲:https://blog.csdn.net/zy19981110/article/details/89446812
这次写的是用定时器,不推薦用延时来模拟。此程序结合了我之前发的矩阵按键程序,按键进行亮度调整。
#include"lcd12864.h"
#include<reg51.h>
uchar code num1[]={" 123456789"};
uchar code num2[]={"0123456789"};
uchar code key_code[] //键值表
={0xff,0xee,0xde,0xbe,0x7e, // 无, K1, K2, K3,K4
0xed,0xdd,0xbd,0x7d, // K5, K6, K7,K8
0xeb,0xdb,0xbb,0x7b, // K9, K10, K11,K12
0xe7,0xd7,0xb7,0x77}; // K13, K14, K15,K16
sbit d1=P1^3;
sbit s2=P1^1;
sbit s3=P1^2;
uchar key_s=0, key_v=0;
uint p;
char n=2,dis1;
void Delay10ms() //误差 0us
{
unsigned char a,b,c;
for(c=1;c>0;c--)
for(b=38;b>0;b--)
for(a=130;a>0;a--);
}
void key()
{
if(s2==0)
{
while(!s2);
n++;
if(n==11)
n=10;
dis1=n;
}
if(s3==0)
{
while(!s3);
n--;
if(n==-1)
n=0;
dis1=n;
}
}
void t0init()
{
TMOD=0x01; //模式设置,00000001,可见采用的是定时器0,工作与模式1(M1=0,M0=1)。
TH0=0Xff; //定时器设置,每隔100微秒发起一次中断。
TL0=0xf7;
EA=1; //开总中断
ET0=1; //开定时器0中断
TR0=1; //打开定时器
}
void main()
{
initlcd();
t0init();
while(1)
{
wcode(0x80); //显示n当前值,占空比为n/10。
wdata(num1[n/10]);
wdata(num2[n%10]);
wdata('0');
wdata('%');
key();
}
}
void t0() interrupt 1
{
TH0=0Xff;
TL0=0xf7;
p++;
if(p>=100)
p=0;
if(p<=n*10) //n=3时,3*10占空比为30% 占空比越大 LED灯越暗
d1=1;
else d1=0;
}
定时器配置内容网上教程已经很成熟了,在此不多作说明。12864程序在后面放出。那时候我按键还在用延时,没有定时器扫描,在写32程序时已经改进了这个坏习惯。不过在没有大工程项目情况下,是没多大问题的。