基于STC12C5A60S2系列1T 8051单片机八位ADC转换器应用

本文详细介绍了STC12C5A60S2系列1T 8051单片机的A/D转换器,包括其管脚图、I/O口工作模式、转换器结构和特殊功能寄存器的使用,特别是AUXR、AUXR1、P1ASF和ADC_CONTR等寄存器的配置。同时,讨论了如何将电压模拟量转换为数字量,并提供了中断方式实现转换的实例。
摘要由CSDN通过智能技术生成

STC12C5A60S2系列1T 8051单片机管脚图

在这里插入图片描述在这里插入图片描述

STC12C5A60S2系列1T 8051单片机I/O口各种不同工作模式及配置

在这里插入图片描述

STC12C5A60S2系列1T 8051单片机I/O口各种不同工作模式介绍

在这里插入图片描述在这里插入图片描述

STC12C5A60S2系列1T 8051单片机A/D转换器介绍

在这里插入图片描述在这里插入图片描述在这里插入图片描述

STC12C5A60S2系列1T 8051单片机A/D转换器的结构

在这里插入图片描述在这里插入图片描述在这里插入图片描述

基于STC12C5A60S2系列1T 8051单片机A/D转换器的特殊功能寄存器列表

在这里插入图片描述

基于STC12C5A60S2系列1T 8051单片机A/D转换器用到的特殊功能寄存器

STC12C5A60S2系列1T 8051单片机辅助寄存器AUXR

在这里插入图片描述

STC12C5A60S2系列1T 8051单片机辅助寄存器AUXR1

在这里插入图片描述

A/D转换器P1口模拟功能控制寄存器P1ASF

在这里插入图片描述作用:用来设置STC12C5A60S2系列1T 8051单片机A/D转换器模拟输入通道

A/D转换器控制寄存器ADC_CONTR

在这里插入图片描述在这里插入图片描述在这里插入图片描述
作用:用来设置STC12C5A60S2系列1T 8051单片机A/D转换器以下功能
(1)、设置A/D转换器电源
(2)、设置A/D转换器转换速度
(3)、设置A/D转换器转换结束标志位
(4)、设置A/D转换器转换启动
(5)、设置A/D转换器模拟输入通道

A/D转换器控制寄存器ADC_RES ADC_RESL

在这里插入图片描述在这里插入图片描述在这里插入图片描述
作用:用来设置STC12C5A60S2系列1T 8051单片机A/D转换器保存转换的结果

A/D转换器中断寄存器

在这里插入图片描述在这里插入图片描述
作用:用来设置STC12C5A60S2系列1T 8051单片机A/D转换器中断

基于STC12C5A60S2系列1T 8051单片机八位ADC转换器转换电压模拟量为模拟量数字量

在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述
main.c

