mirror of
https://github.com/TomHarte/CLK.git
synced 2025-01-13 22:32:03 +00:00
Made an effort to implement proper pixel output for sprites.
This commit is contained in:
parent
40954d6a2a
commit
9ce68c38ae
@ -631,7 +631,7 @@ void TIA::draw_player(Player &player, CollisionType collision_identity, const in
|
|||||||
next_event_time = movement_time + 4;
|
next_event_time = movement_time + 4;
|
||||||
}
|
}
|
||||||
|
|
||||||
// is the next event a graphics draw?
|
// is the next event a graphics trigger?
|
||||||
int next_copy = 160;
|
int next_copy = 160;
|
||||||
if(player.graphic)
|
if(player.graphic)
|
||||||
{
|
{
|
||||||
@ -650,8 +650,31 @@ void TIA::draw_player(Player &player, CollisionType collision_identity, const in
|
|||||||
if(next_copy_time < next_event_time) next_event_time = next_copy_time;
|
if(next_copy_time < next_event_time) next_event_time = next_copy_time;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// maybe a deferred draw?
|
||||||
|
if(player.output_delay > 0)
|
||||||
|
{
|
||||||
|
if(start + player.output_delay < next_event_time) next_event_time = start + player.output_delay;
|
||||||
|
}
|
||||||
|
|
||||||
|
// the decision is to progress by length
|
||||||
|
const int length = next_event_time - start;
|
||||||
|
|
||||||
|
if(player.pixel_position < 32)
|
||||||
|
{
|
||||||
|
int adder = 4 >> player.size;
|
||||||
|
// player.pixel_position &= ~(adder - 1);
|
||||||
|
int output_cursor = 0;
|
||||||
|
while(player.pixel_position < 32 && output_cursor < length)
|
||||||
|
{
|
||||||
|
int shift = (player.pixel_position >> 2) ^ player.reverse_mask;
|
||||||
|
collision_buffer_[start + output_cursor - first_pixel_cycle] |= ((player.graphic >> shift)&1) * (uint8_t)collision_identity;
|
||||||
|
output_cursor++;
|
||||||
|
player.pixel_position += adder;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// the next interesting event is after next_event_time cycles, so progress
|
// the next interesting event is after next_event_time cycles, so progress
|
||||||
position = (position + next_event_time - start) % 160;
|
position = (position + length) % 160;
|
||||||
start = next_event_time;
|
start = next_event_time;
|
||||||
|
|
||||||
// if the event is a motion tick, apply
|
// if the event is a motion tick, apply
|
||||||
@ -661,16 +684,17 @@ void TIA::draw_player(Player &player, CollisionType collision_identity, const in
|
|||||||
movement_time += 4;
|
movement_time += 4;
|
||||||
}
|
}
|
||||||
|
|
||||||
// if it's a draw trigger, draw (TODO: use the actual graphic)
|
// if an output delay is being counted down, continue doing so
|
||||||
|
if(player.output_delay > 0)
|
||||||
|
{
|
||||||
|
player.output_delay -= length;
|
||||||
|
if(!player.output_delay) player.pixel_position = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
// if it's a draw trigger, trigger a draw
|
||||||
if(position == (next_copy % 160))
|
if(position == (next_copy % 160))
|
||||||
{
|
{
|
||||||
int cursor = start + 5 - first_pixel_cycle;
|
player.output_delay = 5;
|
||||||
int terminus = std::min(160, cursor+8);
|
|
||||||
while(cursor < terminus)
|
|
||||||
{
|
|
||||||
collision_buffer_[cursor] |= (uint8_t)collision_identity;
|
|
||||||
cursor++;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -134,6 +134,9 @@ class TIA {
|
|||||||
int copy_flags; // a bit field, corresponding to the first few values of NUSIZ
|
int copy_flags; // a bit field, corresponding to the first few values of NUSIZ
|
||||||
uint8_t graphic; // the player graphic
|
uint8_t graphic; // the player graphic
|
||||||
int reverse_mask; // 7 for a reflected player, 0 for normal
|
int reverse_mask; // 7 for a reflected player, 0 for normal
|
||||||
|
|
||||||
|
int pixel_position;
|
||||||
|
int output_delay;
|
||||||
} player_[2];
|
} player_[2];
|
||||||
|
|
||||||
// missile state
|
// missile state
|
||||||
|
Loading…
x
Reference in New Issue
Block a user