yulonglong/TetrisAI
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
master
Could not load branches
Nothing to show
Could not load tags
Nothing to show
{{ refName }}
default
Name already in use
A tag already exists with the provided branch name. Many Git commands accept both tag and branch names, so creating this branch may cause unexpected behavior. Are you sure you want to create this branch?
Code
-
Clone
Use Git or checkout with SVN using the web URL.
Work fast with our official CLI. Learn more.
- Open with GitHub Desktop
- Download ZIP
Sign In Required
Please sign in to use Codespaces.
Launching GitHub Desktop
If nothing happens, download GitHub Desktop and try again.
Launching GitHub Desktop
If nothing happens, download GitHub Desktop and try again.
Launching Xcode
If nothing happens, download Xcode and try again.
Launching Visual Studio Code
Your codespace will open once ready.
There was a problem preparing your codespace, please try again.
Latest commit
Git stats
Files
Failed to load latest commit information.
Type
Name
Latest commit message
Commit time
This is a basic Tetris simulation. Files: State - tetris simulation TFrame - frame that draws the board TLabel - drawing library PlayerSkeleton - setup for implementing a player State: This is the tetris simulation. It keeps track of the state and allows you to make moves. The board state is stored in field (a double array of integers) and is accessed by getField(). Zeros denote an empty square. Other values denote the turn on which that square was placed. NextPiece (accessed by getNextPiece) contains the ID (0-6) of the piece you are about to play. Moves are defined by two numbers: the SLOT, the leftmost column of the piece and the ORIENT, the orientation of the piece. Legalmoves gives an nx2 int array containing the n legal moves. A move can be made by specifying the two parameters as either 2 ints, an int array of length 2, or a single int specifying the row in the legalMoves array corresponding to the appropriate move. It also keeps track of the number of lines cleared - accessed by getRowsCleared(). draw() draws the board. drawNext() draws the next piece above the board clearNext() clears the drawing of the next piece so it can be drawn in a different slot/orientation TFrame: This extends JFrame and is instantiated to draw a state. It can save the current drawing to a .png file. The main function allows you to play a game manually using the arrow keys. TLabel: This is a drawing library. PlayerSkeleton: An example of how to implement a player. The main function plays a game automatically (with visualization). xx xx xxxx X XXX X XXX x xxx xx xx xx xx
About
(Completed). Tetris Artifical Intelligence Project.
Resources
Stars
Watchers
Forks
Packages 0
No packages published