s3c2440的A/D转换应用

发布者:平和宁静最新更新时间:2016-05-30 来源: eefocus关键字:s3c2440  AD转换 手机看文章 扫描二维码
随时随地手机看文章
   A/D转换,又称为模数转换,是将模拟信号转换为计算机能够处理的数字信号。s3c2440集成了8通道10位CMOS A/D转换器。
 
       对于s3c2440来说,实现A/D转换比较简单,主要应用的是ADC控制寄存器ADCCON和ADC转换数据寄存器ADCDAT0。寄存器ADCDAT0的低10位用于存储A/D转换后的数据。寄存器ADCCON的第15位用于标识A/D转换是否结束。第14位用于使能是否进行预分频,而第6位到第13位则存储的是预分频数值,因为A/D转换的速度不能太快,所以要通过预分频处理才可以得到正确的A/D转换速度,如我们想要得到A/D转换频率为1MHz,则预分频的值应为49。第3位到第5位表示的是A/D转换的通道选择。第2位可以实现A/D转换的待机模式。第1位用于是否通过读取操作来使能A/D转换的开始。第0位则是在第1位被清零的情况下用于开启A/D转换。
 
       下面我们就给出一个A/D转换的实例。我们在AIN2引脚上接了一个温度传感器,被检测的温度范围为0度~99度,它对应于A/D转换数据的0~0x3FF。检测到的温度被实时地显示在LCD上,这里我们只显示温度的整数部分。由于要实时显示数据,因此就涉及到LCD刷新的问题,如果处理得不好,会出现LCD闪烁的现象。所以在程序中,我们只对要刷新的区域进行刷新处理,而对其他区域不更新,这样就有效地防止了LCD的闪烁。
 
 
……  ……
unsigned char degree[]=                      //℃                48×48字模
{
……  ……
};
unsigned char colon[]=                       //:                48×48字模
{
……  ……
};
unsigned char du[]=                            //度                48×48字模
{
……  ……
};
unsigned char wen[]=                         //温                48×48字模
{
……  ……
};
unsigned char digital[]=                      //0~9的ASCII码字符数组                24×48字模
{
……  ……
};
 
