韩顺平_轻松搞定网页设计(html+css+javascript)_第34讲_js超级玛丽小游戏_学习笔记_源代码图解_PPT文档整理

采用面向对象思想设计超级马里奥游戏人物(示意图)

怎么用通过按键,来控制图片的位置
这个小游戏,用面向对象会很方便,不用面向对象会很麻烦很麻烦,比如以后要讲解的坦克大战的游戏,要是用纯的面向过程或函数式的方式写,那维护起来会非常的麻烦。

游戏分析:
(1)看看如何通过按钮来控制mario的位置
(2)设计相关的对象(Mario x y ...)
Event对象
onclick属性:当用户点击某个对象时调用的事件句柄

素材

mario.css

  1. .gamediv{
  2. width: 500px;
  3. height: 400px;
  4. pink;
  5. }
  6. /*表格样式*/
  7. .controlcenter{
  8. width: 200px;
  9. height: 200px;
  10. border: 1px solid red;
  11. }
.gamediv{
width: 500px;
height: 400px;
background-color: pink;
} /*表格样式*/
.controlcenter{
width: 200px;
height: 200px;
border: 1px solid red;
}

mario.html

  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  2. <html>
  3. <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
  4. <link rel="stylesheet" type="text/css" href="mario.css" />
  5. <head>
  6. <script language="javascript">
  7. //设计Mario类
  8. function Mario(){
  9. this.x=0;
  10. this.y=0;
  11. //移动 顺时针 0->上 1->右 2->下 3->左
  12. this.move=function(direct){
  13. switch(direct){
  14. case 1:
  15. //window.alert("mario 右移动");
  16. //这里为了改变 img的left 和top,我们需要得到 img元素。需要用到javascript的DOM编程。img 对象
  17. var mymario=document.getElementById('mymario');
  18. //取出 img 的top值
  19. //window.alert(mymario.style.top);
  20. //怎样去掉50px的px
  21. var top=mymario.style.top;
  22. //px占据两个,即lenght-2
  23. //window.alert(top.substr(0,top.length-2));
  24. //现在还是串,要转成数值才能加减
  25. top=parseInt(top.substr(0,top.length-2));
  26. //window.alert(top);
  27. mymario.style.top=(top+2)+"px"; //开始移动2px,看怎么拼接的,字符串和数值之间的转换
  28. //此时mario就可以向下移动了,把上面的打印调试输出代码都注释掉
  29. break;
  30. }
  31. }
  32. }
  33. //创建Mario对象
  34. var mario=new Mario();
  35. //全局函数
  36. function marioMove(direct){
  37. switch(direct){
  38. case 1:
  39. mario.move(direct);
  40. break;
  41. case 0:
  42. break;
  43. case 2:
  44. break;
  45. case 3:
  46. break;
  47. }
  48. }
  49. </script>
  50. </head>
  51. <body>
  52. <div class="gamediv">
  53. <img id="mymario" src="mario.jpg" style="left:100px; top:50px; position:absolute;" /> <!--用到了绝对定位-->
  54. </div>
  55. <table border="1px" class="controlcenter">
  56. <tr>
  57. <td colspan="3">游戏键盘</td>
  58. </tr>
  59. <tr>
  60. <td>**</td>
  61. <td><input type="button" value="↑↑" onclick="marioMove(1)" /></td>
  62. <td>**</td>
  63. </tr>
  64. <tr>
  65. <td><input type="button" value="←←" /></td>
  66. <td>**</td>
  67. <td><input type="button" value="→→" /></td>
  68. </tr>
  69. <tr>
  70. <td>**</td>
  71. <td><input type="button" value="↓↓" /></td>
  72. <td>**</td>
  73. </tr>
  74. </table>
  75. </body>
  76. </html>


再要求:
(1)mario碰到边界给一个提示

