//LED8*8滚动显示
//列扫描,低电平有效
/*--------------------------------------------------------------*/
//包含头文件
#include <reg52.h>
#include "74HC595.H"
#include<intrins.h>  //包含_nop_()函数定义的头文件/*--------------------------------------------------------------*/
//全局变量定义
unsigned char  i,flag,t,w,t;
unsigned int  m,n;
unsigned char  t1,t2,t3,t4;/*--------------------------------------------------------------*/
//代码库
#define  num  sizeof(buff)  //代码长度
unsigned char code aa[]={0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0x7f};unsigned char code table2[]={0x60,0x60,0x00,0x3E,0x7F,0x41,0x7F,0x3E,/*"0",0*/0x60,0x60,0x00,0x42,0x7F,0x7F,0x40,0x00,/*"1",1*/0x60,0x60,0x00,0x62,0x73,0x59,0x4F,0x46,/*"2",2*/0x60,0x60,0x00,0x22,0x6B,0x49,0x7F,0x36,/*"3",3*/0x60,0x60,0x00,0x38,0x3E,0x7F,0x7F,0x20,/*"4",4*/0x60,0x60,0x00,0x4F,0x4F,0x49,0x79,0x31,/*"5",5*/0x60,0x60,0x00,0x3E,0x7F,0x49,0x7B,0x32,/*"6",6*/0x60,0x60,0x00,0x03,0x73,0x79,0x0F,0x07,/*"7",7*/0x60,0x60,0x00,0x36,0x7F,0x49,0x7F,0x36,/*"8",8*/0x60,0x60,0x00,0x26,0x6F,0x49,0x7F,0x3E,/*"9",9*/
};unsigned char code table1[]= {
//取模方式 阴码 列扫描 逆向0x00,0x3E,0x7F,0x41,0x7F,0x3E,0x00,0x00,/*"0",0*/0x00,0x42,0x7F,0x7F,0x40,0x00,0x00,0x00,/*"1",1*/0x00,0x62,0x73,0x59,0x4F,0x46,0x00,0x00,/*"2",2*/0x00,0x22,0x6B,0x49,0x7F,0x36,0x00,0x00,/*"3",3*/0x00,0x38,0x3E,0x7F,0x7F,0x20,0x00,0x00,/*"4",4*/0x00,0x4F,0x4F,0x49,0x79,0x31,0x00,0x00,/*"5",5*/0x00,0x3E,0x7F,0x49,0x7B,0x32,0x00,0x00,/*"6",6*/0x00,0x03,0x73,0x79,0x0F,0x07,0x00,0x00,/*"7",7*/0x00,0x36,0x7F,0x49,0x7F,0x36,0x00,0x00,/*"8",8*/0x00,0x26,0x6F,0x49,0x7F,0x3E,0x00,0x00,/*"9",9*/0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,/*" ",10*/
};
unsigned char buff[]={0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,/*" ",10*/0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,/*" ",10*/0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,/*" ",10*/0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,/*" ",10*/0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,/*" ",10*/0x00,0x03,0x03,0x3E,0x7F,0x41,0x63,0x22,/*"C",0*/0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,/*" ",10*/
};
/************************************************************************
以下是DS18B20的操作程序
************************************************************************/
sbit DQ=P3^3;
unsigned char time;   //设置全局变量,专门用于严格延时
/*****************************************************
函数功能:将DS18B20传感器初始化,读取应答信号
出口参数:flag
***************************************************/
bit Init_DS18B20(void)
{bit flag;         //储存DS18B20是否存在的标志,flag=0,表示存在;flag=1,表示不存在DQ = 1;           //先将数据线拉高for(time=0;time<2;time++) //略微延时约6微秒;DQ = 0;           //再将数据线从高拉低,要求保持480~960usfor(time=0;time<200;time++)  //略微延时约600微秒;         //以向DS18B20发出一持续480~960us的低电平复位脉冲DQ = 1;           //释放数据线(将数据线拉高)for(time=0;time<10;time++);  //延时约30us(释放总线后需等待15~60us让DS18B20输出存在脉冲)flag=DQ;          //让单片机检测是否输出了存在脉冲(DQ=0表示存在)for(time=0;time<200;time++)  //延时足够长时间,等待存在脉冲输出完毕;return (flag);    //返回检测成功标志
}
/*****************************************************
函数功能:从DS18B20读取一个字节数据
出口参数:dat
***************************************************/
unsigned char ReadOneChar(void)
{unsigned char i=0;unsigned char dat;  //储存读出的一个字节数据for (i=0;i<8;i++){DQ =1;       // 先将数据线拉高_nop_();       //等待一个机器周期DQ = 0;      //单片机从DS18B20读书据时,将数据线从高拉低即启动读时序dat>>=1;_nop_();     //等待一个机器周期DQ = 1;     //将数据线"人为"拉高,为单片机检测DS18B20的输出电平作准备for(time=0;time<2;time++);      //延时约6us,使主机在15us内采样if(DQ==1)dat|=0x80;  //如果读到的数据是1,则将1存入datelsedat|=0x00;//如果读到的数据是0,则将0存入dat//将单片机检测到的电平信号DQ存入r[i]for(time=0;time<8;time++);              //延时3us,两个读时序之间必须有大于1us的恢复期}return(dat);    //返回读出的十进制数据
}
/*****************************************************
函数功能:向DS18B20写入一个字节数据
入口参数:dat
***************************************************/
WriteOneChar(unsigned char dat)
{unsigned char i=0;for (i=0; i<8; i++){DQ =1;         // 先将数据线拉高_nop_();         //等待一个机器周期DQ=0;          //将数据线从高拉低时即启动写时序DQ=dat&0x01;   //利用与运算取出要写的某位二进制数据,//并将其送到数据线上等待DS18B20采样for(time=0;time<10;time++);//延时约30us,DS18B20在拉低后的约15~60us期间从数据线上采样DQ=1;          //释放数据线for(time=0;time<1;time++);//延时3us,两个写时序间至少需要1us的恢复期dat>>=1;       //将dat中的各二进制位数据右移1位}for(time=0;time<4;time++); //稍作延时,给硬件一点反应时间
}void ReadyReadTemp(void)
{Init_DS18B20();     //将DS18B20初始化WriteOneChar(0xCC); // 跳过读序号列号的操作WriteOneChar(0x44); // 启动温度转换for(time=0;time<100;time++);   //温度转换需要一点时间Init_DS18B20();     //将DS18B20初始化WriteOneChar(0xCC); //跳过读序号列号的操作WriteOneChar(0xBE); //读取温度寄存器,前两个分别是温度的低位和高位
}/*--------------------------------------------------------------*/
//显示函数
void Display(void)
{if(flag==2){Ser_IN[[aa[i]]]; //列扫描数据Ser_IN(buff[i + n]);                //查表取出行扫描数据Par_OUT();                           //输出显示i++; if(i == 8) i = 0;               //循环扫描m++; if(m == 100) {m = 0; n++;}        //滚动速度控制if(n == num-7){n = 0;                //循环显示flag=1;}}
}
/*--------------------------------------------------------------*/
//定时器初始化
void T_init(void)
{TMOD = 0x11;TH0  = 0xfc; //1MSTL0  = 0x66;EA = 1;                  //允许CPU中断ET0 = 1;              //定时器0中断打开TR0  = 1;
}
/*--------------------------------------------------------------*/
//定时器中断服务
void T0_intservice(void) interrupt 1 using 0
{TH0 = 0xfc;TL0 = 0x66;Display();
}
/*--------------------------------------------------------------*/
//主函数
void main (void)
{unsigned char TL;     //储存暂存器的温度低位unsigned char TH;    //储存暂存器的温度高位unsigned char TN;      //储存温度的整数部分unsigned char TD;       //储存温度的小数部分flag=1;T_init();while(1){if(flag==1){ReadyReadTemp();     //读温度准备TL=ReadOneChar();    //先读的是温度值低位TH=ReadOneChar();    //接着读的是温度值高位TN=TH*16+TL/16;      //实际温度值=(TH*256+TL)/16,即:TH*16+TL/16//这样得出的是温度的整数部分,小数部分被丢弃了TD=(TL%16)*10/16;    //计算温度的小数部分,将余数乘以10再除以16取整,t1=TN/100;              //取百位t2=(TN%100)/10;    //取十位t3=TN%10;             //取个位t4=TD;flag=0;}if(flag==0){for(w=1;w<6;w++){if(w==5){flag=2;}for(t=0;t<8;t++){switch(w){case 1:buff[t+(8*w)]=table1[(8*t1)+t];break;case 2:buff[t+(8*w)]=table1[(8*t2)+t];break;case 3:buff[t+(8*w)]=table1[(8*t3)+t];break;case 4:buff[t+(8*w)]=table2[(8*t4)+t];break;}}}}};
}//Note: 74HC595驱动
//      '''                   '''
//Note: MR 主复位接电源正极, OE 使能端,输出有效接电源负极
/*--------------------------------------------*/
#ifndef '''74HC595_H'''
#define '''74HC595_H'''
/*--------------------------------------------*/
sbit SD    = P1^4; //串行数据输入
sbit ST_CK = P1^5; //存储寄存器时钟输入
sbit SH_CK = P1^6; //移位寄存器时钟输入
/*--------------------------------------------*/
//数码管断码和位码的定义
//unsigned char code seg[]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0x88,0x83,0xc6,0xa1,0x86,0x8e,0x00,0xff};
//0   1    2    3    4    5    6    7    8    9    a    b    c     d    e     f    8   无
//unsigned char code pos[]={0x01,0x02,0x04,0x08,0x10,0x20,0x40,0x80};
//1    2    3   4    5    6     7   8
/*--------------------------------------------*/
//函数声明
void Ser_IN(unsigned char Data);    //串行数据输入
void Par_OUT(void);                 //串行数据输出
//void Ser_Par(unsigned char Data); //串行输入,并行输出
/*--------------------------------------------*/
//串行数据输入
void Ser_IN(unsigned char Data)
{unsigned char i;for(i = 0; i < 8; i++){SH_CK = 0;           //CLOCK_MAX=100MHzSD = Data & 0x80;Data <<= 1;SH_CK = 1;}
}
/*--------------------------------------------*/
//并行数据输出
void Par_OUT(void)
{ST_CK = 0;ST_CK = 1;
}/*--------------------------------------------*/
//串行输入,并行输出
/*void Ser_Par(unsigned char Data)
{
Ser_IN(Data);
Par_OUT();
}
*/
/*--------------------------------------------*/
#endif

转载地址:http://www.jdgcs.org/wiki/Downloads

在此仅做备份,如有侵权,请联系删除!

51单片机8X8点阵滚动显示温度--C51源代码相关推荐

  1. 52 8x8点阵c语言程序,51单片机8x8点阵显示程序

    <51单片机8x8点阵显示程序>由会员分享,可在线阅读,更多相关<51单片机8x8点阵显示程序(3页珍藏版)>请在人人文库网上搜索. 1.include #include#de ...

  2. 51单片机——8X8点阵显示

    74hc595.h: #ifndef __74hc595_H__ #define __74hc595_H__ /************************************位定义***** ...

  3. 51单片机1602、18B20电子钟--C51源代码

    #include"REGx52.h" #include"RICHMCU.H" sbit a0 = ACC^0; sbit a1 = ACC^1; sbit a2 ...

  4. 51单片机PS2键盘解码实验--C51源代码

    //地址:http://www.jdgcs.org/wiki/Downloads #include <at89x51.h> #include "KBCODE.H" #d ...

  5. 51单片机 16X192点阵程序动态显示汉字 PROTEUS 和51单片机教程(附仿真文件+源代码)

    51单片机 16X192点阵程序动态显示任意汉字 程序参考源代码如下: #include<AT89X52.H> sbit ST=P3^5; sbit E1=P3^4; sbit MR=P3 ...

  6. 【proteus仿真】单片机汇编+74xx595驱动8X8点阵滚动显示

    [proteus仿真]单片机汇编+74xx595驱动8X8点阵滚动显示 Proteus仿真 汇编代码(.asm) ORG 00HJMP MAINORG 0BHLJMP INTS_T0ORG 30H M ...

  7. 51单片机实现c语言字母滚动,使用51单片机实现点阵汉字平滑滚动显示

    使用51单片机实现点阵汉字平滑滚动显示 #说明:采用的芯片是89C51,LED点阵屏的规格是16*16,同时使用了两个74HC595芯片,字模生成软件在文末有网盘链接. 1 连接原理图 整体的电路连接 ...

  8. 基于51单片机的电子万年历的设计-源代码

    电子万年历的设计目录 电子万年历的设计 电子万年历的系统整体设计框图 所需要的元件 DS18B20模块 DS18B20的特点 DS18B20内部结构 DS18B20管脚排列 DS1302模块 SPI时 ...

  9. 51单片机LED点阵显示文字

    51单片机LED点阵显示文字 代码如下. #include <REGX51.H> #define u8 unsigned char sbit SER = P3^4; sbit RCLK = ...

最新文章

  1. 【python教程入门学习】Pandas库下载和安装
  2. linux内核线程创建销毁机制
  3. 整理了一下linux/ubuntu里面卸载软件的方法
  4. Android Studio导出jar包
  5. AI应用开发基础傻瓜书系列目录
  6. 资深程序员:Python中你不知道的那些小工具
  7. python技术简介_Python多线程技术简介,简单,阐述,python
  8. 了解计算机中的信息编码教案,《信息编码》教学设计
  9. antd中分页器如何自定义_react+antd分页 实现分页及页面刷新时回到刷新前的page...
  10. 深圳有哪些牛逼的互联网公司?看完你再跳槽!
  11. C语言程序设计(第三版)何钦铭著 习题2-1
  12. Java打印输出print和prinntln
  13. APM代码调试知识点汇总
  14. Adobe国际认证让科技赋能时尚
  15. leetcode 每日一题 一起进步714 买卖股票的最佳时机含手续费
  16. 牛客NOIP暑期七天营-普及组4 D-火龙果画
  17. 申请免费SSL证书教程之华为云20张免费证书
  18. 我是谁 是我心魔乱舞 对与错 我能顿悟 恶魔开始 让真理复苏
  19. python新年贺卡_写个新年贺卡生成器,各位小伙伴们新年快乐呀~
  20. 运维工程师都在做什么

热门文章

  1. 2019.7.20十道js题目
  2. LuoguP2680 运输计划
  3. 蚂蚁养鸡线下支付扫码链接,蚂蚁养鸡线下支付链接
  4. CodeFirst Update-Database 出现对象'DF__**__**__**' 依赖于 列'**'。
  5. 在那些打磨汉芯的日子里[转贴]
  6. python解压缩gz文件_使用python解压缩.gz文件的一部分
  7. 用终端访问路由器设置端口开发_网络故障排查最全总结!ONU、机顶盒、路由器常见网络问题及处理方法...
  8. python 判断div 之间的内容是否为空_python实现数据结构与算法之双端队列实现
  9. 2016年4月计算机组成原理试题答案,全国2018年4月自考(02318)计算机组成原理试题及答案...
  10. Android之本地摄像头,Android之调用本地摄像头