欧美极品高清xxxxhd,国产日产欧美最新,无码AV国产东京热AV无码,国产精品人与动性XXX,国产传媒亚洲综合一区二区,四库影院永久国产精品,毛片免费免费高清视频,福利所导航夜趣136

標(biāo)題: 32LED單片機心形花樣流水燈程序+視頻 [打印本頁]

作者: xiaos    時間: 2015-4-11 17:25
標(biāo)題: 32LED單片機心形花樣流水燈程序+視頻
本帖最后由 xiaos 于 2015-4-11 17:27 編輯

視頻:
http://player.youku.com/player.php/sid/XNDI4NjQ3Njky/v.swf

程序源代碼如下:
  1. include<reg51.h>
  2. #include <intrins.h>
  3. #define uint unsigned int
  4. #define uchar unsigned char
  5. uchar code zou[]={0x01,0x02,0x04,0x08,0x10,0x20,0x40,0x80};//單個從0到7
  6. uchar code you[]={0x80,0x40,0x20,0x10,0x08,0x04,0x02,0x01};//單個從7到0
  7. uchar code liang0_7[]={0x01,0x03,0x07,0x0f,0x1f,0x3f,0x7f,0xff}; // 逐個點亮0~7
  8. uchar code liang7_0[]={0x80,0xc0,0xe0,0xf0,0xf8,0xfc,0xfe,0xff}; // 逐個點亮7~0
  9. uchar code mie0_7[]={0xfe,0xfc,0xf8,0xf0,0xe0,0xc0,0x80,0x00}; // 逐個滅0~7
  10. uchar code mie7_0[]={0x7f,0x3f,0x1f,0x0f,0x07,0x03,0x01,0x00}; // 逐個滅7~0
  11. /***********************************************************/
  12. void delay(uint t); //延時
  13. void zg(uint t,uchar a);//兩邊逐個亮
  14. void qs(uint t,uchar a);//全部閃爍
  15. void zgxh(uint t,uchar a);  // 逆時針逐個點亮
  16. //void zgxh1(uint t,uchar a);  // 順時針逐個點亮
  17. void djs(uint t,uchar a);  //對角閃
  18. void lbzgm(uint t,uchar a);//兩邊逐個滅
  19. //void sszgm(uint t,uchar a); // 順時針逐個滅
  20. void nszgm(uint t,uchar a); // 逆時針逐個滅
  21. void sztl(uint t,uchar a);//順時逐個同步亮
  22. void nztl(uint t,uchar a);//逆時逐個同步亮
  23. void sztm(uint t,uchar a);//順時逐個同步滅
  24. void nztm(uint t,uchar a);//逆時逐個同步滅
  25. void hwzjl(uint t,uchar a); //橫往中間亮
  26. void hwzjm(uint t,uchar a); //橫往中間滅
  27. //void swzjl(uint t,uchar a); //豎往中間亮
  28. //void swzjm(uint t,uchar a); //豎往中間滅
  29. void nzdl(uint t,uchar a); //逆時逐段亮
  30. void nzdgl(uint t,uchar a);   //逆時逐段一個點亮
  31. void jgs(uint t,uchar a);   //間隔閃
  32. /**********************************************************/
  33. void zg(uint t,uchar a)//兩邊逐個亮
  34. {
  35. uchar i,j;
  36.       for(j=0;j<a;j++)
  37.   {
  38.      P0=P1=P2=P3=0x00;
  39.     P0=0x01;
  40.     delay(t);
  41.     for(i=0;i<7;i++)
  42.     {
  43.     P0=liang0_7[i+1];
  44.     P3=liang7_0[i];
  45.     delay(t);
  46.     }
  47.     P3=0xff;P1=0x01;
  48.     delay(t);
  49.     for(i=0;i<7;i++)
  50.     {
  51.      P1=liang0_7[i+1];
  52.    P2=liang7_0[i];
  53.    delay(t);
  54.     }
  55.     P2=0xff;delay(t);
  56.    }
  57. }

  58. void qs(uint t,uchar a)  //全部閃爍
  59. {
  60. uchar j;
  61. for(j=0;j<a;j++)
  62. {
  63.     P0=P1=P2=P3=0x00;
  64.     delay(t);
  65.     P0=P1=P2=P3=0xff;
  66.     delay(t);
  67.   }  
  68. }


  69. void zgxh(uint t,uchar a)  // 逆時針逐個點亮
  70. {
  71. uchar i,j;
  72. for (j=0;j<a;j++)
  73. {
  74.   P0=P1=P2=P3=0xff;
  75.   for (i=0;i<8;i++)
  76.   {
  77.    P3=liang7_0[i];
  78.    delay(t);
  79.   }
  80.   for(i=0;i<8;i++)
  81.   {
  82.    P2=liang7_0[i];
  83.    delay(t);
  84.   }
  85.   for(i=0;i<8;i++)
  86.   {
  87.    P1=liang7_0[i];
  88.    delay(t);
  89.   }
  90.   for(i=0;i<8;i++)
  91.   {
  92.    P0=liang7_0[i];
  93.    delay(t);
  94.   }
  95. }
  96. }
  97. void nszgm(uint t,uchar a) // 逆時針逐個滅
  98. {
  99. uchar i,j;
  100. for(j=0;j<a;j++)
  101. {
  102.   P0=P1=P2=P3=0xff;
  103.   for (i=0;i<8;i++)
  104.   {
  105.    P3=mie7_0[i];delay(t);
  106.   }
  107.   for (i=0;i<8;i++)
  108.   {
  109.    P2=mie7_0[i];delay(t);
  110.   }
  111.   for (i=0;i<8;i++)
  112.   {
  113.    P1=mie7_0[i];delay(t);
  114.   }
  115.   for (i=0;i<8;i++)
  116.   {
  117.    P0=mie7_0[i];delay(t);
  118.   }
  119. }

  120. }


  121. void djs(uint t,uchar a)  //對角閃
  122. {
  123. uchar j;
  124. for(j=0;j<a;j++)
  125. {
  126.   P0=P1=P2=P3=0x00;
  127.   P0=P3=0xff;
  128.   delay(t);
  129.   P0=P1=P2=P3=0x00;
  130.   P1=P2=0xff;
  131.   delay(t);
  132. }

  133. }

  134. void lbzgm(uint t,uchar a)//兩邊逐個滅
  135. {
  136.    uchar i,j;
  137.    for (j=0;j<a;j++)
  138.    {
  139.     P0=P1=P2=P3=0x00;
  140.   P3=0x7f;delay(t);
  141.   for(i=0;i<7;i++)
  142.   {
  143.    P3=mie7_0[i+1];
  144.    P0=mie0_7[i];
  145.    delay(t);
  146.   }
  147.   P0=0x00;
  148.   P2=0x7f;delay(t);
  149.   for(i=0;i<7;i++)
  150.   {
  151.    P2=mie7_0[i+1];
  152.    P1=mie0_7[i];
  153.    delay(t);
  154.   }
  155.   P1=0x00;delay(t);
  156.    }
  157. }
  158. void sztl(uint t,uchar a)//順時逐個同步亮
  159. {
  160. uchar i,j;
  161. for(j=0;j<a;j++)
  162. {
  163.   P0=P1=P2=P3=0x00;
  164.   for(i=0;i<8;i++)
  165.   {
  166.    P0=liang0_7[i];
  167.    P1=P2=P3=liang0_7[i];
  168.    delay(t);
  169.   }
  170. }
  171. }
  172. void nztl(uint t,uchar a)//逆時逐個同步亮
  173. {
  174. uchar i,j;
  175. for(j=0;j<a;j++)
  176. {
  177.   P0=P1=P2=P3=0x00;
  178.   for(i=0;i<8;i++)
  179.   {
  180.    P0=liang7_0[i];
  181.    P1=P2=P3=liang7_0[i];
  182.    delay(t);
  183.   }
  184. }
  185. }
  186. void sztm(uint t,uchar a)//順時逐個同步滅
  187. {
  188. uchar i,j;
  189. for(j=0;j<a;j++)
  190. {
  191.   P0=P1=P2=P3=0xff;
  192.   for(i=0;i<8;i++)
  193.   {
  194.    P0=mie0_7[i];
  195.    P1=P2=P3=mie0_7[i];
  196.    delay(t);
  197.   }
  198. }
  199. }

  200. void nztm(uint t,uchar a)//逆時逐個同步滅
  201. {
  202. uchar i,j;
  203. for(j=0;j<a;j++)
  204. {
  205.   P0=P1=P2=P3=0xff;
  206.   for(i=0;i<8;i++)
  207.   {
  208.    P0=mie7_0[i];
  209.    P1=P2=P3=mie7_0[i];
  210.    delay(t);
  211.   }
  212. }
  213. }
  214. void hwzjl(uint t,uchar a) //橫往中間亮
  215. {
  216. uchar i,j;
  217. for (j=0;j<a;j++)
  218. {
  219.   P0=P1=P2=P3=0x00;
  220.   for(i=0;i<8;i++)
  221.   {
  222.    P0=P2=liang0_7[i];
  223.    P1=P3=liang7_0[i];delay(t);
  224.   }
  225. }
  226. }
  227. void hwzjm(uint t,uchar a) //橫往中間滅
  228. {
  229. uchar i,j;
  230. for (j=0;j<a;j++)
  231. {
  232.   P0=P1=P2=P3=0xff;
  233.   for(i=0;i<8;i++)
  234.   {
  235.    P0=P2=mie0_7[i];
  236.    P1=P3=mie7_0[i];delay(t);
  237.   }
  238. }
  239. }

  240. void nzdl(uint t,uchar a) //逆時逐段亮
  241. {
  242. uchar i,j;
  243. for (j=0;j<a;j++)
  244. {
  245.   P0=P1=P2=P3=0x00;
  246.   for(i=0;i<8;i++)
  247.   {
  248.    P0=liang0_7[i];
  249.    delay(t);
  250.   }
  251.   P0=0x00;
  252.   for(i=0;i<8;i++)
  253.   {
  254.    P1=liang0_7[i];
  255.    delay(t);
  256.   }
  257.   P1=0x00;
  258.   for(i=0;i<8;i++)
  259.   {
  260.    P2=liang0_7[i];
  261.    delay(t);
  262.   }
  263.   P2=0x00;
  264.   for(i=0;i<8;i++)
  265.   {
  266.    P3=liang0_7[i];
  267.    delay(t);
  268.   }
  269.   P3=0x00;
  270. }
  271. }

  272. void nzdgl(uint t,uchar a)   //逆時逐段一個點亮
  273. {
  274. uchar i,j;
  275. for (j=0;j<a;j++)
  276. {
  277.   P0=P1=P2=P3=0x00;
  278.   for(i=0;i<8;i++)
  279.   {
  280.    P3=liang7_0[i];
  281.    delay(t);
  282.   }
  283.   P3=0x00;
  284.   for(i=0;i<8;i++)
  285.   {
  286.    P2=liang7_0[i];
  287.    delay(t);
  288.   }
  289.   P2=0x00;
  290.   for(i=0;i<8;i++)
  291.   {
  292.    P1=liang7_0[i];
  293.    delay(t);
  294.   }
  295.   P1=0x00;
  296.   for(i=0;i<8;i++)
  297.   {
  298.    P0=liang7_0[i];
  299.    delay(t);
  300.   }
  301.   P0=0x00;
  302. }
  303. }

  304. void jgs(uint t,uchar a)   //間隔閃
  305. {
  306. uchar j;
  307. for (j=0;j<a;j++)
  308. {
  309.   P0=P1=P2=P3=0x55;
  310.   delay(t);
  311.   P0=P1=P2=P3=0xaa;
  312.   delay(t);
  313. }
  314. }

  315. void main()
  316. {
  317. uchar i;
  318. while(1)
  319. {
  320.   zg(100,1);    //兩邊逐個亮
  321.   lbzgm(100,1);   //兩邊逐個滅
  322.   jgs(300,10);
  323.   djs(100,20);  //對角閃
  324. ////////////////////////////////////////////
  325. P1=P2=P3=0x00;
  326. for(i=0;i<3;i++)
  327. {
  328.   P0=0xff;delay(800);
  329.   P0=0x00;delay(800);
  330.   }
  331.   P0=0xff;
  332.   for(i=0;i<3;i++)
  333. {
  334.   P1=0xff;delay(800);
  335.   P1=0x00;delay(800);
  336.   }
  337.   P1=0xff;
  338.   for(i=0;i<3;i++)
  339. {
  340.   P2=0xff;delay(800);
  341.   P2=0x00;delay(800);
  342.   }
  343.   P2=0xff;
  344.   for(i=0;i<3;i++)
  345. {
  346.   P3=0xff;delay(800);
  347.   P3=0x00;delay(800);
  348.   }
  349.   P3=0xff;
  350.   qs(500,3);

  351. /////////////////////////////////////////////
  352. for(i=0;i<6;i++)
  353. {
  354.   zgxh(50,1);
  355.   nszgm(50,1);
  356.   }
  357. djs(100,20);  //對角閃
  358. for(i=0;i<3;i++)
  359. {
  360.   zg(100,1);    //兩邊逐個亮
  361.   lbzgm(100,1);   //兩邊逐個滅
  362. }
  363.   qs(200,10);djs(100,50);
  364.   for(i=0;i<5;i++)
  365.   {
  366.    sztl(200,1); //順時逐個同步亮
  367.   nztm(200,1);
  368.    nztl(200,1);
  369.   sztm(200,1); //順時逐個同步滅
  370.   }
  371.   djs(300,10);  //對角閃
  372.   nzdgl(300,10);   //逆時逐段一個點亮
  373.   jgs(300,10);   //間隔閃
  374. for(i=0;i<3;i++)
  375. {
  376.   zgxh(100,1);
  377.   nszgm(100,1);
  378.   }


  379.    nzdl(200,3); //逆時逐段亮
  380.    jgs(50,100);   //間隔閃


  381. nzdgl(50,40);   //逆時逐段一個點亮
  382. for(i=0;i<4;i++)
  383. {
  384.   zg(100,1);qs(100,10);
  385.   lbzgm(100,1);
  386. }
  387. //  djs(50,100);  //對角閃

  388.   for(i=0;i<3;i++)
  389. {
  390.   zgxh(100,1);
  391.   nszgm(100,1);
  392.   }

  393.      djs(1000,10);
  394.   for(i=0;i<10;i++)
  395.   {
  396.   hwzjl(200,1); //橫往中間亮
  397.   hwzjm(200,1); //橫往中間滅
  398.      }
  399.   djs(300,10);  //對角閃
  400. for(i=0;i<5;i++)
  401. {
  402.   zgxh(100,1);
  403.   nszgm(100,1);
  404.   }
  405.   djs(100,20);  //對角閃
  406.   zg(300,1);
  407.   lbzgm(300,1);
  408.   for(i=0;i<5;i++)
  409.   {
  410.    sztl(200,1);  //順時逐個同步亮
  411.   nztm(200,1);
  412.    nztl(200,1);
  413.   sztm(200,1); //順時逐個同步滅
  414.   }
  415.   djs(500,20);  //對角閃
  416.   djs(100,30);  //對角閃
  417.   djs(50,50);  //對角閃
  418. //  djs(10,100);  //對角閃
  419.   delay(1000);
  420. }

  421. }

  422. void delay(uint t)
  423. {
  424. uint x,y;
  425. for (x=t;x>0;x--)
  426. {
  427.   for (y=120;y>0;y--);
  428. }
  429. }
