最近微信的飞机大战非常流行,下载量非常高。

利用JS进行模拟制作了一个简单的飞机大战[此源码有很多地方可以进行重构和优化]

[此游戏中没有使用HTML5 任何浏览器都可以运行]。

效果图:

原理:利用javascript setInterval函数不停的进行元素位置的切换和添加飞机子弹,在飞机和子弹的运动中进行位置

检测,进行子弹和飞机的消失。

1、添加飞机

setInterval(function () {
var flyDiv = $('<div class="flyDiv"></div>');
flyDiv.css({left: Math.random() * 578, top: -22});
flyDiv.appendTo(main);
}, 3000);

2、添加子弹

    setInterval(function () {
var flyZ = $('<span class="z"></span>');
var l = m.offset().left + 23, t = m.offset().top;
flyZ.css({left: l, top: t});
flyZ.appendTo(main);
}, 600);

3、飞机的运动

setInterval(function () {
var allDiv = main.find('div'), allZ = main.find('span');
for (var i = 0; i < allDiv.length; i++) {
var f = $(allDiv[i]);
var nowTop = f.offset().top;
nowTop += 10;
f.css({top: nowTop});
for (var j = 0; j < allZ.length; j++) {
var z = $(allZ[j]);
if (testColl(
z.offset().left, z.offset().top, z.width(), z.height(),
f.offset().left, f.offset().top, f.width(), f.height()
)) {
z.remove();
f.remove();
sum.text(parseInt(sum.text()) + 1);
}
}
if (nowTop + 22 >= 400) {
f.remove();
}
}
}, 60);
4、子弹的运动
    setInterval(function () {
var allZ = main.find('span'),
allDiv = main.find('div');
for (var i = 0; i < allZ.length; i++) {
var z = $(allZ[i]);
var nowTop = z.offset().top;
nowTop -= 10;
z.css({top: nowTop}); for (var j = 0; j < allDiv.length; j++) {
var f = $(allDiv[j]);
if (testColl(
z.offset().left, z.offset().top, z.width(), z.height(),
f.offset().left, f.offset().top, f.width(), f.height()
)) {
z.remove();
f.remove();
sum.text(parseInt(sum.text()) + 1);
}
}
if (nowTop + 22 <= 0) {
z.remove();
}
} }, 60);

5、碰撞检测

function testColl(x1, y1, w1, h1, x2, y2, w2, h2) {
var l1 = x1;
var r1 = x1 + w1;
var t1 = y1;
var b1 = y1 + h1; var l2 = x2;
var r2 = x2 + w2;
var t2 = y2;
var b2 = y2 + h2; if (r1 < l2 || l1 > r2 || b1 < t2 || t1 > b2) {
return false;
}
else {
return true;
}
}

【完整源码】

<!DOCTYPE html>

<html lang="zh">

<head>

    <meta charset="utf-8"/>

    <meta http-equiv="X-UA-Compatible" content="IE=Edge,chrome=1"/>

    <title> new document </title>

    <style type="text/css">

        * {

            margin: 0;

            padding: 0;

        }

 

        #main {

            width: 600px;

            height: 400px;

            border: solid 1px #000;

            background: #cccccc;

        }

 

        .flyDiv {

            width: 20px;

            height: 20px;

            background: red;

            position: absolute;

        }

 

        .z {

            display: block;

            width: 4px;

            background: #000000;

            height: 10px;

            position: absolute;

            top: 390px;

        }

 

        .m {

            width: 50px;

            height: 50px;

            background: #000000;

            position: absolute;

            top: 345px;

            left: 275px;

        }

    </style>

</head>

 

<body>

<!-- html :begin -->

<div id="main"></div>

<div class="m" id="m"></div>

<div>

    打击飞机数:<label id="sum">0</label>

</div>

<!-- html :end -->

</body>

<script src="js/jquery-1.10.2.min.js"></script>

