/*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