復(fù)制代碼




作者: 810858721    時間: 2015-12-5 20:42
親,你的代碼有proteus仿真圖嗎     ?我p0口不亮
作者: admin    時間: 2015-12-5 23:45
810858721 發(fā)表于 2015-12-5 20:42
親,你的代碼有proteus仿真圖嗎     ?我p0口不亮

p0是不是沒有加上拉電阻,看看p2 p3 p1 亮不亮?
作者: 810858721    時間: 2015-12-6 15:50
加了上拉電阻了 ,已經(jīng)弄好了。上拉電阻加的大了,所以不亮 ,已經(jīng)好了,謝謝大神
作者: 張威320324    時間: 2015-12-8 14:28
樓主,有電路圖嗎,我也想自己做個
作者: 1871499206    時間: 2017-9-27 19:04
求分享666666666
作者: 1871499206    時間: 2017-9-27 19:04
XT151盒裝最小系統(tǒng)(1)
作者: yatou520    時間: 2017-11-11 19:15
謝謝樓主的分享。
作者: yatou520    時間: 2017-11-13 16:01
樓主,上拉電阻可以用多大的電阻替代?
作者: JohnhanWu    時間: 2017-11-13 21:07
怎么做?

作者: tbjgdtcn    時間: 2017-12-16 17:03
謝謝樓主的分享
作者: 聽書人    時間: 2018-4-3 19:42
大神 有電路圖嗎
作者: 聽書人    時間: 2018-4-3 19:46
810858721 發(fā)表于 2015-12-5 20:42
**** 作者被禁止或刪除 內(nèi)容自動屏蔽 ****

有電路圖嗎
作者: 耆睿    時間: 2019-3-31 11:47
大神牛逼




歡迎光臨 (http://www.raoushi.com/bbs/) Powered by Discuz! X3.1