#include "STC12C5A60S2.h"
#include "Timer0.h"
//#include "Timer1.h"
//#include "Key.h"
#include "Digitron.h"
//#include "ADC0832.h"
#include "STC12ADC.h"
#include "STC12ADCAnalogFliterMiddle.h"
#define uchar unsigned char//自定义无符号字符型为uchar
#define uint unsigned int//自定义无符号整数型为uint
//#define SinglechipVoltage 5.000//自定义单片机电压为5V
uchar STC12ADCAnalogDataResult = 0;//定义STC12ADC转换器模拟量数字结果变量为0 即模拟量转十进制数变量
//float InputVoltage = 0.000;//声明外部输入电压变量
//uchar AnalogSamplingCount = 0;//定义模拟采样计数变量为0
//uint OutPutVoltage = 0;//定义输出电压变量为0
//uint AnalogFilterVoltage = 0;//定义模拟滤波电压变量为0
//uint AnalogFilterOutPutVoltage = 0;//定义模拟滤波后输出电压变量为0

  void main(void)//主函数
{
   
   Timer0Init();//定时器0初始化函数
   STC12ADCInit();//STC12ADC转换器初始化函数
//   Timer1Init();//定时器1初始化函数  
//	 ADC0832Init();//ADC0832初始化函数
   DigitronBootDisplay();//数码管开机显示函数
   while(1)//主循环
 {
   	
//	  AnalogDataResult = ADC0832Change();//ADC0832转化函数转化的模拟量十进制数赋给模拟量数字结果变量 即模拟量转十进制数变量
//    OutPutVoltage = (AnalogDataResult * 1.0 * 5 / 255) * 1000;//输出电压计算公式 5是基准电压5V 255是模数芯片ADC0832内部八位模拟转换寄存器储存的最大数值 为啥乘以1000? 由于输出电压是用四位数码管来显示 需要乘以1000来把输出电压变成四位数在四位数码管上分解显示出来
//    DigitronDisplayDataSplit();//数码管显示数据分解函数
   STC12ADCAnalogDataResult = STC12ADCAnalogFliterMiddle();//STC12ADC转换器模拟量中位值滤波算法函数(采样101次 冒泡排序 取中间值 采样次数Sample可以按照需求改动 Sample值需为奇数)返回值赋给STC12ADC转换器模拟量数字结果变量
//	STC12ADCAnalogDataResult = STC12ADCAnalogChangeResult(0);//STC12ADC转换器通道0模拟量转化结果赋给STC12ADC转换器模拟量数字结果变量
//    InputVoltage = SinglechipVoltage * STC12ADCAnalogDataResult / 255;//计算输入电压公式:输入电压 / 基准电压 = STC12ADC转换器模拟量转化结果(即模拟量转十进制数变量)/ 255份
//    DigitronDisplayData();//数码管显示数据函数
//    KeyScan();//按键扫描函数 该函数放在定时器定时2ms的中断函数中扫描
//	  KeyScanResult();//按键扫描结果函数
//    AnalogFilterVoltage = AnalogFilterVoltage + OutPutVoltage;//模拟滤波电压变量
//    AnalogSamplingCount++;//模拟采样计数变量自加1
//    if(AnalogSamplingCount >= 8)//模拟采样计数变量计8次
//  {
   
//     AnalogFilterOutPutVoltage = AnalogFilterVoltage >> 3;//模拟滤波电压变量右移三位 表示模拟滤波电压变量除以8取平均滤波后的输出电压
//     AnalogSamplingCount = 0;//模拟采样计数变量清0
//     AnalogFilterVoltage = 0;//模拟滤波电压变量清0  
//    }
   }
  }

STC12ADCAnalogFliterMiddle.c

#include "STC12ADCAnalogFliterMiddle.h"
//#include "ADC0832.h"
#include "STC12ADC.h"
#define uchar unsigned char//自定义无符号字符型为uchar
#define uint unsigned int//自定义无符号整数型为uint
#define Sample 101//采样次数	
 void delayms(uint ms)//
{
   
  uint msi,msj;//
  for(msi = 0;msi < ms;msi++)//
   for(msj = 0;msj < 120;msj++);//
 }
// uchar FliterRange()//模拟量限幅滤波算法
//{
   
//	uchar NewValue;
//	NewValue = ADC0832Change();//ADC0832转化函数 还没转化成数字量
//	if((NewValue - Value > 10) || (Value - NewValue > 10)) 
//  return Value;
//	return NewValue;
// }
 uchar STC12ADCAnalogFliterMiddle()//STC12ADC转换器模拟量中位值滤波算法函数(采样101次 冒泡排序 取中间值 采样次数Sample可以按照需求改动 Sample值需为奇数)
{
   
  uchar ValueBuf[Sample];//
  uchar Count,i,j,Temp;//
  for(Count = 0;Count < Sample;Count++)//连续采样101次
 {
   
   ValueBuf[Count] = STC12ADCAnalogChangeResult(0);//STC12ADC转换器模拟量转化结果函数
   delayms(20);//
  }
  for(j = 0;j < Sample-1;j++)//冒泡法排序
 {
   
   for(i = 0;i < Sample-1-j;i++)//
  {
   
	if(ValueBuf[i] > ValueBuf[i+1])//
   {
   
	 Temp = ValueBuf[i];//
	 ValueBuf[i] = ValueBuf[i+1];//
	 ValueBuf[i+1] = Temp;//
	}
   }
  }
  return ValueBuf[(Sample - 1) / 2];//返回中间值
 }

STC12ADCAnalogFliterMiddle.h

