画布:仅在X轴上允许移动?

时间:2016-03-23 18:50:27

标签: javascript html5 canvas

问题

我正在创建一个游戏,你必须远离或避开射向你的射弹,我已经让用户移动他们控制的图像,但此时用户可以将图像放在画布上的任何位置。 / p>

问题

我怎样才能让用户沿画布的指定部分移动,只沿X轴移动?例如:

这是我的游戏,"工作进度":

enter image description here

用户控制着船只,他们应该只能像这样向左或向右移动,例如:

enter image description here

守则

<script>
    var game = create_game();
    game.init();

    //music
    var snd = new Audio("menu.mp3");
    snd.play();
        document.getElementById('mute').addEventListener('click', function (evt) {
        if ( snd.muted ) {
            snd.muted = false
            evt.target.innerHTML = 'mute'
        }
        else {
            snd.muted = true
            evt.target.innerHTML = 'unmute'
        }
    })

    function create_game() {
        debugger;
        var level = 1;
        var projectiles_per_level = 1;
        var min_speed_per_level = 1;
        var max_speed_per_level = 2;
        var last_projectile_time = 0;
        var next_projectile_time = 0;
        var width = 600;
        var height = 500;
        var delay = 1000;
        var item_width = 30;
        var item_height = 30;
        var total_projectiles = 0;
        var projectile_img = new Image();
        var projectile_w = 30;
        var projectile_h = 30;
        var player_img = new Image();
        var c, ctx;

        var projectiles = [];
        var player = {
            x: 200,
            y: 400,
            score: 0
        };

        function init() {
            projectile_img.src = "apple.png";
            player_img.src = "basket.png";

            level = 1;
            total_projectiles = 0;
            projectiles = [];

            c = document.getElementById("c");
            ctx = c.getContext("2d");
            ctx.fillStyle = "#ff6600";
            ctx.fillRect(0, 0, 500, 600);

            c.addEventListener("mousemove", function (e) {
                //moving over the canvas.
                var bounding_box = c.getBoundingClientRect();
                player.x = (e.clientX - bounding_box.left) * (c.width / bounding_box.width) - player_img.width / 2;
                player.y = (e.clientY - bounding_box.top) * (c.height / bounding_box.height) - player_img.height / 2;
            }, false);

            setupProjectiles(); 
            requestAnimationFrame(tick);
        }

        function setupProjectiles() {
            var max_projectiles = level * projectiles_per_level;
            while (projectiles.length < max_projectiles) {
                initProjectile(projectiles.length);
            }
        }

        function initProjectile(index) {
            var max_speed = max_speed_per_level * level;
            var min_speed = min_speed_per_level * level;
            projectiles[index] = {
                x: Math.round(Math.random() * (width - 2 * projectile_w)) + projectile_w,
                y: -projectile_h,
                v: Math.round(Math.random() * (max_speed - min_speed)) + min_speed,
                delay: Date.now() + Math.random() * delay
            }
            total_projectiles++;
        }

        function collision(projectile) {
            if (projectile.y + projectile_img.height < player.y + 74) {
                return false;
            }
            if (projectile.y > player.y + 74) {
                return false;
            }
            if (projectile.x + projectile_img.width < player.x + 177) {
                return false;
            }
            if (projectile.x > player.x + 177) {
                return false;
            }

            return true;
        }

        function maybeIncreaseDifficulty() {
            level = Math.max(1, Math.ceil(player.score / 10));
            setupProjectiles();
        }

        function tick() {
            var i;
            var projectile;
            var dateNow = Date.now();
            c.width = c.width;
            for (i = 0; i < projectiles.length; i++) {
                projectile = projectiles[i];
                if (dateNow > projectile.delay) {
                    projectile.y += projectile.v;
                    if (collision(projectile)) {
                        initProjectile(i);
                        player.score++;
                    } else if (projectile.y > height) {
                        initProjectile(i);
                    } else {
                        ctx.drawImage(projectile_img, projectile.x, projectile.y);
                    }
                }
            }
            ctx.font = "bold 24px sans-serif";
            ctx.fillStyle = "#ff6600";
            ctx.fillText(player.score, c.width - 50, 50);
            ctx.fillText("Level: " + level, 20, 50);

            ctx.drawImage(player_img, player.x, player.y);
            maybeIncreaseDifficulty();
            requestAnimationFrame(tick);
        }

        return {
            init: init
        };
    }           

</script>

JSFiddle (已破碎)

https://jsfiddle.net/3oc4jsf6/10/

1 个答案:

答案 0 :(得分:3)

如果您的船只与鼠标移动相关联,并且您希望仅允许在X轴上移动,则可以简单地避免在鼠标移动侦听器中更改其.y属性。

删除此行:

 player.y = (e.clientY - bounding_box.top) * (c.height / bounding_box.height) - player_img.height / 2;