Skip to main content

A Manim plugin that allows you to generate scenes with chessboards with minimal setup.

Project description

Manim Chessboard

A Manim plugin that allows you to generate scenes with chessboards with minimal setup.

Installation

pip install manim-chessrender

Features

  • Initialize Chessboard: Easily create and display a fully initialized chessboard.
  • Move Pieces: Animate standard piece movements using UCI notation.
  • Special Moves: Handle special chess moves like castling and en passant.
  • Load FEN Strings: Load and display a board configuration from a FEN string.
  • Play PGN Files: Load and animate moves from PGN files.
  • Customization: Customize the appearance of the chessboard and pieces with different colors and image paths.

Usage

To render the examples, you need to run the script using Manim. Below are the examples included in this project.

MovePieceExample

This example initializes the chessboard and demonstrates moving a piece.

MovePieceExample

class MovePieceExample(MovingCameraScene):
    """
    Scene to demonstrate moving a piece on the chessboard.
    """
    def construct(self):
        """
        Constructs the scene by initializing the chessboard and moving a piece.
        """
        chessboard = ChessBoard()
        chessboard.initialize_board()
        self.add(chessboard.board)
        self.wait(1)
        self.play(chessboard.execute_move('e2e4'))
        self.wait(2)

PlayPGNExample

This example demonstrates playing moves from a PGN file on the chessboard.

PlayPGNExample

class PlayPGNExample(MovingCameraScene):
    """
    Scene to demonstrate playing moves from a PGN file on the chessboard.
    """
    def construct(self):
        """
        Constructs the scene by loading a PGN file and animating the moves on the chessboard.
        """
        chessboard = ChessBoard()
        chessboard.initialize_board()
        self.add(chessboard.board)
        self.wait(1)
        
        games = chessboard.load_pgn("./example/example.pgn")
        game = games[0]
        for move in game:
            self.play(chessboard.execute_move(move.uci()))
            self.wait(0.5)

Running the Examples

To run any of the examples, execute the script using Manim. For instance, to run the InitializeChessBoard example:

manim -pql examples.py InitializeChessBoard

Replace InitializeChessBoard with the class name of the example you want to run.

License

This project is licensed under the MIT License. See the LICENSE file for more details.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

manim_chessrender-0.1.2.tar.gz (168.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

manim_chessrender-0.1.2-py3-none-any.whl (178.0 kB view details)

Uploaded Python 3

File details

Details for the file manim_chessrender-0.1.2.tar.gz.

File metadata

  • Download URL: manim_chessrender-0.1.2.tar.gz
  • Upload date:
  • Size: 168.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.10.12

File hashes

Hashes for manim_chessrender-0.1.2.tar.gz
Algorithm Hash digest
SHA256 f62b227b09d6d7ae0591923ba9d019c16ac1fa244f72a4938eb077866422a57a
MD5 4c25cf8280ae8159f188a0b4ac57d650
BLAKE2b-256 487c9c110fc9e63a1200881fa0261db8f16c6e839279f9e924df40f2d216e441

See more details on using hashes here.

File details

Details for the file manim_chessrender-0.1.2-py3-none-any.whl.

File metadata

File hashes

Hashes for manim_chessrender-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 396dd2f51e7da44ac0c4660a3e74a7c6099d543b25a2906524db69dbcd7950b4
MD5 8308398214edcf237d65db4389a9b160
BLAKE2b-256 dff3db05949757ab47e9b6254923eecde64c60e7b0eb7f6891d29bbcfab105cb

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page