Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/lewisgaul/minegauler
A clone of the original minesweeper game with many added features
https://github.com/lewisgaul/minegauler
minesweeper minesweeper-game pyqt5 python
Last synced: 2 months ago
JSON representation
A clone of the original minesweeper game with many added features
- Host: GitHub
- URL: https://github.com/lewisgaul/minegauler
- Owner: LewisGaul
- License: gpl-3.0
- Created: 2016-06-07T17:13:36.000Z (over 8 years ago)
- Default Branch: main
- Last Pushed: 2023-12-27T18:10:39.000Z (about 1 year ago)
- Last Synced: 2024-10-14T05:42:20.060Z (3 months ago)
- Topics: minesweeper, minesweeper-game, pyqt5, python
- Language: Python
- Homepage:
- Size: 153 MB
- Stars: 12
- Watchers: 1
- Forks: 8
- Open Issues: 53
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE.txt
Awesome Lists containing this project
README
[![Build badge](https://img.shields.io/github/actions/workflow/status/LewisGaul/minegauler/full-test.yml?branch=dev)](https://github.com/LewisGaul/minegauler/actions?query=workflow%3A%22Workflow+for+full+test+matrix%22+branch%3Adev)
[![Codecov badge](https://img.shields.io/codecov/c/github/LewisGaul/minegauler/dev)](https://codecov.io/gh/LewisGaul/minegauler/)
[![PyPI badge](https://img.shields.io/pypi/v/minegauler.svg)](https://pypi.python.org/pypi/minegauler/)
[![Downloads badge](https://img.shields.io/github/downloads/LewisGaul/minegauler/total)](https://github.com/LewisGaul/minegauler/releases/)
[![Code style badge](https://img.shields.io/badge/code%20style-black-000000.svg)](https://black.readthedocs.io/en/stable/)# Minegauler v4.2.0-b0
Remake of the classic Minesweeper game, written in Python.
Read more about the project history in [my blog post](https://www.lewisgaul.co.uk/blog/coding/2020/02/12/minegauler/).
## Try it out!
### Download the executable
The application has been packaged with PyInstaller so that it can be played without setting up Python.
Download links available here:
- [Windows (amd64)](https://github.com/LewisGaul/minegauler/releases/download/v4.2.0-b0/minegauler-v4.2.0-b0-windows-amd64.zip)
- [Linux (x86_64)](https://github.com/LewisGaul/minegauler/releases/download/v4.2.0-b0/minegauler-v4.2.0-b0-linux-x86_64.tar.gz)
- [MacOS (x86_64)](https://github.com/LewisGaul/minegauler/releases/download/v4.2.0-b0/minegauler-v4.2.0-b0-macos-x86_64.tar.gz)
- MacOS (arm64) (not yet available, see [issue #214](https://github.com/LewisGaul/minegauler/issues/214))### Install from PyPI
The Python package is also available on PyPI: https://pypi.org/project/minegauler/.
1. Python 3.8+ required (check with `python3 --version`)
2. Install with `python3 -m pip install minegauler`
3. Run with `python3 -m minegauler`See note on system dependencies below, or [get in touch](#Contact) if you have any issues.
### Clone the repo
You will need Python 3.8+ to run the code (check with `python3 --version`).
1. Clone the repo: `git clone https://github.com/LewisGaul/minegauler`
2. Change directory: `cd minegauler`
3. Consider setting up a [virtual environment](https://docs.python.org/3/tutorial/venv.html)
4. Install requirements with `python3 -m pip install -r requirements.txt`
5. Run with `python3 -m minegauler`### System dependencies
#### WSL
If running in WSL (Windows Subsystem for Linux) you will need to set up an X-server for running graphical apps. This isn't too difficult to do, see or search online for further advice - I would recommend downloading and using Xming.
#### Linux
If running with `python -m minegauler` fails with `Aborted (core dumped)` on Linux, you may need a package that provides graphical support. For me this was fixed by running `sudo apt install libxkbcommon-x11-0` on Ubuntu in WSL1.
## Features
This app provides all of the basic functionality of the classic minesweeper game plus much more!
### Special features
Game menu:
* Create boards - create a board by placing mines, which can then be saved and loaded.
* Save and load boards - challenge friends to a board you played or created.
* Get current game info - see some info about the current game, e.g. if you lose a game you get a completion percentage and a predicted time.
* Local highscores - stores highscores and allows filtering/sorting in the UI.
* 5 difficulty levels - the standard beginner, intermediate and expert, plus two bonus levels of increasing difficulty!
* Custom - set a custom board size and number of mines.
* Button size - set the size of the cells.
* Themes - app themes include 'butterfly', 'halloween', 'christmas'.Options menu:
* Safe start - ensure the first click always gives an opening, or at least gives a safe cell if there are too many mines to give an opening.
* Drag select - enable selecting cells by clicking once and dragging the mouse.
* Max mines per cell - allow up to 3 mines per cell.
* Reach - the number of neighbouring cells cell numbers detect.
* Game mode
* Regular - the standard minesweeper game.
* Split cell - Each large cell can be split into the 4 underlying regular cells using 'right-click'. Large cells can only be split if they contain at least one mine, and must be split to find all of the safe regular cells.Note that all of the options above except 'safe start' have separate highscore tables.
Help menu:
* Rules, features, tips.
* Retrieve highscores - import highscores from an old version of the app (only works for versions at least v4.0).### What's new/upcoming?
Check the [changelog](CHANGELOG.md) to see a log of changes that have been made. See [issues](https://github.com/LewisGaul/minegauler/issues) for upcoming features/fixes.
If there's a feature you'd like to see added, please don't hesitate to [contact me](#Contact)!
## Development guide
Install the developer requirements with `python3 -m pip install -r requirements-dev.txt`.
Run the tests with the command `pytest` (see the [pytest docs](https://docs.pytest.org/en/latest/how-to/usage.html)).
Get coverage information using the pytest-cov plugin: `pytest --cov minegauler [--cov-report html]`.
## Contact
Please don't hesitate to [open an issue](https://github.com/LewisGaul/minegauler/issues/new) or a [discussion](https://github.com/LewisGaul/minegauler/discussions) if you think you've found a bug, have a feature request, or just want to say hi!
You can also email at [[email protected]](mailto:[email protected]).