15655浏览
查看: 15655|回复: 8

[项目] 【俄罗斯方块】arduino+12864+红外遥控

[复制链接]
这是一个基于UNO+12864+红外遥控的俄罗斯方块,由于没学过算法,只学过C++,于是用很暴力的代码写了这个程序,所以代码的效率不高,也就是不美吧!另外,其实最开始做这个的时候,是想着写个UI,再加时钟,再加俄罗斯方块的(所以最开始是采用串口的模式进行12864绘图的),写到最后,由于功力真的不够深厚,所以一个简单的俄罗斯都占有了很多字节,以至于在mega328里面剩余的字节不够写其他程序了。

     关于此俄罗斯方块的一些详细说明:
     通过红外遥控玩俄罗斯方块(由于身边只有2个按键,只有2个!!所以最后选择了红外遥控)
     红外遥控的上键实现图形旋转,左右键分别实现左移、右移,下键实现快速下落!

    OK,先上
   
  1. #include <IRremote.h>
  2. #include <U8glib.h>
  3. U8GLIB_ST7920_128X64 u8g(18, 16, 17, U8G_PIN_NONE);
  4. int dot[20][10]={
  5.   0,0,0,0,0,0,0,0,0,0,
  6.   0,0,0,0,0,0,0,0,0,0,
  7.   0,0,0,0,0,0,0,0,0,0,
  8.   0,0,0,0,0,0,0,0,0,0,
  9.   0,0,0,0,0,0,0,0,0,0,
  10.   0,0,0,0,0,0,0,0,0,0,
  11.   0,0,0,0,0,0,0,0,0,0,
  12.   0,0,0,0,0,0,0,0,0,0,
  13.   0,0,0,0,0,0,0,0,0,0,
  14.   0,0,0,0,0,0,0,0,0,0,
  15.   0,0,0,0,0,0,0,0,0,0,
  16.   0,0,0,0,0,0,0,0,0,0,
  17.   0,0,0,0,0,0,0,0,0,0,
  18.   0,0,0,0,0,0,0,0,0,0,
  19.   0,0,0,0,0,0,0,0,0,0,
  20.   0,0,0,0,0,0,0,0,0,0,
  21.   0,0,0,0,0,0,0,0,0,0,
  22.   0,0,0,0,0,0,0,0,0,0,
  23.   0,0,0,0,0,0,0,0,0,0,
  24.   0,0,0,0,0,0,0,0,0,0
  25. };
  26. int level=0;
  27. int score=0;
  28. int px=36;
  29. int py=34;
  30. int draw_state=0;
  31. int k,knext;
  32. int firsttrick,nexttrick;  
  33. int irReceivePin=2;
  34. IRrecv irrecv(irReceivePin);
  35. decode_results results;
  36. void checkright(int rightx,int righty,int rightcase)
  37. {
  38.   switch(rightcase)
  39.   {
  40.     case 1:
  41.     if(py<=18)
  42.     {
  43.       py=py;
  44.     }
  45.     else if(dot[(rightx/4-10)][(righty-22)/4]==1||dot[(rightx/4-9)][(righty-22)/4]==1)
  46.     {
  47.       py=py;
  48.     }
  49.     else
  50.     {
  51.       py=py-4;
  52.     };
  53.     break;   
  54.     case 2:
  55.     if(py<=18)
  56.     {
  57.       py=py;
  58.     }
  59.     else if(dot[(rightx/4-10)][(righty-14)/4]==1||dot[(rightx/4-9)][(righty-22)/4]==1)
  60.     {
  61.       py=py;
  62.     }
  63.     else
  64.     {
  65.       py=py-4;
  66.     };
  67.     break;  
  68.     case 3:
  69.     if(py<=18)
  70.     {
  71.       py=py;
  72.     }
  73.     else if(dot[(rightx/4-11)][(righty-22)/4]==1||dot[(rightx/4-10)][(righty-18)/4]==1||dot[(rightx/4-9)][(righty-18)/4]==1)
  74.     {
  75.       py=py;
  76.     }
  77.     else
  78.     {
  79.       py=py-4;
  80.     };
  81.     break;  
  82.      case 4:
  83.     if(py<=18)
  84.     {
  85.       py=py;
  86.     }
  87.     else if(dot[(rightx/4-10)][(righty-22)/4]==1||dot[(rightx/4-9)][(righty-22)/4]==1)
  88.     {
  89.       py=py;
  90.     }
  91.     else
  92.     {
  93.       py=py-4;
  94.     };
  95.     break;  
  96.     case 5:
  97.     if(py<=18)
  98.     {
  99.       py=py;
  100.     }
  101.     else if(dot[(rightx/4-11)][(righty-22)/4]==1||dot[(rightx/4-10)][(righty-22)/4]==1||dot[(rightx/4-9)][(righty-22)/4]==1)
  102.     {
  103.       py=py;
  104.     }
  105.     else
  106.     {
  107.       py=py-4;
  108.     };
  109.     break;  
  110.     case 6:
  111.     if(py<=18)
  112.     {
  113.       py=py;
  114.     }
  115.     else if(dot[(rightx/4-10)][(righty-22)/4]==1||dot[(rightx/4-9)][(righty-22)/4]==1)
  116.     {
  117.       py=py;
  118.     }
  119.     else
  120.     {
  121.       py=py-4;
  122.     };
  123.     break;
  124.      case 7:
  125.     if(py<=18)
  126.     {
  127.       py=py;
  128.     }
  129.     else if(dot[(rightx/4-11)][(righty-18)/4]==1||dot[(rightx/4-10)][(righty-18)/4]==1||dot[(rightx/4-9)][(righty-22)/4]==1)
  130.     {
  131.       py=py;
  132.     }
  133.     else
  134.     {
  135.       py=py-4;
  136.     };
  137.     break;  
  138.     case 8:
  139.     if(py<=18)
  140.     {
  141.       py=py;
  142.     }
  143.     else if(dot[(rightx/4-10)][(righty-22)/4]==1||dot[(rightx/4-9)][(righty-14)/4]==1)
  144.     {
  145.       py=py;
  146.     }
  147.     else
  148.     {
  149.       py=py-4;
  150.     };
  151.     break;
  152.     case 9:
  153.     if(py<=14)
  154.     {
  155.       py=py;
  156.     }
  157.     else if(dot[(rightx/4-11)][(righty-18)/4]==1||dot[(rightx/4-10)][(righty-18)/4]==1||dot[(rightx/4-9)][(righty-18)/4]==1)
  158.     {
  159.       py=py;
  160.     }
  161.     else
  162.     {
  163.       py=py-4;
  164.     };
  165.     break;
  166.     case 10:
  167.     if(py<=18)
  168.     {
  169.       py=py;
  170.     }
  171.     else if(dot[(rightx/4-10)][(righty-18)/4]==1||dot[(rightx/4-9)][(righty-22)/4]==1)
  172.     {
  173.       py=py;
  174.     }
  175.     else
  176.     {
  177.       py=py-4;
  178.     };
  179.     break;
  180.     case 11:
  181.     if(py<=18)
  182.     {
  183.       py=py;
  184.     }
  185.     else if(dot[(rightx/4-11)][(righty-18)/4]==1||dot[(rightx/4-10)][(righty-22)/4]==1||dot[(rightx/4-9)][(righty-18)/4]==1)
  186.     {
  187.       py=py;
  188.     }
  189.     else
  190.     {
  191.       py=py-4;
  192.     };
  193.     break;     
  194.     case 12:
  195.     if(py<=18)
  196.     {
  197.       py=py;
  198.     }
  199.     else if(dot[(rightx/4-10)][(righty-22)/4]==1||dot[(rightx/4-9)][(righty-18)/4]==1)
  200.     {
  201.       py=py;
  202.     }
  203.     else
  204.     {
  205.       py=py-4;
  206.     };
  207.     break;
  208.     case 13:
  209.     if(py<=14)
  210.     {
  211.       py=py;
  212.     }
  213.     else if(dot[(rightx/4-11)][(righty-18)/4]==1||dot[(rightx/4-10)][(righty-18)/4]==1||dot[(rightx/4-9)][(righty-18)/4]==1)
  214.     {
  215.       py=py;
  216.     }
  217.     else
  218.     {
  219.       py=py-4;
  220.     };
  221.     break;  
  222.     case 14:
  223.     if(py<=18)
  224.     {
  225.       py=py;
  226.     }
  227.     else if(dot[(rightx/4-10)][(righty-18)/4]==1||dot[(rightx/4-9)][(righty-22)/4]==1)
  228.     {
  229.       py=py;
  230.     }
  231.     else
  232.     {
  233.       py=py-4;
  234.     };
  235.     break;   
  236.      case 15:
  237.     if(py<=18)
  238.     {
  239.       py=py;
  240.     }
  241.     else if(dot[(rightx/4-11)][(righty-22)/4]==1||dot[(rightx/4-10)][(righty-22)/4]==1||dot[(rightx/4-9)][(righty-18)/4]==1)
  242.     {
  243.       py=py;
  244.     }
  245.     else
  246.     {
  247.       py=py-4;
  248.     };
  249.     break;  
  250.     case 16:
  251.     if(py<=18)
  252.     {
  253.       py=py;
  254.     }
  255.     else if(dot[(rightx/4-10)][(righty-22)/4]==1||dot[(rightx/4-9)][(righty-18)/4]==1)
  256.     {
  257.       py=py;
  258.     }
  259.     else
  260.     {
  261.       py=py-4;
  262.     };
  263.     break;
  264.      case 17:
  265.     if(py<=14)
  266.     {
  267.       py=py;
  268.     }
  269.     else if(dot[(rightx/4-11)][(righty-14)/4]==1||dot[(rightx/4-10)][(righty-18)/4]==1||dot[(rightx/4-9)][(righty-18)/4]==1)
  270.     {
  271.       py=py;
  272.     }
  273.     else
  274.     {
  275.       py=py-4;
  276.     };
  277.     break;
  278.      case 18:
  279.     if(py<=22)
  280.     {
  281.       py=py;
  282.     }
  283.     else if(dot[(rightx/4-9)][(righty-26)/4]==1)
  284.     {
  285.       py=py;
  286.     }
  287.     else
  288.     {
  289.       py=py-4;
  290.     };
  291.     break;
  292.      case 19:
  293.     if(py<=14)
  294.     {
  295.       py=py;
  296.     }
  297.     else if(dot[(rightx/4-12)][(righty-14)/4]==1||dot[(rightx/4-11)][(righty-14)/4]==1||dot[(rightx/4-10)][(righty-14)/4]==1||dot[(rightx/4-9)][(righty-14)/4]==1)
  298.     {
  299.       py=py;
  300.     }
  301.     else
  302.     {
  303.       py=py-4;
  304.     };
  305.     break;
  306.   }
  307. }
  308. void checkleft(int leftx,int lefty,int leftcase)
  309. {  
  310.   switch(leftcase)
  311.   {
  312.     case 1:   
  313.     if(py>=50)
  314.     {
  315.       py=py;
  316.     }
  317.     else if(dot[(leftx/4-10)][((lefty-10)/4)]==1||dot[(leftx/4-9)][((lefty-10)/4)]==1)
  318.     {
  319.       py=py;
  320.     }
  321.     else
  322.     {
  323.       py=py+4;
  324.     };
  325.     break;
  326.     case 2:
  327.     if(py>=46)
  328.     {
  329.       py=py;
  330.     }
  331.     else if(dot[(leftx/4-10)][((lefty-6)/4)]==1||dot[(leftx/4-9)][((lefty-6)/4)]==1)
  332.     {
  333.       py=py;
  334.     }
  335.     else
  336.     {
  337.       py=py+4;
  338.     };
  339.     break;
  340.     case 3:
  341.     if(py>=50)
  342.     {
  343.       py=py;
  344.     }
  345.     else if(dot[(leftx/4-11)][((lefty-10)/4)]==1||dot[(leftx/4-10)][((lefty-10)/4)]==1||dot[(leftx/4-9)][((lefty-10)/4)]==1)
  346.     {
  347.       py=py;
  348.     }
  349.     else
  350.     {
  351.       py=py+4;
  352.     };
  353.     break;
  354.      case 4:
  355.     if(py>=46)
  356.     {
  357.       py=py;
  358.     }
  359.     else if(dot[(leftx/4-10)][((lefty-6)/4)]==1||dot[(leftx/4-9)][((lefty-14)/4)]==1)
  360.     {
  361.       py=py;
  362.     }
  363.     else
  364.     {
  365.       py=py+4;
  366.     };
  367.     break;
  368.     case 5:
  369.     if(py>=50)
  370.     {
  371.       py=py;
  372.     }
  373.     else if(dot[(leftx/4-11)][((lefty-14)/4)]==1||dot[(leftx/4-10)][((lefty-14)/4)]==1||dot[(leftx/4-9)][((lefty-10)/4)]==1)
  374.     {
  375.      py=py;
  376.     }
  377.     else
  378.     {
  379.       py=py+4;
  380.     };
  381.     break;
  382.     case 6:
  383.     if(py>=46)
  384.     {
  385.       py=py;
  386.     }
  387.     else if(dot[(leftx/4-10)][((lefty-14)/4)]==1||dot[(leftx/4-9)][((lefty-14)/4)]==1)
  388.     {
  389.       py=py;
  390.     }
  391.     else
  392.     {
  393.       py=py+4;
  394.     };
  395.     break;
  396.     case 7:
  397.     if(py>=50)
  398.     {
  399.       py=py;
  400.     }
  401.     else if(dot[(leftx/4-11)][((lefty-10)/4)]==1||dot[((leftx/4-10))][((lefty-10)/4)]==1||dot[(leftx/4-9)][((lefty-10)/4)]==1)
  402.     {
  403.       py=py;
  404.     }
  405.     else
  406.     {
  407.       py=py+4;
  408.     };
  409.     break;
  410.     case 8:
  411.     if(py>=46)
  412.     {
  413.       py=py;
  414.     }
  415.     else if(dot[(leftx/4-10)][((lefty-6)/4)]==1||dot[(leftx/4-9)][((lefty-6)/4)]==1)
  416.     {
  417.       py=py;
  418.     }
  419.     else
  420.     {
  421.       py=py+4;
  422.     };
  423.     break;
  424.     case 9:
  425.     if(py>=46)
  426.     {
  427.       py=py;
  428.     }
  429.     else if(dot[(leftx/4-11)][(lefty-6)/4]==1||dot[(leftx/4-10)][((lefty-10)/4)]==1||dot[(leftx/4-9)][((lefty-10)/4)]==1)
  430.     {
  431.       py=py;
  432.     }
  433.     else
  434.     {
  435.       py=py+4;
  436.     };
  437.     break;
  438.     case 10:
  439.     if(py>=46)
  440.     {
  441.       py=py;
  442.     }
  443.     else if(dot[(leftx/4-10)][((lefty-10)/4)]==1||dot[(leftx/4-9)][((lefty-6)/4)]==1)
  444.     {
  445.       py=py;
  446.     }
  447.     else
  448.     {
  449.       py=py+4;
  450.     };
  451.     break;
  452.     case 11:
  453.     if(py>=50)
  454.     {
  455.       py=py;
  456.     }
  457.     else if(dot[(leftx/4-11)][((lefty-10)/4)]==1||dot[(leftx/4-10)][((lefty-10)/4)]==1||dot[(leftx/4-9)][((lefty-10)/4)]==1)
  458.     {
  459.       py=py;
  460.     }
  461.     else
  462.     {
  463.       py=py+4;
  464.     };
  465.     break;
  466.     case 12:
  467.     if(py>=46)
  468.     {
  469.       py=py;
  470.     }
  471.     else if(dot[(leftx/4-10)][((lefty-6)/4)]==1||dot[(leftx/4-9)][((lefty-10)/4)]==1)
  472.     {
  473.       py=py;
  474.     }
  475.     else
  476.     {
  477.       py=py+4;
  478.     };
  479.     break;
  480.     case 13:
  481.     if(py>=46)
  482.     {
  483.       py=py;
  484.     }
  485.     else if(dot[(leftx/4-11)][(lefty-10)/4]==1||dot[(leftx/4-10)][((lefty-6)/4)]==1||dot[(leftx/4-9)][((lefty-10)/4)]==1)
  486.     {
  487.       py=py;
  488.     }
  489.     else
  490.     {
  491.       py=py+4;
  492.     };
  493.     break;
  494.      case 14:
  495.     if(py>=46)
  496.     {
  497.       py=py;
  498.     }
  499.     else if(dot[(leftx/4-10)][((lefty-6)/4)]==1||dot[(leftx/4-9)][((lefty-10)/4)]==1)
  500.     {
  501.       py=py;
  502.     }
  503.     else
  504.     {
  505.       py=py+4;
  506.     };
  507.     break;
  508.      case 15:
  509.     if(py>=50)
  510.     {
  511.       py=py;
  512.     }
  513.     else if(dot[(leftx/4-11)][(lefty-14)/4]==1||dot[(leftx/4-10)][(lefty-10)/4]==1||dot[(leftx/4-9)][((lefty-10)/4)]==1)
  514.     {
  515.       py=py;
  516.     }
  517.     else
  518.     {
  519.       py=py+4;
  520.     };
  521.     break;
  522.     case 16:
  523.     if(py>=50)
  524.     {
  525.       py=py;
  526.     }
  527.     else if(dot[(leftx/4-10)][((lefty-10)/4)]==1||dot[(leftx/4-9)][((lefty-6)/4)]==1)
  528.     {
  529.       py=py;
  530.     }
  531.     else
  532.     {
  533.       py=py+4;
  534.     };
  535.     break;
  536.      case 17:
  537.     if(py>=46)
  538.     {
  539.       py=py;
  540.     }
  541.     else if(dot[(leftx/4-11)][((lefty-6)/4)]==1||dot[(leftx/4-10)][((lefty-6)/4)]==1||dot[(leftx/4-9)][((lefty-10)/4)]==1)
  542.     {
  543.       py=py;
  544.     }
  545.     else
  546.     {
  547.       py=py+4;
  548.     };
  549.     break;
  550.     case 18:
  551.     if(py>=46)
  552.     {
  553.       py=py;
  554.     }
  555.     else if(dot[(leftx/4-9)][(lefty-6)/4]==1)
  556.     {
  557.       py=py;
  558.     }
  559.     else
  560.     {
  561.       py=py+4;
  562.     };
  563.     break;
  564.     case 19:
  565.     if(py>=50)
  566.     {
  567.       py=py;
  568.     }
  569.     else if(dot[(leftx/4-12)][(lefty-10)/4]==1||dot[(leftx/4-11)][(lefty-10)/4]==1||dot[(leftx/4-10)][(lefty-10)/4]==1||dot[(leftx/4-9)][(lefty-10)/4]==1)
  570.     {
  571.       py=py;
  572.     }
  573.     else
  574.     {
  575.       py=py+4;
  576.     };
  577.     break;   
  578.   }
  579. }
  580. void checkdown(int downx,int downy,int downcase)
  581. {
  582.   switch(downcase)
  583.   {
  584.     case 1:
  585.     downx=downx-8;   
  586.     if(dot[(downx-36)/4+3][(downy-22)/4+1]==1||dot[(downx-36)/4+3][(downy-22)/4+2]==1)
  587.     {      
  588.       reachgraph(downx,downy,downcase);
  589.       px=36;
  590.     }
  591.     else
  592.     {
  593.       px=px+4;
  594.     };
  595.     break;
  596.     case 2:
  597.     downx=downx-8;
  598.      if(dot[(downx-36)/4+3][(downy-22)/4+1]==1||dot[(downx-36)/4+3][(downy-22)/4+2]==1||dot[(downx-36)/4+3][(downy-22)/4+3]==1)
  599.     {            
  600.       reachgraph(downx,downy,downcase);
  601.       px=36;
  602.     }
  603.     else
  604.     {
  605.       px=px+4;
  606.     };
  607.     break;
  608.     case 3:
  609.     downx=downx-12;
  610.      if(dot[(downx-36)/4+2][(downy-22)/4+1]==1||dot[(downx-36)/4+4][(downy-22)/4+2]==1)
  611.     {           
  612.       reachgraph(downx,downy,downcase);
  613.       px=36;
  614.     }
  615.     else
  616.     {
  617.       px=px+4;
  618.     };
  619.     break;
  620.     case 4:
  621.     downx=downx-12;
  622.      if(dot[(downx-36)/4+3][(downy-22)/4+2]==1||dot[(downx-36)/4+3][(downy-22)/4+3]==1||dot[(downx-36)/4+4][(downy-22)/4+1]==1)
  623.     {           
  624.       reachgraph(downx,downy,downcase);
  625.       px=36;
  626.     }
  627.     else
  628.     {
  629.       px=px+4;
  630.     };
  631.     break;
  632.     case 5:
  633.     downx=downx-12;
  634.      if(dot[(downx-36)/4+4][(downy-22)/4+1]==1||dot[(downx-36)/4+4][(downy-22)/4+2]==1)
  635.     {           
  636.       reachgraph(downx,downy,downcase);
  637.       px=36;
  638.     }
  639.     else
  640.     {
  641.       px=px+4;
  642.     };
  643.     break;
  644.      case 6:
  645.      downx=downx-8;   
  646.      if(dot[(downx-36)/4+3][(downy-22)/4+1]==1||dot[(downx-36)/4+3][(downy-22)/4+2]==1||dot[(downx-36)/4+3][(downy-22)/4+3]==1)
  647.     {        
  648.       reachgraph(downx,downy,downcase);
  649.       px=36;
  650.     }
  651.     else
  652.     {
  653.       px=px+4;
  654.     };
  655.     break;
  656.      case 7:
  657.      downx=downx-12;
  658.      if(dot[(downx-36)/4+4][(downy-22)/4+1]==1||dot[(downx-36)/4+4][(downy-22)/4+2]==1)
  659.     {         
  660.       reachgraph(downx,downy,downcase);
  661.       px=36;
  662.     }
  663.     else
  664.     {
  665.       px=px+4;
  666.     };
  667.     break;
  668.      case 8:
  669.      downx=downx-8;  
  670.      if(dot[(downx-36)/4+2][(downy-22)/4+1]==1||dot[(downx-36)/4+2][(downy-22)/4+2]==1||dot[(downx-36)/4+3][(downy-22)/4+3]==1)
  671.     {   
  672.       reachgraph(downx,downy,downcase);
  673.       px=36;
  674.     }
  675.     else
  676.     {
  677.       px=px+4;
  678.     };
  679.     break;
  680.     case 9:
  681.     downx=downx-12;
  682.      if(dot[(downx-36)/4+2][(downy-22)/4+3]==1||dot[(downx-36)/4+4][(downy-22)/4+2]==1)
  683.     {      
  684.       reachgraph(downx,downy,downcase);
  685.       px=36;
  686.     }
  687.     else
  688.     {
  689.       px=px+4;
  690.     };
  691.     break;
  692.     case 10:
  693.     downx=downx-8;
  694.      if(dot[(downx-36)/4+3][(downy-22)/4+1]==1||dot[(downx-36)/4+3][(downy-22)/4+2]==1||dot[(downx-36)/4+3][(downy-22)/4+3]==1)
  695.     {     
  696.       reachgraph(downx,downy,downcase);
  697.       px=36;
  698.     }
  699.     else
  700.     {
  701.       px=px+4;
  702.     };
  703.     break;
  704.     case 11:
  705.     downx=downx-12;
  706.      if(dot[(downx-36)/4+3][(downy-22)/4+1]==1||dot[(downx-36)/4+4][(downy-22)/4+2]==1)
  707.     {   
  708.       reachgraph(downx,downy,downcase);
  709.       px=36;
  710.     }
  711.     else
  712.     {
  713.       px=px+4;
  714.     };
  715.     break;
  716.     case 12:
  717.     downx=downx-12;
  718.      if(dot[(downx-36)/4+3][(downy-22)/4+1]==1||dot[(downx-36)/4+3][(downy-22)/4+3]==1||dot[(downx-36)/4+4][(downy-22)/4+2]==1)
  719.     {      
  720.       reachgraph(downx,downy,downcase);
  721.       px=36;
  722.     }
  723.     else
  724.     {
  725.       px=px+4;
  726.     };
  727.     break;
  728.     case 13:
  729.      downx=downx-12;
  730.      if(dot[(downx-36)/4+3][(downy-22)/4+3]==1||dot[(downx-36)/4+4][(downy-22)/4+2]==1)
  731.     {      
  732.       reachgraph(downx,downy,downcase);
  733.       px=36;
  734.     }
  735.     else
  736.     {
  737.       px=px+4;
  738.     };
  739.     break;
  740.     case 14:
  741.       downx=downx-12;  
  742.      if(dot[(downx-36)/4+3][(downy-22)/4+3]==1||dot[(downx-36)/4+4][(downy-22)/4+1]==1||dot[(downx-36)/4+4][(downy-22)/4+2]==1)
  743.     {   
  744.       reachgraph(downx,downy,downcase);
  745.       px=36;
  746.     }
  747.     else
  748.     {
  749.       px=px+4;
  750.     };
  751.     break;
  752.     case 15:
  753.     downx=downx-12;
  754.      if(dot[(downx-36)/4+3][(downy-22)/4+1]==1||dot[(downx-36)/4+4][(downy-22)/4+2]==1)
  755.     {      
  756.       reachgraph(downx,downy,downcase);
  757.       px=36;
  758.     }
  759.     else
  760.     {
  761.       px=px+4;
  762.     };
  763.     break;
  764.     case 16:
  765.     downx=downx-12;
  766.      if(dot[(downx-36)/4+3][(downy-22)/4+1]==1||dot[(downx-36)/4+4][(downy-22)/4+2]==1||dot[(downx-36)/4+4][(downy-22)/4+3]==1)
  767.     {      
  768.       reachgraph(downx,downy,downcase);
  769.       px=36;
  770.     }
  771.     else
  772.     {
  773.       px=px+4;
  774.     };
  775.     break;
  776.     case 17:
  777.     downx=downx-12;
  778.      if(dot[(downx-36)/4+3][(downy-22)/4+3]==1||dot[(downx-36)/4+4][(downy-22)/4+2]==1)
  779.     {
  780.       reachgraph(downx,downy,downcase);
  781.       px=36;
  782.     }
  783.     else
  784.     {
  785.       px=px+4;
  786.     };
  787.     break;
  788.     case 18:
  789.     downx=downx-12;
  790.      if(dot[(downx-36)/4+4][(downy-22)/4+1]==1||dot[(downx-36)/4+4][(downy-22)/4+2]==1||dot[(downx-36)/4+4][(downy-22)/4+3]==1||dot[(downx-36)/4+4][(downy-22)/4]==1)
  791.     {
  792.       reachgraph(downx,downy,downcase);
  793.       px=36;
  794.     }
  795.     else
  796.     {
  797.       px=px+4;
  798.     };
  799.     break;
  800.     case 19:
  801.     downx=downx-12;
  802.      if(dot[(downx-36)/4+4][(downy-22)/4+2]==1)
  803.     {
  804.       reachgraph(downx,downy,downcase);
  805.       px=36;
  806.     }
  807.     else
  808.     {
  809.       px=px+4;
  810.     };
  811.     break;   
  812.   }  
  813. }
  814. void reachgraph(int reachx,int reachy,int graphyk)
  815. {
  816.   switch(graphyk)
  817.   {
  818.     case 1:
  819.     dot[(px-44+4)/4][(py-22+4)/4]=1;
  820.     dot[(px-44+8)/4][(py-22+4)/4]=1;
  821.     dot[(px-44+8)/4][(py-22+8)/4]=1;
  822.     dot[(px-44+4)/4][(py-22+8)/4]=1;
  823.     break;
  824.     case 2:
  825.      dot[(px-44+4)/4][(py-22+12)/4]=1;
  826.     dot[(px-44+8)/4][(py-22+4)/4]=1;
  827.     dot[(px-44+8)/4][(py-22+8)/4]=1;
  828.     dot[(px-44+8)/4][(py-22+12)/4]=1;
  829.     break;   
  830.     case 3:
  831.     dot[(px-48+4)/4][(py-22+4)/4]=1;
  832.     dot[(px-48+4)/4][(py-22+8)/4]=1;
  833.     dot[(px-48+8)/4][(py-22+8)/4]=1;
  834.     dot[(px-48+12)/4][(py-22+8)/4]=1;
  835.     break;   
  836.     case 4:
  837.     dot[(px-48+12)/4][(py-22+4)/4]=1;
  838.     dot[(px-48+8)/4][(py-22+4)/4]=1;
  839.     dot[(px-48+8)/4][(py-22+8)/4]=1;
  840.     dot[(px-48+8)/4][(py-22+12)/4]=1;
  841.     break;   
  842.     case 5:
  843.      dot[(px-48+12)/4][(py-22+8)/4]=1;
  844.     dot[(px-48+4)/4][(py-22+4)/4]=1;
  845.     dot[(px-48+8)/4][(py-22+4)/4]=1;
  846.     dot[(px-48+12)/4][(py-22+4)/4]=1;
  847.     break;   
  848.     case 6:
  849.     dot[(px-44+4)/4][(py-22+4)/4]=1;
  850.     dot[(px-44+8)/4][(py-22+4)/4]=1;
  851.     dot[(px-44+8)/4][(py-22+8)/4]=1;
  852.     dot[(px-44+8)/4][(py-22+12)/4]=1;
  853.     break;   
  854.     case 7:
  855.     dot[(px-48+12)/4][(py-22+4)/4]=1;
  856.     dot[(px-48+4)/4][(py-22+8)/4]=1;
  857.     dot[(px-48+8)/4][(py-22+8)/4]=1;
  858.     dot[(px-48+12)/4][(py-22+8)/4]=1;
  859.     break;   
  860.      case 8:
  861.      dot[(px-44+8)/4][(py-22+12)/4]=1;
  862.     dot[(px-44+4)/4][(py-22+4)/4]=1;
  863.     dot[(px-44+4)/4][(py-22+8)/4]=1;
  864.     dot[(px-44+4)/4][(py-22+12)/4]=1;
  865.     break;   
  866.      case 9:
  867.      dot[(px-48+4)/4][(py-22+12)/4]=1;
  868.     dot[(px-48+4)/4][(py-22+8)/4]=1;
  869.     dot[(px-48+8)/4][(py-22+8)/4]=1;
  870.     dot[(px-48+12)/4][(py-22+8)/4]=1;
  871.     break;   
  872.      case 10:
  873.      dot[(px-44+4)/4][(py-22+8)/4]=1;
  874.     dot[(px-44+8)/4][(py-22+4)/4]=1;
  875.     dot[(px-44+8)/4][(py-22+8)/4]=1;
  876.     dot[(px-44+8)/4][(py-22+12)/4]=1;
  877.     break;   
  878.      case 11:
  879.      dot[(px-48+8)/4][(py-22+4)/4]=1;
  880.     dot[(px-48+4)/4][(py-22+8)/4]=1;
  881.     dot[(px-48+8)/4][(py-22+8)/4]=1;
  882.     dot[(px-48+12)/4][(py-22+8)/4]=1;
  883.     break;   
  884.      case 12:
  885.      dot[(px-48+12)/4][(py-22+8)/4]=1;
  886.     dot[(px-48+8)/4][(py-22+4)/4]=1;
  887.     dot[(px-48+8)/4][(py-22+8)/4]=1;
  888.     dot[(px-48+8)/4][(py-22+12)/4]=1;
  889.     break;   
  890.      case 13:
  891.      dot[(px-48+8)/4][(py-22+12)/4]=1;
  892.     dot[(px-48+4)/4][(py-22+8)/4]=1;
  893.     dot[(px-48+8)/4][(py-22+8)/4]=1;
  894.     dot[(px-48+12)/4][(py-22+8)/4]=1;
  895.     break;   
  896.      case 14:
  897.      dot[(px-48+8)/4][(py-22+8)/4]=1;
  898.     dot[(px-48+8)/4][(py-22+12)/4]=1;
  899.     dot[(px-48+12)/4][(py-22+4)/4]=1;
  900.     dot[(px-48+12)/4][(py-22+8)/4]=1;
  901.     break;   
  902.      case 15:
  903.      dot[(px-48+8)/4][(py-22+8)/4]=1;
  904.     dot[(px-48+12)/4][(py-22+8)/4]=1;
  905.     dot[(px-48+8)/4][(py-22+4)/4]=1;
  906.     dot[(px-48+4)/4][(py-22+4)/4]=1;
  907.     break;   
  908.      case 16:
  909.      dot[(px-48+8)/4][(py-22+4)/4]=1;
  910.     dot[(px-48+8)/4][(py-22+8)/4]=1;
  911.     dot[(px-48+12)/4][(py-22+8)/4]=1;
  912.     dot[(px-48+12)/4][(py-22+12)/4]=1;
  913.     break;   
  914.      case 17:
  915.      dot[(px-48+8)/4][(py-22+8)/4]=1;
  916.     dot[(px-48+12)/4][(py-22+8)/4]=1;
  917.     dot[(px-48+4)/4][(py-22+12)/4]=1;
  918.     dot[(px-48+8)/4][(py-22+12)/4]=1;
  919.     break;   
  920.      case 18:
  921.      dot[(px-44+8)/4][(py-22)/4]=1;
  922.     dot[(px-44+8)/4][(py-22+4)/4]=1;
  923.     dot[(px-44+8)/4][(py-22+8)/4]=1;
  924.     dot[(px-44+8)/4][(py-22+12)/4]=1;
  925.     break;   
  926.      case 19:
  927.      dot[(px-48)/4][(py-22+8)/4]=1;
  928.     dot[(px-48+4)/4][(py-22+8)/4]=1;
  929.     dot[(px-48+8)/4][(py-22+8)/4]=1;
  930.     dot[(px-48+12)/4][(py-22+8)/4]=1;
  931.     break;   
  932.   }
  933. }
  934. void firstTrick(int x,int y,int firsttrick)
  935. {
  936.   if(firsttrick==1||firsttrick==2||firsttrick==6||firsttrick==8||firsttrick==10||firsttrick==18)
  937.   {
  938.     shape(px-8,py,firsttrick);   
  939.   }
  940.   else
  941.   {
  942.     shape(px-12,py,firsttrick);
  943.   }
  944. }
  945. void profile(int level,int score)
  946. {
  947.   u8g.drawLine(34,63,34,20);//boarline
  948.   u8g.drawLine(35,63,35,20);
  949.   u8g.drawLine(36,63,115,63);
  950.   u8g.drawLine(36,62,115,62);
  951.   u8g.drawLine(116,63,116,20);
  952.   u8g.drawLine(117,63,117,20);
  953.   u8g.drawLine(36,21,115,21);
  954.   u8g.drawLine(36,20,115,20);
  955.   u8g.setFont(u8g_font_micro);//next
  956.   u8g.drawStr270(40,18,"NEXT:");  
  957.   u8g.drawStr270(70,18,"LEVEL");
  958.   u8g.setFont(u8g_font_6x13_67_75);
  959.   switch(level)
  960.   {
  961.     case 1:
  962.     u8g.drawBox(80,14,2,2);
  963.     break;
  964.     case 2:
  965.     u8g.drawBox(80,14,2,2);
  966.     u8g.drawBox(78,11,4,2);
  967.     break;
  968.     case 3:
  969.     u8g.drawBox(80,14,2,2);
  970.     u8g.drawBox(78,11,4,2);
  971.     u8g.drawBox(76,8,6,2);
  972.     break;
  973.     case 4:
  974.     u8g.drawBox(80,14,2,2);
  975.     u8g.drawBox(78,11,4,2);
  976.     u8g.drawBox(76,8,6,2);
  977.     u8g.drawBox(74,5,8,2);
  978.     break;
  979.     case 5:
  980.     u8g.drawBox(80,14,3,2);
  981.     u8g.drawBox(78,11,5,2);
  982.     u8g.drawBox(76,8,7,2);
  983.     u8g.drawBox(74,5,9,2);
  984.     u8g.drawBox(72,2,11,2);
  985.     break;
  986.     default:
  987.     break;   
  988.   }
  989.   u8g.setFont(u8g_font_5x7);//score
  990.   u8g.drawStr270(15,62,"SCORE:");
  991.   int scorege=score%10;
  992.   writeScore(15,5,scorege);
  993.   int scoreshi=(score%100-scorege)/10;
  994.   writeScore(15,11,scoreshi);
  995.   int scorebai=(score%1000-scoreshi*10-scorege)/100;
  996.   writeScore(15,17,scorebai);
  997.   int scoreqian=(score%10000-scorebai*100-scoreshi*10-scorege)/1000;
  998.   writeScore(15,23,scoreqian);
  999.   int scorewan=(score%100000-scoreqian*1000-scorebai*100-scoreshi*10-scorege)/10000;
  1000.   writeScore(15,29,scorewan);  
  1001. }
  1002. void writeScore(int x,int y,int score)
  1003. {
  1004.   switch(score)
  1005.   {
  1006.     case 0:
  1007.     u8g.drawStr270(x,y,"0");
  1008.     break;
  1009.     case 1:
  1010.     u8g.drawStr270(x,y,"1");
  1011.     break;
  1012.     case 2:
  1013.     u8g.drawStr270(x,y,"2");
  1014.     break;
  1015.     case 3:
  1016.     u8g.drawStr270(x,y,"3");
  1017.     break;
  1018.     case 4:
  1019.     u8g.drawStr270(x,y,"4");
  1020.     break;
  1021.     case 5:
  1022.     u8g.drawStr270(x,y,"5");
  1023.     break;
  1024.     case 6:
  1025.     u8g.drawStr270(x,y,"6");
  1026.     break;
  1027.     case 7:
  1028.     u8g.drawStr270(x,y,"7");
  1029.     break;
  1030.     case 8:
  1031.     u8g.drawStr270(x,y,"8");
  1032.     break;
  1033.     case 9:
  1034.     u8g.drawStr270(x,y,"9");
  1035.     break;   
  1036.   }
  1037. }
  1038. void switchrotate(int rotate)
  1039. {
  1040.   if(rotate==1)
  1041.   {
  1042.     rotate=rotate;
  1043.   }
  1044.   else if(rotate==5||rotate==9||rotate==13||rotate==15||rotate==17||rotate==19)
  1045.   {
  1046.     rotate=rotate-1;
  1047.   }
  1048.   else
  1049.   {
  1050.     rotate=rotate+1;
  1051.   };
  1052. }
  1053. void shape(int x,int y,int k)
  1054. {
  1055.   switch(k)
  1056.   {
  1057.     case 1:  
  1058.     if((x+4)>=36&&(x+4)<=115&&(y+4)>=22&&(y+4)<=61)
  1059.     {
  1060.     base(x+4,y+4);
  1061.     };
  1062.     if((x+8)>=36&&(x+8)<=115&&(y+4)>=22&&(y+4)<=61)
  1063.     {
  1064.     base(x+8,y+4);   
  1065.     };
  1066.     if((x+8)>=36&&(x+8)<=115&&(y+8)>=22&&(y+8)<=61)
  1067.     {
  1068.     base(x+8,y+8);     
  1069.     };
  1070.     if((x+4)>=36&&(x+4)<=115&&(y+8)>=22&&(y+8)<=61)
  1071.     {
  1072.     base(x+4,y+8);     
  1073.     };
  1074.     break;
  1075.     case 2:
  1076.     if((x+4)>=36&&(x+4)<=115&&(y+12)>=22&&(y+12)<=61)
  1077.     {
  1078.     base(x+4,y+12);
  1079.     };
  1080.     if((x+8)>=36&&(x+8)<=115&&(y+4)>=22&&(y+4)<=61)
  1081.     {
  1082.     base(x+8,y+4);
  1083.     };
  1084.     if((x+8)>=36&&(x+8)<=115&&(y+8)>=22&&(y+8)<=61)
  1085.     {
  1086.     base(x+8,y+8);
  1087.     };
  1088.     if((x+8)>=36&&(x+8)<=115&&(y+12)>=22&&(y+12)<=61)
  1089.     {
  1090.     base(x+8,y+12);
  1091.     };
  1092.     break;
  1093.     case 3:
  1094.     if((x+4)>=36&&(x+4)<=115&&(y+4)>=22&&(y+4)<=61)
  1095.     {
  1096.     base(x+4,y+4);
  1097.     };
  1098.     if((x+4)>=36&&(x+4)<=115&&(y+8)>=22&&(y+8)<=61)
  1099.     {
  1100.     base(x+4,y+8);
  1101.     };
  1102.     if((x+8)>=36&&(x+8)<=115&&(y+8)>=22&&(y+8)<=61)
  1103.     {
  1104.     base(x+8,y+8);
  1105.     };
  1106.     if((x+12)>=36&&(x+12)<=115&&(y+8)>=22&&(y+8)<=61)
  1107.     {
  1108.     base(x+12,y+8);
  1109.     };
  1110.     break;
  1111.     case 4:
  1112.     if((x+12)>=36&&(x+12)<=115&&(y+4)>=22&&(y+4)<=61)
  1113.     {
  1114.     base(x+12,y+4);
  1115.     };
  1116.     if((x+8)>=36&&(x+8)<=115&&(y+4)>=22&&(y+4)<=61)
  1117.     {
  1118.     base(x+8,y+4);
  1119.     };
  1120.     if((x+8)>=36&&(x+8)<=115&&(y+8)>=22&&(y+8)<=61)
  1121.     {
  1122.     base(x+8,y+8);
  1123.     };
  1124.     if((x+8)>=36&&(x+8)<=115&&(y+12)>=22&&(y+12)<=61)
  1125.     {
  1126.     base(x+8,y+12);
  1127.     };
  1128.     break;
  1129.     case 5:
  1130.     if((x+12)>=36&&(x+12)<=115&&(y+8)>=22&&(y+8)<=61)
  1131.     {
  1132.     base(x+12,y+8);
  1133.     };
  1134.     if((x+4)>=36&&(x+4)<=115&&(y+4)>=22&&(y+4)<=61)
  1135.     {
  1136.     base(x+4,y+4);
  1137.     };
  1138.     if((x+8)>=36&&(x+8)<=115&&(y+4)>=22&&(y+4)<=61)
  1139.     {
  1140.     base(x+8,y+4);
  1141.     };
  1142.     if((x+12)>=36&&(x+12)<=115&&(y+4)>=22&&(y+4)<=61)
  1143.     {
  1144.     base(x+12,y+4);
  1145.     };
  1146.     break;
  1147.     case 6:
  1148.     if((x+4)>=36&&(x+4)<=115&&(y+4)>=22&&(y+4)<=61)
  1149.     {
  1150.     base(x+4,y+4);
  1151.     };
  1152.     if((x+8)>=36&&(x+8)<=115&&(y+4)>=22&&(y+4)<=61)
  1153.     {
  1154.     base(x+8,y+4);
  1155.     };
  1156.     if((x+8)>=36&&(x+8)<=115&&(y+8)>=22&&(y+8)<=61)
  1157.     {
  1158.     base(x+8,y+8);
  1159.     };
  1160.     if((x+8)>=36&&(x+8)<=115&&(y+12)>=22&&(y+12)<=61)
  1161.     {
  1162.     base(x+8,y+12);
  1163.     };
  1164.     break;
  1165.     case 7:
  1166.     if((x+12)>=36&&(x+12)<=115&&(y+4)>=22&&(y+4)<=61)
  1167.     {
  1168.     base(x+12,y+4);
  1169.     };
  1170.     if((x+4)>=36&&(x+4)<=115&&(y+8)>=22&&(y+8)<=61)
  1171.     {
  1172.     base(x+4,y+8);
  1173.     };
  1174.     if((x+8)>=36&&(x+8)<=115&&(y+8)>=22&&(y+8)<=61)
  1175.     {
  1176.     base(x+8,y+8);
  1177.     };
  1178.     if((x+12)>=36&&(x+12)<=115&&(y+8)>=22&&(y+8)<=61)
  1179.     {
  1180.     base(x+12,y+8);
  1181.     };
  1182.     break;
  1183.     case 8:
  1184.     if((x+8)>=36&&(x+8)<=115&&(y+12)>=22&&(y+12)<=61)
  1185.     {
  1186.     base(x+8,y+12);
  1187.     };
  1188.     if((x+4)>=36&&(x+4)<=115&&(y+4)>=22&&(y+4)<=61)
  1189.     {
  1190.     base(x+4,y+4);
  1191.     };
  1192.     if((x+4)>=36&&(x+4)<=115&&(y+8)>=22&&(y+8)<=61)
  1193.     {
  1194.     base(x+4,y+8);
  1195.     };
  1196.     if((x+4)>=36&&(x+4)<=115&&(y+12)>=22&&(y+12)<=61)
  1197.     {
  1198.     base(x+4,y+12);
  1199.     };
  1200.     break;
  1201.     case 9:
  1202.     if((x+4)>=36&&(x+4)<=115&&(y+12)>=22&&(y+12)<=61)
  1203.     {
  1204.     base(x+4,y+12);
  1205.     };
  1206.     if((x+4)>=36&&(x+4)<=115&&(y+8)>=22&&(y+8)<=61)
  1207.     {
  1208.     base(x+4,y+8);
  1209.     };
  1210.     if((x+8)>=36&&(x+8)<=115&&(y+8)>=22&&(y+8)<=61)
  1211.     {
  1212.     base(x+8,y+8);
  1213.     };
  1214.     if((x+12)>=36&&(x+12)<=115&&(y+8)>=22&&(y+8)<=61)
  1215.     {
  1216.     base(x+12,y+8);
  1217.     };
  1218.     break;  
  1219.     case 10:
  1220.     if((x+4)>=36&&(x+4)<=115&&(y+8)>=22&&(y+8)<=61)
  1221.     {
  1222.     base(x+4,y+8);
  1223.     };
  1224.     if((x+8)>=36&&(x+8)<=115&&(y+4)>=22&&(y+4)<=61)
  1225.     {
  1226.     base(x+8,y+4);
  1227.     };
  1228.     if((x+8)>=36&&(x+8)<=115&&(y+8)>=22&&(y+8)<=61)
  1229.     {
  1230.     base(x+8,y+8);
  1231.     };
  1232.     if((x+8)>=36&&(x+8)<=115&&(y+12)>=22&&(y+12)<=61)
  1233.     {
  1234.     base(x+8,y+12);
  1235.     };
  1236.     break;
  1237.     case 11:
  1238.     if((x+8)>=36&&(x+8)<=115&&(y+4)>=22&&(y+4)<=61)
  1239.     {
  1240.     base(x+8,y+4);
  1241.     };
  1242.     if((x+4)>=36&&(x+4)<=115&&(y+8)>=22&&(y+8)<=61)
  1243.     {
  1244.     base(x+4,y+8);
  1245.     };
  1246.     if((x+8)>=36&&(x+8)<=115&&(y+8)>=22&&(y+8)<=61)
  1247.     {
  1248.     base(x+8,y+8);
  1249.     };
  1250.     if((x+12)>=36&&(x+12)<=115&&(y+8)>=22&&(y+8)<=61)
  1251.     {
  1252.     base(x+12,y+8);
  1253.     };
  1254.     break;
  1255.     case 12:
  1256.     if((x+12)>=36&&(x+12)<=115&&(y+8)>=22&&(y+8)<=61)
  1257.     {
  1258.     base(x+12,y+8);
  1259.     };
  1260.     if((x+8)>=36&&(x+8)<=115&&(y+4)>=22&&(y+4)<=61)
  1261.     {
  1262.     base(x+8,y+4);
  1263.     };
  1264.     if((x+8)>=36&&(x+8)<=115&&(y+8)>=22&&(y+8)<=61)
  1265.     {
  1266.     base(x+8,y+8);
  1267.     };
  1268.     if((x+8)>=36&&(x+8)<=115&&(y+12)>=22&&(y+12)<=61)
  1269.     {
  1270.     base(x+8,y+12);
  1271.     };
  1272.     break;
  1273.     case 13:
  1274.     if((x+8)>=36&&(x+8)<=115&&(y+12)>=22&&(y+12)<=61)
  1275.     {
  1276.     base(x+8,y+12);
  1277.     };
  1278.     if((x+4)>=36&&(x+4)<=115&&(y+8)>=22&&(y+8)<=61)
  1279.     {
  1280.     base(x+4,y+8);
  1281.     };
  1282.     if((x+8)>=36&&(x+8)<=115&&(y+8)>=22&&(y+8)<=61)
  1283.     {
  1284.     base(x+8,y+8);
  1285.     };
  1286.     if((x+12)>=36&&(x+12)<=115&&(y+8)>=22&&(y+8)<=61)
  1287.     {
  1288.     base(x+12,y+8);
  1289.     };
  1290.     break;
  1291.     case 14:
  1292.     if((x+8)>=36&&(x+8)<=115&&(y+8)>=22&&(y+8)<=61)
  1293.     {
  1294.     base(x+8,y+8);
  1295.     };
  1296.     if((x+8)>=36&&(x+8)<=115&&(y+12)>=22&&(y+12)<=61)
  1297.     {
  1298.     base(x+8,y+12);
  1299.     };
  1300.     if((x+12)>=36&&(x+12)<=115&&(y+4)>=22&&(y+4)<=61)
  1301.     {
  1302.     base(x+12,y+4);
  1303.     };
  1304.     if((x+12)>=36&&(x+12)<=115&&(y+8)>=22&&(y+8)<=61)
  1305.     {
  1306.     base(x+12,y+8);
  1307.     };
  1308.     break;
  1309.     case 15:
  1310.     if((x+8)>=36&&(x+8)<=115&&(y+8)>=22&&(y+8)<=61)
  1311.     {
  1312.     base(x+8,y+8);
  1313.     };
  1314.     if((x+12)>=36&&(x+12)<=115&&(y+8)>=22&&(y+8)<=61)
  1315.     {
  1316.     base(x+12,y+8);
  1317.     };
  1318.     if((x+8)>=36&&(x+8)<=115&&(y+4)>=22&&(y+4)<=61)
  1319.     {
  1320.     base(x+8,y+4);
  1321.     };
  1322.     if((x+4)>=36&&(x+4)<=115&&(y+4)>=22&&(y+4)<=61)
  1323.     {
  1324.     base(x+4,y+4);
  1325.     };
  1326.     break;
  1327.     case 16:
  1328.     if((x+8)>=36&&(x+8)<=115&&(y+4)>=22&&(y+4)<=61)
  1329.     {
  1330.     base(x+8,y+4);
  1331.     };
  1332.     if((x+8)>=36&&(x+8)<=115&&(y+8)>=22&&(y+8)<=61)
  1333.     {
  1334.     base(x+8,y+8);
  1335.     };
  1336.     if((x+12)>=36&&(x+12)<=115&&(y+8)>=22&&(y+8)<=61)
  1337.     {
  1338.     base(x+12,y+8);
  1339.     };
  1340.     if((x+12)>=36&&(x+12)<=115&&(y+12)>=22&&(y+12)<=61)
  1341.     {
  1342.     base(x+12,y+12);
  1343.     };
  1344.     break;
  1345.     case 17:
  1346.     if((x+8)>=36&&(x+8)<=115&&(y+8)>=22&&(y+8)<=61)
  1347.     {
  1348.     base(x+8,y+8);
  1349.     };
  1350.     if((x+12)>=36&&(x+12)<=115&&(y+8)>=22&&(y+8)<=61)
  1351.     {
  1352.     base(x+12,y+8);
  1353.     };
  1354.     if((x+4)>=36&&(x+4)<=115&&(y+12)>=22&&(y+12)<=61)
  1355.     {
  1356.     base(x+4,y+12);
  1357.     };
  1358.     if((x+8)>=36&&(x+8)<=115&&(y+12)>=22&&(y+12)<=61)
  1359.     {
  1360.     base(x+8,y+12);
  1361.     };
  1362.     break;
  1363.     case 18:
  1364.     if((x+8)>=36&&(x+8)<=115&&y>=22&&y<=61)
  1365.     {
  1366.     base(x+8,y);
  1367.     };
  1368.     if((x+8)>=36&&(x+8)<=115&&(y+4)>=22&&(y+4)<=61)
  1369.     {
  1370.     base(x+8,y+4);
  1371.     };
  1372.     if((x+8)>=36&&(x+8)<=115&&(y+8)>=22&&(y+8)<=61)
  1373.     {
  1374.     base(x+8,y+8);
  1375.     };
  1376.     if((x+8)>=36&&(x+8)<=115&&(y+12)>=22&&(y+12)<=61)
  1377.     {
  1378.     base(x+8,y+12);
  1379.     };
  1380.     break;
  1381.     case 19:
  1382.     if(x>=36&&x<=115&&(y+8)>=22&&(y+8)<=61)
  1383.     {
  1384.     base(x,y+8);
  1385.     };
  1386.     if((x+4)>=36&&(x+4)<=115&&(y+8)>=22&&(y+8)<=61)
  1387.     {
  1388.     base(x+4,y+8);
  1389.     };
  1390.     if((x+8)>=36&&(x+8)<=115&&(y+8)>=22&&(y+8)<=61)
  1391.     {
  1392.     base(x+8,y+8);
  1393.     };
  1394.     if((x+12)>=36&&(x+12)<=115&&(y+8)>=22&&(y+8)<=61)
  1395.     {
  1396.     base(x+12,y+8);
  1397.     };
  1398.     break;   
  1399.     default:
  1400.     break;
  1401.   }
  1402. }
  1403. void shapenext(int x,int y,int k)
  1404. {
  1405.   switch(k)
  1406.   {
  1407.     case 1:      
  1408.     base(x+4,y+4);   
  1409.     base(x+8,y+4);      
  1410.     base(x+8,y+8);      
  1411.     base(x+4,y+8);      
  1412.     break;
  1413.     case 2:  
  1414.     base(x+4,y+12);   
  1415.     base(x+8,y+4);   
  1416.     base(x+8,y+8);      
  1417.     base(x+8,y+12);   
  1418.     break;
  1419.     case 3:   
  1420.     base(x+4,y+4);
  1421.     base(x+4,y+8);   
  1422.     base(x+8,y+8);   
  1423.     base(x+12,y+8);   
  1424.     break;
  1425.     case 4:   
  1426.     base(x+12,y+4);   
  1427.     base(x+8,y+4);   
  1428.     base(x+8,y+8);   
  1429.     base(x+8,y+12);   
  1430.     break;
  1431.     case 5:   
  1432.     base(x+12,y+8);   
  1433.     base(x+4,y+4);   
  1434.     base(x+8,y+4);   
  1435.     base(x+12,y+4);   
  1436.     break;
  1437.     case 6:   
  1438.     base(x+4,y+4);   
  1439.     base(x+8,y+4);   
  1440.     base(x+8,y+8);   
  1441.     base(x+8,y+12);   
  1442.     break;
  1443.     case 7:   
  1444.     base(x+12,y+4);   
  1445.     base(x+4,y+8);   
  1446.     base(x+8,y+8);   
  1447.     base(x+12,y+8);  
  1448.     break;
  1449.     case 8:   
  1450.     base(x+8,y+12);   
  1451.     base(x+4,y+4);   
  1452.     base(x+4,y+8);   
  1453.     base(x+4,y+12);   
  1454.     break;
  1455.     case 9:   
  1456.     base(x+4,y+12);   
  1457.     base(x+4,y+8);   
  1458.     base(x+8,y+8);   
  1459.     base(x+12,y+8);   
  1460.     break;  
  1461.     case 10:   
  1462.     base(x+4,y+8);   
  1463.     base(x+8,y+4);
  1464.     base(x+8,y+8);   
  1465.     base(x+8,y+12);   
  1466.     break;
  1467.     case 11:   
  1468.     base(x+8,y+4);   
  1469.     base(x+4,y+8);   
  1470.     base(x+8,y+8);   
  1471.     base(x+12,y+8);   
  1472.     break;
  1473.     case 12:   
  1474.     base(x+12,y+8);   
  1475.     base(x+8,y+4);   
  1476.     base(x+8,y+8);   
  1477.     base(x+8,y+12);   
  1478.     break;
  1479.     case 13:   
  1480.     base(x+8,y+12);   
  1481.     base(x+4,y+8);   
  1482.     base(x+8,y+8);        
  1483.     base(x+12,y+8);   
  1484.     break;
  1485.     case 14:   
  1486.     base(x+8,y+8);   
  1487.     base(x+8,y+12);   
  1488.     base(x+12,y+4);   
  1489.     base(x+12,y+8);   
  1490.     break;
  1491.     case 15:   
  1492.     base(x+8,y+8);   
  1493.     base(x+12,y+8);   
  1494.     base(x+8,y+4);
  1495.     base(x+4,y+4);
  1496.     break;
  1497.     case 16:   
  1498.     base(x+8,y+4);
  1499.     base(x+8,y+8);   
  1500.     base(x+12,y+8);   
  1501.     base(x+12,y+12);   
  1502.     break;
  1503.     case 17:   
  1504.     base(x+8,y+8);   
  1505.     base(x+12,y+8);   
  1506.     base(x+4,y+12);   
  1507.     base(x+8,y+12);   
  1508.     break;
  1509.     case 18:   
  1510.     base(x+8,y);
  1511.     base(x+8,y+4);   
  1512.     base(x+8,y+8);   
  1513.     base(x+8,y+12);   
  1514.     break;
  1515.     case 19:   
  1516.     base(x,y+8);   
  1517.     base(x+4,y+8);   
  1518.     base(x+8,y+8);   
  1519.     base(x+12,y+8);   
  1520.     break;   
  1521.     default:
  1522.     break;
  1523.   }
  1524. }
  1525. void base(int x,int y)
  1526. {
  1527.   u8g.drawLine(x,y,x+3,y);
  1528.   u8g.drawLine(x,y+1,x,y+3);
  1529.   u8g.drawLine(x+2,y+3,x+1,y+3);
  1530.   u8g.drawLine(x+3,y+1,x+3,y+3);
  1531.   u8g.drawPixel(x+1,y+1);
  1532.   u8g.drawPixel(x+2,y+2);
  1533. }
  1534. void draw()
  1535. {
  1536.   switch(draw_state)
  1537.   {
  1538.     case 1:
  1539.     profile(level,score);   
  1540.     firstTrick(px,py-12,firsttrick);
  1541.     shapenext(41,0,knext);   
  1542.     break;
  1543.     case 2:
  1544.      for(int ix=0;ix<20;ix++)
  1545.    {
  1546.     for(int iy=0;iy<10;iy++)
  1547.     {
  1548.       if(dot[ix][iy]==1)
  1549.       {
  1550.         base((4*ix+36),(4*iy+22));
  1551.       }
  1552.      }
  1553.     };
  1554.     profile(level,score);      
  1555.     shapenext(41,0,knext);
  1556.     firstTrick(px,py-12,nexttrick);   
  1557.     break;   
  1558.   }
  1559. }
  1560. void setup()
  1561. {  
  1562.   // flip screen, if required
  1563.   u8g.setRot180();
  1564.   // assign default color value
  1565.   if ( u8g.getMode() == U8G_MODE_R3G3B2 )
  1566.     u8g.setColorIndex(255);     // white
  1567.   else if ( u8g.getMode() == U8G_MODE_GRAY2BIT )
  1568.     u8g.setColorIndex(3);         // max intensity
  1569.   else if ( u8g.getMode() == U8G_MODE_BW )
  1570.     u8g.setColorIndex(1);         // pixel on  
  1571.   pinMode(13, OUTPUT);           
  1572.   digitalWrite(13, HIGH);
  1573.   randomSeed(analogRead(A0));
  1574.   irrecv.enableIRIn();
  1575.   //Serial.begin(9600);
  1576. }
  1577. void loop()
  1578. {
  1579.   if(px==36)
  1580.   {
  1581.     k=random(1,20);        
  1582.     firsttrick=random(1,20);
  1583.     nexttrick=knext;
  1584.     py=34;
  1585.     knext=k;
  1586.      if(draw_state<2)
  1587.     {
  1588.       draw_state++;
  1589.     }
  1590.     else
  1591.     {
  1592.       draw_state=draw_state;
  1593.     };
  1594.   }
  1595.   else
  1596.   {
  1597.     knext=knext;
  1598.   };
  1599.   u8g.firstPage();
  1600.   do{   
  1601.     draw();
  1602.   }
  1603.   while(u8g.nextPage());
  1604.   if(irrecv.decode(&results))
  1605.   {
  1606.     long remotesignal=results.value;
  1607.    // Serial.println(results.value);
  1608.     if(remotesignal==16584943)              //zuo
  1609.     {
  1610.       if(draw_state==1)
  1611.       {
  1612.         checkleft(px,py,firsttrick);
  1613.       }
  1614.       else
  1615.       {
  1616.         checkleft(px,py,nexttrick);
  1617.       };
  1618.       if(draw_state==1)
  1619.       {
  1620.         checkdown(px,py,firsttrick);
  1621.       }
  1622.       else
  1623.       {
  1624.         checkdown(px,py,nexttrick);
  1625.       };
  1626.     }
  1627.     else if(remotesignal==16601263)           //you
  1628.     {
  1629.        if(draw_state==1)
  1630.       {
  1631.         checkright(px,py,firsttrick);
  1632.       }
  1633.       else
  1634.       {
  1635.         checkright(px,py,nexttrick);
  1636.       };
  1637.      if(draw_state==1)
  1638.       {
  1639.         checkdown(px,py,firsttrick);
  1640.       }
  1641.       else
  1642.       {
  1643.         checkdown(px,py,nexttrick);
  1644.       };
  1645.     }
  1646.     else if(remotesignal==16621663)           //xuanzhuan
  1647.     {
  1648.       if(firsttrick==1)
  1649.       {
  1650.         firsttrick=firsttrick;
  1651.       }
  1652.         else if(firsttrick==5||firsttrick==9||firsttrick==13)
  1653.       {
  1654.         firsttrick=firsttrick-3;
  1655.       }
  1656.       else if(firsttrick==15||firsttrick==17||firsttrick==19)
  1657.       {
  1658.         firsttrick=firsttrick-1;
  1659.       }
  1660.       else
  1661.       {
  1662.         firsttrick=firsttrick+1;
  1663.       };
  1664.       if(nexttrick==1)
  1665.       {
  1666.         nexttrick=nexttrick;
  1667.       }
  1668.         else if(nexttrick==5||nexttrick==9||nexttrick==13)
  1669.       {
  1670.         nexttrick=nexttrick-3;
  1671.       }
  1672.       else if(nexttrick==15||nexttrick==17||nexttrick==19)
  1673.       {
  1674.         nexttrick=nexttrick-1;
  1675.       }
  1676.       else
  1677.       {
  1678.         nexttrick=nexttrick+1;
  1679.       };  
  1680.       if(draw_state==1)
  1681.       {
  1682.         checkdown(px,py,firsttrick);
  1683.       }
  1684.       else
  1685.       {
  1686.         checkdown(px,py,nexttrick);
  1687.       };
  1688.     }
  1689.     else if(remotesignal==16625743)               //xia
  1690.     {
  1691.    if(draw_state==1)
  1692.       {
  1693.         checkdown(px,py,firsttrick);
  1694.       }
  1695.       else
  1696.       {
  1697.         checkdown(px,py,nexttrick);
  1698.       };
  1699.       if(draw_state==1)
  1700.       {
  1701.         checkdown(px,py,firsttrick);
  1702.       }
  1703.       else
  1704.       {
  1705.         checkdown(px,py,nexttrick);
  1706.       };
  1707.     };
  1708.     if(px==112)
  1709.     {
  1710.       if(draw_state==1)
  1711.       {
  1712.       reachgraph(px,py,firsttrick);
  1713.       }
  1714.       else if(draw_state==2)
  1715.       {
  1716.       reachgraph(px,py,nexttrick);
  1717.       };
  1718.       px=36;      
  1719.       py=34;
  1720.     };
  1721.     irrecv.resume();
  1722.   }
  1723.   else
  1724.   {
  1725.     if(px==112)
  1726.     {
  1727.       if(draw_state==1)
  1728.       {
  1729.       reachgraph(px,py,firsttrick);
  1730.       }
  1731.       else if(draw_state==2)
  1732.       {
  1733.       reachgraph(px,py,nexttrick);
  1734.       };
  1735.       px=36;      
  1736.       py=34;
  1737.     }
  1738.     else
  1739.     {
  1740.     if(draw_state==1)
  1741.       {
  1742.         checkdown(px,py,firsttrick);
  1743.       }
  1744.       else
  1745.       {
  1746.         checkdown(px,py,nexttrick);
  1747.       };
  1748.     }
  1749.   };
  1750.   for(int xiaox=19;xiaox>=0;xiaox--)
  1751.   {
  1752.     int scoretimes=0;
  1753.     if(dot[xiaox][0]==1&&dot[xiaox][1]==1&&dot[xiaox][2]==1&&dot[xiaox][3]==1&&dot[xiaox][4]==1&&dot[xiaox][5]==1&&dot[xiaox][6]==1&&dot[xiaox][7]==1&&dot[xiaox][8]==1&&dot[xiaox][9]==1)
  1754.     {
  1755.       for(int updatex=xiaox;updatex>=0;updatex--)
  1756.       {
  1757.         for(int updatey=0;updatey<10;updatey++)
  1758.         {
  1759.           dot[updatex][updatey]=dot[updatex-1][updatey];
  1760.         };
  1761.       };
  1762.       scoretimes=scoretimes+1;
  1763.     }
  1764.     if(scoretimes==4)
  1765.     {
  1766.       score=score+50;
  1767.     }
  1768.     else
  1769.     {
  1770.       score=score+10*scoretimes;
  1771.     }
  1772.   };
  1773.   if(score<200)
  1774.   {
  1775.     level=1;
  1776.   }
  1777.   else if(score>=200&&score<500)
  1778.   {
  1779.     level=2;
  1780.   }
  1781.   else if(score>=500&&score<800)
  1782.   {
  1783.     level=3;
  1784.   }
  1785.   else if(score>=800&&score<1000)
  1786.   {
  1787.     level=4;
  1788.   }
  1789.   else if(score>=1000)
  1790.   {
  1791.     level=5;
  1792.   };
  1793.   int unittime=1000-level*100;
  1794.   delay(unittime);
  1795. //delay(50);
  1796. }
