js实现带积分弹球小游戏


Posted in Javascript onJuly 21, 2020

本文实例为大家分享了js实现带积分的弹球小游戏的具体代码,供大家参考,具体内容如下

注:如果小球与底部方块的角碰撞,积分可能有些许bug

<style>
  #box {
   width: 400px;
   height: 400px;
   border: 1px solid #000000;
   margin: 50px auto;
   position: relative;
  }

  #ball {
   height: 60px;
   width: 60px;
   border-radius: 50%;
   background-color: red;
   position: absolute;
   left: 0;
   top: 0;
  }

  #block {
   width: 100px;
   height: 20px;
   position: absolute;
   left: 150px;
   bottom: 0;
   background-color: black;
  }

  #count {
   color: #ff0000;
   font-size: 18px;
   position: absolute;
   width: 20px;
   height: 20px;
   left: -20px;
   top: 0;
  }
</style>
<body>
 <div id="box">
  <div id="count">0</div>
  <div id="ball"></div>
  <div id="block"></div>
 </div>
</body>
<script>
 var oBox = document.querySelector('#box');
 var oBall = document.querySelector('#ball');
 var oBlock = document.querySelector('#block');
 var oCount = document.querySelector('#count');

 var speedBlock = 5;
 var speedX = 5;
 var speedY = 4;

 var maxLeft = oBox.clientWidth - oBall.offsetWidth;
 var maxTop = oBox.clientHeight - oBall.offsetHeight;
 var max = oBox.clientWidth - oBlock.offsetWidth;

 setInterval(function () {
  var left = oBall.offsetLeft;
  var top = oBall.offsetTop;

  left += speedX;
  top += speedY;

  if (left < 0 || left > maxLeft) {
   speedX = -speedX;
  }

  if (top < 0) {
   speedY *= -1;
  }

  var r = oBall.offsetWidth / 2;

  if (left >= oBlock.offsetLeft - r && // 左边线碰撞条件
   left <= oBlock.offsetLeft - r + oBlock.offsetWidth && // 右边线碰撞条件
   top >= maxTop - oBlock.offsetHeight   // 下边线碰撞条件
  ) {
   // console.log('撞上了');
   speedY = -Math.abs(speedY);
   // speedY *= -1;
   oCount.innerHTML = oCount.innerHTML * 1 + 1;
  }

  if (top > maxTop) {
   left = 0;
   top = 0;
  }

  oBall.style.left = left + 'px';
  oBall.style.top = top + 'px';

 }, 50);

 document.onkeydown = function (e) {
  var ev = event || e;
  var keyCode = ev.keyCode || ev.which;

  var left = oBlock.offsetLeft;

  if (keyCode === 37) {
   left -= speedBlock;
  }
  if (keyCode === 39) {
   left += speedBlock;
  }

  if (left <= 0) {
   left = 0
  }

  if (left >= max) {
   left = max;
  }

  oBlock.style.left = left + 'px';
 }
</script>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
获取网站跟路径的javascript代码(站点及虚拟目录)
Oct 20 Javascript
JavaScript定时器和优化的取消定时器方法
Jul 03 Javascript
jqTransform美化表单
Oct 10 Javascript
JavaScript判断对象是否为数组
Dec 22 Javascript
jQuery取得iframe中元素的常用方法详解
Jan 14 Javascript
jQuery实现多级联动下拉列表查询框
Jan 18 Javascript
深入解析JavaScript中的arguments对象
Jun 12 Javascript
AngularJS使用$http配置对象方式与服务端交互方法
Aug 13 Javascript
Vue实现简易翻页效果源码分享
Nov 08 Javascript
关于vue3.0中的this.$router.replace({ path: '/'})刷新无效果问题
Jan 16 Javascript
JS前端广告拦截实现原理解析
Feb 17 Javascript
jquery实现轮播图特效
Apr 12 jQuery
在vue中created、mounted等方法使用小结
Jul 21 #Javascript
解决vue的touchStart事件及click事件冲突问题
Jul 21 #Javascript
解决Vue 移动端点击出现300毫秒延迟的问题
Jul 21 #Javascript
解决Vue中的生命周期beforeDestory不触发的问题
Jul 21 #Javascript
详解微信小程序入门从这里出发(登录注册、开发工具、文件及结构介绍)
Jul 21 #Javascript
vue 清空input标签 中file的值操作
Jul 21 #Javascript
Vue-resource安装过程及使用方法解析
Jul 21 #Javascript
You might like
PHP 内存缓存加速功能memcached安装与用法
2009/09/03 PHP
drupal 代码实现URL重写
2011/05/04 PHP
PHP 如何获取二维数组中某个key的集合
2014/06/03 PHP
php表单提交实例讲解
2015/11/12 PHP
Yii框架结合sphinx,Ajax实现搜索分页功能示例
2016/10/18 PHP
基于yaf框架和uploadify插件,做的一个导入excel文件,查看并保存数据的功能
2017/01/24 PHP
在IIS下安装PHP扩展的方法(超简单)
2017/04/10 PHP
js bind 函数 使用闭包保存执行上下文
2011/12/26 Javascript
js用Date对象处理时间实现思路及代码
2013/01/31 Javascript
js编写trim()函数及正则表达式的运用
2013/10/24 Javascript
javascript闭包传参和事件的循环绑定示例探讨
2014/04/17 Javascript
PHP结合jQuery实现红蓝投票功能特效
2015/07/22 Javascript
Markdown+Bootstrap图片自适应属性详解
2016/05/21 Javascript
angular ng-repeat数组中的数组实例
2017/02/18 Javascript
javascript 数据存储的常用函数总结
2017/06/01 Javascript
解决mpvue + vuex 开发微信小程序vuex辅助函数mapState、mapGetters不可用问题
2018/08/03 Javascript
[54:58]完美世界DOTA2联赛PWL S2 LBZS vs Rebirth 第一场 11.25
2020/11/25 DOTA
python实现监控windows服务并自动启动服务示例
2014/04/17 Python
python读取json文件并将数据插入到mongodb的方法
2015/03/23 Python
python如何在终端里面显示一张图片
2016/08/17 Python
200 行python 代码实现 2048 游戏
2018/01/12 Python
Python WSGI的深入理解
2018/08/01 Python
python3 http提交json参数并获取返回值的方法
2018/12/19 Python
详解Python连接MySQL数据库的多种方式
2019/04/16 Python
tensorflow实现训练变量checkpoint的保存与读取
2020/02/10 Python
解决pytorch-yolov3 train 报错的问题
2020/02/18 Python
详解Ubuntu环境下部署Django+uwsgi+nginx总结
2020/04/02 Python
Python实现快速大文件比较代码解析
2020/09/04 Python
python,Java,JavaScript实现indexOf
2020/09/09 Python
python数据抓取3种方法总结
2021/02/07 Python
定制iPhone和Macbook保护壳:Slick Case
2018/11/21 全球购物
华为智利官方商店:Huawei Chile
2020/05/09 全球购物
事业单位请假制度
2014/01/13 职场文书
公司承诺书怎么写
2014/05/24 职场文书
2019企业给员工的慰问信
2019/06/24 职场文书
浅谈MySQL函数
2021/10/05 MySQL