- 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
本人呕心沥血制作的一个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)