/*DA转换实验 例如产生锯齿波*/ 



 #include <reg52.h> 



 unsigned char xdata ad_cs0   _at_  0xc000; 

 unsigned char xdata ad_cs1   _at_  0xc001 ; 

 unsigned char xdata key_seg   _at_  0xd004; 

 unsigned char xdata key_bit   _at_  0xd002; 



 sbit EOC=P3^2; 

 unsigned char disp_ram[6]; 

 unsigned char seg7[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f, 

                       0x77,0x7c,0x39,0x5e,0x79,0x71,0,0x80}; 

 unsigned char scan[]={0x01,0x02,0x04,0x08,0x10,0x20}; 



 void delay() 

 { 

   unsigned char i,j; 

   for (i=0;i<200;i++) 

     for (j=0;j<2;j++); 

 } 



 void main() 

 { 

    unsigned char i=0; 

    unsigned char ad_value; 

    unsigned char tmp,a; 







     disp_ram[0]=17; 

     disp_ram[1]=16; 

     disp_ram[2]=16; 

     disp_ram[3]=16; 

     disp_ram[4]=16; 

     disp_ram[5]=16; 



     ad_cs0=0; 



     while(1) 

     { 

        key_bit=scan[i]; 

        a=seg7[disp_ram[i]]; 

        if (i==5) 

           a=a|0x80; 

        key_seg=a; 

        delay(); 

        i++; 

        i=i%6  ; 



        if (EOC) 

        { 

           ad_value=ad_cs0; 

           disp_ram[5]=ad_value*5/256; 

           tmp=(ad_value*5)%256; 

           disp_ram[4]=tmp/100; 

           disp_ram[3]=(tmp%100)/10; 

        } 

        ad_cs0=0; 

     } ; 





 }




DA转换 Code