Skip to content

Commit

Permalink
Fix for issue #10
Browse files Browse the repository at this point in the history
Changed the order in which new mouse motion is output; code now change phase first then outputs the phase to the IO
  • Loading branch information
Simon Inns committed Jul 30, 2020
1 parent 1c32a98 commit 3f1aff5
Showing 1 changed file with 18 additions and 20 deletions.
38 changes: 18 additions & 20 deletions SmallyMouse2/main.c
Original file line number Diff line number Diff line change
Expand Up @@ -114,24 +114,23 @@ ISR(TIMER0_COMPA_vect)
{
// Process X output
if (mouseDistanceX > 0) {
// Change phase and range check
if (mouseDirectionX == 0) {
mouseEncoderPhaseX--;
if (mouseEncoderPhaseX < 0) mouseEncoderPhaseX = 3;
} else {
mouseEncoderPhaseX++;
if (mouseEncoderPhaseX > 3) mouseEncoderPhaseX = 0;
}

// Set the output pins according to the current phase
if (mouseEncoderPhaseX == 0) X1_PORT |= X1; // Set X1 to 1
if (mouseEncoderPhaseX == 1) X2_PORT |= X2; // Set X2 to 1
if (mouseEncoderPhaseX == 2) X1_PORT &= ~X1; // Set X1 to 0
if (mouseEncoderPhaseX == 3) X2_PORT &= ~X2; // Set X2 to 0

// Change phase
if (mouseDirectionX == 0) mouseEncoderPhaseX--; else mouseEncoderPhaseX++;

// Decrement the distance left to move
mouseDistanceX--;

// Range check the phase
if ((mouseDirectionX == 1) && (mouseEncoderPhaseX > 3)) mouseEncoderPhaseX = 0;
if ((mouseDirectionX == 0) && (mouseEncoderPhaseX < 0)) mouseEncoderPhaseX = 3;
} else {
// Reset the phase if the mouse isn't moving
mouseEncoderPhaseX = 0;
}

// Set the timer top value for the next interrupt
Expand All @@ -143,24 +142,23 @@ ISR(TIMER2_COMPA_vect)
{
// Process Y output
if (mouseDistanceY > 0) {
// Change phase and range check
if (mouseDirectionY == 0) {
mouseEncoderPhaseY--;
if (mouseEncoderPhaseY < 0) mouseEncoderPhaseY = 3;
} else {
mouseEncoderPhaseY++;
if (mouseEncoderPhaseY > 3) mouseEncoderPhaseY = 0;
}

// Set the output pins according to the current phase
if (mouseEncoderPhaseY == 3) Y1_PORT &= ~Y1; // Set Y1 to 0
if (mouseEncoderPhaseY == 2) Y2_PORT &= ~Y2; // Set Y2 to 0
if (mouseEncoderPhaseY == 1) Y1_PORT |= Y1; // Set Y1 to 1
if (mouseEncoderPhaseY == 0) Y2_PORT |= Y2; // Set Y2 to 1

// Change phase
if (mouseDirectionY == 0) mouseEncoderPhaseY--; else mouseEncoderPhaseY++;

// Decrement the distance left to move
mouseDistanceY--;

// Range check the phase
if ((mouseDirectionY == 1) && (mouseEncoderPhaseY > 3)) mouseEncoderPhaseY = 0;
if ((mouseDirectionY == 0) && (mouseEncoderPhaseY < 0)) mouseEncoderPhaseY = 3;
} else {
// Reset the phase if the mouse isn't moving
mouseEncoderPhaseY = 0;
}

// Set the timer top value for the next interrupt
Expand Down

0 comments on commit 3f1aff5

Please sign in to comment.