Skip to content

alex566/Match3Kit

Folders and files

NameName
Last commit message
Last commit date

Latest commit

6b4bd6d · Mar 23, 2025

History

41 Commits
Sep 7, 2023
Jun 27, 2023
May 24, 2020
Mar 23, 2025
Mar 23, 2025
May 1, 2020
May 2, 2020
Mar 23, 2025
May 24, 2020

Repository files navigation

Match3Kit

Library for simple Match3 games. It can work with a solid grid of figures and spill them only in columns.

Forest walk

Example

Create the enum for all kinds of figures:

typealias MyGrid = Grid<Shape>
typealias MyController = Controller<Shape, Generator<Shape>, Matcher<Shape>>

enum Shapes: String, GridFilling {
    case square
    case circle
    case triangle

    var pattern: Pattern {
        Pattern(indices: [])
    }
}

Create a grid controller with configurations:

let controller = MyController(
    size: Size(columns: 6, rows: 6),
    basic: [.square, .circle, .triangle],
    bonuse: [],
    obstacles: []
)

Create UI based on the grid that the controller generated:

for index in allIndices {
    let cell = controller.grid.cell(at: index)
    setupUI(for: cell, at: index)
}

Swap figures after the user interaction:

func swap(source: Index, target: Index) {
    if controller.canSwapCell(at: source, with: target) {
        swapUI(source, target)
        if controller.shouldSwapCell(at: source, with: target) {
            let indices = controller.swapAndMatchCell(at: source, with: target)
            let match = controller.match(indices: indices, swapIndices: [source, target], refill: .spill)
            remove(indices)
            spawn(match.spawned)
            spill(match.removed)
        } else {
            swapUI(source, target)
        }
    } 
}

Used in:

Forest walk

Forest walk

TODO:

  • Add more examples with bonuses
  • Add a demo project