找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 3044|回复: 3
收起左侧

PCF8591+单片机测光强程序哪里有问题,串口得到的数据全是255

[复制链接]
ID:508775 发表于 2019-4-24 16:02 | 显示全部楼层 |阅读模式
大家好,我是个小白,然后这个问题也是问了很多次了,我这边这个程序写完之后串口得到的数据一直是255,另外我使用的芯片是PCF8591,一路输入模拟信号用来测光强,请大家看看我的程序看看我的问题究竟出在哪里,谢谢各位大佬了,各位觉得有任何问题都可以提出来,我这边真的想不出来办法了。

单片机源程序如下:

  1. #include "reg52.h"
  2. #include <intrins.h>

  3. #define unchar unsigned char
  4. #define uint unsigned int

  5. sbit scl=P2^1;
  6. sbit sda=P2^0;

  7. unchar dat[4]={'0','0','0','0'};


  8. void delay_4us()
  9. {
  10.         _nop_();
  11.         _nop_();
  12.         _nop_();
  13.         _nop_();
  14.         
  15. }


  16. void delay(uint i)
  17. {
  18.         while(i--);
  19. }

  20. void i2c_init()
  21. {
  22.         scl=0;
  23.         sda=1;
  24.         delay_4us();
  25.         scl=1;
  26.         delay_4us();
  27.         scl=0;
  28. }

  29. void i2c_start()
  30. {
  31.         scl=0;
  32.         delay_4us();
  33.         sda=1;
  34.         delay_4us();
  35.         scl=1;
  36.         delay_4us();
  37.         sda=0;
  38.         delay_4us();
  39.         scl=0;
  40. }


  41. void i2c_stop()
  42. {
  43.         scl=0;
  44.         delay_4us();
  45.         sda=0;
  46.         delay_4us();
  47.         scl=1;
  48.         delay_4us();
  49.         sda=1;
  50.         delay_4us();
  51.         scl=0;
  52.         delay_4us();
  53. }


  54. void i2c_ack(unchar ackbit)
  55. {
  56.         if(!ackbit)
  57.         {
  58.                 sda=0;
  59.         }
  60.         else
  61.         {
  62.                 sda=1;
  63.         }
  64.         delay_4us();
  65.         scl=1;
  66.         delay_4us();
  67.         scl=0;
  68.         delay_4us();
  69.         sda=1;
  70.         delay_4us();
  71.         scl=1;
  72.         delay_4us();
  73.         scl=0;
  74.         
  75. }


  76. bit i2c_waitack()
  77. {
  78.         sda=1;
  79.         delay_4us();
  80.         scl=1;
  81.         delay_4us();
  82.         if(sda)
  83.         {
  84.                 scl=0;
  85.                 i2c_stop();
  86.                 return 0;
  87.         }
  88.         else
  89.         {
  90.                 scl=0;
  91.                 return 1;
  92.         }
  93. }


  94. void i2c_send(unchar byte)
  95. {
  96.         unchar i;
  97.         for(i=0;i++;i<8)
  98.         {
  99.                 if(byte&0x80)
  100.                 {
  101.                         sda=1;
  102.                 }
  103.                 else
  104.                 {
  105.                         sda=0;
  106.                 }
  107.                 delay_4us();
  108.                 byte<<=1;
  109.                 delay_4us();
  110.                 scl=0;
  111.         }
  112.         
  113. }


  114. unchar i2c_receive()
  115. {
  116.         unchar dat,i;
  117.         for(i=0;i<8;i++)
  118.         {
  119.                 scl=1;
  120.                 delay_4us();
  121.                 dat <<=1;
  122.                 if(sda)
  123.                 {
  124.                         dat|=0x01;
  125.                 }
  126.                 scl=0;
  127.                 delay_4us();
  128.         }
  129.         return dat;
  130. }


  131. void ustart_init()
  132. {
  133.         PCON= 0x80;                //????????SMOD
  134.         SCON= 0x50;                //8???,?????
  135.   TMOD= 0x20;                //?????1?8???????
  136.   TL1 = 0xF3;                //??????
  137.   TH1 = 0xF3;
  138.   ET1 = 0;                //?????1??
  139.   TR1 = 1;                //?????1
  140.   ES=1;                                                
  141.   EA=1;
  142. }

  143. void ustart_send(unchar c)
  144. {
  145.         SBUF=c;
  146.         while(!TI);
  147.         TI=0;
  148. }


  149. void main()
  150. {
  151.         unchar temp[12] ="hguangqiang:";
  152.         unchar i,j;
  153.         unchar shuju;
  154.         while(1)
  155.         {
  156.                
  157.                 i2c_start();
  158.                 i2c_send(0x90);
  159.                 i2c_waitack();
  160.                 i2c_send(0x00);
  161.                 i2c_waitack();
  162.                 i2c_send(0x91);
  163.                 i2c_waitack();
  164.                 shuju=i2c_receive();
  165.                 i2c_ack(1);
  166.                 i2c_stop();
  167.                 dat[0]='0'+shuju/1000;
  168.                 dat[1]='0'+shuju%1000/100;
  169.                 dat[2]='0'+shuju%100/10;
  170.                 dat[3]='0'+shuju%10;
  171.                
  172.                 ustart_init();
  173.                 for(i=0;i<12;i++)
  174.                 {
  175.                         ustart_send(temp[i]);
  176.                 }
  177.                 delay(10000);
  178.                 for(j=0;j<4;j++)
  179.                 {
  180.                         ustart_send(dat[j]);
  181.                 }
  182.                 delay(10000);
  183.                
  184.         }

  185. }

  186.         
  187.         


  188. void zhognduan() interrupt 4
  189. {
  190.         unchar receiveData;
  191.         RI=0;
  192.         receiveData=SBUF;
  193.         SBUF=receiveData;
  194.         while(!TI);
  195.         TI=0;
  196. }
复制代码
回复

使用道具 举报

ID:507540 发表于 2019-4-30 09:12 | 显示全部楼层
感觉程序上没大问题,可能是硬件上的问题,是不是用光敏电阻和固定电阻的分压啊,建议使用下vcc和GND间用个蓝白可调电阻来分压当做模拟输入量,这几天我也在研究这个芯片。。。
程序上感觉dat[4]没必要,输出数字量最大为255,用dat[3]不就可以了?
回复

使用道具 举报

ID:849422 发表于 2020-11-29 19:47 来自手机 | 显示全部楼层
楼主解决了吗?我也是这样的问题,头都快炸了
回复

使用道具 举报

ID:960769 发表于 2021-8-25 10:13 | 显示全部楼层
楼主解决了码?我也遇到了同样的问题,求解答
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表