- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
微机原理 频率计 程序
源程序(加注释)
#include reg51.h
#define LEDLen 6
#define Tick 10000 // 定时时间为10000*100us = 1s
#define T100us (256-50) // 100us时间常数(6M)
xdata unsigned char OUTBIT _at_ 0x8002; // 位控制口
xdata unsigned char OUTSEG _at_ 0x8004; // 段控制口
xdata unsigned char IN _at_ 0x8001; // 键盘读入口
unsigned int C100us; // 100us记数单元
unsigned int n=0;
unsigned long cou;
unsigned char LEDBuf[LEDLen]; // 显示缓冲
code unsigned char LEDMAP[] = { // 八段管显示码
0x3f, 0x06, 0x5b, 0x4f, 0x66, 0x6d, 0x7d, 0x07,0x7f,0x6f, 0x77, 0x7c, 0x39, 0x5e, 0x79, 0x71
};
void Delay(unsigned char CNT) //显示下一位延时
{
unsigned char i;
while(CNT--!=0)
for(i=100;i!=0;i--);
}
void DisplayLED()
{
unsigned char i;
unsigned char Pos;
Pos = 0x20; // 从左边开始显示
for(i=0;iLEDLen;i++)
{
OUTBIT=0; // 关所有八段管
OUTSEG = LEDBuf[i];
OUTBIT = Pos; // 显示一位八段管
Delay(1); //延时
Pos = 1; // 显示下一位
}
OUTBIT=0; // 关所有八段管
}
void T0Int() interrupt 1 using 1//用定时器0的中断,此中断编号为1
{
C100us--;
if(C100us==0)
{
TR0=0;
cou= n*65536+TL1+TH1*256;
C100us = Tick; //100us计数器为1,重置计数器
TR0=1;
TL1=0;
TH1=0;
n=0;
}
}
void T1Int() interrupt 3 using 1
{
n=n+1;
}
void main()
{
unsigned int a;
unsigned int b;
unsigned int c;
unsigned int d;
unsigned int e;
unsigned int f;
unsigned char j;
TMOD = 0x52; //启动方式1计数器1 ,方式2定时器0
TH0 = T100us; //高8位定时赋初值
TL0 = T100us;
TH1 = 0; //计数器高8位赋初值
TL1 = 0;
IE = 0x8A; //打开定时器0中断,开总中断(EA=1,IT0=1)
C100us = Tick; //100us计数器为1,重置计数器
TR0 = 1; //定时器0开始工作
TR1 = 1; // 计数器1开始工作
while(1)
{
a=cou/100000;
b=cou%100000/10000;
c=cou%10000/1000;
d=cou%1000/100;
e=cou%100/10;
f=cou%10;
LEDBuf[0] = LEDMAP[a 0x0f];
LEDBuf[1] = LEDMAP[b 0x0f];
LEDBuf[2] = LEDMAP[c 0x0f];
LEDBuf[3] = LEDMAP[d 0x0f];
LEDBuf[4] = LEDMAP[e 0x0f];
LEDBuf[5] = LEDMAP[f 0x0f];
for(j=0;j50;j++) //数码管数值显示循环程序
DisplayLED();
您可能关注的文档
最近下载
- 建设单位质量管理制度.docx
- _【石油修井】特殊井大修工艺技术.pdf VIP
- 《0~3岁婴幼儿教育活动设计与指导》项目四 婴幼儿认知发展教育活动设计与指导.pptx VIP
- 第四章 石油修井 修井工具讲义.pdf VIP
- 2024年《义务教育课程标准(2022年版)课例式解读》初中英语读后感.docx VIP
- 银行半结构化面试必问题目及参考回答.docx VIP
- GB_T 33700-2017地基导航卫星遥感水汽观测规范.docx VIP
- GB_T 42988-2023 多源遥感影像网络协同解译.pdf VIP
- DB42T 2425-2025 自然资源光学遥感卫星影像应用分类分级规范.pdf VIP
- 油水井井筒大修作业资料讲解.ppt VIP
原创力文档


文档评论(0)