From 381f09f39f7a57cf64932b7750c2a6e6ef727430 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=D0=90=D1=80=D1=82=D1=91=D0=BC=20=D0=9D=D0=BE=D0=B2=D0=B8?= =?UTF-8?q?=D0=BA=D0=BE=D0=B2?= Date: Mon, 26 Jun 2023 09:28:15 +0000 Subject: [PATCH] =?UTF-8?q?=D0=98=D0=B7=D0=BC=D0=B5=D0=BD=D0=B8=D0=BB(?= =?UTF-8?q?=D0=B0)=20=D0=BD=D0=B0=20'Encoder.c'?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- Encoder.c | 118 ++++++++++++++++++++++++++++-------------------------- 1 file changed, 61 insertions(+), 57 deletions(-) diff --git a/Encoder.c b/Encoder.c index 494965e..cbc69f9 100644 --- a/Encoder.c +++ b/Encoder.c @@ -1,68 +1,72 @@ +#include "Encoder.h" #include #include + /* Дефайны */ -#define F_CPU 1000000UL // тактовая частота -#define PIND_MASK 0b00001100 // Маска для сравнения с PIND +#define PIND_MASK 0b00001100 + /* Переменные */ -volatile uint8_t next_state, prev_state, up_state, down_state, state; -int sw34; // Передача +volatile int32_t next_state, prev_state, up_state, down_state, state; +int sw34; // Передача +int32_t encoder_value = 0; + /* Прерывания */ ISR(TIMER1_COMPA_vect) { - next_state = PIND & PIND_MASK; // Считываем текущее значение битов - if (next_state != prev_state) { - switch (prev_state) { - case 8: { - if (next_state == 3) state++; - if (next_state == 0) state--; - break; - } - case 0: { - if (next_state == 2) state++; - if (next_state == 1) state--; - break; - } - case 4: { - if (next_state == 0) state++; - if (next_state == 3) state--; - break; - } - case 12: { - if (next_state == 1) state++; - if (next_state == 2) state--; - break; - } - default: { - break; - } + next_state = PIND & PIND_MASK; + if (next_state != prev_state) { + switch (prev_state) { + case 8: { + if (next_state == 3) state++; + if (next_state == 0) state--; + break; + } + case 0: { + if (next_state == 2) state++; + if (next_state == 1) state--; + break; + } + case 4: { + if (next_state == 0) state++; + if (next_state == 3) state--; + break; + } + case 12: { + if (next_state == 1) state++; + if (next_state == 2) state--; + break; + } + default: { + break; + } + } + prev_state = next_state; // Присваиваем текущему состоянию предыдущее } - prev_state = next_state; // Присваиваем текущему состоянию предыдущее - } - TCNT1H = 0x00; - TCNT1L = 0x00; // Обнуляем счетчик(на всякий случай) + TCNT1H = 0x00; + TCNT1L = 0x00; // Обнуляем счетчик(на всякий случай) + encoder_value = state; } -void timer1_init() { - TCCR1A = 0x00; - TCCR1B |= (1<