Índice:
2025 Autor: John Day | [email protected]. Última modificação: 2025-01-13 06:58
Enquanto eu estava finalizando as decisões de design para um projeto baseado no ESP32 WiFi Kit 32 que exigia entrada de três botões, um problema perceptível era que o WiFi Kit 32 não possuía um único botão mecânico, apenas três botões mecânicos para entrada. No entanto, o WiFi Kit 32 tem muitas entradas de toque capacitivas, então passei algum tempo montando hardware, escrevendo software e testando um design de entrada de três botões utilizando o recurso de entrada de toque capacitivo ESP32 e três plugues de orifício metálico de 3/8 "" para botões.
Como qualquer um que experimentou as entradas de toque capacitivas ESP32 descobriu, as entradas de toque são certamente barulhentas o suficiente para exigir filtragem para detecção de entrada confiável. Para minimizar a contagem total de peças para o próximo projeto, determinei que um filtro digital controlado por interrupção simples (mais um "debounce" do que um filtro, mas estou divagando), em oposição a adicionar hardware de filtro externo, poderia silenciar as entradas ruidosas. E após o teste, tornou-se aparente que as entradas capacitivas ESP32, três plugues de orifício metálico de 3/8 "e algum software de" filtragem "digital realmente forneceriam uma entrada confiável de três botões para o projeto.
Portanto, se você estiver interessado em testar a entrada capacitiva com filtragem digital em um ESP32, incluí o código-fonte "Buttons.ino" no formato do ambiente Arduino junto com as instruções de montagem e programação, além de uma breve descrição do código-fonte, para o que descobri ser uma entrada de três botões altamente confiável.
E, como de costume, provavelmente esqueci um ou dois arquivos ou quem sabe o que mais, então se você tiver alguma dúvida, não hesite em perguntar, pois eu cometo muitos erros.
E uma nota final, não recebo qualquer forma de compensação, incluindo, mas não se limitando a amostras grátis, por qualquer um dos componentes usados neste projeto
Etapa 1: Hardware
O projeto utiliza o seguinte hardware:
- Um, Kit WiFi 32.
- Três bujões metálicos de 3/8 ".
- Três, 4 "comprimentos de fio 28awg.
Para montar o hardware, executei as seguintes etapas:
- Descascou e estanhou as pontas de cada comprimento de fio de 10 cm, conforme mostrado.
- Soldou o primeiro fio no pino 13 do ESP32 (a entrada TOUCH4, ou "T4").
- Soldou o segundo fio no pino 12 do ESP32 (a entrada TOUCH5, ou "T5").
- Soldou o terceiro fio no pino 14 do ESP32 (o TOUCH6 ou entrada "T6").
- Soldou um de cada um dos três plugues de furo metálico de 3/8 "nas extremidades livres dos três comprimentos de fio.
Etapa 2: Software
O arquivo "Buttons.ino" é um arquivo de ambiente Arduino que contém o software para o design. Além deste arquivo, você precisará da biblioteca gráfica "U8g2lib" para o display OLED do WiFi Kit32 (consulte https://github.com/olikraus/u8g2/wiki para obter mais informações sobre esta biblioteca).
Com a biblioteca gráfica U8g2lib instalada no diretório do Arduino e "Buttons.ino" carregado no ambiente do Arduino, compile e baixe o software no ESP32.
Depois de baixado e executado, a linha superior do visor deve mostrar "Botões" com a segunda linha do visor lendo "1 2 3" como os indicadores dos botões. Abaixo de cada um dos indicadores de botão 1, 2, 3 estão os valores de leitura de toque não filtrado, e abaixo de cada um deles estão os indicadores de botão pressionado ("1" para pressionado, "0" para não pressionado). Como pode ser visto no vídeo (e conforme o teste de longo prazo confirmado), o filtro de software fornece detecção de entrada de botão confiável sem disparos falsos.
Etapa 3: Sobre o software
O software contém três seções principais de código; o Arduino exigia as seções "setup ()" e "loop ()" e uma seção "Interrupts". A seção setup () contém o código necessário para inicializar OLED e interromper serviços. As funções de configuração do OLED são descritas no link acima. As funções de configuração do serviço de interrupção são as seguintes:
- "timerLoopSemaphore = xSemaphoreCreateBinary ()" cria um semáforo para "InterruptService ()" (a rotina de serviço de interrupção) para informar ao loop () quando é hora de executar uma passagem de loop.
- "timerInterruptService = timerBegin (0, 80, true)" cria um cronômetro usando o cronômetro de hardware 0 com uma pré-escala de 80.
- "timerAttachInterrupt (timerInterruptService, & InterruptService, true)" anexa InterruptService () ao cronômetro.
- "timerAlarmWrite (timerInterruptService, 1000, true)" define a taxa de interrupção do serviço para 1000 Hz.
- "timerAlarmEnable (timerInterruptService)" inicia o alarme do cronômetro e, portanto, interrompe o serviço.
Com a configuração concluída, o loop () é inserido e para imediatamente na linha:
if (xSemaphoreTake (timerLoopSemaphore, portMAX_DELAY) == pdTRUE), o que significa que loop () irá esperar neste ponto até que o semáforo de InterruptService () chegue. Quando o semáforo chega, o código loop () é executado, atualizando a tela OLED com os dados do botão e, em seguida, retornando ao topo para aguardar novamente o próximo semáforo. Com InterruptService () rodando a 1000 Hz e um valor LOOP_DELAY de 30, loop () é executado a cada 30 ms, ou a uma taxa de atualização de exibição de 33.333 Hz. Embora seja uma taxa de atualização de tela mais alta do que a necessária para a maioria dos aplicativos ESP32, usei essa configuração para ilustrar a capacidade de resposta do filtro. Eu testei e determinei que o tempo necessário para executar uma única passagem de loop () era de 20 ms.
InterruptService () é chamado pelo cronômetro criado em setup () a uma taxa de 1000 Hz. Quando chamado, ele atualiza dois contadores decrescentes, nLoopDelay e nButtonDelay. Quando nLoopDelay é contado regressivamente até zero, ele envia o semáforo permitindo que loop () execute uma única passagem e, em seguida, redefine nLoopDelay. Quando nButtonDelay é contado regressivamente até zero, ele também é redefinido e o botão "filtros" é executado.
Cada filtro de botão tem um contador de filtro exclusivo (por exemplo, nButton1Count, nButton2Count e nButton3Count). Enquanto o valor de entrada de toque atribuído ao botão for maior ou igual ao valor limite definido (BUTTON_THRESHHOLD), o contador de filtro atribuído ao botão e o botão permanecerão zero. Se o valor de entrada de toque atribuído ao botão for menor que o limite definido, o contador do filtro atribuído ao botão é incrementado em um a cada 20 ms. Quando o contador do filtro ultrapassa o valor do filtro do botão (BUTTON_FILTER), o botão é considerado "pressionado". O efeito desse método é criar um filtro que requer 80ms (20ms nButtonDelay * 4ms nButtonCountN onde N é o número do botão) de valores de entrada de toque contínuo abaixo do limite definido para considerar o botão realmente pressionado. Qualquer tempo inferior a 80 ms é considerado uma "falha" e é rejeitado pelo filtro.
Dada esta breve descrição, se você tiver alguma dúvida, fique à vontade para perguntar e farei o meu melhor para respondê-la.
Espero que você tenha aproveitado!
Etapa 4: O "Projeto Futuro"
O próximo projeto, "Intelligrill® Pro", é um monitor de fumante com dupla sonda de temperatura apresentando:
- Cálculos da sonda de temperatura Steinhart-Hart (em oposição às tabelas de "consulta") para maior precisão.
- Tempo preditivo para conclusão na sonda 1 incorporando a maior precisão derivada dos cálculos de Steinhart-Hart.
- Uma segunda sonda, sonda 2, para monitorar a temperatura do fumante (limitada de 32 a 399 graus).
- Controles de entrada de toque capacitivo (como neste Instructable).
- Monitoramento remoto baseado em WIFI (com um endereço IP fixo, permite monitorar o progresso do fumante de qualquer lugar onde uma conexão de internet esteja disponível).
- Faixa de temperatura estendida (novamente 32 a 399 graus).
- Alarmes de conclusão audíveis no transmissor Intelligrill® e na maioria dos dispositivos de monitoramento com capacidade WiFi.
- Exibição da temperatura em graus F ou graus C.
- Formato de hora em HH: MM: SS ou HH: MM.
- Exibição da bateria em volts ou% carregada.
- E, em breve, saída PID para fumantes baseados em trado.
O "Intelligrill® Pro" está testando para se tornar o Intelligrill® baseado em HTML mais preciso, cheio de recursos e confiável que eu projetei.
Ainda está em teste, mas com as refeições está ajudando a preparar durante o teste, ganhei mais do que alguns quilos.
Mais uma vez, espero que gostem!
Etapa 5: a seguir: entrada analógica da sonda de temperatura NTP ESP32 com correção Steinhart-Hart
Esteja preparado para tirar a poeira de seus livros de álgebra.