It's not so hard as it may sound if you break it down. The key components of a game are as follows:
- Output
- Input
- Logic
- Data Storage
How do you update the state of the game? You can simply print out a bunch of blank lines to shift everything up, and then reprint the next state. To get timer-based event loop, use the WAITFOR command to introduce a half-second or so delay between frames. If you do this, you will find a problem - the output doesn't display immediately. Even if you print a bunch of output, do a WAITFOR, print more output, WAITFOR again, and then finally some output and finish the query, you'll see that nothing displays until the entire query is finished processing. There is a trick to flush the output buffer - by raising a level-0 error:
raiserror('',0,1) with nowait --to flush the buffer
waitfor delay '00:00:10' --pause for 10 seconds
This basically solves the problem of output - create a continuous loop that prints out the board state and has a delay. The downside is an ever-growing output buffer which may eventually crash SSMS once it reaches the limit of available memory. You may have to restart the output cycle from time to time to prevent reaching this limit.
Getting input is quite a bit trickier. I explored a number of different options, including running queries in a separate tab, and using macros. The best solution I've come up with is to have an entirely separate SSMS window open for input (works best with multiple monitors), so that you can interact with the second session while leaving the output screen running constantly. To get somewhat interactive input, I've opted to make use of the Query Shortcuts feature, found in Tools -> Options -> Environment -> Keyboard -> Query Shortcuts. This allows you to define something like a macro, in the form of a SQL command that runs when you hit the predefined key CTRL+1 through 9.
The key inputs for Tetris are moving the piece left, right, and down, dropping the piece to the bottom, and rotating left and right. This would require a total of 6 macros, which can be handled by 6 stored procedures to implement the logic. If the game state is stored in a table which is shared by the two SSMS sessions, then the output will update live as the macros are executed. All that remains is to implement the logic for displaying the game and processing the input. I will leave that for Part 2.
Happy Programming!
No comments:
Post a Comment