找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 3652|回复: 0
收起左侧

基于51单片机的波形发生器和电子密码锁仿真与源码

[复制链接]
ID:297063 发表于 2018-3-26 09:35 | 显示全部楼层 |阅读模式
这里面包含了波形发生器和电子密码锁的防真及程序,暂时只是部分图片浏览详细大家可以去看压缩包。

仿真原理图如下(proteus仿真工程文件可到本帖附件中下载)
原理图.png 工.png fuwei.png
0.png

所有资料51hei提供下载:
caiwenjun.rar (253.27 KB, 下载次数: 35)


单片机源程序如下:
  1.                                                  
  2.                                           #include<reg52.h>
  3. #define uchar unsigned char
  4. #define uint unsigned int


  5. sbit csda=P3^2;                                                                                          //定义DA的CS端口
  6. sbit wr=P3^6;
  7.                                                                                                 //定义DA的WR端口
  8. sbit s1=P3^4;
  9. sbit s2=P3^5;                                                                                          //定义两个按键

  10. uchar k=0,p=0,delay=0;
  11. uchar bxxz=0;pinglv=0;
  12. uchar a=1,b=0,c=0,d=0,e=0;

  13. uchar code sin[64]={
  14. 135,145,158,167,176,188,199,209,218,226,234,240,245,249,252,254,254,253,251,247,243,237,230,222,213,204,193,182,170,158,
  15. 146,133,121,108,96,84,72,61,50,41,32,24,17,11,7,3,1,0,0,2,5,9,14,20,28,36,45,55,66,78,90,102,114,128
  16. };                                                                                                                 //正弦波
  17. uchar code juxing[64]={
  18. 255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,
  19. 255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0
  20. };                                                                                                                //矩形波
  21. uchar code juchi[64]={
  22. 0,4,8,12,16,20,24,28,32,36,40,45,49,53,57,61,65,69,73,77,81,85,89,93,97,101,105,109,113,117,121,125,130,134,138,142,
  23. 146,150,154,158,162,166,170,174,178,182,186,190,194,198,202,206,210,215,219,223,227,231,235,239,243,247,251,255
  24. };                                                                                                                //锯齿波
  25. uchar code tixing[64]={
  26. 0,13,26,39,52,65,78,91,104,117,130,143,156,169,182,195,208,221,234,247,247,247,247,247,247,247,247,247,247,247,247,247,247,247,247,247,247,247,
  27. 247,247,247,247,247,247,247,242,229,216,203,190,177,164,151,138,125,112,99,86,73,60,47,34,21,8
  28. };                                                                                                                //梯形波
  29. uchar code sanjiao[64]={
  30. 0,8,16,24,32,40,48,56,64,72,80,88,96,104,112,120,128,136,144,152,160,168,176,184,192,200,208,216,224,232,240,248,
  31. 248,240,232,224,216,208,200,192,184,176,168,160,152,144,136,128,120,112,104,96,88,80,72,64,56,48,40,32,24,16,8,0
  32. };                                                                                                                //三角波
  33. void delay1()                                                                               
  34. {
  35.         int a,b;
  36.         for(a=1;a>0;a--)
  37.                 for(b=122;b>0;b--);                                                                //延时函数
  38. }
  39. void key1(void)                                                                                        //频率选择,独立按键1
  40. {       
  41.         if(s1==0)
  42.         {
  43.                 delay1();
  44.                 if(s1==0)                                                                          //按键按下               
  45.                 {
  46.                         p++;                                                                         //p频率选择参数
  47.                         if(p==8)
  48.                         p=0;
  49.                         switch(p)
  50.                         {
  51.                                 case 1 :
  52.                                         pinglv=3;
  53.                                         break;
  54.                                 case 2 :
  55.                                         pinglv=6;
  56.                                         break;       
  57.                                 case 3 :
  58.                                         pinglv=9;
  59.                                         break;
  60.                                 case 4 :
  61.                                         pinglv=12;
  62.                                         break;
  63.                                 case 5 :
  64.                                         pinglv=15;
  65.                                         break;
  66.                                 case 6 :
  67.                                         pinglv=18;
  68.                                         break;
  69.                                 case 7 :
  70.                                         pinglv=21;
  71.                                         break;                               
  72.                                 default :
  73.                                         pinglv=0;
  74.                                         break;
  75.                         }
  76.                         while(!s1);                                                   ///等待按键松开       
  77.                 }
  78.         }
  79. }
  80. void key2(void)                                                                        //波形选择,按键2
  81. {                       
  82.         if(s2==0)
  83.         {
  84.                 delay1();
  85.                 if(s2==0)
  86.                 {               
  87.                         bxxz++;                                                        //波形类型++
  88.                         if(bxxz==5)
  89.                                 bxxz=0;
  90.                         switch(bxxz)
  91.                         {
  92.                                 case 0 :
  93.                                         {a=1,b=0,c=0,d=0,e=0;}
  94.                                         break;
  95.                                 case 1 :
  96.                                         {a=0,b=1,c=0,d=0,e=0;}
  97.                                         break;
  98.                                 case 2 :
  99.                                         {a=0,b=0,c=1,d=0,e=0;}
  100.                                         break;       
  101.                                 case 3 :
  102.                                         {a=0,b=0,c=0,d=1,e=0;}
  103.                                         break;
  104.                                 case 4 :
  105.                                         {a=0,b=0,c=0,d=0,e=1;}
  106.                                         break;
  107.                         }
  108.                         delay1();
  109.                         while(!s2);                                                //等待按键松开       
  110.                 }
  111.         }
  112. }
  113. void keyscan(void)
  114. {
  115.         key1();                                                                         //频率
  116.         key2();                                                                         //波形
  117. }       


  118. /*----------------------main----------------*/
  119. /*----------------------main----------------*/
  120. /*----------------------main----------------*/
  121. /*----------------------main----------------*/
  122. /*----------------------main----------------*/
  123. /*----------------------main----------------*/

  124. void main()
  125. {
  126.         csda=0;                                        //选通DAC0832
  127.         wr=0;                                        //WR有效
  128.         while(1)
  129.         {
  130.                 keyscan();                        //调用按键扫描
  131.                 if(a)
  132.                 {
  133.                         delay=pinglv;
  134.                         P0=sin[k];
  135.                         k++;
  136.                         if(k==64)
  137.                         k=0;
  138.                         while(delay)            
  139.                             delay--;
  140.                 }
  141.                 if(b)
  142.                 {
  143.                          delay=pinglv;
  144.                         P0=juxing[k];
  145.                         k++;
  146.                         if(k==64)
  147.                                 k=0;
  148.                         while(delay)           
  149.                             delay--;
  150.                 }
  151.                 if(c)
  152.                 {
  153.                          delay=pinglv;
  154.                         P0=juchi[k];
  155.                         k++;
  156.                         if(k==64)
  157.                                 k=0;
  158.                         while(delay)            
  159.                             delay--;
  160.                 }
  161.                 if(d)
  162.                 {
  163. ……………………

  164. …………限于本文篇幅 余下代码请从51黑下载附件…………
复制代码


回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表