找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 3202|回复: 4
收起左侧

STM32单片机LCD240128搬货物Proteus仿真程序

[复制链接]
ID:475247 发表于 2020-4-2 10:24 | 显示全部楼层 |阅读模式
0001.jpg

单片机源程序如下:
  1. #include <reg52.h>
  2. #include <SS.h> //关卡的界面
  3. #include <SB.h> //在此文件中定义了汉字编码,用点阵液晶字模提取软件
  4. #define uchar unsigned char
  5. #define uint  unsigned int

  6. sbit cd = P2^0;          //=0,数据通道;=1,命令通道
  7. sbit rd = P2^1;          //=0,读选通有效
  8. sbit wr = P2^2;          //=0,写选通有效
  9. sbit ce = P2^3;         
  10. sbit md = P2^4;
  11. sbit rst= P2^5;         

  12. uchar  renh=6,   renl=4,  bu=0,  guan=1;
  13. static uchar SB[8][10];
  14. bit flag=1;

  15. void  wrdat(uchar) ;//写数据
  16. void  wrcmd(uchar cmd);                     //写命令
  17. void  wrdcmd(uchar dat1, cmd);//写带有一个参数的命令
  18. void  lcddcmd(uchar dat1,dat2,cmd);  //写带有两个参数的命令
  19. void  LCD24012864_init();
  20. void  dischar(uchar hang,uchar lie,uchar cha) ;//写ASCII码字符
  21. void  delay();
  22. void  disxg();                   //显示选关提示
  23. void  clear();               //清屏
  24. void  disphz(uchar count) ; //数字和汉字代码写入自定义字符存储区
  25. void  dishan(uchar hang, lie,uchar bianma);//写汉字代码行,列,bianma汉字在自定义字符中的位置,
  26. void  disshu(uchar hang, lie, bianma);//写数字代码行,列,bianma汉字在自定义字符中的位置,
  27. void  bushu();
  28. uchar key()        ;               //检测按键

  29. void tupian()          //画关卡地图
  30. {
  31.         uchar i,j;
  32.         for(i=0;i<8;i++)
  33.                 for(j=0;j<10;j++)
  34.                 {
  35.                         dishan(2*i,2*j,han[map[guan-1][i][j]]);
  36.                         SB[i][j]=map[guan-1][i][j];
  37.                         if(SB[i][j]==0x07) SB[i][j]=0x00;
  38.                 }
  39.                 dishan(4,22,han[4]);
  40.                 disshu(4,24,shu[0]);
  41.                 disshu(4,25,shu[guan]);
  42.                 dishan(4,26,han[5]);
  43.                 bushu();
  44.                 dishan(2*renh,2*renl,han[1]);
  45. }

  46. void shengli()                         //过关判断
  47. {
  48.         uchar i,j,s1=0,s2=0;
  49.         for(i=0;i<8;i++)
  50.                 for(j=0;j<10;j++)
  51.                 {
  52.                         if(map[guan-1][i][j]==0x07)     //检视目标
  53.                         {
  54.                                 s1++;                                            //目标计数
  55.                                 if(SB[i][j]==0x02) s2++;        //目标上箱子计数
  56.                         }
  57.                 }
  58.                 if(s1==s2)                                    //目标计数和目标上箱子计数相同,则过关
  59.                 {
  60.                         dishan(2,20,han[10]);                //显示过关提示
  61.                         dishan(2,22,han[11]);
  62.                         dishan(2,24,han[12]);
  63.                         dishan(2,26,han[5]);
  64.                         disshu(2,28,shu[11]);
  65.                         flag=0;                                     //停止游戏
  66.                         disxg();                                 //显示选关提示
  67.                 }
  68. }

  69. void xuanguan(uchar k)                 //选关处理
  70. {
  71.         if((k==1||k==3)&&guan<3) {guan++;renh=6;renl=4;tupian();}
  72.         if((k==2||k==4)&&guan>1) {guan--;renh=6;renl=4;tupian();}
  73. }

  74. void huintfumubiao()                //恢复目标显示,(被人踩的目标)
  75. {
  76.         uchar i,j;
  77.         for(i=0;i<8;i++)
  78.                 for(j=0;j<10;j++)
  79.                 {
  80.                         if(map[guan-1][i][j]==0x07&&SB[i][j]!=0x02)         //有目标且没有箱子
  81.                         {
  82.                                 if(renh!=i||renl!=j) dishan(2*i,2*j,han[7]);
  83.                         }
  84.                 }        
  85. }

  86. void game(uchar k)                        //游戏控制
  87. {
  88.         if(k==1)                        //向上
  89.         {
  90.                 if(SB[renh-1][renl]==0x00)                    //上面是空白
  91.                 {
  92.                         dishan(2*renh,2*renl,han[0]);          //人原来的位置清0
  93.                         renh--;                                                          //上移一行
  94.                         dishan(2*renh,2*renl,han[1]);          //人新位置显示
  95.                         bu++;                                                      //步数加1
  96.                 }

  97.                 else if((SB[renh-1][renl]==0x02)&&(SB[renh-2][renl]==0x00)) //上面是箱子,箱子上是空格
  98.                 {
  99.                         dishan(2*renh,2*renl,han[0]);dishan(2*(renh-1),2*renl,han[0]);
  100.                         renh--;
  101.                         dishan(2*renh,2*renl,han[1]);dishan(2*(renh-1),2*renl,han[2]);
  102.                         SB[renh][renl]=0x00;SB[renh-1][renl]=0x02;
  103.                         bu++;
  104.                 }
  105.         }

  106.         if(k==4)
  107.         {
  108.                 if(SB[renh+1][renl]==0x00)
  109.                 {
  110.                         dishan(2*renh,2*renl,han[0]);
  111.                         renh++;
  112.                         dishan(2*renh,2*renl,han[1]);
  113.                         bu++;
  114.                 }
  115.                 else if((SB[renh+1][renl]==0x02)&&(SB[renh+2][renl]==0x00))
  116.                 {
  117.                         dishan(2*renh,2*renl,han[0]);dishan(2*(renh+1),2*renl,han[0]);
  118.                         renh++;
  119.                         dishan(2*renh,2*renl,han[1]);dishan(2*(renh+1),2*renl,han[2]);
  120.                         SB[renh][renl]=0x00;SB[renh+1][renl]=0x02;
  121.                         bu++;
  122.                 }
  123.         }
  124.            if(k==2)
  125.         {
  126.                 if(SB[renh][renl-1]==0x00)
  127.                 {
  128.                         dishan(2*renh,2*renl,han[0]);
  129.                         renl--;
  130.                         dishan(2*renh,2*renl,han[1]);
  131.                         bu++;
  132.                 }
  133.                 else if((SB[renh][renl-1]==0x02)&&(SB[renh][renl-2]==0x00))
  134.                 {
  135.                         dishan(2*renh,2*renl,han[0]);dishan(2*renh,2*(renl-1),han[0]);
  136.                         renl--;
  137.                         dishan(2*renh,2*renl,han[1]);dishan(2*renh,2*(renl-1),han[2]);
  138.                         SB[renh][renl]=0x00;SB[renh][renl-1]=0x02;
  139.                         bu++;
  140.                 }
  141.         }
  142.            if(k==3)
  143.         {
  144.                 if(SB[renh][renl+1]==0x00)
  145.                 {
  146.                         dishan(2*renh,2*renl,han[0]);
  147.                         renl++;
  148.                         dishan(2*renh,2*renl,han[1]);
  149.                         bu++;
  150.                 }
  151.                 else if((SB[renh][renl+1]==0x02)&&(SB[renh][renl+2]==0x00))
  152.                 {
  153.                         dishan(2*renh,2*renl,han[0]);dishan(2*renh,2*(renl+1),han[0]);
  154.                         renl++;
  155.                         dishan(2*renh,2*renl,han[1]);dishan(2*renh,2*(renl+1),han[2]);
  156.                         SB[renh][renl]=0x00;SB[renh][renl+1]=0x02;
  157.                         bu++;
  158.                 }
  159.         }
  160.         huintfumubiao();
  161.         bushu();
  162.         shengli();
  163. }

  164. void clear()        //清屏
  165. {
  166.         uchar i,j;
  167.         for(i=0;i<8;i++)
  168.                 for(j=0;j<15;j++)
  169.                 {
  170.                         dishan(2*i,2*j,han[0]);         //写0
  171.                 }
  172. }


  173. void keychuli(uchar  k)          //按键处理
  174. {
  175.         if(k==5)         {flag=0;disxg();goto over;}          //键值为5,“选关”
  176.         if(k==6)         {flag=1;bu=0;renl=4;renh=6;clear();tupian();goto over;}        //键值为5,“开始”
  177.         if(k<5)
  178.         {
  179.                 if(flag==0)        xuanguan(k);  //选关处理
  180.                 else                        game(k);          //游戏控制
  181.         }
  182. over:
  183.         ;
  184. }


  185. void main()
  186. {
  187.         uchar k;
  188.         LCD24012864_init();
  189.         disphz(14);         //写入汉字
  190.         
  191.         tupian();
  192.         while(1)
  193.         {                        
  194.                 k=key();
  195.                 if(k!=0) keychuli(k);
  196.         }
  197. }

  198. void wrdat(uchar dat)              //写数据
  199. {
  200.         cd=0;
  201.         wr=0;
  202.         P0=dat;
  203.         wr=1;
  204. }

  205. void wrcmd(uchar cmd)                     //写命令
  206. {
  207.         cd=1;
  208.         wr=0;
  209.         P0=cmd;
  210.         wr=1;
  211. }

  212. void wrdcmd(uchar dat1, cmd)  //写带有一个参数的命令
  213. {
  214.         wrdat(dat1);
  215.         wrcmd(cmd);
  216. }

  217. void lcddcmd(uchar dat1,dat2,cmd)  //写带有两个参数的命令
  218. {
  219.         wrdat(dat1);
  220.         wrdat(dat2);
  221.         wrcmd(cmd);
  222. }

  223. void LCD24012864_init()               
  224. {
  225.         ce=0;         
  226.         md=0;
  227.         rst=1;        
  228.         lcddcmd(0x00,0x10,0x40); //设置文本显示区首地址
  229.         lcddcmd(30,0x00,0x41);   //设置文本显示区宽度
  230.         lcddcmd(0x00,0x00,0x42); //设置图形显示区首地址
  231.         lcddcmd(30,0x00,0x43);   //设置图形显示区宽度
  232.         wrcmd(0xa2);            //设置光标形状
  233.         wrcmd(0x80);            //设置显示方式,文本图形“或”
  234.         wrcmd(0x9e);            //设置光标闪烁,不显示,文本与图形显示
  235. }

  236. void dischar(uchar hang,uchar lie,uchar cha) //写ASCII码字符,hang字符行(=8图形行),lie字符列(=8图形列),chaASCII码
  237. {  //显示ASCII码时,16行x30列
  238.         uint address;
  239.         uchar dat1,dat2;
  240.         address=hang*30+lie+0x1000; //计算文本显示区地址
  241.         dat1=address;
  242.         dat2=address>>8;
  243.         lcddcmd(dat1,dat2,0x24);//地址指针定位
  244.         wrdcmd(cha,0xc4); //写字符,地址指针不变
  245. }

  246. void delay()                        //延时
  247. {
  248.         uint x;
  249.         for(x=0;x<1000;x++);
  250. }

  251. void disxg()                   //显示选关提示
  252. {
  253.         dishan(0,22,han[8]);
  254.         dishan(0,24,han[9]);
  255.         dishan(0,26,han[5]);
  256.         disshu(0,28,shu[10]);
  257. }

  258. void disphz(uchar count)  //count是要写的汉字个数  //数字和汉字代码写入自定义字符存储区
  259. {
  260.         uint i;
  261.         lcddcmd(0x03,0x00,0x22); //定义自定义字符(在GCRAM中)存储区字节地址高5位为0x03,
  262.         lcddcmd(0x00,0x1c,0x24); //0x03<<11+0x0400=0x1c00(字节地址)
  263.         for(i=0;i<16*8*12/8;i++)
  264.                 wrdcmd(shucode[i],0xc0);        //写数字(每个16*8)*12(0-9,:)到GCRAM
  265.         for(i=0;i<16*16*count/8;i++)
  266.                 wrdcmd(hancode[i],0xc0);         //写汉字(每个16*16)*count到GCRAM
  267. }

  268. void dishan(uchar hang, lie,uchar bianma)//写汉字代码行,列,bianma汉字在自定义字符中的位置,
  269. {
  270.         dischar(hang,lie,bianma);//每个汉字按左上,左下,右上,右下存放
  271.         dischar(hang+1,lie,bianma+1);
  272.         dischar(hang,lie+1,bianma+2);
  273.         dischar(hang+1,lie+1,bianma+3);
  274. }
  275. void disshu(uchar hang, lie, bianma)//写数字汉字代码行,列,bianma汉字在自定义字符中的位置,
  276. {
  277.         dischar(hang,lie,bianma);//每个汉字按左上,左下,右上,右下存放
  278.         dischar(hang+1,lie,bianma+1);
  279. }
  280. uchar key()                       //检测按键
  281. {
  282.         uchar x,k=0;
  283.         P1=0xff;
  284.         x=P1;
  285.         if(x==0xff)               //没按键跳出
  286.                 goto over;
  287.         else
  288.         {
  289.                 delay();           //有按键,延时
  290.                 P1=0xff;
  291.                 x=P1;
  292.                 if(x==0xff)                //再测
  293.                         goto over;wait:           //等待按键释放
  294.                         P1=0xff;
  295.                         x=P1;
  296.                         if(x==0xff) goto over;
  297.                         else goto wait;
  298.                 }
  299.         }
  300. over:
  301.         return k;
  302. }
复制代码

LCD240128搬货物.rar (23.03 KB, 下载次数: 89)
回复

使用道具 举报

ID:102963 发表于 2020-5-5 13:37 | 显示全部楼层
这是STM32单片机的?楼主发错了吧
回复

使用道具 举报

ID:475247 发表于 2020-7-13 14:53 | 显示全部楼层
songxia8013 发表于 2020-5-5 13:37
这是STM32单片机的?楼主发错了吧

咯!原来标题是LCD240128搬货物Proteus仿真,让他们改在前面加个STM32
回复

使用道具 举报

ID:865812 发表于 2021-6-18 15:37 | 显示全部楼层
第三关貌似有bug 过不去
回复

使用道具 举报

ID:254046 发表于 2022-10-18 21:13 | 显示全部楼层
.h文件也发出来看看吧,谢谢
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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