//重新改写刷屏的程序,确定了要刷屏的区域范围
void Brush_Background( int x,int y,int width,int height,U32 c)
{
       int i,j ;
             
for( j = y ; j        {
       for( i = x ; i < width ; i++ )
              {
                     LCD_BUFFER[j][i] = c ;
       }
       }
}
 
int readADC(void)
{
       rADCCON = (1<<14)|(49<<6)|(2<<3);              //设置预分频器和A/D通道
      
       rADCCON|=0x1;                                      //启动A/D转换
 
       while(rADCCON & 0x1)
              ;                                                //确认A/D转换是否开始
       while(!(rADCCON & 0x8000))
              ;                                                //等待A/D转换的结束
 
       return ( (int)rADCDAT0 & 0x3ff );      //读取A/D转换的数据
}
 
void Main(void)
{
       int temperature,oldTemp;
       unsigned char value[2],oldValue;
 
LCD_Init();   
       rLCDCON1|=1;
   
Brush_Background(0,0,LCD_WIDTH,LCD_HEIGHT,0xFFFFFF);          //刷写这个LCD
       Draw_Text48(16,96,0xff0000,wen)  ;
Draw_Text48(64,96,0xff0000,du)  ;
       Draw_Text48(112,96,0xff0000,colon)  ;
Draw_Text48(208,96,0xff0000,degree)  ;
 
oldTemp=0;
       oldValue=0;
  
while(1)
       {
          
       temperature = (int)readADC()*99/0x3ff;                   //读取温度
              if(oldTemp != temperature)                        //判断温度是否有变化
       {
                     oldTemp = temperature;
                    
                     value[0] = (unsigned char)temperature/10;                 //温度的十位数据
              value[1] = (unsigned char)temperature%10;               //温度的个位数据
                     if(oldValue!=value[0])                        //十位数据没有变化就不需要更新
              {
                            oldValue=value[0];
                     Brush_Background(150,96,150+24,96+48,0xFFFFFF);             //刷新十位数据的区域
                            Draw_ASCII(150,96,0xff0000,digital+144*value[0]);                     //显示十位数据
              }
                     Brush_Background(174,96,174+24,96+48,0xFFFFFF);                    //刷新个位数据区域
              Draw_ASCII(174,96,0xff0000,digital+144*value[1]);                            //显示个位数据
              }
       delay(1000000);
       }
}
 

 
既然可以上传图片了,我就把LCD显示的结果给大家展示一下!
 
 
 

 
 
鉴于有一些网友向我索要Draw_Text48函数和Draw_ASCII函数,那么我就索性把它们也贴出来。
 
void PutPixel(U32 x,U32 y, U32 c )
{
LCD_BUFFER[y][x] = c;
}
 
//48*48
void Draw_Text48(U32 x,U32 y,U32 color,unsigned char ch[])
{
       unsigned short int i,j;
       unsigned char mask,buffer;
      
       for(i=0;i<48;i++)
       {
              mask=0x80;
              buffer=ch[i*6];
              for(j=0;j<8;j++)
              {
                    
                     if(buffer&mask)
                     {
                            PutPixel(x+j,y+i,color);
                     }
                     mask=mask>>1;                  
              }
              mask=0x80;
              buffer=ch[i*6+1];
              for(j=0;j<8;j++)
              {
                    
                     if(buffer&mask)
                     {
                            PutPixel(x+j+8,y+i,color);
                     }
                     mask=mask>>1;                  
              }
             
              mask=0x80;
              buffer=ch[i*6+2];
              for(j=0;j<8;j++)
              {
                    
                     if(buffer&mask)
                     {
                            PutPixel(x+j+16,y+i,color);
                     }
                     mask=mask>>1;                  
              }
              mask=0x80;
              buffer=ch[i*6+3];
              for(j=0;j<8;j++)
              {
                    
                     if(buffer&mask)
                     {
                            PutPixel(x+j+24,y+i,color);
                     }
                     mask=mask>>1;                  
              }
             
              mask=0x80;
              buffer=ch[i*6+4];
              for(j=0;j<8;j++)
              {
                    
                     if(buffer&mask)
                     {
                            PutPixel(x+j+32,y+i,color);
                     }
                     mask=mask>>1;                  
              }
              mask=0x80;
              buffer=ch[i*6+5];
              for(j=0;j<8;j++)
              {
                    
                     if(buffer&mask)
                     {
                            PutPixel(x+j+40,y+i,color);
                     }
                     mask=mask>>1;                  
              }
       }
}
 
//24*48 for ASCII
void Draw_ASCII(U32 x,U32 y,U32 color,const unsigned char ch[])
{
       unsigned short int i,j;
       unsigned char mask,buffer;
      
       for(i=0;i<48;i++)
       {
              mask=0x80;
              buffer=ch[i*3];
              for(j=0;j<8;j++)
              {
                    
                     if(buffer&mask)
                     {
                            PutPixel(x+j,y+i,color);
                     }
                     mask=mask>>1;                  
              }
             
              mask=0x80;
              buffer=ch[i*3+1];
              for(j=0;j<8;j++)
              {
                    
                     if(buffer&mask)
                     {
                            PutPixel(x+j+8,y+i,color);
                     }
                     mask=mask>>1;                  
              }
             
              mask=0x80;
              buffer=ch[i*3+2];
              for(j=0;j<8;j++)
              {
                    
                     if(buffer&mask)
                     {
                            PutPixel(x+j+16,y+i,color);
                     }
                     mask=mask>>1;                  
              }
       }
}
关键字:s3c2440  AD转换 引用地址:s3c2440的A/D转换应用

上一篇:s3c2440的触摸屏应用与校正
下一篇:s3c2440的IIC应用——读写AT24C02A

推荐阅读最新更新时间:2024-03-16 14:55

1.8.2_S3C2440_LCD控制器_P
LCD控制器主要有两个功能,第一是从内存中取出某个像素的数据,第二,配合其他信号把这个数据发给LCD,怎么配合其他信号发送数据则需要阅读LCD的芯片手册,知道LCD的时序要求,设置LCD控制器。 实际上,不管是2440或其他型号的ARM芯片,他们的功能都是一样的,只是控制器略有差异。简单说,就分为两个。 取数据:从FrameBuffer中将数据取出来,需要先把FrameBuffer的地址告诉LCD控制器,还需要将BPP,分辨率告诉LCD控制器。 发数据:把时序告诉LCD控制器,设置引脚的极性(某些LCD是在时钟的下降沿取数据,某些是在上升沿;某些行同步信号HSYNC是在低电平有效,某些是在高电平有效,这些都需要阅读LC
[单片机]
1.8.2_S3C2440_LCD控制器_P
s3c2440裸板_中断体系结构
S3C2440一共有60个中断源,其中有15个子中断源,它们与SUBSRCPND寄存器中的每一位相对应,其他45个中断源与SRCPND中的每一位相对应。要注意的是EINT4~7对应的是同一位SRCPND ,而EINT8~23对应的也是SRCPND 一位 1 S3C2440的中断寄存器 中断分两大类:外部中断和内部中断。 1.1 外部中断寄存器 24个外部中断占用GPF0-GPF7(EINT0-EINT7),GPG0-GPG15(EINT8-EINT23)。用这些脚做中断输入,则必须配置引脚为中断,并且不要上拉。具体可参考datesheet数据手册。 寄存器: EXTINT0-EXT
[单片机]
<font color='red'>s3c2440</font>裸板_中断体系结构
基于S3C2440处理器和Windows CE实现电能计量带电核查仪系统的设计
随着我国经济的迅速发展,大规模工业用电和商业用电需求快速增长。我国城乡普遍使用的国家电压标准10 kV及以上的高压供电系统,出于对供电可靠性及变损的考虑,10KV及以上的工业供电多数采用高压供电高压计量(简称高供高计)的计量方式。但是对现有的计量装置核查时,为了保障现场操作人员的安全,需要断电后才能对高供高计进行检查和数据读取,这给用户的正常用电造成了很大不便。由于受高供高计设备带高压电的特殊性和困难性的影响,目前国内对高供高计设备的检测设备还很少,但市场很需要。 电能计量带电核查仪系统主要用于对10 kV及10 kV以上带电设备的核查、探伤和数据采集。具有采集高供高计电力设备的各方位外观图像信息,可以很方便在计算机或笔记本电
[单片机]
基于<font color='red'>S3C2440</font>处理器和Windows CE实现电能计量带电核查仪系统的设计
s3c2440学习之路-006 clock的设置
1.基本知识 1.1clock模块介绍 2440主要的时钟有4个2个PLL:FCLK,HCLK,PCLK,UCLK;MPLL,UPLL。 FCLK是给CPU用的,频率最高。HCLK是给高速外设用的,如LCD、NAND Flash、Camera。 PCLK是给低速外设用的,如UART,IIS,IIC等。HCLK和PCLK都是从FCLK分频得到的。UCLK是专门给USB使用的。 MPLL, UPLL主要是用来升频的,将外部的晶振(jz2440为12M)升频到需要频率。 MPLL是用来给FCLK升频的,UPLL则是给UCLK升频的。 本博客主要介绍FCLK,HCLK,PCLK和MPLL;ULCK和UPLL暂时不讲。 1.
[单片机]
<font color='red'>s3c2440</font>学习之路-006 clock的设置
基于S3C2440微处理器的工业超声探伤仪设计
  超声波探伤仪的种类繁多,但在实际的探伤过程,脉冲反射式超声波探伤仪应用的最为广泛。一般在均匀的材料中,缺陷的存在将造成材料的不连续,这种不连续往往又造成声阻抗的不一致,由反射定理我们知道,超声波在两种不同声阻抗的介质的交界面上将会发生反射,反射回来的能量的大小与交界面两边介质声阻抗的差异和交界面的取向、大小有关。脉冲反射式超声波探伤仪就是根据这个原理设计的。   超声探伤时,应用得最多的是A型显示,如图1所示。在A型显示中,横坐标代表被测物的深度,纵坐标代表回波信号的幅度。   本文利用ARM9芯片和高速FPGA数据采集及信号处理技术,在Linux操作系统平台上设计并实现了一种新型数字超声探伤仪。该探伤仪具有高性能、低
[单片机]
基于<font color='red'>S3C2440</font>微处理器的工业超声探伤仪设计
S3C2440 跳到 SDRAM 中执行程序
从Nandflash启动CPU时,CPU会通过内部的硬件将Nandflash开始的4KB数据复制到为Steppingstone的4Kb的内部RAM中(起始地址为0) 然后跳到0地址开始执行. 我们这个例子是先使用汇编语言设置好存储控制器,使我们外接的SDRAM可用,然后把程序本身从Steppingstone复制到SDRAM处, 最后跳到SDRAM中执行. 程序的什么关看门狗,设置存储控制器,复制代码到SDRAM中都比较简单, 程序跳入到C程序之前要设置栈供C程序使用!!! ldr sp, =0x34000000 @ 设置堆栈 栈设置在顶部,自上而下. 写这篇记录博客的原因最重要的是:
[单片机]
<font color='red'>S3C2440</font> 跳到 SDRAM 中执行程序
十五、S3C2440裸机—系统时钟和定时器
15.1 介绍   CPU 的时钟控制逻辑既可以外接晶振,然后通过内部电路产生时钟源;也可以直接使用外部提供的时钟源,它们通过引脚的设置来选择。S3C2440A有两个锁相环,(MPLL)一个用于FCLK、PCLK和HCLK,(UPLL)另一个用于USB模块(48MHZ)。时钟控制逻辑给整个芯片提供三种时钟: FCLK:用于CPU 核 HCLK:用于 AHB 总线上设备,比如CPU核、存储器控制器、中断控制器、LCD控制器、DMA 和 USB 主机模块等 PCLK:用于 APB 总线上的设备,比如 WATCHDOG、IIS、IIC、PWM 定时器、MMC 接口、ADC、UART、GPIO、RTC 和 SPI   AHB(Ad
[单片机]
十五、<font color='red'>S3C2440</font>裸机—系统时钟和定时器
(一)s3c2440——GPIO(流水灯实验)
一、GPIO流水灯实验 1、实验目的   a:掌握GPIO的使用方法   b:熟悉Linux下编程的方法 2、实验内容   通过控制GPIO引脚来使LED显示 3、主要程序:   a:start.S文件是启动文件。第一个开始的程序。它实现的功能是关闭看门狗(不关闭会一直重启),并且设置堆栈(调用c函数之前必须设置堆栈)。   b:Makefile文件。它是进行编译链接生成可执行文件。   c:blink.c文件。实现主要功能,使led灯实现流水的效果 4、GPIO主要操作两个寄存器GPXCON和GPXDAT。前者设置引脚的模式(输出、输入、中断等),后者设置引脚的电平。   但是在操作过程中,出现了
[单片机]
(一)<font color='red'>s3c2440</font>——GPIO(流水灯实验)
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved