60行代码,制作H5版飞机大战游戏

用最基础的代码逻辑,实现了飞机大战的核心玩法


点击这里可以试玩欧

制作使用了PIXI框架,对于制作H5应用的运行效率优化的还算不错。

感兴趣可以一起研究

制作了如下功能

1、制作了游戏的场景元素及动画效果

2、飞机的控制

3、发射子弹击落敌机,得分功能

4、Game Over后,重新游戏

功能涵盖了基本H5游戏的制作套路。

可通过“复制”“粘贴”大法,进行功能的丰富

源码可以在线调试,也手机直接浏览

源码地址:​​​​​​​​​​​​​​http://pro.youyu001.com

代码说明

以下内容可以作为H5游戏开发的帮助手册使用

1)创建应用

var app = new PIXI.Application(512,768);
document.body.appendChild(app.view);

2)添加图片,设置图片位置与定位点

var plane = new PIXI.Sprite.fromImage("res/plane_blue_01.png");
app.stage.addChild(plane); //将图片放置到舞台
plane.anchor.x = 0.5; //设置图片锚点为图片中心
plane.anchor.y = 0.5;
plane.x = 200; //设置图片的位置
plane.y = 600;

3)添加文本显示

var scoreTxt = new PIXI.Text("score 0");
app.stage.addChild(scoreTxt); //将文本添加到舞台

4)添加控制功能,获取鼠标位置

bg.interactive = true;//背景图片允许接受控制信息
bg.on("pointermove", movePlane); //滑动控制
function movePlane(event) {
    var pos = event.data.getLocalPosition(app.stage); //获取鼠标当前位置
    plane.x = pos.x;
    plane.y = pos.y;
}

5)制作动画

app.ticker.add(animate); //指定帧频函数
function animate() {
    //背景图片移动
    bg.y += 2;
    if(bg.y >= 0) {
        bg.y = -768;
    }
}

6)游戏的碰撞逻辑

//根据两张图片的位置,计算距离
var pos = (bullet.x - enemy.x) * (bullet.x - enemy.x) + (bullet.y - enemy.y) * (bullet.y - enemy.y);
if(pos < 40 * 40) { //小于一定距离,则判定为碰上了


}

 完整的源码

<body></body>
<script src="pixi.js"></script>     
<script>
    //创建应用
    var app = new PIXI.Application(512,768);
    document.body.appendChild(app.view);
    app.view.style.height = "100%";

    //添加背景
    var bg = new PIXI.Sprite.fromImage("res/bg/img_bg_level_3.jpg");
    app.stage.addChild(bg);

    //添加子弹
    var bullet = new PIXI.Sprite.fromImage("res/bullet_01.png");
    app.stage.addChild(bullet);
    bullet.anchor.x = 0.5;   //设置飞机图片锚点为图片中心
    bullet.anchor.y = 0.5;

    //创建飞机图片
    var plane = new PIXI.Sprite.fromImage("res/plane_blue_01.png");
    app.stage.addChild(plane); //将图片放置到舞台
    plane.anchor.x = 0.5; //设置图片锚点为图片中心
    plane.anchor.y = 0.5;
    plane.x = 200; //设置图片的位置
    plane.y = 600;

    //添加敌机
    var enemy = new PIXI.Sprite.fromImage("res/enemy_01.png");
    app.stage.addChild(enemy);
    enemy.anchor.x = 0.5;   //设置飞机图片锚点为图片中心
    enemy.anchor.y = 0.5;
    enemy.x = 200;

    //创建得分显示文本
    var scoreTxt = new PIXI.Text("score 0");
    app.stage.addChild(scoreTxt); //将文本添加到舞台
    var score = 0; //得分变量,记录得分使用

    bg.interactive = true;//背景图片允许接受控制信息
    bg.on("pointermove", movePlane); //滑动控制
    function movePlane(event) {
        var pos = event.data.getLocalPosition(app.stage); //获取鼠标当前位置
        plane.x = pos.x;
        plane.y = pos.y;
    }

    var isGameOver = false; //是否游戏结束
    app.ticker.add(animate); //指定帧频函数
    function animate() {
        if(isGameOver == true) { //如果游戏结束,则不执行下面动画
            return;
        }

        //背景移动
        bg.y += 2;
        if(bg.y >= 0) {
            bg.y = -768;
        }

        //子弹移动
        bullet.y -= 10;
        if(bullet.y < -50) {
            bullet.x = plane.x;
            bullet.y = plane.y;
        }

        //敌机移动
        enemy.y += 5;
        if(enemy.y > 800) {
            enemy.y = -100;
            enemy.x = Math.random() * 450 + 50;
        }

        //子弹与敌机碰撞
        var pos = (bullet.x - enemy.x) * (bullet.x - enemy.x) + (bullet.y - enemy.y) * (bullet.y - enemy.y);
        if(pos < 40 * 40) {
            //敌机重新出现
            enemy.y = -100;
            enemy.x = Math.random() * 450 + 50;
            //重新发射子弹
            bullet.x = plane.x;
            bullet.y = plane.y;
            //得分+1
            score ++; 
            scoreTxt.text = "score " + score;
        }

        //玩家飞机与敌机碰撞
        var pos = (enemy.x - plane.x) * (enemy.x - plane.x) + (enemy.y - plane.y) * (enemy.y - plane.y);
        if(pos < 40 * 40) {
            //游戏结束标记
            isGameOver = true;
            //是否重玩
            if (confirm("Game Over, restart?")==true){  
                window.location.reload();
            }
        }
    }


