找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 3650|回复: 1
打印 上一主题 下一主题
收起左侧

基于51单片机的电子琴16键程序

[复制链接]
跳转到指定楼层
楼主
  1. #include <AT89X51.H>
  2. unsigned char code table[]={0x3f,0x06,0x5b,0x4f,
  3.                             0x66,0x6d,0x7d,0x07,
  4.                             0x7f,0x6f,0x77,0x7c,
  5.                             0x39,0x5e,0x79,0x71};
  6. unsigned char temp;
  7. unsigned char key;
  8. unsigned char i,j;
  9. unsigned char STH0;
  10. unsigned char STL0;
  11. unsigned int code tab[]={64021,64103,64260,64400,
  12.                           64524,64580,64684,64777,
  13.                           64820,64898,64968,65030,
  14.                           65058,65110,65157,65178};

  15. void main(void)
  16. {
  17.   TMOD=0x01;
  18.   ET0=1;
  19.   EA=1;
  20.   while(1)
  21.     {
  22.       P3=0xff;
  23.       P3_4=0;
  24.       temp=P3;
  25.       temp=temp & 0x0f;
  26.       if (temp!=0x0f)
  27.         {
  28.           for(i=50;i>0;i--)
  29.           for(j=200;j>0;j--);
  30.           temp=P3;
  31.           temp=temp & 0x0f;
  32.           if (temp!=0x0f)
  33.             {
  34.               temp=P3;
  35.               temp=temp & 0x0f;              
  36.               switch(temp)
  37.                 {
  38.                   case 0x0e:
  39.                     key=3;
  40.                     break;
  41.                   case 0x0d:
  42.                     key=2;
  43.                     break;
  44.                   case 0x0b:
  45.                     key=1;
  46.                     break;
  47.                   case 0x07:
  48.                     key=0;
  49.                     break;
  50.                 }
  51.               temp=P3;
  52.               //多P1_0=~P1_0;
  53.               P0=table[key];
  54.               STH0=tab[key]/256;
  55.               STL0=tab[key]%256;
  56.               TR0=1;
  57.               temp=temp & 0x0f;              
  58.               while(temp!=0x0f)
  59.                 {
  60.                   temp=P3;
  61.                   temp=temp & 0x0f;              
  62.                 }
  63.               TR0=0;
  64.             }
  65.         }
  66.   
  67.       P3=0xff;
  68.       P3_5=0;
  69.       temp=P3;
  70.       temp=temp & 0x0f;
  71.       if (temp!=0x0f)
  72.         {
  73.           for(i=50;i>0;i--)
  74.           for(j=200;j>0;j--);
  75.           temp=P3;
  76.           temp=temp & 0x0f;
  77.           if (temp!=0x0f)
  78.             {
  79.               temp=P3;
  80.               temp=temp & 0x0f;              
  81.               switch(temp)
  82.                 {
  83.                   case 0x0e:
  84.                     key=7;
  85.                     break;
  86.                   case 0x0d:
  87.                     key=6;
  88.                     break;
  89.                   case 0x0b:
  90.                     key=5;
  91.                     break;
  92.                   case 0x07:
  93.                     key=4;
  94.                     break;
  95.                 }
  96.               temp=P3;
  97.               //多P1_0=~P1_0;
  98.               P0=table[key];
  99.               STH0=tab[key]/256;
  100.               STL0=tab[key]%256;
  101.               TR0=1;
  102.               temp=temp & 0x0f;              
  103.               while(temp!=0x0f)
  104.                 {
  105.                   temp=P3;
  106.                   temp=temp & 0x0f;              
  107.                 }
  108.               TR0=0;
  109.             }
  110.         }
  111.   
  112.       P3=0xff;
  113.       P3_6=0;
  114.       temp=P3;
  115.       temp=temp & 0x0f;
  116.       if (temp!=0x0f)
  117.         {
  118.           for(i=50;i>0;i--)
  119.           for(j=200;j>0;j--);
  120.           temp=P3;
  121.           temp=temp & 0x0f;
  122.           if (temp!=0x0f)
  123.             {
  124.               temp=P3;
  125.               temp=temp & 0x0f;              
  126.               switch(temp)
  127.                 {
  128.                   case 0x0e:
  129.                     key=11;
  130.                     break;
  131.                   case 0x0d:
  132.                     key=10;
  133.                     break;
  134.                   case 0x0b:
  135.                     key=9;
  136.                     break;
  137.                   case 0x07:
  138.                     key=8;
  139.                     break;
  140.                 }
  141.               temp=P3;
  142.               //多P1_0=~P1_0;
  143.               P0=table[key];
  144.               STH0=tab[key]/256;
  145.               STL0=tab[key]%256;
  146.               TR0=1;
  147.               temp=temp & 0x0f;              
  148.               while(temp!=0x0f)
  149.                 {
  150.                   temp=P3;
  151.                   temp=temp & 0x0f;              
  152.                 }
  153.               TR0=0;
  154.             }
  155.         }
  156.   
  157.       P3=0xff;
  158.       P3_7=0;
  159.       temp=P3;
  160.       temp=temp & 0x0f;
  161.       if (temp!=0x0f)
  162.         {
  163.           for(i=50;i>0;i--)
  164.           for(j=200;j>0;j--);
  165.           temp=P3;
  166.           temp=temp & 0x0f;
  167.           if (temp!=0x0f)
  168.             {
  169.               temp=P3;
  170.               temp=temp & 0x0f;              
  171.               switch(temp)
  172.                 {
  173.                   case 0x0e:
  174.                     key=15;
  175.                     break;
  176.                   case 0x0d:
  177.                     key=14;
  178.                     break;
  179.                   case 0x0b:
  180.                     key=13;
  181.                     break;
  182.                   case 0x07:
  183.                     key=12;
  184.                     break;
  185.                 }
  186.               temp=P3;
  187.              //多P1_0=~P1_0;
  188.               P0=table[key];
  189.               STH0=tab[key]/256;
  190.               STL0=tab[key]%256;
  191.               TR0=1;
  192.               temp=temp & 0x0f;              
  193.               while(temp!=0x0f)
  194.                 {
  195.                   temp=P3;
  196.                   temp=temp & 0x0f;              
  197.                 }
  198.               TR0=0;
  199.             }
  200.         }      
  201.     }
  202. }
  203.   
  204. void t0(void) interrupt 1 using 0
  205. {
  206.   TH0=STH0;
  207.   TL0=STL0;
  208.   P1_0=~P1_0;
  209. }

复制代码

里面有汇编和C两种。

L0TQU{_@H7)JJ}XN7_9_0[9.png (7.42 KB, 下载次数: 39)

L0TQU{_@H7)JJ}XN7_9_0[9.png

51dianziqin.zip

139.94 KB, 下载次数: 72, 下载积分: 黑币 -5

51,Proteus

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖 顶 踩
回复

使用道具 举报

沙发
ID:727867 发表于 2020-4-15 22:22 | 只看该作者
请问楼主用的仿真软件是什么?proteus仿真不了
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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