User:Nightmareci: Difference between revisions
No edit summary |
No edit summary |
||
Line 63: | Line 63: | ||
After the "READY, GO" sequence, every frame the following is processed from top to bottom, until the game ends: | After the "READY, GO" sequence, every frame the following is processed from top to bottom, until the game ends: | ||
# Interactive gameplay (piece is in field and in control): | # Interactive gameplay (piece is in field and in control): | ||
#* If this is the first frame of this piece: | <!-- Begin Rotation --> | ||
#** If | #* If a single rotation input is pressed down this frame: | ||
#*** | #** TGM Rotation | ||
#** If this is the first frame of this piece: | |||
#*** Play the IRS sound | |||
#*** Skip to frame render | |||
<!-- End Rotation --> | |||
<!-- Begin Shift --> | |||
#* If left/right shift is read this frame: | |||
#** If das_counter == 0 or das_counter > 14: | |||
#*** Shift left/right 1 column | |||
#** Else if das_counter <= 14: | |||
#*** Increment das_counter by 1 | |||
#* Else: | #* Else: | ||
#** | #** das_counter = 0 | ||
<!-- End Shift --> | |||
# Uninteractive delays (lock flash, line clear, ARE): | # Uninteractive delays (lock flash, line clear, ARE): | ||
#* TODO: Fill this up (have enough data currently, just sort it out) | #* TODO: Fill this up (have enough data currently, just sort it out) |
Revision as of 07:24, 25 February 2009
Definitions
In this page, the very top row is row number 0, the row below the top row is row number 1, and so on, until 20 (TGM1 has 20 visible rows + 1 vanish zone row).
Tetris The Grand Master
Some of the following information may not be consistent with other wiki pages; where this applies, simply ignore the information elsewhere in the wiki. Corrections to this information by others are only accepted if supported by examples. Information here is still work in progress.
Gravity
Directly from Tetris The Grand Master, here is the gravity curve:
Level | Interal Gravity (1/256 G) |
Level | Internal Gravity (1/256 G) |
---|---|---|---|
0 | 4 | 220 | 32 |
30 | 6 | 230 | 64 |
35 | 8 | 233 | 96 |
40 | 10 | 236 | 128 |
50 | 12 | 239 | 160 |
60 | 16 | 243 | 192 |
70 | 32 | 247 | 224 |
80 | 48 | 251 | 256 (1G) |
90 | 64 | 300 | 512 (2G) |
100 | 80 | 330 | 768 (3G) |
120 | 96 | 360 | 1024 (4G) |
140 | 112 | 400 | 1280 (5G) |
160 | 128 | 420 | 1024 (4G) |
170 | 144 | 450 | 768 (3G) |
200 | 4 | 500 | 5120 (20G) |
This is also based on a timings table in Tetris The Grand Master, but is modified to better fit observations I've made:
Level | DAS (frames) |
Lock (frames) |
Lock flash (frames) |
Line clear (frames) |
ARE (frames) |
---|---|---|---|---|---|
000 - 999 | 14 | 30 | 4 | 41 | 27 |
The different ordering is chosen such that it somewhat represents the order in which each delay happens, left being first, right being last, although DAS charging can occur during ARE.
In the following, "gravity_count" is the current Gravity Count; "gravity" is the current Gravity Speed, and is equal to one of the Internal Gravity entries in the above table; das_counter is the current count of DAS charge frames. A % is used to represent a "remainder of division" operator (commonly known as "modulo", i.e. 13 % 5 = 3). All division has the fractional part truncated, as in ISO C (60/256 == 0, 252/256 == 0, 260/256 == 1).
On the first frame of piece display, all inputs are ignored, and read as "not pressed", even if in reality input is being sent on that frame.
At the start of a game, there is a single "READY, GO" sequence; it is a special case, in this description:
- Begin "READY, GO" sequence:
- 170 frames of uninteractive display until the first pieces' first frame TODO: Expand this after more observations (how long "READY" displays, etc.)
After the "READY, GO" sequence, every frame the following is processed from top to bottom, until the game ends:
- Interactive gameplay (piece is in field and in control):
- If a single rotation input is pressed down this frame:
- TGM Rotation
- If this is the first frame of this piece:
- Play the IRS sound
- Skip to frame render
- If left/right shift is read this frame:
- If das_counter == 0 or das_counter > 14:
- Shift left/right 1 column
- Else if das_counter <= 14:
- Increment das_counter by 1
- If das_counter == 0 or das_counter > 14:
- Else:
- das_counter = 0
- If a single rotation input is pressed down this frame:
- Uninteractive delays (lock flash, line clear, ARE):
- TODO: Fill this up (have enough data currently, just sort it out)
Ignore the following (it'll be shoved into the above sooner or later):
- Preparation for the pieces' first displayed frame (such as during ARE):
- If Gspeed > 256:
- Gcount = Gspeed % 256
- Else:
- Gcount = 0
- Gspeed is set to the appropriate value for the current level
- Attempt to place the piece in row number 1 + Gspeed / 256, higher if necessary
- If Gspeed > 256:
- Every frame this piece is displayed:
- If soft drop is pressed:
- If Gspeed < 256:
- Attempt to drop one line
- If the piece has blocks beneath it now:
- Lock the piece
- Go to 3.
- If Gspeed < 256:
- If there are blocks below this piece:
- Set Gcount to Gspeed
- If Gcount is greater than or equal to 256:
- Attempt to drop Gcount / 256 lines
- Gcount %= 256
- Increase Gcount by Gspeed
- Go to 3.
- If soft drop is pressed:
- Further processing after gravity (processing will come back to 2. if the piece hasn't locked)
In the above, the first If...Else sequence may appear curious, as all Internal Gravity values in the TGM series are either <256 or an even multiple of 256, but it's purpose is to properly support gravity speeds such as 4.5G; none of the TGM games have gravity like this, but this makes this description more general. If your implementation is only conforming to actual TGM gravity, the sequence can be replaced with "Gcount = 0".