复制代码



   

hnyzcj  版主

发表于 2015-8-30 18:55:14

林海牛叉
回复

使用道具 举报

大连林海  初级技神
 楼主|

发表于 2015-8-30 18:57:44


学习别人 希望自己也能做出好玩的 和天蝎男一些玩耍
回复

使用道具 举报

丄帝De咗臂  高级技匠

发表于 2015-8-31 10:51:00

林海牛叉
回复

使用道具 举报

吹口琴的钢铁侠  初级技匠

发表于 2015-8-31 11:12:43

代码真长......
回复

使用道具 举报

大连林海  初级技神
 楼主|

发表于 2015-8-31 18:08:22


换一个新词好玩不 不要用陈老师的台词 {:2_27:}
回复

使用道具 举报

20060606  高级技匠

发表于 2020-8-22 19:20:01

好创意,赞一个,要是有电路图就更好了
回复

使用道具 举报

李狗蛋  学徒

发表于 2020-12-25 20:03:42

一人血书求出电路图
回复

使用道具 举报

xiang12138  学徒

发表于 2023-9-3 12:19:18

版主,能不能提供一下接线的图,我想复刻一下你这个方案,驱动一下显示屏,我一直失败.....
回复

使用道具 举报

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

本版积分规则

为本项目制作心愿单
购买心愿单
心愿单 编辑
[[wsData.name]]

硬件清单

  • [[d.name]]
btnicon
我也要做!
点击进入购买页面
上海智位机器人股份有限公司 沪ICP备09038501号-4

© 2013-2024 Comsenz Inc. Powered by Discuz! X3.4 Licensed

mail