<script>

    $(document).ready(function () {

        var main = $('#main'),

                m = $('#m'),

                sum = $('#sum');

        $(document).on('keydown', function (ev) {

            var oEvent = ev || window.event;

            var l = m.offset().left,

                    t = m.offset().top;

            switch (oEvent.keyCode) {

                case 37:

                    if (l >= 0) {

                        l -= 12;

                    }

                    break;

                /*    case 38:

                 if (t >= 0) {

                 t -= 2;

                 }

                 break;*/

                case 39:

                    if (!(l + 50 > 600)) {

                        l += 12;

                    }

                    break;

                case 40:

                    if (!(t + 50 > 400)) {

                        t += 12;

                    }

                    break;

            }

            m.css({left: l, top: t});

        });

        setInterval(function () {

            var flyDiv = $('<div class="flyDiv"></div>');

            flyDiv.css({left: Math.random() * 578, top: -22});

            flyDiv.appendTo(main);

        }, 3000);

 

        setInterval(function () {

            var allDiv = main.find('div'), allZ = main.find('span');

            for (var i = 0; i < allDiv.length; i++) {

                var f = $(allDiv[i]);

                var nowTop = f.offset().top;

                nowTop += 10;

                f.css({top: nowTop});

                for (var j = 0; j < allZ.length; j++) {

                    var z = $(allZ[j]);

                    if (testColl(

                            z.offset().left, z.offset().top, z.width(), z.height(),

                            f.offset().left, f.offset().top, f.width(), f.height()

                    )) {

                        z.remove();

                        f.remove();

                        sum.text(parseInt(sum.text()) + 1);

                    }

                }

                if (nowTop + 22 >= 400) {

                    f.remove();

                }

            }

        }, 60);

 

        setInterval(function () {

            var flyZ = $('<span class="z"></span>');

            var l = m.offset().left + 23, t = m.offset().top;

            flyZ.css({left: l, top: t});

            flyZ.appendTo(main);

        }, 600);

 

        setInterval(function () {

            var allZ = main.find('span'),

                    allDiv = main.find('div');

            for (var i = 0; i < allZ.length; i++) {

                var z = $(allZ[i]);

                var nowTop = z.offset().top;

                nowTop -= 10;

                z.css({top: nowTop});

 

                for (var j = 0; j < allDiv.length; j++) {

                    var f = $(allDiv[j]);

                    if (testColl(

                            z.offset().left, z.offset().top, z.width(), z.height(),

                            f.offset().left, f.offset().top, f.width(), f.height()

                    )) {

                        z.remove();

                        f.remove();

                        sum.text(parseInt(sum.text()) + 1);

                    }

                }

                if (nowTop + 22 <= 0) {

                    z.remove();

                }

            }

 

        }, 60);

 

        function testColl(x1, y1, w1, h1, x2, y2, w2, h2) {

            var l1 = x1;

            var r1 = x1 + w1;

            var t1 = y1;

            var b1 = y1 + h1;

 

            var l2 = x2;

            var r2 = x2 + w2;

            var t2 = y2;

            var b2 = y2 + h2;

 

            if (r1 < l2 || l1 > r2 || b1 < t2 || t1 > b2) {

                return false;

            }

            else {

                return true;

            }

        }

    });

</script>

 

</html>