#ifndef __STC12ADCANALOGFILTERMIDDLE_H__
#define __STC12ADCANALOGFILTERMIDDLE_H__
#include "STC12C5A60S2.h" 
#define uchar unsigned char//自定义无符号字符型为uchar
#define uint unsigned int//自定义无符号整数型为uint
//unsigned char  Fliter_range();//模拟量限幅滤波算法
uchar STC12ADCAnalogFliterMiddle();//STC12ADC转换器模拟量中位值滤波算法函数(采样101次 冒泡排序 取中间值 采样次数Sample可以按照需求改动 Sample值需为奇数)
#endif

STC12ADC.c

#include "STC12ADC.h"
//#include "ADC0832Filter.h"
//#include "ADC0832.h"
//#include "Timer0.h"
//#include "math.h"
#include "intrins.h"
#define uchar unsigned char//自定义无符号字符型为uchar
#define uint unsigned int//自定义无符号整数型为uin
//uchar STC12ADCAnalogTransformResult = 0;//声明STC12ADC转换器模拟量转换结果变量
//uchar STC12ADCLowBitResult = 0;//声明STC12ADC转换器低位转换结果变量
//uchar STC12ADCChangeOverFlag = 0;//定义STC12ADC转换器转换结束标志位清0 
//float Rt = 0,NTCTemperature = 0,NTCOutPutVoltage = 0;//定义NTC当前阻值变量、NTC当前温度变量、NTC当前电压变量
//float Rp = 10000;//定义NTC在25℃的阻值 这里是10K
//float Bx = 3435;//定义NTC的B值
//float T3 = 273.15;//定义开尔文温度 等于273.15+NTC当前摄氏度T
//float T4 = 273.15+25;//定义开尔文温度 等于273.15+摄氏度25
// float GetNTCTemperature()//获取NTC温度函数
//{
   
//	if(Timer0CountTimeFlag == 1)//计时1秒时间到 定时器0计时标志位变量置1
// {
   
//	 Timer0CountTimeFlag = 0;//定时器0计时标志位变量清0
//	 AnalogDataResult = ADC0832Change();//ADC0832转化函数转化的模拟量十进制数赋给模拟量数字结果变量 即模拟量转十进制数变量
	AnalogDataResult = FliterMiddle();//模拟量数值取中间值滤波采样
