ad转换

  • B5MA82A905
    了解作者
  • C/C++
    开发工具
  • 91KB
    文件大小
  • rar
    文件格式
  • 0
    收藏次数
  • 5 积分
    下载积分
  • 0
    下载次数
  • 2022-06-30 11:10
    上传日期
ad转换及显示。。。。。。。。。。。。。
AD转换及显示.rar
  • AD转换及显示
  • source
  • output
  • ADandDisplay.lnp
    127B
  • ADandDisplay.plg
    170B
  • SRTT_II main.obj
    27KB
  • ADandDisplay.hex
    5KB
  • BitSet.plg
    171B
  • BitSet.lnp
    115B
  • BitSet
    36.2KB
  • ADandDisplay
    23.7KB
  • STARTUP.obj
    787B
  • BitSet_Opt.Bak
    1.4KB
  • ADandDisplay.m51
    26.8KB
  • SRTT_II main.OBJ
    33.7KB
  • STARTUP.OBJ
    749B
  • BitSet_Uv2.Bak
    2.2KB
  • BitSet.plg
    21.6KB
  • BitSet.lnp
    66B
  • BitSet
    28.9KB
  • BitSet.M51
    41.1KB
  • STARTUP.A51
    6.2KB
  • SRTT_II main.c
    11.7KB
  • BitSet.uvproj
    13.3KB
  • BitSet.uvopt
    55.5KB
  • STC12C.h
    1.3KB
  • STARTUP.LST
    13.8KB
  • BitSet_uvopt.bak
    55.5KB
  • BitSet.opt.bak
    1.2KB
  • SRTT_II main.LST
    23.7KB
  • BitSet.Uv2.bak
    2.2KB
