Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/bog-walk/minesweeper
:sunglasses: Retro Minesweeper built with Compose for Desktop.
https://github.com/bog-walk/minesweeper
compose-for-desktop jetpack-compose kotlin minesweeper
Last synced: 2 months ago
JSON representation
:sunglasses: Retro Minesweeper built with Compose for Desktop.
- Host: GitHub
- URL: https://github.com/bog-walk/minesweeper
- Owner: bog-walk
- License: mit
- Created: 2021-05-04T01:17:50.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2023-04-17T21:37:34.000Z (over 1 year ago)
- Last Synced: 2024-10-08T23:22:23.409Z (3 months ago)
- Topics: compose-for-desktop, jetpack-compose, kotlin, minesweeper
- Language: Kotlin
- Homepage:
- Size: 1.32 MB
- Stars: 3
- Watchers: 1
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.txt
Awesome Lists containing this project
README
# :rocket: Minesweeper :sunglasses::boom:
![](screenshots/ms_beginner.gif)
![](screenshots/ms_intermediate.gif):video_game: A dark-mode Minesweeper desktop app built using **JetBrains**
[Compose for Desktop](https://www.jetbrains.com/lp/compose-desktop/).## :memo: Game details
The game follows the classic rules with 3 built-in levels, as well as a custom level that allows the user to choose
the size of the game grid and the amount of mines.![](screenshots/ms_window_change.gif)
## :briefcase: Features
- Recursive expansion of selected cells with no surrounding mines
- Left- vs right-click mouse handling
- Use of `Canvas` to draw composables (including 7-segment digital screens) with a retro feel
- Window menu items trigger pop-up dialogs for: viewing rules, customizing game options
- Pop-up dialog triggered when in-game time exceeded, handled by state holder and `Timer()`
- Text fields validate input while typing and trigger composition of appropriate error messages regardless of focus order
- Robust model and UI test suites## :computer: Run desktop application
Clone the repository then pick an option:
- Open the project in IntelliJ IDEA and run `Main.kt`
- `./gradlew run` from an open terminal in the root of the project
- Open the Gradle toolbar and select `minesweeper/Tasks/compose desktop/run`
## :microscope: Run tests
Clone the repository then pick an option:
- Open the project in IntelliJ IDEA then choose specific tests using gutter icons or right-click the `src/test` folder and
select `Run 'Tests in 'minesweeper.test''`- `./gradlew test` from an open terminal in the root of the project
- Open the Gradle toolbar and select `minesweeper/Tasks/verification/test`