ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

TX-1C板:A/D转换数码管锁死在255问题的解决和提高数码管数字显示的一些小的改进

2022-02-05 22:58:58  阅读:208  来源: 互联网

标签:wela P0 TX uchar delayms dula 数码管 1C 0xff


书上原题如下

书上代码如下

#include <reg52.h>    		//52系列单片机头文件
#include <intrins.h>
#define uchar unsigned char
#define uint unsigned int 
sbit dula=P2^6;		//申明U1锁存器的锁存端
sbit wela=P2^7;		//申明U2锁存器的锁存端
sbit adwr=P3^6;		//定义AD的WR端口
sbit adrd=P3^7;		//定义AD的RD端口
uchar code table[]={
0x3f,0x06,0x5b,0x4f,
0x66,0x6d,0x7d,0x07,
0x7f,0x6f,0x77,0x7c,
0x39,0x5e,0x79,0x71};
void delayms(uint xms)				
{
	uint i,j;
	for(i=xms;i>0;i--)		      //i=xms即延时约xms毫秒
		for(j=110;j>0;j--);
}

void display(uchar bai,uchar shi,uchar ge)  //显示子函数
{
    dula=1;
	P0=table[bai];    //送段选数据
	dula=0;
	P0=0xff;		//送位选数据前关闭所有显示,防止打开位选锁存时
	wela=1;			//原来段选数据通过位选锁存器造成混乱
	P0=0x7e;		//送位选数据
	wela=0;
	delayms(5);	    //延时

	dula=1;
	P0=table[shi];
	dula=0;
	P0=0xff;
	wela=1;
	P0=0x7d;
	wela=0;
	delayms(5);

	dula=1;
	P0=table[ge];
	dula=0;
	P0=0xff;
	wela=1;
	P0=0x7b;
	wela=0;
	delayms(5);
}


void main()		//	主程序
{

 	uchar a,A1,A2,A3,adval;
	wela=1;
	P0=0x7f;           //置CSAD为0,选通ADCS 以后不必再管ADCS
	wela=0;
    while(1)
	{
		adwr=1;
		_nop_();
		adwr=0;			//启动AD转换
		_nop_();
		adwr=1;
		for(a=10;a>0;a--)        //TX-1C实验板AD工作频率较低,所以启动转换后要多留点时间用来转换
		{                        //这里把显示部分放这里的原因也是为了延长转换时间                                                                                                                                                                                                                           
			display(A1,A2,A3);
		}
		P1=0xff;                    //读取P1口之前先给其写全1 
		adrd=1;                    //选通ADCS
		_nop_();	
		adrd=0;                     //AD读使能
		_nop_();
		adval=P1;			//AD数据读取赋给P1口
		adrd=1;
		A1=adval/100;		//分出百,十,和个位
		A2=adval%100/10;
		A3=adval%10;
	 }
}

但是代码运行结果如下图所示:数码管显示锁死在255,按照书上110页的方法也未能改变,按下Reset时数码管数字短暂地显示000后立刻回到255。但是拧动A/D旁边电位器Re2时发光二极管阵列处有显示变化。

 自己尝试着改进和简化了一下,效果比较理想也符合题目要求。有些问题还没有太想明白,欢迎大家的讨论和指正!

改进如下:

#include<reg52.h>
#include<intrins.h>
#define uchar unsigned char
#define uint unsigned int

sbit dula=P2^6;//声明锁存器U1的锁存端
sbit wela=P2^7;//声明锁存器U2的锁存端
sbit adwr=P3^6;//定义A/D的WR端口
sbit adrd=P3^7;//定义A/D的RD端口

uchar code table[]=
{
	0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,
	0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71
};

void delayms(uint xms)
{
	uint i,j;
	for(i=xms;i>0;i--)
		for(j=55;j>0;j--); //改进延时为0.5x毫秒
}

void display(uchar bai,uchar shi,uchar ge)
{
	dula=1;
	P0=table[bai];
	dula=0;
	P0=0xff;
	wela=1;
	P0=0x7e;
	wela=0;
	P0=0xff;
	delayms(5);

	dula=1;
	P0=table[shi];
	dula=0;
	P0=0xff;
	wela=1;
	P0=0x7d;
	wela=0;
	P0=0xff;
	delayms(5);

	dula=1;
	P0=table[ge];
	dula=0;
	P0=0xff;
	wela=1;
	P0=0x7b;
	wela=0;
	P0=0xff;
	delayms(5);
}

void main()
{
	uchar A1,A2,A3,adval1,adval2,adval3;//a
	wela=1;
	P0=0x7f;//置CSAD为0,选通ADCS以后不必再管ADCS
	wela=0;
	delayms(50);
	while(1)
	{
		adwr=1;
		_nop_();
		adwr=0;//启动A/D转换
		_nop_();
		adwr=1;
		adrd=1;//选通ADCS
		_nop_();
		adrd=0;//A/D读使能
		_nop_();
		adval1=P1; //A/D数据读取赋予P1口
		delayms(2);
		adval2=P1;
		delayms(2);
		adval3=P1;
		adrd=1;
		if((adval1==adval2)&&(adval2==adval3))
		{
			A1=adval1/100;//百位
			A2=adval1%100/10;//十位
			A3=adval1%10;//个位 
			display(A1,A2,A3);		
		}		
	}
}

标签:wela,P0,TX,uchar,delayms,dula,数码管,1C,0xff
来源: https://blog.csdn.net/qq_46369644/article/details/122794271

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有