例子:js超级玛丽小游戏的更多相关文章

  1. Creator仿超级玛丽小游戏源码分享

    Creator仿超级玛丽小游戏源码分享 之前用Cocos Creator 做的一款仿超级玛丽的游戏,使用的版本为14.2 ,可以直接打包为APK,现在毕设已经完成,游戏分享出来,大家一起学习进步.特别 ...

  2. pixi.js 微信小游戏 入手

    pixi是什么?一款h5游戏引擎 优点:简单简洁性能第一 缺点:大多数用的国产三大引擎,pixi资料少,工具少, 为什么学,装逼 用pixi开发小游戏行吗? 行.但要简单处理下 下载官网上的 weap ...

  3. JS写小游戏(一):游戏框架

    前言 前一阵发现一个不错的网站,都是一些用html5+css+js写的小游戏,于是打算学习一番,写下这个系列博客主要是为了加深理解,当然也有一些个人感悟,如果英文好可以直接Click Here. 概述 ...

  4. three.js 微信小游戏

    最近在 https://classroom.udacity.com/courses/cs291 学习了一些 3D 引擎和 three.js 的知识 把 three.js 弄到微信小游戏里,先随便跑一跑 ...

  5. js消除小游戏(极简版)

    js小游戏极简版 (1) 基础布局 <div class = "box"> <p></p> <div class="div&qu ...

  6. JS扫雷小游戏

    HTML代码 <title> 扫雷 </title> <!-- ondragstart:防拖拽生成新页面 oncontextmenu:屏蔽右键菜单--> <b ...

  7. 使用JS制作小游戏贪吃蛇

    先看效果图: 过程如下: 1.首先创建一张画布地图<div class="map"> </div>: 2.创建食物的自调用函数 (function (){ ...

  8. 用原生js写小游戏--Flappy Bird

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  9. js石头剪刀布小游戏

    代码: <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title ...

随机推荐

  1. redis在Linux上的安装和简单使用

    一.官方文档介绍方式 这里演示的版本是Redis4.0.6,Linux系统是CentOS6.7,Jdk1.7,Jedis2.8.1 下载,解压,编译: $ wget http://download.r ...

  2. 深入理解Java虚拟机---学习感悟以及笔记

    一.为什么要学习Java虚拟机?       这里我们使用举例来说明为什么要学习Java虚拟机,其实这个问题就和为什么要学习数据结构和算法是一个道理,工欲善其事,必先利其器.曾经的我经常害怕处理内存溢 ...

  3. hdu 1151 Air Raid DAG最小边覆盖 最大二分匹配

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1151 题目大意: 城镇之间互相有边,但都是单向的,并且不会构成环,现在派伞兵降落去遍历城镇,问最少最少 ...

  4. 蓝桥杯 牌型种数 DFS

    牌型种数 小明被劫持到X赌城,被迫与其他3人玩牌. 一副扑克牌(去掉大小王牌,共52张),均匀发给4个人,每个人13张. 这时,小明脑子里突然冒出一个问题: 如果不考虑花色,只考虑点数,也不考虑自己得 ...

  5. ConcurrentHashMap\HashMap put操作时key为什么要rehash

    参考java并发编程的艺术一书中,对ConcurrentHashMap的讲解 ConcurrentHashMap使用的是分段锁Segment来保证不同的Segment区域互相不干扰,不存在锁竞争关系, ...

  6. 【OCR技术系列之二】文字定位与切割

    要做文字识别,第一步要考虑的就是怎么将每一个字符从图片中切割下来,然后才可以送入我们设计好的模型进行字符识别.现在就以下面这张图片为例,说一说最一般的字符切割的步骤是哪些. 当然,我们实际上要识别的图 ...

  7. Common Data Service (CDS) 初探

    作者:陈希章 发表于 2017年12月16日 前言 Common Data Service(以下简称为CDS),通用数据服务是一个创新性的基础功能,这是微软试图打造一个全新的基于SaaS模式的数据服务 ...

  8. ABAP CDS Table Function介绍与示例

    Core data services(以下简称CDS)可以指两样东西,一个是HANA CDS,一个是ABAP CDS. 如我们所知,HANA CDS只支持HANA数据库,ABAP CDS理论上支持多种 ...

  9. 剑指Offer_4_二维数组中的查找

    题目描述       在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数.       ...

  10. SAP ABAP编程 Table Control动态隐藏列

    在SAP DIALOG设计中,有时候须要动态的隐藏某些列,以下是方法. ***数据定义 CONTROLS: table_control TYPE TABLEVIEW USING SCREEN 0100 ...