代码增进对IIC的理解

  1. 我看了一下,写的确实不错,基于51的
  2. #include<reg52.h>  
  3. #define uchar unsigned char  
  4. sbit sda=P2^0;  
  5. sbit scl=P2^1;              //用单片机的两个I/O口模拟I2C接口  
  6. uchar a;  
  7. ***************************************************************************  
  8. void delay()                             //简单延时函数  
  9. { ;; }  
  10. ***************************************************************************  
  11. void start()             //开始信号 SCL在高电平期间,SDA一个下降沿则表示启动信号  
  12. {     
  13.     sda=1;              //释放SDA总线  
  14.     delay();  
  15.     scl=1;  
  16.     delay();  
  17.     sda=0;  
  18.     delay();  
  19. }  
  20. ***************************************************************************  
  21. void stop()   //停止 SCL在高电平期间,SDA一个上升沿则表示停止信号  
  22. {  
  23.     sda=0;  
  24.     delay();  
  25.     scl=1;  
  26.     delay();  
  27.     sda=1;  
  28.     delay();  
  29. }***************************************************************************  
  30. void respons()  //应答 SCL在高电平期间,SDA被从设备拉为低电平表示应答  
  31. {  
  32.     uchar i;  
  33.     scl=1;  
  34.     delay();  
  35.     while((sda==1)&&(i<250))i++;  
  36.     scl=0;  
  37.     delay();  
  38. }  
  39. ***************************************************************************  
  40. /*总线初始化 将总线都拉高一释放总线  发送启动信号前,要先初始化总线。即总有检测到总线空闲才开始发送启动信号*/
  41. void init()
  42. {  
  43.     sda=1;  
  44.     delay();  
  45.     scl=1;  
  46.     delay();  
  47. }  
  48. /***************************************************************************/
  49. void write_byte(uchar date) //写一个字节  
  50. {  
  51.     uchar i,temp;  
  52.     temp=date;  
  53.   
  54.   
  55.     for(i=0;i<8;i++)  
  56.     {  
  57.         temp=temp<<1;  
  58.         scl=0;     //拉低SCL,因为只有在时钟信号为低电平期间按数据线上的高低电平状态才允许变化;并在此时和上一个循环的scl=1一起形成一个上升沿  
  59.         delay();  
  60.         sda=CY;  
  61.         delay();  
  62.         scl=1;         //拉高SCL,此时SDA上的数据稳定  
  63.         delay();  
  64.     }  
  65.     scl=0;          //拉低SCL,为下次数据传输做好准备  
  66.     delay();  
  67.     sda=1;          //释放SDA总线,接下来由从设备控制,比如从设备接收完数据后,在SCL为高时,拉低SDA作为应答信号  
  68.     delay();  
  69. }  
  70. ***************************************************************************  
  71. uchar read_byte()           //读一个字节  
  72. {  
  73.     uchar i,k;  
  74.     scl=0;  
  75.     delay();  
  76.     sda=1;  
  77.     delay();  
  78.     for(i=0;i<8;i++)  
  79.     {  
  80.         scl=1;           //上升沿时,IIC设备将数据放在sda线上,并在高电平期间数据已经稳定,可以接收啦  
  81.         delay();      
  82.         k=(k<<1)|sda;  
  83.         scl=0;          //拉低SCL,使发送端可以把数据放在SDA上  
  84.         delay();      
  85.     }  
  86.     return k;  
  87. }  
  88. ***************************************************************************  
  89. void write_add(uchar address,uchar date)//任意地址写一个字节  
  90. {  
  91.     start();        //启动  
  92.     write_byte(0xa0);        //发送从设备地址  
  93.     respons();                  //等待从设备的响应  
  94.     write_byte(address);        //发出芯片内地址  
  95.     respons();                       //等待从设备的响应  
  96.     write_byte(date);         //发送数据  
  97.     respons();                  //等待从设备的响应  
  98.     stop();                       //停止  
  99. }  
  100. ***************************************************************************  
  101. uchar read_add(uchar address)//读取一个字节  
  102. {  
  103.     uchar date;  
  104.     start();              //启动  
  105.     write_byte(0xa0);             //发送从设备地址 写操作  
  106.     respons();                      //等待从设备的响应  
  107.     write_byte(address);          //发送芯片内地址  
  108.     respons();                        //等待从设备的响应  
  109.     start();                                //启动  
  110.     write_byte(0xa1);                //发送从设备地址 读操作  
  111.     respons();                             //等待从设备的响应  
  112.     date=read_byte();                //获取数据  
  113.     stop();                                 //停止  
  114.     return date;                      //返回数据  
  115. }  
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
自动控制节水灌溉技术的高低代表着农业现代化的发展状况,灌溉系统自动化水平较低是制约我国高效农业发展的主要原因。本文就此问题研究了单片机控制的滴灌节水灌溉系统,该系统可对不同土壤的湿度进行监控,并按照作物对土壤湿度的要求进行适时、适量灌水,其核心是单片机和PC机构成的控制部分,主要对土壤湿度与灌水量之间的关系、灌溉控制技术及设备系统的硬件、软件编程各个部分进行了深入的研究。 单片机控制部分采用上下位机的形式。下位机硬件部分选用AT89C51单片机为核心,主要由土壤湿度传感器,信号处理电路,显示电路,输出控制电路,故障报警电路等组成,软件选用汇编语言编程。上位机选用586型以上PC机,通过MAX232芯片实现同下位机的电平转换功能,上下位机之间通过串行通信方式进行数据的双向传输,软件选用VB高级编程语言以建立友好的人机界面。系统主要具有以下功能:可在PC机提供的人机对话界面上设置作物要求的土壤湿度相关参数;单片机可将土壤湿度传感器检测到的土壤湿度模拟量转换成数字量,显示于LED显示器上,同时单片机可采用串行通信方式将此湿度值传输到PC机上;PC机通过其内设程序计算出所需的灌水量和灌水时间,且显示于界面上,并将有关的灌水信息反馈给单片机,若需灌水,则单片机系统启动鸣音报警,发出灌水信号,并经放大驱动设备,开启电磁阀进行倒计时定时灌水,若不需灌水,即PC机上显示的灌水量和灌水时间均为0,系统不进行灌水。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值