- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
基于单片机的出租车计费(c语言)
基于单片机的出租车计费(c语言)
基于proteus仿真
一.设计要求:
1.用实现出租车计费器的设计。
出租车起步开始计程和计费,计程系统按实际公里数计程,计费系统首先显示起步价(如.0),车行驶2km以内,只收起步价元。
出租车行驶超过km后,按每公里1.元在.0元的基础上增加。
出租车达到目的地后,(用一个按钮)计程和计费数据清零,为下一次计费开始。
出租车行驶仿真:把信号发生器的输出接到单片机外部中断上,设置信号发生器不同的频率输出,分别表示速度的快慢。
每一个脉冲表示轮胎转一圈,目前出租车轮胎周长为1.83米。
(时、分、秒)
9.出租车行驶超过10km后(或超过20元路费),每公里加收50%的车费,即车费变为每公里2.元。
行驶速度计算
参数设置:可以修改轮胎周长,修改起步价,修改每公里单价等。
三.设计程序
#includereg51.h
unsignedchar d[]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0xbf};//段选
unsigned char f=0x00,y=0x00,k=0x00,m=0x00,z=0x00,q=0x00,w=0x00,s=0x00;//定义变量注意其范围(不然容易出现乱码)
unsigned int x=0;
#define uint unsigned int
#define uchar unsigned char
void delay(unsigned int i)//延时1ms
{
unsigned char j;
while(i--)
{
for(j=0;j125;j++)
{;}
}
}
void div2()//显示
{ P2=0x80;
P1=d[s/10];//计时小时
P0=d[y/100];//计费百位
delay(5);
P2=0x40;
P1=d[s%10];//小时个位
P0=d[y%100/10];//计费十位
delay(5);
P2=0x20;
P1=d[10];//显示“-”
P0=d[y%10]0x7f;//计费个位
delay(5);
P2=0x10;
P1=d[f/10];//分钟
P0=d[x*2/10000];//路程万位
delay(5);
P2=0x08;
P1=d[f%10];
P0=d[x*2%10000/1000];//路程千位
delay(5);
P2=0x04;
P1=d[10];
P0=d[x*2%1000/100];
delay(5);
P2=0x02;
P1=d[w/10];//秒
P0=d[x*2%100/10];
delay(5);
P2=0x01;
P1=d[w%10];
P0=d[x*2%10];
delay(5);
}
void tt()//总费用函数
{
if(x*22000)
{y=5;}
else if(x*22000)
{
y=5+(x*2-2000)/1000*2;
}
else if(x*210000)
{
y=21+(x*2-10000)/1000*3;
}
}
void main()//开3个中断端
{
EX0=1;//开启外部中断源
IT0=1;
EX1=1;
IT1=1;
TH0=(65535-50000)/256;
TL0=(65535-50000)%256;
TMOD=0X01;ET0=1;TR0=1;//开启定时中断
EA=1;//开中断源
while(1)
{
div2();tt();
}
}
void int1(void) interrupt 0 //信号中断服务程序
{
x++;
}
void int2() interrupt 2 //清零中断
{
w=0;
f=0;
s=0;
x=0;
y=0;
EX0=0;
ET0=0;
}
void int0() interrupt 1//计时中断服务程序
{ ET0=0;
TR0=0;
TH0=(65536-50000)/256;
TL0=(65536-50000)%256;
TR0=1;
q++;
if(q==20)//计数20恰好为1秒
{
q=0;w++;
if(w==60)//秒到60
{
w=0;f
您可能关注的文档
最近下载
- 专题07 作文(2023-2025年期中典型试题)(解析版)(2023-2025年期中典型试题,上海专用)八年级语文上册新教材.docx VIP
- 2025年MK 袋鼠数学竞赛Level-B (3-4年级) 真题+解析.pdf
- 初中语文诗词易错字34篇.pdf VIP
- 电子商务物流第二版毕娅习题答案.doc VIP
- 学堂在线 大国航母与舰载机(2025秋) 作业答案.docx VIP
- 《生涯发展报告》.pdf.pptx VIP
- LTCC多层电路基板设计规范-2016简版-1.pdf VIP
- 四年级语文上册第八单元作业设计.pdf VIP
- 学堂课程在线人工智能原理(北大)章节测试答案.docx
- 学前教育学专业职业生涯规划书发展报告应届硕士毕业生全国大学生职业规划大赛模板范文1500字.pdf VIP
原创力文档


文档评论(0)