内容介绍
#include <reg52.h> #include <STC12C.h> #include <intrins.h> sbit LCD_RS=P3^2; /*LCD寄存器选择信号*/ sbit LCD_R_W=P3^3; /*LCD读写信号*/ sbit LCD_E=P3^4; /*LCD片选信号*/ //变量类型标识的宏定义,大家都喜欢这么做 #define Uchar unsigned char #define Uint unsigned int #define uchar unsigned char #define uint unsigned int /* 定义命令 */ #define ISP_IAP_BYTE_READ 0x01 /* 字节读数据存储区 */ #define ISP_IAP_BYTE_PROGRAM 0x02 /* 字节编程数据存储区 */ #define ISP_IAP_SECTOR_ERASE 0x03 /* 扇区擦除数据存储区 */ /* 定义Flash 操作等待时间 */ #define ENABLE_ISP 0x84 #define DATA_FLASH_START_ADDRESS 0x2800 typedef unsigned char INT8U; /* 8 bit 无符号整型 */ typedef unsigned int INT16U; /* 16 bit 无符号整型 */ #define DELAY_CONST 60000 /* 定义常量 */ #define ERROR 0 #define OK 1 // 控制引脚定义,不同的连接必须修改的部分 sbit RS=P3^2; sbit RW=P3^3; sbit Elcm=P3^4; sbit SelA=P1^1; sbit SelB=P3^7; sbit PA=P1^5; sbit PB=P1^6; sbit PC=P1^7; unsigned int data AdcMem; unsigned char data tempAdc; unsigned char lcd_data[5]; unsigned int i,k,j; unsigned char disp_bool; unsigned char tempC; unsigned char overflag; unsigned char changeflag; #define DataPort P2 // 数据端口 #define Busy 0x80 #define uchar unsigned char #define uint unsigned int #define ulong unsigned long #define _Nop() _nop_() unsigned int thinkness; char idata word_storeroom[]= {'0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'}; void Delay400Ms(void); void Delay5Ms(void); void WaitForEnable( void ); void LcdWriteData( char dataW ); void LcdWriteCommand( Uchar CMD,Uchar AttribC ); void LcdReset( void ); void Display( Uchar dd ); void DispOneChar(Uchar x,Uchar y,Uchar Wdata); //void ePutstr(Uchar x,Uchar y, Uchar code *ptr); void SmallCur(void); void BigCur(void); void send(uchar i); /*======================================================= 显示字符串 =======================================================*/ /*void ePutstr(Uchar x,Uchar y, Uchar code *ptr) { Uchar i,l=0; while (ptr[l] >31) {l++;}; for (i=0;i<16;i++) { DispOneChar(x++,y,ptr[i]); if ( x == 16 ){ x = 0; y ^= 1; } } }*/ /*======================================================= 演示一行连续字符串,配合上位程序演示移动字串 =======================================================*/ /*void Display( Uchar dd ) { Uchar i; for (i=0;i<16;i++) { DispOneChar(i,1,dd++); dd &= 0x7f; if (dd<32) dd=32; } }*/ /*======================================================= 显示光标定位 =======================================================*/ void Disp_XY( char posx,char posy) { uchar temp; temp = posx %40;// & 0x07; posy &= 0x01; if ( posy==1) {temp |= 0x40;} temp |= 0x80; LcdWriteCommand(temp,1); } /*======================================================= 按指定位置显示数出一个字符 =======================================================*/ void DispOneChar(Uchar x,Uchar y,Uchar Wdata) { Disp_XY( x, y ); // 定位显示地址 LcdWriteData( Wdata ); // 写字符 } /*======================================================= 初始化程序, 必须按照产品资料介绍的初始化过程进行 =======================================================*/ void LcdReset( void ) { LcdWriteCommand( 0x38, 0); // 显示模式设置(不检测忙信号) Delay5Ms(); LcdWriteCommand( 0x38, 0); // 共三次 Delay5Ms(); LcdWriteCommand( 0x38, 0); Delay5Ms(); LcdWriteCommand( 0x38, 1); // 显示模式设置(以后均检测忙信号) LcdWriteCommand( 0x08, 1); // 显示关闭 LcdWriteCommand( 0x01, 1); // 显示清屏 LcdWriteCommand( 0x06, 1); // 显示光标移动设置 LcdWriteCommand( 0x0c, 1); // 显示开及光标设置 LcdWriteCommand( 0x02, 1); // 显示开及光标设置 } /*======================================================= 写控制字符子程序: E=1 RS=0 RW=0 =======================================================*/ void LcdWriteCommand( Uchar CMD,Uchar AttribC ) { if (AttribC) WaitForEnable(); // 检测忙信号? RS = 0; RW = 0; _nop_(); DataPort = CMD; _nop_(); // 送控制字子程序 Elcm = 1;_nop_();_nop_();Elcm = 0; // 操作允许脉冲信号 } /*======================================================= 当前位置写字符子程序: E =1 RS=1 RW=0 =======================================================*/ void LcdWriteData( char dataW ) { WaitForEnable(); // 检测忙信号 RS = 1; RW = 0; _nop_(); DataPort = dataW; _nop_(); Elcm = 1; _nop_(); _nop_(); Elcm = 0; // 操作允许脉冲信号 } /*======================================================= 正常读写操作之前必须检测LCD控制器状态: CS=1 RS=0 RW=1 DB7: 0 LCD控制器空闲; 1 LCD控制器忙 ========================================================*/ void WaitForEnable( void ) { DataPort = 0xff; RS =0; RW = 1; _nop_(); Elcm = 1; _nop_(); _nop_(); while( DataPort & Busy ); Elcm = 0; } // 短延时 void Delay5Ms(void) { Uint i = 5552; while(i--); } //长延时 void Delay400Ms(void) { Uchar i = 5; Uint j; while(i--) { j=7269; while(j--); }; } void delay(unsigned int t) //延时 { unsigned int i, j; for(i=0;i<t;i++) { for(j=0;j<10;j++) {;} } } uint Adc(unsigned char n) { unsigned char i; uint result=0; ADC_CONTR = ADC_CONTR|0x80; delay(10); i = 0x01<<n; P1M0 = P1M0|i; P1M1 = P1M1|i; delay(10); ADC_CONTR = 0xE0|n; delay(10); ADC_DATA = 0; ADC_LOW2 = 0; ADC_CONTR = ADC_CONTR|0x08; delay(10); ADC_CONTR = ADC_CONTR&0xE7; result = ADC_DATA; result<<=2; result = result&0x03FC; result = result|(ADC_LOW2 & 0x03); return(result); } void cominit(void) { SCON=0X50; TMOD=0X20; TH1=0xfd; TL1=0xfd; TR1=1; //ES=1; //EA=1; } uint Adc6(void) { uint i,j,k; uint result=0; uint Tmin=0x3ff,Tmax=0; ulong T_tatol=0; uint temp1; uint comp; k=0; j=0; overflag=1; comp=3;// AdcMem; //值保存 for(i=0;i<1000;i++) { temp1=Adc(2);// AdcMem; //值保存 if(temp1<comp) { result=Adc(1);// AdcMem; //值保存 temp1=Adc(2);// AdcMem; //值保存 if(temp1>comp) continue; } else { j++; if(j>900) return 0; continue; } k++; if(Tmin>result) Tmin=result; if(Tmax<result) Tmax=result; T_tatol=T_tatol+result; if(k==21) { T_tatol=T_tatol-Tmin; T_tatol=T_tatol-Tmax; T_tatol>>=2; overflag=0; return((uint)T_tatol); } } return 0; } //void disptempC(uchar data1) //{ // tempAdc = data1%0x000A; // lcd_data[0] = word_storeroom[tempAdc]; // data1 = data1/0x000A; // tempAdc = data1%0x000A; // lcd_data[1] = word_storeroom[tempAdc]; // data1 = data1/0x000A; // tempAdc = data1%0x000A; // lcd_data[2] = word_storeroom[tempAdc]; // // //显示BCD码 // DispOneChar(4,0,lcd_data[2]); // DispOneChar(5,0,'.'); // DispOneChar(6,0,lcd_data[1]); // DispOneChar(7,0,lcd_data[0]); //} void send(uchar i) { TI=0; SBUF=i; while(TI==0); TI=0; } void dispint(uint data1) { uint tempAdc; tempAdc = data1%0x000A; lcd_data[0] = word_storeroom[tempAdc]; data1 = data1/0x000A; tempAdc = data1%0x000A; lcd_data[1] = word_storeroom[tempAdc]; data1 = data1/0x000A; tempAdc = data1%0x000A; lcd_data[2] = word_storeroom[tempAdc]; //显示BCD码 DispOneChar(4,1,lcd_data[2]); DispOneChar(5,1,'.');
评论
    相关推荐
    • AD7988.zip
      AD7988芯片的控制和采样时序,可以作为测试程序进行验证
    • AD元件库
      AD元件库,大家可以在学习过程中应用到元件库,在AD实验都需要
    • ad学习资料
      ad9学习资料。。。。。。。。。。。。。
    • AD绘制 PCB
      AD用于绘制PCB,安装简单方便易懂,可以尝试。
    • RD-AD
      #RD-AD(广告请求-检测) 此脚本有助于实时检测,跟踪和阻止来自AD的恶意请求,攻击或收集信息请求,以保护诸如BloodHound,Mimikatz之类的有价值的信息(帐户管理员,密码和GPO ...) .... 它们允许轻松读取事件...
    • AD770X.zip
      AD采集模块,2路AD,基于arduino代码。
    • AD5791.rar
      AD5791,驱动,stm32f407平台
    • AD9517_Gerber.zip
      AD9517时钟芯片相关资料,可用于picozed开发,picozed平台高速时钟
    • AD5254.rar
      AD5254 digital potentiometer test board
    • AD.zip
      基于单片机的ad转换程序以及其程序和原理仿真图