Saya mencoba menulis kode untuk menyalakan LED saat mati dan mematikan ketika menggunakan sakelar tombol tekan taktil. Saya telah menulis apa yang saya yakini sebagai kode yang tepat dengan pustaka wiringPi, tetapi saya hanya bisa mengaktifkannya ketika dimatikan dan tidak bisa mematikannya setelah itu. Pada contoh yang sangat jarang dan setelah banyak penekanan berulang kali LED akan mati ketika dinyalakan dan saya menekan tombol, tapi saya yakin bukan itu cara kerjanya.
#include <wiringPi.h>
int main (void)
{
wiringPiSetup ();
pinMode (0, OUTPUT);
pinMode (1, INPUT);
digitalWrite (0, LOW);
for(;;)
{
if(digitalRead (1) == LOW)
{
if(digitalRead (0) == HIGH)
digitalWrite (0, LOW);
else if(digitalRead (0) == LOW)
digitalWrite (0, HIGH);
}
}
return 0;
}
Saya telah memasang gambar tentang bagaimana rangkaian ini dihubungkan.
Jawaban:
Kabel terlihat benar untuk kode.
Masalahnya adalah bahwa kode tersebut berada dalam loop yang sangat ketat. Secara teori, ketika tombol ditekan, loop body berulang kali menyalakan dan mematikan LED. Secara teori, akan ada kemungkinan 50/50 LED dibiarkan hidup (atau mati) ketika tombol dilepaskan. Apakah Anda melihat perubahan kecerahan ketika tombol ditekan. Mungkin tidak cukup untuk diperhatikan.
Dalam praktiknya, alasan kecenderungan membiarkan LED menyala adalah cara Anda menguji apakah sudah menyala. Penulisan pin 0 TINGGI berlaku 3,3 V ke output. Tapi kabel itu terhubung ke LED dan pin dikonfigurasi untuk menjadi output. LED mungkin menjatuhkan voltase cukup rendah untuk tidak mendaftar sebagai TINGGI ketika dibaca, tetapi kadang-kadang itu terjadi karena dekat dengan cutoff.
Dalam praktiknya, kode untuk mematikan dan menghidupkan LED dengan setiap tombol tekan akan menggunakan interupsi yang dipicu oleh jatuh. Seperti yang ditunjukkan dalam komentar, Anda ingin menghilangkan interupsi dalam kasus itu. Anda juga dapat melakukan hal yang sama tanpa menyela dengan merekam keadaan tombol sebelumnya dan hanya mengubah LED ketika keadaan tombol telah berubah. Debouncing saat kode ditulis sekarang tidak masuk akal.
sumber
Mungkin lebih mudah untuk mempertahankan "keadaan" dalam variabel normal daripada mencoba menyimpulkannya dari keadaan GPIO saat ini.
Juga "loop sibuk" akan mengkonsumsi setiap siklus CPU OS akan memungkinkan proses; untuk proses yang begitu sederhana, Anda akan melihat bahwa beban CPU Anda akan naik hingga 100%! Anda harus mengizinkan proses untuk melepaskan CPU ke tugas lain dengan
usleep()
panggilan misalnya. Penundaan juga akan berfungsi untuk menonaktifkan sakelar.sumber