找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 4358|回复: 3
收起左侧

基于51单片机的LED灯显示电子琴制作 原理图与源程序

[复制链接]
ID:592038 发表于 2021-2-26 02:48 | 显示全部楼层 |阅读模式
电路原理图如下:
8A1%0XEOF}X07XO~SCVI932.png E02B6EE58064D9E78C3CDDDA55F9B575.png 5F44E5F8758D9FA43DB51EB6620B7E29.png _CF6S30663L{BP_@%ZDX[_B.png 6BF645ED06530E766FF942697DC0E32E.png D09EF350DF2F5A8AB90717AE1B8E7B73.png

单片机源程序如下:
  1. sfr P4=0xe8;// 定义 P4组 I0 口
  2. #include<reg51.h>
  3. #define uint unsigned int
  4. #define uchar unsigned char
  5. sbit speaker=P1^4;// 喇叭接 30 脚
  6. sbit key1=P1^0;// 流水灯按键 (暂时)
  7. sbit key2=P1^1;// 播放音乐按键(暂定)
  8. uchar a,b,num1,s1num,n1,n2;
  9. char num;// 定义 num为可以负数
  10. uchar code yinfu[]={0xfb,0xe9, //Do
  11. 0xfc,0x5c, //Re
  12. 0xfc,0xc1, //Mi
  13. 0xfc,0xef, //Fa
  14. 0xfd,0x45, //So
  15. 0xfd,0x92, //La
  16. 0xfd,0xd0, //Si
  17. 0xfd,0xee, //Do#
  18. 0x00,0x00, // 间隔
  19. };

  20. uchar code shengri_tone[]={ 1,0,1,2,1,4,3,0, // 生日快乐音调
  21. 1,0,1,2,1,5,4,0,
  22. 1,0,1,8,6,4,3,2,0,
  23. 7,0,7,6,4,5,4,0 //0 代表不发声,即停顿;数字即为音调
  24. };
  25. uchar code shengri_beat[]={ 24,1,24,48,48,48,72,5,// 节拍
  26. 24,1,24,48,48,48,72,5,
  27. 24,1,24,48,48,48,48,72,5,
  28. 24,1,24,48,48,48,72,5 // 节拍,即tone 表各音调的延时
  29. };
  30. uchar code ledtable[]={0x7f,0xbf,0xdf,0xef, // 取反
  31. 0xf7,0xfb,0xfd,0xfe};//P0 组口的发光二极管代码(焊接过程可能会相反,具体更改)
  32. uchar code ledtable2[]={0x7f,0xbf,0xdf,0xef, // 取反
  33. 0xf7,0xfb,0xfd,0xfe};//P2 组口发光二极管代码 , 相反!
  34. void check_key();// 改为 P3组为按键
  35. void keyscan();
  36. void turn();// 顺时针流动
  37. void back();
  38. void qianhou();
  39. void dangshuang();
  40. void delay(uint z);// 延时函数声明
  41. void delay1(void);// 声明第二个延时函数
  42. void play1(void);// 播放生日快乐
  43. void main()
  44. {
  45. s1num=0;// 流水灯种类标志
  46. key1=1;
  47. key2=1;
  48. TMOD=0x01;
  49. TH0=a;
  50. TL0=b;
  51. ET0=1;// 打开定时器,但是未允许中断
  52. TR0=1;
  53. while(1)
  54. {
  55. check_key();
  56. keyscan();
  57. }
  58. }
  59. void time0() interrupt 1
  60. {
  61. TH0=a;
  62. TL0=b;
  63. speaker=~speaker;
  64. }
  65. void check_key()
  66. {
  67. P3=0xff;// 先赋给 P2组口高电平
  68. switch(P3)// 按下一个键相应 4 个灯亮
  69. {
  70. case 0xfe:P0=0xee;P2=0x77;a=0xfb;b=0xe9;EA=1;break;//P0,P2 组为发光二极管组
  71. case 0xfd:P0=0xdd;P2=0xbb;a=0xfc;b=0x5c;EA=1;break;// 注意: EA不能改为 TR0
  72. case 0xfb:P0=0xbb;P2=0xdd;a=0xfc;b=0xc1;EA=1;break;
  73. case 0xf7:P0=0x77;P2=0xee;a=0xfc;b=0xef;EA=1;break;
  74. case 0xef:P0=0xee;P2=0x77;a=0xfd;b=0x45;EA=1;break;
  75. case 0xdf:P0=0xdd;P2=0xbb;a=0xfd;b=0x92;EA=1;break;
  76. case 0xbf:P0=0xbb;P2=0xdd;a=0xfd;b=0xd0;EA=1;break;
  77. case 0x7f:P0=0x77;P2=0xee;a=0xfd;b=0xee;EA=1;break;
  78. default:EA=0;speaker=0;//P0=0xff;P2=0xff ;
  79. }
  80. }
  81. void delay(uint z)
  82. {
  83. uint x,y;
  84. for(x=z;x>0;x--)
  85. for(y=110;y>0;y--);
  86. }
  87. void keyscan()
  88. {
  89. if(key1==0)
  90. {
  91. delay(5);
  92. if(key1==0)
  93. {
  94. s1num++;
  95. while(!key1);
  96. if(s1num==1)
  97. {
  98. turn();
  99. }
  100. }
  101. if(s1num==2)
  102. {
  103. back();
  104. }
  105. if(s1num==3)
  106. {
  107. qianhou();
  108. }
  109. if(s1num==4)
  110. {
  111. dangshuang();
  112. }
  113. if(s1num==5)
  114. s1num=1;
  115. }
  116. if(key2==0)
  117. {
  118. delay(5);
  119. while(~key2);
  120. play1();
  121. }
  122. }
  123. void delay1(void)// 第二个延时函数
  124. {
  125. uchar n=15;
  126. while(n--)
  127. {
  128. uchar i;
  129. for(i=0;i<125;i++);
  130. }
  131. }
  132. void play1(void)// 播放生日快乐
  133. {
  134. uchar m=0;
  135. uchar s;
  136. uchar c=1;
  137. P0=0xaa;
  138. P2=0x55;
  139. while(1)
  140. {
  141. EA=0;
  142. c=shengri_tone[m]; // 取音符
  143. s=shengri_beat[m]; // 取节拍
  144. a=yinfu[2*c-2];
  145. b=yinfu[2*c-1];
  146. EA=1;
  147. while(s--)
  148. {
  149. delay1();
  150. P0=~P0;
  151. P2=~P2;
  152. }
  153. m++;
  154. if(m>=33) return; // 数值是 shengri相关表中的元素数量
  155. }
  156. }
  157. /* 以下为 N种流水灯流动花式 */
  158. void turn()// 流水灯顺时针走动( 5 次)
  159. {
  160. for(num1=0;num1<8;num1++)
  161. {
  162. for(num=0;num<8;num++)
  163. {
  164. P0=ledtable[num];
  165. delay(30);// 时间暂定
  166. }
  167. P0=0xff;// 之后关闭 P1组
  168. for(num=7;num>-1;num--)
  169. {
  170. P2=ledtable2[num];
  171. delay(30);
  172. }
  173. P2=0xff;// 之后关闭 P2组
  174. }
  175. }
  176. void back()// 逆时针流动
  177. {
  178. for(num1=0;num1<8;num1++)
  179. {
  180. for(num=0;num<8;num++)
  181. {
  182. P2=ledtable[num];
  183. delay(30);
  184. }
  185. P2=0xff;
  186. for(num=7;num>-1;num--)
  187. {
  188. P0=ledtable2[num];
  189. delay(30);
  190. }
  191. P0=0xff;
  192. }
  193. }
  194. void qianhou()// 前后来回
  195. {
  196. for(num1=0;num1<10;num1++)
  197. {
  198. for(num=0;num<8;num++)
  199. {
  200. P0=ledtable[num];
  201. P2=ledtable2[num];
  202. delay(30);
  203. }
  204. P0=0xff;
  205. P2=0xff;
  206. for(num=7;num>-1;num--)
  207. {
  208. P0=ledtable[num];
  209. P2=ledtable2[num];
  210. delay(30);
  211. }
  212. P0=0xff;
  213. P2=0xff;
  214. }
  215. }
  216. void dangshuang()// 单数双数
  217. {
  218. for(num1=0;num1<15;num1++)
  219. {
  220. P0=0x55;
  221. P2=0xaa;
  222. delay(150);
  223. P0=0xaa;
  224. P2=0x55;
  225. delay(150);
  226. }
  227. }
复制代码

原理图是png图片格式的,以上程序的Keil格式文件下载:已删除

评分

参与人数 1黑币 +50 收起 理由
admin + 50 共享资料的黑币奖励!

查看全部评分

回复

使用道具 举报

ID:883031 发表于 2021-2-26 10:11 | 显示全部楼层
厉害,顶一下
回复

使用道具 举报

ID:842709 发表于 2021-4-2 11:28 | 显示全部楼层
没有原理图的文件吗
回复

使用道具 举报

ID:1050360 发表于 2022-11-10 14:21 | 显示全部楼层
原理图呢?
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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