Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/banghuazhao/classic_2048

Classic 2048 is a mobile puzzle game developed with Flutter. Slide tiles on a grid to combine numbers and reach 2048. Enjoy multiple grid sizes, stunning backgrounds, and smooth gameplay. Available on the Google Play Store.
https://github.com/banghuazhao/classic_2048

2048 2048-game dart flutter flutter-apps flutter-examples fluttergame

Last synced: 3 months ago
JSON representation

Classic 2048 is a mobile puzzle game developed with Flutter. Slide tiles on a grid to combine numbers and reach 2048. Enjoy multiple grid sizes, stunning backgrounds, and smooth gameplay. Available on the Google Play Store.

Awesome Lists containing this project

README

        

# ๐ŸŽฎ Classic 2048 Game

## ๐Ÿ“ Overview

Classic 2048 is a mobile puzzle game inspired by the original 2048 game developed using Flutter. The objective is to slide numbered tiles on a grid to combine them and create a tile with the number 2048.

[Available on Google Play](https://play.google.com/store/apps/details?id=com.appsbay.classic_2048)

## ๐ŸŒŸ Features

- ๐Ÿ“ **Multiple Grid Sizes**: Choose from 4x4, 5x5, and 6x6 grids for different levels of difficulty.
- ๐ŸŽฒ **Random and Shuffle Options**: Mix up the tiles with Random and Shuffle buttons to add an extra challenge.
- ๐Ÿ–ผ๏ธ **Beautiful Backgrounds**: Enjoy stunning background images as you play, inspired by nature and scenic locations.
- ๐Ÿ’ซ **Smooth Animations**: Experience smooth and fluid animations that enhance gameplay.
- ๐Ÿ‘ค **User-friendly Interface**: Simple and intuitive UI design for an engaging user experience.

## Screenshots


iOS Screenshot
iOS Screenshot

## ๐Ÿ”ง Version Constraints

- **Dart**: `>=3.0.0 <4.0.0`
- **Flutter**: `>=3.10.0`

## ๐ŸŽฎ How to Play

1. **Choose Game Mode**: Select your preferred grid size.
2. **Slide to Play**: Swipe in any direction to move the tiles. When two tiles with the same number touch, they merge into one.
3. **Aim for 2048**: Keep merging tiles until you create a tile with the number 2048.
4. **Use Shuffle and Random**: If you're stuck, use the Shuffle or Random buttons to mix up the board.

## ๐Ÿงฉ Game Logic

The main game mechanics for Classic 2048 are implemented in the `Game` class, which controls the board's state, score, and tile movements. Hereโ€™s an overview of the core functions:

- **`init()`**: Initializes the game board with empty cells, sets the score to zero, and places the starting tiles.
- **`moveLeft()`, `moveRight()`, `moveUp()`, `moveDown()`**: Handles the movement of tiles in each respective direction. These methods merge tiles of the same value and shift them appropriately to create new tiles.
- **`canMoveLeft()`, `canMoveRight()`, `canMoveUp()`, `canMoveDown()`**: Checks if a move in the specified direction is possible by identifying mergeable or empty adjacent cells.
- **`mergeLeft()`, `mergeRight()`, `mergeUp()`, `mergeDown()`**: Merges tiles as they shift, combining them if they have the same value and are adjacent, then updates the score.
- **`randomEmptyCell(int cnt)`**: Randomly places a new tile (2 or 4) on an empty cell after a move. The probability of spawning a 4 is set to 1/15.
- **`isGameOver()`**: Determines if there are no possible moves left, indicating the game is over.
- **`shuffle()`**: Randomizes the tiles on the board, adding an extra layer of challenge for players.
- **`resetMergeStatus()`**: Resets the merge status of all cells on the board, preparing for the next move.

The **`BoardCell`** class represents each tile on the grid, tracking its position, value, and whether it has recently merged. Together, these functions and classes enable smooth gameplay with responsive tile merging, movement, and scoring.

## ๐Ÿค Contribution

Feel free to fork this repository and submit pull requests. For major changes, please open an issue first to discuss what you would like to change.

## ๐Ÿ“„ License

This project is licensed under the MIT [License](LICENSE).