//	 NTCOutPutVoltage = (float)(AnalogDataResult) * (5.0 / 255.0);//模拟量转化成数字量 即电压模拟量转化成电压数字量 NTCOutPutVoltage = (float)(AnalogDataResult) * (5.0 / 255.0)是咋么算的?根据电压数字量 / 模拟量数值 = 5V电压 / 5V电压分成255份来算的 即NTCOutPutVoltage / AnalogDataResult = 5.0 / 255 转化后可得NTCOutPutVoltage = (float)(AnalogDataResult) * (5.0 / 255.0)
//	 Rt = NTCOutPutVoltage * 1000 / (5.0 -  NTCOutPutVoltage);//Rt = NTCOutPutVoltage * 1000 / (5.0 -  NTCOutPutVoltage)是咋么算的?其中1000是NTC串联的电阻1K 5是基准电压5V 根据NTC与串联电阻串联电流相等 即(基准电压-NTC当前电压) / 串联电阻阻值 = NTC当前电压 / NTC当前阻值 基准电压取5V 串联电阻阻值取1k 由此可得(5. 0 - NTCOutPutVoltage) / 1000 = NTCOutPutVoltage / Rt 转化可得Rt = NTCOutPutVoltage * 1000 / (5.0 - NTCOutPutVoltage)
//   NTCTemperature = 1 / (1 / T4 + log( Rt / Rp) / Bx) - T3 - 2;//减2是为了减少温度误差 由NTC当前阻值与NTC当前温度计算公式:Rt = Rp * EXP(Bx * ( 1 / T3 - 1 / T4))转换可得T1 = 1 /(ln(Rt / Rp )/ Bx + 1 / T4) 其中Rt是NTC在T3温度下的阻值 Rp是NTC常温下标称阻值 EXP是e的n次方 Bx是NTC的B值 T3是开尔文温度273.15 + NTC当前摄氏度T T4是开尔文温度等于273.15 + 摄氏度25 其中T3 = 273.15 + NTC当前摄氏度T T4 = 273.15 + 摄氏度25 由此可换算成273.15 + T = 1 /(ln(Rt / Rp )/ Bx + 1 / T4)进一步转换成T = [ 1 /(ln(Rt / Rp )/ Bx + 1 / T4)] - 273.15 再次转换可得T = [ 1 /(log(Rt / Rp )/ Bx + 1 / T4)] - 273.15 代入数据可得T = [1 / (log(Rt / 10000)/ 3950 + 1 / (273.15 + 25))] - 273.15
//  }
//	return NTCTemperature;//返回NTC温度变量值
// }
  uchar STC12ADCAnalogChangeResult(uchar PassageWay)//STC12ADC转换器模拟量转化结果函数
 {
   
   ADC_CONTR = ADC_POWER | ADC_SPEEDHH | PassageWay | ADC_START;//启动STC12ADC转换器电源 设置STC12ADC转换器转换速度为最高 90时钟周期STC12ADC转换器转换一次 设置STC12ADC转换器转换通道 启动STC12ADC转换器转换
//   ADC_CONTR = ADC_POWER;//启动STC12ADC转换器电源
//   ADC_CONTR = ADC_SPEEDHH;//设置STC12ADC转换器转换速度为最高 90时钟周期STC12ADC转换器转换一次
//   ADC_CONTR = PassageWay;//设置STC12ADC转换器转换通道
//   ADC_CONTR = ADC_START;//启动STC12ADC转换器转换
   _nop_();
   _nop_();
   _nop_();
   _nop_();
   while (!(ADC_CONTR & ADC_FLAG));//等待STC12ADC转换器转换标志位变量ADC_FLAG为1 就跳出while()循环
   ADC_CONTR &= ~ADC_FLAG;//STC12ADC转换器转换标志位变量ADC_FLAG清0
   return ADC_RES;//返回STC12ADC转换器结果寄存器存储的8位数据
//   while(STC12ADCChangeOverFlag == 0)//当STC12ADC转换器转换结束标志位为0
//  {
   
//    STC12ADCChangeOverFlag = ADC_CONTR & 0x10;//判断STC12ADC转换器转换是否结束 当STC12ADCChangeOverFlag = 0x10表示STC12ADC转换器转换结束 跳出while()循环
//   }
//   ADC_CONTR &= 0xe7;//STC12ADC转换器转换结束后 STC12ADC转换器结束标志位与转换启动控制位都清0
//   STC12ADCAnalogTransformResult = ADC_RES;//STC12ADC转换器高位STC12ADC转换结果寄存器高八位存放值赋给STC12ADC转换器模拟量转换结果变量
//   STC12ADCAnalogTransformResult <<= 2;//STC12ADC转换器模拟量转换结果左移2位变成高八位和空出低二位
//   STC12ADCLowBitResult = ADC_RESL;//STC12ADC转换器低位STC12ADC转换结果寄存器低二位存放值赋给STC12ADC转换器低位模拟量转换结果变量
//   STC12ADCLowBitResult &= 0x03;//保留STC12ADC转换器低位模拟量转换结果寄存器低二位存放值 屏蔽STC12ADC转换器低位模拟量转换结果寄存器其他位
//   STC12ADCAnalogTransformResult |= STC12ADCLowBitResult;//STC12ADC转换器高位模拟量转换结果寄存器高八位存放值或上STC12ADC转换器低位模拟量转换结果寄存器低二位存放值组成一个十位数据
//   return STC12ADCAnalogTransformResult;//返回STC12ADC转换器模拟量转换结果
//  }
  void STC12ADCInit()//STC12ADC转换器初始化函数
 {
   
   P1ASF = 0xff;//单片机P1口设置成高阻状态 作为STC12ADC转换器转换模拟量端口   
   AUXR1 = 0X00;//设置STC12ADC转换器结果寄存器为高八位存储	 
//   P1M0 = 0xff;//设置P1组单片机引脚为开漏输出
//   P1M1 = 0xff;//设置P1组单片机引脚为开漏输出
   ADC_RES = 0x00;//STC12ADC转换器结果寄存器存储的高八位数据清0
//	 ADC_LOW2 = 0x00;//设置STC12ADC转换器结果寄存器为低二位存储 如果加上ADC_DATA = 0x00就可以设置STC12ADC转换器结果寄存器为十位存储
//   ADC_CONTR = 0xe1;//设置STC12ADC转换器转换速度为最高 90时钟周期STC12ADC转换器转换一次 选P1.0端口作为STC12ADC转换器模拟输入通道 STC12ADC转换器转换结束标志位清0 STC12ADC转换器转换启动控制位清0
   ADC_CONTR = ADC_POWER | ADC_SPEEDHH;//启动STC12ADC转换器电源 设置STC12ADC转换器转换速度为最高 90时钟周期STC12ADC转换器转换一次
//   P1ASF |= 0x01;//设置P1.0端口为STC12ADC转换器模拟输入通道
//   AUXR1 = 0x00;//设置STC12ADC转换器转换结果寄存器CON_RES存放高八位STC12ADC转换器转换结果 CON_RESL存放低二位STC12ADC转换器转换结果 
//   ADC_CONTR |= 0x80;//打开STC12ADC转换器电源
//   _nop_();
//   _nop_();
//   _nop_();
//   _nop_();
//   ADC_CONTR = 0xe1;//设置STC12ADC转换器转换速度为最高 选P1.0端口作为STC12ADC转换器模拟输入通道 STC12ADC转换器转换结束标志位清0 STC12ADC转换器转换启动控制位清0
//   ADC_CONTR |= 0x08;//启动STC12ADC转换器
  }

STC12ADC.h

#ifndef __STC12ADC_H__
#define __STC12ADC_H__
#include "STC12C5A60S2.h"
#define uchar unsigned char//自定义无符号字符型为uchar
#define uint unsigned int//自定义无符号整数型为uin
#define ADC_POWER   0x80//STC12ADC转换器电源控制位
#define ADC_FLAG    0x10//STC12ADC转换器转换标志位
#define ADC_START   0x08//STC12ADC转换器转换启动控制位
#define ADC_SPEEDLL 0x00//540时钟周期STC12ADC转换器转换一次
#define ADC_SPEEDL  0x20//360时钟周期STC12ADC转换器转换一次
#define ADC_SPEEDH  0x40//180时钟周期STC12ADC转换器转换一次
#define ADC_SPEEDHH 0x60//90时钟周期STC12ADC转换器转换一次
//extern uchar STC12ADCTransformResult;//声明STC12ADC转换器转换结果变量
//extern uchar STC12ADCAdcLowBitResult;//声明STC12ADC转换器低位转换结果变量
//extern uchar STC12ADCChangeOverFlag;//定义STC12ADC转换器转换结束标志位清0 
//extern float Rt,NTCTemperature,NTCOutPutVoltage;//声明NTC当前阻值变量、NTC当前温度变量、NTC当前电压变量
//extern float Rp;//声明NTC在25℃的阻值变量
//extern float Bx;//声明NTC的B值变量
//extern float T3;//声明开尔文温度变量
//extern float T4;//声明开尔文温度变量
//extern float GetNTCTemperature();//获取NTC温度函数
extern uint STC12ADCAnalogChangeResult(uchar PassageWay);//STC12ADC转换器模拟量转化结果函数
extern void STC12ADCInit();//STC12ADC转换器初始化函数
#endif

Digitron.c

#include "Digitron.h"
//#include "NTC10KB3435.h"
//#include "Key.h"
#define uchar unsigned char//自定义无符号字符型为uchar
#define uint unsigned int//自定义无符号整数型为uint
//uchar code DigitronBitCodeArray[] = {0x01,0x02,0x04,0x08,0x10,0x20,0x40,0x80};//定义八位共阴数码管位码数组变量 为什么不是{0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0x7f} 这才是定义八位共阴数码管位码数组变量 不对吗? 在不使用NPN三极管驱动 用单片机端口直接连接驱动 位码数组是对的 但数码管亮度不够 因此使用了NPN型三极管(比如S8050)来驱动共阴数码管位选 NPN型三极管(比如S8550)基极输入高电平才能导通 解释:共阴数码管 阴极是公共端 对应位选 低电平选通 阳极是显示端 对应段选 高电平选通 由于共阴数码管阴极公共端接单片机来驱动共阴数码管阳极显示端 共阴数码管的亮度会比较低 需要借助NPN型三极管的集电极连接共阴数码管阴极公共端 而NPN型三极管的基电极串个限流电阻连接单片机端口 通过单片机端口输出高电平到NPN型三极管的基电极 从而导通NPN型三极管 放大流过共阴数码管的电流 这样共阴数码管的亮度才会比较亮    
//uchar code DigitronSegmentCodeArray[] = {0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71,0x40,0x00};//定义共阴数码管显示0到F数据及符号“—”及熄灭数组变量
//uchar code DigitronSegmentCodeOfPointArray[] = {0xbf,0x86,0xdb,0xcf,0xe6,0xed,0xfd,0x87,0xff,0xef,0xf7,0xfc,0xb9,0xde,0xf9,0xf1,0x40,0x00};//定义带小数点共阴数码管显示0.到F.数据及符号“—”及熄灭数组变量
uchar code DigitronBitCodeArray[] = {
   0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0x7f};//定义八位共阳数码管位码数组变量 为什么不是{0x01,0x02,0x04,0x08,0x10,0x20,0x40,0x80} 这才是定义八位共阳数码管位码数组变量 不对吗? 在不使用PNP三极管驱动 用单片机端口直接连接驱动 位码数组是对的 但数码管亮度不够 因此使用了PNP型三极管(比如S8550)来驱动共阳数码管位选 PNP型三极管(比如S8550)基极输入低电平才能导通 解释:共阳数码管 阳极是公共端 对应位选 高电平选通 阴极是显示端 对应段选 低电平选通 由于共阳数码管阳极公共端接单片机来驱动共阳数码管阴极显示端 共阳数码管的亮度会比较低 需要借助PNP型三极管的集电极连接共阳数码管阳极公共端 而PNP型三极管的基电极串个限流电阻连接单片机端口 通过单片机端口输出低电平到PNP型三极管的基电极 从而导通PNP型三极管 由外接电源来驱动共阳数码管 这样共阳数码管的亮度才会比较亮    
uchar code DigitronSegmentCodeArray[] = {
   0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0x88,0x83,0xc6,0xa1,0x86,0x8e,0x89,0xc7,0xbf,0x7f,0xff};//定义共阳数码管显示0到F数据及"H"、"L"及符号“—”、“.”及熄灭数组变量
//uchar code DigitronSegmentCodeOfPointArray[] = {0x40,0x79,0x24,0x30,0x19,0x12,0x02,0x78,0x00,0x10,0x08,0x03,0x46,0x21,0x06,0x0e,0xbf,0xff};//定义带小数点共阳数码管显示0.到F.数据及符号“—”及熄灭数组变量
uchar DigitronCacheDataArray[] = {
   0,0,0,0,};//定义共阳数码管缓存数据数组变量 
uchar DigitronBootTimerFlag = 1;//定义共阳数码管开机时间标志位变量            
uint  DigitronBootTimer = 0;//定义数码管开机时间变量  
extern uchar STC12ADCAnalogDataResult;//如果在main.c文件下已经定义STC12ADC模拟量数字结果变量STC12ADCAnalogDataResult 则以此语句来引用main.c文件下的STC12ADC模拟量数字结果变量STC12ADCAnalogDataResult 否则先在Digitron.c文件下定义STC12ADC模拟量数字结果变量STC12ADCAnalogDataResult 接着在Digitron.h文件下的用extern关键字声明STC12ADC模拟量数字结果变量STC12ADCAnalogDataResult 最后通过在其他.c文件下#include "Key.h" 就可以引用在Digitron.c文件下已经定义的STC12ADC模拟量数字结果变量STC12ADCAnalogDataResult
//extern uint AnalogFilterOutPutVoltage;//定义模拟滤波后输出电压变量为0
//extern uint OutPutVoltage;//定义输出电压变量
//uchar SymbolFlags = 0;//定义符号标志位变量为0
//float Temp = 0;//定义临时变量为0
//int Temperature = 0;//定义温度变量为0
//extern uint KeyPressNumber;//如果在Key.c文件下已经定义按键按下数值变量KeyPressNumber 则以此语句来引用Key.c文件下的按键按下数值变量KeyPressNumber 否则先在Key.c文件下定义按键按下数值变量KeyPressNumber 接着在Key.h文件下的用extern关键字声明按键按下数值变量KeyPressNumber 最后通过在其他.c文件下#include "Key.h" 就可以引用在Key.c文件下已经定义的按键按下数值变量KeyPressNumber
  void DigitronBootDisplay()//数码管开机显示函数
{
   
   do
 {
   
    //if(DigitronBootTimer == 500 )//如果数码管开机时间等于1s
    LED0 = ~ LED0;//LED灯亮灭更新
   }while(DigitronBootTimer <= 500);//当数码管开机时间小于5s
   DigitronBootTimerFlag = 0;//数码管开机时间标志位清0
   LED0 = 1;//LED灯熄灭
  }
  void DigitronDisplayDataSplit()//数码管显示数据分解函数
 {
   
//   uchar DigitronQianWei,DigitronBaiWei,DigitronShiWei,DigitronGeWei;//声明数码管千位、百位、十位、个位变量
//	 
//	 DigitronQianWei = AnalogFilterOutPutVoltage / 1000;//数码管千位数据分解
//   DigitronBaiWei = AnalogFilterOutPutVoltage / 100 % 10;//数码管百位数据分解
//   DigitronShiWei = AnalogFilterOutPutVoltage / 10 % 10;//数码管十位数据分解
//   DigitronGeWei = AnalogFilterOutPutVoltage % 10;//数码管个位数据分解
//	 
//	 DigitronCacheDataArray[0] = DigitronQianWei;//数码管千位数据显示 
//   DigitronCacheDataArray[1] = DigitronBaiWei;//数码管百位数据显示
//   DigitronCacheDataArray[2] = DigitronShiWei;//数码管十位数据显示
//   DigitronCacheDataArray[3] = DigitronGeWei;//数码管个位数据显示
	 
  DigitronCacheDataArray[0] = STC12ADCAnalogDataResult / 1000;//数码管千位数据显示
  DigitronCacheDataArray[1] = STC12ADCAnalogDataResult / 100 % 10;//数码管百位数据显示
  DigitronCacheDataArray[2] = STC12ADCAnalogDataResult / 10 % 10;//数码管十位数据显示
  DigitronCacheDataArray[3] = STC12ADCAnalogDataResult % 10;//数码管个位数据显示	 
	 
  if(STC12ADCAnalogDataResult < 1000)//如果STC12ADC模拟量数字结果变量小于1000
 {
   
   DigitronCacheDataArray[0] = 20;//数码管千位数据不显示
  }
  else
 {
   
   DigitronCacheDataArray[0] = STC12ADCAnalogDataResult / 1000;//数码管千位数据显示
  }
  if(STC12ADCAnalogDataResult < 100)//如果STC12ADC模拟量数字结果变量小于100
 {
   
   DigitronCacheDataArray[1] = 20;//数码管百位数据不显示
  }
  else
 {
   
   DigitronCacheDataArray[1] = STC12ADCAnalogDataResult / 100 % 10;//数码管百位数据显示
  }
  if(STC12ADCAnalogDataResult < 10)//如果STC12ADC模拟量数字结果变量小于10
 {
   
   DigitronCacheDataArray[2] = 20;//数码管十位数据不显示
  }
  else
 {
   
   DigitronCacheDataArray[2] = STC12ADCAnalogDataResult / 10 % 10;//数码管十位数据显示
  }
  DigitronCacheDataArray[3] = STC12ADCAnalogDataResult % 10;//数码管个位数据显示
	 
//	 DigitronCacheDataArray[0] = OutPutVoltage / 1000;//数码管千位数据显示
//   DigitronCacheDataArray[1] = OutPutVoltage / 100 % 10;//数码管百位数据显示
//   DigitronCacheDataArray[2] = OutPutVoltage / 10 % 10;//数码管十位数据显示
//   DigitronCacheDataArray[3] = OutPutVoltage % 10;//数码管个位数据显示

//	 DigitronCacheDataArray[0] = Temperature / 1000;//数码管千位数据显示
//   DigitronCacheDataArray[1] = Temperature / 100 % 10;//数码管百位数据显示
//   DigitronCacheDataArray[2] = Temperature / 10 % 10;//数码管十位数据显示
//   DigitronCacheDataArray[3] = Temperature % 10;//数码管个位数据显示
	  
//   Temp = GetNTCTemperature();//获取NTC温度赋给临时变量
//	 Temperature = Temp * 100;//临时变量保存NTC当前温度扩大100倍变成5位整数 赋给温度变量
//	 
//	 if(Temperature < 0)//如果温度变量保存的温度数值小于0
//	{
   
//		Temperature = - Temperature;//温度变量保存的数值取正数 
//		DigitronCacheDataArray[0] = 18 ;//18对应DigitronSegmentCodeArray[]中的第18个数据0xbf 表示数码管十万位数据显示“-”符号
//	 }
//	 else//否则温度变量保存的温度数值大于0
//	{
   
//    DigitronCacheDataArray[0] = Temperature / 10000;//数码管万位数据显示
//	 }	 
	 DigitronCacheDataArray[0] = Temperature / 10000;//数码管万位数据显示
//   DigitronCacheDataArray[1] = Temperature / 1000 % 10;//数码管千位数据显示
//   DigitronCacheDataArray[2] = Temperature / 100 % 10;//数码管百位数据显示
//   DigitronCacheDataArray[3] = Temperature / 10 % 10;//数码管十位数据显示
//	 DigitronCacheDataArray[4] = Temperature % 10;//数码管个位数据显示
	 
//	 if(Temperature < 0)//如果温度变量保存的温度数值小于0
//	{
   
//		Temperature = - Temperature;//温度变量保存的数值取正数 
//		DigitronCacheDataArray[0] = 18 ;//17对应DigitronSegmentCodeArray[]中的第18个数据0xbf 表示数码管十万位数据显示“-”符号
//	 }
//	 else//否则温度变量保存的温度数值大于0
//	{
   
//	  DigitronCacheDataArray[0] = 16 ;//16对应DigitronSegmentCodeArray[]中的第16个数据0x89 表示数码管十万位数据显示H 也表示“+”符号
//	 } 
//	 
//	 DigitronCacheDataArray[1] = Temperature / 10000 % 10;//数码管万位数据显示
//   DigitronCacheDataArray[2] = Temperature / 1000 % 10;//数码管千位数据显示
//   DigitronCacheDataArray[3] = Temperature / 100 % 10;//数码管百位数据显示
//   DigitronCacheDataArray[4] = Temperature / 10 % 10;//数码管十位数据显示
//	 DigitronCacheDataArray[5] = Temperature % 10;//数码管个位数据显示
  }

  void DigitronDisplayData()//数码管显示数据函数  
{
     
   static uchar i = 0;//定义静态数码管管位变化变量
   DigitronSegmentCode = 0xff;//数码管段码消影
   DigitronBitCode = 0xff;//数码管位码消影
   switch(i)//数码管管位变化筛选
 {
   
    case 0 ://数码管千位显示
            DigitronSegmentCode = 0xff;//数码管段码消影
            DigitronSegmentCode = DigitronSegmentCodeArray[DigitronCacheDataArray[0]];//数码管千位的段码段码显示 
            DigitronBitCode = DigitronBitCodeArray[0];//数码管千位码显示
            i++;//数码管管位变化自加1
            break;//跳出
    case 1 ://数码管百位显示
            DigitronSegmentCode = 0xff;//数码管段码消影
            DigitronSegmentCode = DigitronSegmentCodeArray[DigitronCacheDataArray[1]];//数码管百位的段码显示
            DigitronBitCode = DigitronBitCodeArray[1];//数码管百位码显示
            i++;//数码管管位变化自加1
            break;//跳出 
    case 2 ://数码管十位显示
            DigitronSegmentCode = 0xff;//数码管段码消影
            DigitronSegmentCode = DigitronSegmentCodeArray[DigitronCacheDataArray[2]];//数码管十位的段码显示
            DigitronBitCode = DigitronBitCodeArray[2];//数码管十位码显示
            i++;//数码管管位变化自加1
            break;//跳出
    case 3 ://数码管个位显示
            DigitronSegmentCode = 0xff;//数码管段码消影
            DigitronSegmentCode = DigitronSegmentCodeArray[DigitronCacheDataArray[3]];//数码管个位的段码显示
            DigitronBitCode = DigitronBitCodeArray[3];//数码管个位码显示
            i = 0;//数码管管位变化清0
            break;//跳出
    default:break;//跳出
        
//		case 0 ://数码管万位显示
//            DigitronSegmentCode = 0xff;//数码管段码消影
//            DigitronSegmentCode = DigitronSegmentCodeArray[DigitronCacheDataArray[0]];//数码管万位的段码显示
//            DigitronBitCode = DigitronBitCodeArray[0];//数码管万位码显示
//            i++;//数码管管位变化自加1
//            break;//跳出
//    case 1 ://数码管千位显示
//            DigitronSegmentCode = 0xff;//数码管段码消影
//            DigitronSegmentCode = DigitronSegmentCode
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值