51单片机24c02详细教程.doc

  1. 1、本文档共6页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
本人呕心沥血制作的一个24C02教程,程序已经在protues中仿真,仿真图在下方!! 花了血本制作的,目的是为了通过审核,同时也给想我当初花了2天时间探索24C02的人一个好的案例,这个程序由1602显示,通过开发板测试了,还有结合了24c02pdf,24c02时序图,有了这些24c02就没问题了!希望大家多多支持! ------------------------血顶猎鹰 程序如下,有注释 001.c #includereg52.h #includeintrins.h #include24c #define uchar unsigned char #define uint unsigned int sbit lcdrs=P2^4; //液晶的 sbit lcdrw=P2^5; sbit lcden=P2^6; bit write=0; //写信号 uchar sec,tcnt; void delay(uint z) { uint x,y; for(x=z;x0;x--) for(y=110;y0;y--); } void write_cmd(uchar cmd) { lcden=0; lcdrs=0; lcdrw=0; P0=cmd; _nop_(); lcden=1; delay(1); lcden=0; _nop_(); } void write_dat(uchar dat) { lcden=0; lcdrs=1; P0=dat; _nop_(); lcden=1; delay(1); lcden=0; _nop_(); } void lcdint() { lcden=0; write_cmd(0x38); write_cmd(0x0c); write_cmd(0x06); write_cmd(0x01); } void main() { lcdint(); wp=0; sec=read_add(2); if(sec100) sec=0; TMOD=0x01; ET0=1; EA=1; TH0=(65536-50000)/256; TL0=(65536-50000)%256; TR0=1; while(1) //1秒钟到写一次 { write_cmd(0x80); write_dat(0x30+sec/10); write_dat(0x30+sec%10); if(write==1) { write=0; write_add(2,sec); } } } void t0()interrupt 1 { TH0=(65536-50000)/256; TL0=(65536-50000)%256; tcnt++; if(tcnt==20) { tcnt=0; sec++; write=1; if(sec==100) sec=0; } } 24c02.h sbit wp=P1^0; sbit sda=P1^2; sbit scl=P1^1; void delay1() //延时5us左右 {;;} void start() { scl=1; //对应时序图将SCL拉高 delay1(); //延时 sda=1; //将SDA拉高 delay1(); //延时 sda=0; //造成一个下降沿启动信号 delay1(); } void stop() { scl=1; // SCL拉高 delay1(); sda=0; //SDA拉低 delay1(); sda=1; //造成上升沿终止信号 delay1(); } void respons() { unsigned char i; scl=1; //将SCL拉高 delay1(); while((sda==1)(i250)) i++; //等待SDA低电平如果时间超了就退出 scl=0; //将SCL拉低 delay1(); } void write_byte(unsigned char date) { unsigned char i,temp; temp=date; //写数据 for(i=0;i8;i++) //循环输入 { temp=temp1; //左移一位进CY,再放入sda中 scl=0; delay1(); sda=CY; delay1(); scl=1; delay1(); } scl

文档评论(0)

yurixiang1314 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档