产生波形实验(DA转换)

/*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
  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值