Есть ли готовые решения Пазл на js?

Привет всем , нужно сделать пазлы без использования фреймворков на чистом js.
Может у кого есть какая идея или уже готовое решение , подскажите пожалуйста.
Есть идея просто взять квадрат с изображением и разбить на мелкие квадраты , с возможностью перетаскивания.
Как это сделать?
Есть такой код но это пятнашки.
<!doctype html>
<html>

<head>
    <meta charset="utf-8">
    <title>Пятнашки</title>
    <script src="puzzle15.js"></script>
    <link rel="stylesheet" href="style.css"> </head>

<body>
    <canvas id="puzzle15">Пятнашки</canvas>
    <script>
        init();
    </script>
</body>

</html>

function init() {
    var canvas = document.getElementById("puzzle15");
    canvas.width = 620;
    canvas.height = 620;
    var cellSize = canvas.width / 4;
    var context = canvas.getContext("2d");
    var field = new game15(); // создаём объект пятнашек
    field.mix(350); // тщательно перемешиваем содердимое коробки
    field.setCellView(function (x, y) { // задаём внешний вид пятнашек
        context.fillStyle = "#59409f";
        context.fillRect(x + 1, y + 1, cellSize - 2, cellSize - 2);
    });
    field.setNumView(function () { // параметры шрифта для цифр
        context.font = "bold " + (cellSize / 2) + "px Sans";
        context.textAlign = "center";
        context.textBaseline = "middle";
        context.fillStyle = "#ffffff";
    });
    context.fillStyle = "#222";
    context.fillRect(0, 0, canvas.width, canvas.height);
    field.draw(context, cellSize);

    function event(x, y) { // функция производит необходимые действие при клике(касанию)
        field.move(x, y);
        context.fillStyle = "#222";
        context.fillRect(0, 0, canvas.width, canvas.height);
        field.draw(context, cellSize);
        if (field.victory()) { // если головоломка сложена, то пятнашки заново перемешиваются
            alert("Собрано за " + field.getClicks() + " касание!"); // вывод сообщения о выигрыше!!
            field.mix(300);
            context.fillStyle = "#222";
            context.fillRect(0, 0, canvas.width, canvas.height);
            field.draw(context, cellSize);
        }
    }
    canvas.onclick = function (e) { // обрабатываем клики мышью
        var x = (e.pageX - canvas.offsetLeft) / cellSize | 0;
        var y = (e.pageY - canvas.offsetTop) / cellSize | 0;
        event(x, y); // выхов функции действия
    };
    canvas.ontouchend = function (e) { // обрабатываем касания пальцем
        var x = (e.touches[0].pageX - canvas.offsetLeft) / cellSize | 0;
        var y = (e.touches[0].pageY - canvas.offsetTop) / cellSize | 0;
        event(x, y);
    };
}

function game15() {
    var cellView = null;
    var numView = null;
    var arr = [[1, 2, 3, 4], [5, 6, 7, 8], [9, 10, 11, 12], [13, 14, 15, 0]];
    var clicks = 0;

    function getNull() { // функция возвращает координату пустой клетки
        for (var i = 0; i < 4; i++) {
            for (var j = 0; j < 4; j++) {
                if (arr[j][i] === 0) {
                    return {
                        "x": i
                        , "y": j
                    };
                }
            }
        }
    };
    // функция возвращает произвольное логическое значение
    function getRandomBool() {
        if (Math.floor(Math.random() * 2) === 0) {
            return true;
        }
    }
    // метод возвращает число касаний
    this.getClicks = function () {
        return clicks;
    };
    // метод перемещает "пятнашку" в пустую клутку 
    this.move = function (x, y) {
        var nullX = getNull().x;
        var nullY = getNull().y;
        if (((x - 1 == nullX || x + 1 == nullX) && y == nullY) || ((y - 1 == nullY || y + 1 == nullY) && x == nullX)) {
            arr[nullY][nullX] = arr[y][x];
            arr[y][x] = 0;
            clicks++;
        }
    };
    // проверка условия победы
    this.victory = function () {
        var e = [[1, 2, 3, 4], [5, 6, 7, 8], [9, 10, 11, 12], [13, 14, 15, 0]];
        var res = true;
        for (var i = 0; i < 4; i++) {
            for (var j = 0; j < 4; j++) {
                if (e[i][j] != arr[i][j]) {
                    res = false;
                }
            }
        }
        return res;
    };
    // метод "перемешивает" пятнашки
    this.mix = function (stepCount) {
        var x, y;
        for (var i = 0; i < stepCount; i++) {
            var nullX = getNull().x;
            var nullY = getNull().y;
            var hMove = getRandomBool();
            var upLeft = getRandomBool();
            if (!hMove && !upLeft) {
                y = nullY;
                x = nullX - 1;
            }
            if (hMove && !upLeft) {
                x = nullX;
                y = nullY + 1;
            }
            if (!hMove && upLeft) {
                y = nullY;
                x = nullX + 1;
            }
            if (hMove && upLeft) {
                x = nullX;
                y = nullY - 1;
            }
            if (0 <= x && x <= 3 && 0 <= y && y <= 3) {
                this.move(x, y);
            }
        }
        clicks = 0;
    };
    // внешний вид пятнашки
    this.setCellView = function (func) {
        cellView = func;
    };
    // параметры шрифта цифр
    this.setNumView = function (func) {
        numView = func;
    };
    // Метод рисующий наши пятнашки на холсте
    this.draw = function (context, size) {
        for (var i = 0; i < 4; i++) {
            for (var j = 0; j < 4; j++) {
                if (arr[i][j] > 0) {
                    if (cellView !== null) {
                        cellView(j * size, i * size);
                    }
                    if (numView !== null) {
                        numView();
                        context.fillText(arr[i][j], j * size + size / 2, i * size + size / 2);
                    }
                }
            }
        }
    };
}
  • Вопрос задан
  • 5417 просмотров
Пригласить эксперта
Ответы на вопрос 1
doniys_a
@doniys_a
Backend-разработчик (Php, node.js, python, ruby)
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Войти через центр авторизации
Похожие вопросы