用Javascript模拟微信飞机大战游戏的更多相关文章

  1. 用javascript写星际飞机大战游戏

    在github里看到了个不错的脚本游戏,决定亲自动手来写,效果如下 下面是代码的思路分享 把整个代码理解消化确实不容易,但是如果你坚持看完相信你一定会有收获 如果没兴趣可以直接点击下面的链接 复制代码 ...

  2. 用Swift语言和Sprite Kit复制微信飞机大战游戏

    先上GitHub链接: https://github.com/songrotek/PlaneWar.git 接下来略微解说一下! 这个程序还有点Bug,见谅! 1 说明 游戏採用了Sprite kit ...

  3. 用DIV+Css+Jquery 实现的旧版微信飞机大战。

    用jquery 实现的旧版微信飞机大战. 以前一直都是做后台和业务逻辑,前端很少去做, 现在个小游戏. 方向键控制方向,Ctrl 键 放炸弹(当然你的有炸弹,哈哈)! 主要都是用div+Css实现的, ...

  4. 【一】仿微信飞机大战cocos2d-x3.0rc1

    參考 [偶尔e网事] 的 [cocos2d-x入门实战]微信飞机大战  cocos2dx 2.0版本号,偶尔e网事他写的很具体,面面俱到,大家很有必要看下.能够通过以下链接跳转: cocos2d-x入 ...

  5. 基于Cocos2d-x-1.0.1的飞机大战游戏开发实例(上)

    最近接触过几个版本的cocos2dx,决定每个大变动的版本都尝试一下.本实例模仿微信5.0版本中的飞机大战游戏,如图: 一.工具 1.素材:飞机大战的素材(图片.声音等)来自于网络 2.引擎:coco ...

  6. Cocos2d-x 3.0final 终结者系列教程16-《微信飞机大战》实现

    看到cocos2d-x推出了3.1版本号,真是每月一次新版本号,速度. 另一个好消息就是http://cn.cocos2d-x.org/上线了,祝贺!啥时候把我的视频和教程放上去呢?!! . 视频下载 ...

  7. 基于Cocos2d-x-1.0.1的飞机大战游戏开发实例(下)

    在飞机大战游戏开发中遇到的问题和解决方法: 1.在添加菜单时,我要添加一个有背景的菜单,需要在菜单pMenu中添加一个图片精灵,结果编译过了但是运行出错,如下图: 查了很多资料,调试了很长时间,整个人 ...

  8. 基于Cocos2d-x-1.0.1的飞机大战游戏开发实例(中)

    接<基于Cocos2d-x-1.0.1的飞机大战游戏开发实例(上)> 三.代码分析 1.界面初始化 bool PlaneWarGame::init() { bool bRet = fals ...

  9. 11.pygame飞机大战游戏整体代码

    主程序 # -*- coding: utf-8 -*- # @Time: 2022/5/20 22:26 # @Author: LiQi # @Describe: 主程序 import pygame ...

随机推荐

  1. python的函数调用和参数传递

    不可变对象(immutable):int.string.float.number.tuple 可变对象(mutable):dict.list 对于基本数据类型的变量,变量传递给函数后,函数会在内存中复 ...

  2. 10年微软MVP路(如何成为一个MVP?)

    搞微软技术的,大家或多或少都有听说过微软的"最有价值专家"(MVP), 从2006年到2015年连续10年ASP.NET/IIS MVP.当年很多一起搞微软技术的朋友都转搞其他非微 ...

  3. Servant:基于Web的IIS管理工具

    Servant for IIS是个管理IIS的简单.自动化的Web管理工具.安装Servant的过程很简单,只要双击批处理文件Install Servant Service.bat,然后按照屏幕上的说 ...

  4. Socket programing(make a chat software) summary 1:How to accsess LAN from WAN

    First we should know some basic conceptions about network: 1.Every PC is supposed to have its own IP ...

  5. 使用python拼接多张图片.二三事

    前几日在博客上看到一篇“使用python拼接多张图片”的Blog[具体是能将的图片名字必须是形如xx_1.png ... xx_100.png或者xx_001.png ... xx_100.png,拼 ...

  6. java compiler level does not match the version of the installed java project facet 解决方案

    项目出现 java compiler level does not match the version of the installed java project facet 错误,一般是项目移植出现 ...

  7. 替代jquery1.9版本以前的toggle事件函数(开关)

    以上文章为转载自http://blog.sina.com.cn/s/blog_50042fab0101c7a9.html var flag=1; $(".selector").cl ...

  8. 美图WEB开放平台环境配置

    平台环境配置 1.1.设置crossdomain.xml 下载crossdomain.xml文件,把解压出来的crossdomain.xml文件放在您保存图片或图片来源的服务器根目录下,比如: htt ...

  9. 浅谈linux 下,利用Nginx服务器代理实现ajax跨域请求。

    ajax跨域请求对于前端开发者几乎在任何一个项目中都会用到,众所周知,跨域请求有三种方式: jsonp; XHR2 代理: jsonp: 这种应该是开发中是使用的最多的,最常见的跨域请求方法,其实aj ...

  10. iOS 数据库的增删改查(OC版)

    自己写了几个方法来实现数据的增删改查功能: 首先在TARGETS--->>Build phases里面添加数据库所关联的库文件libsqlite3.tbd 添加完以后,在控制器上添加 #i ...