找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索

单片机adc0832获取光照强度,lcd一直显示255

查看数: 996 | 评论数: 5 | 收藏 0
关灯 | 提示:支持键盘翻页<-左 右->
    组图打开中,请稍候......
发布时间: 2023-3-25 01:02

正文摘要:

uchar ADC_read_data(uchar CH) {     uchar i,test,adval;     adval = 0x00;     test = 0x00;     CLK = 0;       //初始化     D ...

回复

ID:757219 发表于 2023-3-26 17:55
已解决,换了一个ADC0832.dll文件
ID:757219 发表于 2023-3-26 17:38
我用了别人的光照程序依旧不变,我已经开始怀疑是proteus的问题了,但我换了一个proteus8.13还是没用
ID:757219 发表于 2023-3-26 17:16
angmall 发表于 2023-3-25 15:06
应该是时序的问题。

我用了您的程序并没有得到解决。我认为是adc0832程序读取的问题,使电阻改变lcd得不到改变,不知您有什么见解
ID:915071 发表于 2023-3-26 15:00
感觉没什么问题呀,我跟你一样的adc读取程序,除了显示部分有区别外,基本一致,我的能正常显示。
#include "reg51.h"
#include<intrins.h>
#include "lcd.h"
#define uint unsigned int
#define uchar unsigned char


uchar getdata=0;
unsigned char dat = 0;
unsigned long int voltage = 0;
sbit CLK = P2^0;
sbit CS = P2^1;
sbit dio1 = P2^2;
sbit dio0 = P2^2;

uchar ADC0832_Read(uchar CH)
{
        unsigned char adval,test,i;
        adval = 0x00;
        test = 0x00;
        CLK = 0;
        dio1 = 1;
        _nop_();
        CS = 0;
        _nop_();
        CLK = 1;
        _nop_();
        if(CH == 0x00)
        {
                CLK = 0;
                dio1 = 1;
                _nop_();
                CLK = 1;
                _nop_();
                CLK = 0;
                dio1 = 0;
                _nop_();
                CLK = 1;
                _nop_();
        }
        else
        {
                CLK = 0;
                dio1 = 1;
                _nop_();
                CLK = 1;
                _nop_();
                CLK = 0;
                dio1 = 1;
                _nop_();
                CLK = 1;
                _nop_();       
        }
        CLK = 0;
        dio1 = 1;
        for(i=0;i<8;i++)
        {
                _nop_();
                adval<<=1;
                CLK = 1;
                _nop_();
                CLK = 0;
                if(dio0)
                adval |= 0x01;
                else
                adval |= 0x00;
        }
        for(i=0;i<8;i++)
        {
                test>>=1;
                if(dio0)
                test |= 0x80;
                else
                test |= 0x00;
                _nop_();
                CLK = 1;
                _nop_();
                CLK = 0;
        }
//        if(test == adval)
        getdata = test;
        _nop_();
        CS = 1;
        dio0 = 1;
        CLK = 1;
        return getdata;

}

void ADC_change(uchar input)
{
        unsigned char ADC[4] = {0};
       
        voltage = input*5000.0/255;

         ADC[0] = voltage/1000;
         ADC[1] = voltage/100%10;
         ADC[2] = voltage/10%10;
         ADC[3] = voltage%10;
         LcdWriteCom(0x80);
         //LcdWriteCom(0x81);
         LcdWriteData('0'+ADC[0]);
         //LcdWriteCom(0x82);
         LcdWriteData('0'+ADC[1]);
         //LcdWriteCom(0x83);
         LcdWriteData('0'+ADC[2]);
        // LcdWriteCom(0x84);
         LcdWriteData('0'+ADC[3]);
         //LcdWriteCom(0x86);
         LcdWriteData('m');
         LcdWriteData('v');
}

void main()
{
        LcdInit();
        while(1)
        {
                dat = ADC0832_Read(0x00);
                ADC_change(dat);       
        }
}
ID:155507 发表于 2023-3-25 15:06
应该是时序的问题。


  1. unsigned char Get_AD_Result()
  2. {
  3.         unsigned char i,dat1=0,dat2=0;
  4.         CS  = 0; //起始控制位
  5.         CLK = 0;
  6.         DIO = 1; _nop_(); _nop_();
  7.         CLK = 1; _nop_(); _nop_();
  8.         CLK = 0;DIO = 1; _nop_(); _nop_(); //第一个下降沿之前,设DI= 1/0
  9.         CLK = 1; _nop_(); _nop_();         //轩子单端/差分(SGL/DIF)模式中的单端输入模式
  10.         CLK = 0;DIO = 1; _nop_(); _nop_(); //第二个下降沿之前,设DI = 0/1,选择CH0/CH1
  11.         CLK = 1;DIO = 1; _nop_(); _nop_();
  12.         CLK = 0;DIO = 1; _nop_(); _nop_(); //第三个下降沿之前,设DI = 1
  13.         for(i=0;i<8;i++)    //第4~11个下降沿读数据(MSB->LSB)
  14.         {
  15.                  CLK = 1; _nop_(); _nop_();
  16.                 CLK = 0; _nop_(); _nop_();
  17.                 dat1 = dat1 << 1 | DIO;       
  18.         }
  19.         for(i=0;i<8;i++)  //第11~18个下降沿读数据(LSB->MSB)
  20.         {
  21.                  dat2 = dat2 << ((unsigned char)(DIO)<<i);
  22.                 CLK = 1; _nop_(); _nop_();
  23.                 CLK = 0; _nop_(); _nop_();
  24.         }
  25.         CS = 1;
  26.         return (dat1 == dat2) ? dat1:0; //如果MSB->LSB和LSB->MSB读取的结果相同,则返回读取的结果,否则返回0
  27. }

复制代码

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

Powered by 单片机教程网

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