</script>

  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
抱歉,作为AI语言模型,我无法编写完整的游戏代码。但是,我可以给你一些启发和思路来编写飞机大战游戏。 1. 导入必要的库和模块 在编写飞机大战游戏时,你需要使用Python的Pygame库。Pygame是一个专门用于编写2D游戏的Python库。它提供了许多有用的函数和类,可以帮助你轻松地创建游戏图形和动画。 在开始编写游戏之前,你需要导入Pygame库和其他必要的模块。以下是导入Pygame库的示例代码: ```python import pygame ``` 2. 创建游戏窗口 接下来,你需要创建一个游戏窗口,这是游戏中最基本的元素之一。在Pygame中,你可以使用pygame.display.set_mode()函数来创建游戏窗口,并指定窗口的大小和其他属性。 以下是创建游戏窗口的示例代码: ```python # 初始化Pygame pygame.init() # 设置游戏窗口大小 screen_width = 800 screen_height = 600 screen = pygame.display.set_mode((screen_width, screen_height)) # 设置游戏窗口标题和图标 pygame.display.set_caption("飞机大战") icon = pygame.image.load("icon.png") pygame.display.set_icon(icon) ``` 3. 加载游戏资源 在飞机大战游戏中,你需要加载游戏资源,如背景图片、飞机图片和音效。在Pygame中,你可以使用pygame.image.load()函数加载图片,使用pygame.mixer.Sound()函数加载音效。 以下是加载游戏资源的示例代码: ```python # 加载背景图片 background = pygame.image.load("background.png").convert() # 加载飞机图片 player_img = pygame.image.load("player.png").convert_alpha() # 加载音效 bullet_sound = pygame.mixer.Sound("bullet.wav") explosion_sound = pygame.mixer.Sound("explosion.wav") ``` 4. 创建游戏循环 接下来,你需要创建游戏循环,这是游戏中最重要的部分之一。游戏循环不断地更新游戏状态、处理用户输入、绘制游戏元素和播放音效。 在Pygame中,你可以使用while循环来创建游戏循环。在每次循环中,你需要处理Pygame事件,如按键和鼠标点击。你还需要更新游戏状态,并根据更新后的状态重新绘制游戏元素。 以下是创建游戏循环的示例代码: ```python # 设置游戏循环标志 running = True # 开始游戏循环 while running: # 处理Pygame事件 for event in pygame.event.get(): if event.type == pygame.QUIT: running = False # 更新游戏状态 update_game_state() # 绘制游戏元素 draw_game_elements() # 播放音效 play_sound_effects() # 更新屏幕显示 pygame.display.update() # 关闭Pygame pygame.quit() ``` 5. 处理用户输入 在游戏循环中,你需要处理用户输入,如按键和鼠标点击。在飞机大战游戏中,玩家可以使用键盘控制飞机的移动和发射子弹。 在Pygame中,你可以使用pygame.key.get_pressed()函数获取当前按下的键,并根据键盘输入更新游戏状态。 以下是处理用户输入的示例代码: ```python # 处理用户输入 keys = pygame.key.get_pressed() if keys[pygame.K_LEFT]: player.move_left() if keys[pygame.K_RIGHT]: player.move_right() if keys[pygame.K_SPACE]: player.shoot() ``` 6. 更新游戏状态 在游戏循环中,你需要更新游戏状态,如飞机的位置和子弹的状态。在飞机大战游戏中,你需要检测飞机是否与敌机相撞,以及子弹是否命中敌机。 以下是更新游戏状态的示例代码: ```python # 更新游戏状态 player.update() for enemy in enemies: enemy.update() if enemy.collides_with(player): player.explode() game_over() for bullet in player.bullets: if bullet.collides_with(enemy): enemy.explode() bullet.destroy() ``` 7. 绘制游戏元素 在游戏循环中,你需要根据更新后的游戏状态重新绘制游戏元素,如背景、飞机和敌机。 在Pygame中,你可以使用pygame.Surface.blit()函数将游戏元素绘制到屏幕上。你还可以使用pygame.draw()函数绘制简单的图形,如子弹和爆炸效果。 以下是绘制游戏元素的示例代码: ```python # 绘制背景 screen.blit(background, (0, 0)) # 绘制飞机 screen.blit(player_img, (player.x, player.y)) # 绘制敌机 for enemy in enemies: screen.blit(enemy_img, (enemy.x, enemy.y)) # 绘制子弹和爆炸效果 for bullet in player.bullets: pygame.draw.rect(screen, (255, 0, 0), bullet.rect) for explosion in explosions: screen.blit(explosion_anim[explosion.frame], (explosion.x, explosion.y)) ``` 8. 播放音效 在游戏循环中,你需要根据游戏状态播放音效,如发射子弹和敌机爆炸声音。 在Pygame中,你可以使用pygame.mixer.Sound.play()函数播放音效。 以下是播放音效的示例代码: ```python # 播放音效 for bullet in player.bullets: bullet_sound.play() for explosion in explosions: explosion_sound.play() ``` 以上是编写飞机大战游戏的一些思路和示例代码。当然,这只是一个简单的示例,你可以根据自己的需求和想法进修改和扩展,创造出更加丰富和有趣的游戏

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值