Arduino nəzarətçiləri: 10 addım (şəkillərlə birlikdə)
Arduino nəzarətçiləri: 10 addım (şəkillərlə birlikdə)
Anonim
Arduino nəzarətçiləri
Arduino nəzarətçiləri
Arduino nəzarətçiləri
Arduino nəzarətçiləri

Arduino və p5.js kitabxanasından istifadə edən bir Arduino oyun idarəedici sistemi. Bunun ideyası asanlıqla təkrarlanan və genişləndirilə bilən bir Arduino layihəsi yaratmaqdır. Nəzarətçi əlaqələri, hər bir nəzarətçidən asılı olaraq dəyişdirilə bilən bir çox sensorlar və girişlərdən istifadə etmək üçün hazırlanmışdır.

Bu layihə, p5.js üçün hazırlanmış p5.play kitabxanası ilə birlikdə p5.js JavaScript kitabxanasından da istifadə etmək üçün hazırlanmışdır. Bu kitabxanalar oyunlarımızı asanlıqla proqramlaşdırmağa imkan verir. P5.play veb saytında, istifadəçilərin bunun üçün oyunlar yaratması üçün bir çox dərs və nümunələr var. Bu layihə istifadəçilərə hardware və proqram inkişaf etdirmə bacarıqlarını tətbiq etməyə imkan verir.

Addım 1: Nə lazımdır

Ehtiyacınız olacaq
Ehtiyacınız olacaq

Alətlər:

  • Lehimleme dəmir
  • Lehim
  • Tel çıxarıcılar
  • Yan kəsicilər
  • Kəlbətinlər

Avadanlıq:

  • Arduino uyğun lövhə (Sparkfun Redboard, Arduino Uno və Leonardodan istifadə etdim)
  • Mükəmməl lövhə:

    • 8 sm x 6 sm yaşıl rəngli lövhələr
    • Aduino Uno qalxan mükəmməl lövhəsi
  • Müxtəlif sensorlar

    • Joysticks
    • Düymələr (rezistorlar ilə, 10k ohm, onlarla birlikdə)
    • Potensialiometrlər
    • Flex Sensorları
    • Təzyiq Sensorları
    • Və s…
  • Tel:

    • Tək Tel (26 AWG Solid istifadə etdim)
    • Şerit tel və qıvrımlar
  • Başlıqları ayırın (bunlardan ən azı 20 -si)
  • İsteğe bağlı donanım (bunun əvəzinə karton və isti yapışqan/zip bağlarından istifadə edə bilərsiniz):

    • Prototip yaratmaq üçün breadboard və jumper kabelləri
    • 3D çaplı korpuslar
    • Avadanlıq bağlayıcıları (M2.5 vintlərindən istifadə etdim)

Proqram təminatı:

  • Arduino IDE
  • p5.js kitabxanası

    P5. kitabxananı da oynayın

  • p5.serial nəzarət
  • Node.js

Addım 2: Bina: Konsol Hubı, Qalxanı Qurmaq

Bina: Konsol Hub, Qalxanın Qurulması
Bina: Konsol Hub, Qalxanın Qurulması

Başlıqları Arduino Uno qalxan mükəmməl lövhəsinə lehimləyin.

  • Qalxan başlıqları ilə başladım (güc, analoq və rəqəmsal)
  • Sonrakı 2x5 başlıq pinləridir. 2x5 başlıqdan istifadə edə bilərsiniz və ya 5 satır başlıqdan yalnız 2 sıra istifadə edə bilərsiniz. Bunları şaquli olaraq A3 və A4 ilə düzdüm və aralarında 2 boşluq buraxdım.

Addım 3: Bina: Konsol Hubu, Qalxanı Kablolama

Bina: Konsol Hubu, Qalxanı Kablolama
Bina: Konsol Hubu, Qalxanı Kablolama
Bina: Konsol Hubu, Qalxanı Kablolama
Bina: Konsol Hubu, Qalxanı Kablolama
Bina: Konsol Hubu, Qalxanı Kablolama
Bina: Konsol Hubu, Qalxanı Kablolama

Sonra, tellərimizi qalxana yönəltmək istəyirik. Telləri yuxarıdan çəkmək daha asandır, amma daha təmiz baxmaq istəyirsinizsə, onları aşağıdan keçirə bilərsiniz.

Bu telləri yönləndirərkən sxemə (Eagle sxemini yükləmək mümkündür) diqqət yetirmək istəyirsiniz. Bu işdə sizə kömək etmək üçün rəng bələdçisinə də baxa bilərsiniz.

Bu qalxan dizaynının ideyası, hər bir nəzarətçidən 3 analoq girişə və 5 rəqəmsal girişə icazə verməkdir. Bu, Arduino Uno üzərindəki bütün analog girişlərdən və lent kabelimizdə qalan tellərdən tam istifadə edir.

Addım 4: Bina: Nəzarətçilər, Parçalarınızı Qurmaq

Bina: Nəzarətçilər, Parçalarınızı Qurmaq
Bina: Nəzarətçilər, Parçalarınızı Qurmaq
Bina: Nəzarətçilər, Parçalarınızı Qurmaq
Bina: Nəzarətçilər, Parçalarınızı Qurmaq
Bina: Nəzarətçilər, Parçalarınızı Qurmaq
Bina: Nəzarətçilər, Parçalarınızı Qurmaq

Nəzarətçinizi qurmağın ilk addımı hansı sensorların istifadə olunacağını planlaşdırmaqdır. Nümunələrimdə, joystick və bir neçə düymə ilə olduqca standart bir nəzarətçi var. Həm də iki kaydırıcı potansiyometrli bir nəzarətçim var.

Bunu təkrarlamaq istəyirsinizsə, yerləşdirmək üçün şəkillərimə baxa bilərsiniz.

Növbəti addım, lent kabelinizi mükəmməl lövhəyə lehimləməkdir.

  1. Şerit kabelini soyun və qalaylayın
  2. Şerit kabelini mükəmməl lövhənizin yuxarı mərkəzinə lehimləyin.

Növbəti addım tellərinizi yönləndirməkdir. Gücünü (5V/qırmızı tel) və torpağı (qəhvəyi tel) əvvəlcə sensorlara bağlayaraq başladım. Sonra analog girişləri bağladım. Üfüqi hərəkət üçün narıncı kabeli (Analog A0 və ya A3), şaquli hərəkət üçün sarı kabeli (Analog A1 və ya A4) istifadə etməyi asan tapdım.

İşlərin ardıcıl olmasını təmin etmək üçün bütün idarəedicilərimdə bənövşəyi rəngdə kiçik bir düyməni bağladım. Bu, seriyalı portu bağlamaq (bunu daha sonra nəzərdən keçirəcəyəm), həmçinin menyular və ya seçimlər kimi şeylər üçün faydalıdır.

Buna baxmaq istəyirsinizsə, joystick nəzarətçimin sürətli bir sxemini yüklədim. Çıxış diaqramımızdan, hər bir nəzarətçi bağlantısının mümkünlüyünü görə bilərsiniz (3 analoq giriş və 5 rəqəmsal).

Addım 5: İsteğe bağlı: Kassalar

İsteğe bağlı: Kassalar
İsteğe bağlı: Kassalar
İsteğe bağlı: Kassalar
İsteğe bağlı: Kassalar
İsteğe bağlı: Kassalar
İsteğe bağlı: Kassalar

Bu addım isteğe bağlıdır, ancaq 3D printerə çıxışınız varsa, layihənizin nəticəsi bir az daha zərif və bitmiş görünəcək. Prototiplərimdə görə biləcəyiniz kimi, mükəmməl lövhələrin altındakı lehim birləşmələrinin barmaqlarınızı sıxmaması üçün sadə bir karton parçası istifadə etdim.

Bu addıma bağlı 3D modellərimi tapa bilərsiniz. Hub üçün həm Arduino Uno/Leonardo, həm də Sparkfun RedBoard üçün korpuslar yaratdım (bu lövhə bir qədər genişdir və mini USB istifadə edir).

Nəzarətçilər üçün bunları M2.5 vintləri ilə bağlaya bilərsiniz. Qozu PCB tərəfində saxladım və altındakı yuyucudan və vintdən istifadə etdim.

İstifadə etdiyim potensiometrlər üçün düymə sürgüləri üçün 3D modeli də daxil etdim.

Bütün 3D faylları GitHub -da tapa bilərsiniz.

Addım 6: Proqramlaşdırma: Arduino

Proqramlaşdırma: Arduino
Proqramlaşdırma: Arduino

Test etmək üçün sadə bir eskiz quraraq başlayaq. Burada tapılan NYU -da ITP tərəfindən hazırlanan dərslikdən istifadə etməyi təklif edirəm. Bu təlimatı yerinə yetirmək üçün p5.serialcontroll və node.js yüklü olmalısınız. Bu təlimatda, javascript kitabxanamızdan istifadə edə biləcəyiniz serial məlumatları göndərmək üçün bir Arduino qurmaqla tanış olacaqsınız, p5.js. Bunu etmək üçün əvvəlki addımlarda yaratdığımız hub və nəzarətçidən istifadə edə bilərsiniz və ya dərsdə göstərilən sxemləri təkrarlaya bilərsiniz. Bu dərslik, Arduino Uno üzərindəki ilk nəzarət cihazınızın narıncı telinə uyğunlaşdırılmış A0 analog giriş pinindən istifadə edir.

İzləmək istədiyiniz növbəti təlimatı burada tapa bilərsiniz. Bu təlimat, birdən çox giriş qurmaq və onları p5.js. Dərslikdə A0 və A1 analog girişləri istifadə olunur. Bunlar sistemimizin nəzarətçi 1indəki narıncı və sarı tellərə uyğun olacaq.

Yuxarıdakı dərsləri keçdikdən sonra Arduino proqramlaşdıra bilərik. İstifadə etmək istədiyimiz kod aşağıda verilmişdir:

// nəzarətçi 1const int dig2 = 2; // mavi const int dig3 = 3; // bənövşəyi const int dig4 = 4; // boz const int dig5 = 5; // ağ const int dig6 = 6; // qara // nəzarətçi 2 const int dig7 = 7; // mavi const int dig8 = 8; // bənövşəyi const int dig9 = 9; // boz const int dig10 = 10; // ağ const int dig11 = 11; //qara

boş quraşdırma () {

Serial.begin (9600); while (Serial.available () <= 0) {Serial.println ("salam"); // başlanğıc mesaj gecikməsini göndər (300); // 1/3 saniyə gözləyin} pinMode (dig2, INPUT); pinMode (dig3, GİRİŞ); pinMode (dig4, GİRİŞ); pinMode (dig5, GİRİŞ); pinMode (dig6, GİRİŞ); pinMode (dig7, GİRİŞ); pinMode (dig8, GİRİŞ); pinMode (dig9, GİRİŞ); pinMode (dig10, GİRİŞ); pinMode (dig11, GİRİŞ); }

boşluq döngəsi () {

if (Serial.available ()> 0) {// gələn baytı oxuyun: int inByte = Serial.read (); // sensoru oxuyun:

// ANALOG Nəzarətçisi 1

int analog0 = analogRead (A0); int analog1 = analogRead (A1); int analog2 = analogRead (A2); // ANALOG Nəzarətçisi 2 int analog3 = analogRead (A3); int analog4 = analogRead (A4); int analog5 = analogRead (A5); // DİJİTAL Nəzarətçi 1 int digital2 = digitalRead (dig2); int digital3 = digitalRead (dig3); int digital4 = digitalRead (dig4);

int digital5 = digitalRead (dig5);

int digital6 = digitalRead (dig6); // DIGITAL Controller 2 int digital7 = digitalRead (dig7); int digital8 = digitalRead (dig8); int digital9 = digitalRead (dig9); int digital10 = digitalRead (dig10); int digital11 = digitalRead (dig11); // nəticələri çap edin: Serial.print (analog0); // [0] Serial.print (","); Serial.print (analoq1); // [1] Serial.print (","); Serial.print (analoq2); // [2] Serial.print (","); // Start Controller 2 data Serial.print (analog3); // [3] Serial.print (","); Serial.print (analoq4); // [4] Serial.print (","); Serial.print (analoq5); // [5] Serial.print (","); Serial.print (digital2); // [6] Serial.print (","); Serial.print (digital3); // [7] Serial.print (","); Serial.print (digital4); // [8] Serial.print (","); Serial.print (digital5); // [9] Serial.print (","); Serial.print (digital6); // [10] Serial.print (","); // Controller 2 məlumatlarını işə salın Serial.print (digital7); // [11] Serial.print (","); Serial.print (digital8); // [12] Serial.print (","); Serial.print (digital9); // [13] Serial.print (","); Serial.println (digital10); // [14] Serial.print (","); Serial.println (digital11); // [15]}}

Bu kod, hər iki nəzarətçimizdən serial nömrələrini 16 ədədlik bir sıra olaraq göndərir. Bu nömrələrdən ilk 6-sı analog girişlərimizdir (0-1023 arasında), qalan 10 dəyər rəqəmsal dəyərlərimizdir (0 və ya 1).

Kodumuz yükləndikdən sonra bunu ITP -dən 2 -ci dərsdə etdiyimiz kimi serial monitoru açaraq serial monitorumuza bir dəyər yazaraq sınaya bilərik. Vergilərlə ayrılmış dəyərlərimizin bir sətrini almalıyıq.

Addım 7: Proqramlaşdırma: HTML

Arduino qurduqdan və işə saldıqdan sonra veb məhsullarımızı proqramlaşdırmağa başlaya bilərik. HTML kodu çox sadədir.

bədən {doldurma: 0; marj: 0;}

HTML kodu sadəcə javascript sənədlərimizi bir -birinə bağlayır. Kodumuzun çoxu eskiz.js sənədimizdə olacaq.

Addım 8: Proqramlaşdırma: P5.js və Javascript

HTML qurduqdan sonra JavaScript üzərində işləyə bilərik. Əgər hələ etməmisinizsə, indi p5.js və p5.play fayllarını yükləməli və bunları veb saytınız üçün kataloqdakı kitabxanalar qovluğuna əlavə etməlisiniz.

  • p5.js
  • p5. oynayın

Əvvəlki addımımızda, p5.js və p5.play kitabxanalarımıza zəng etmək üçün HTML faylımızı qurduq. Proqramlaşdırma işlərinin çoxunu edəcəyimiz sketch.js faylını istifadə etmək üçün də qurduq. Aşağıda skeletimizin kodu verilmişdir. Burada da tapa bilərsiniz.

// Serial Variablesvar serial; // serialport kitabxanasının bir nümunəsini saxlamaq üçün dəyişən var portName = 'COM4'; // seriya liman adınızı bura daxil edin // Qlobal Oyun Dəyişənləri ---------------

// Quraşdırma funksiyası ----------------------

funksiya qurulması () {createCanvas (640, 480); serial = yeni p5. SerialPort (); // serial.on kitabxanasının yeni bir nümunəsi olun serial.on ('siyahı', printList); // serialport siyahısı hadisəsi serial.on ("bağlı", serverConnected) üçün geri çağırma funksiyası təyin edin; // serial.on serverinə qoşulmaq üçün geri zəng ('açıq', portOpen); // serial.on ('data', serialEvent) açılan liman üçün geri zəng; // yeni məlumatlar serial.on ('səhv', serialError) gəldikdə geri çağırma; // serial.on ('yaxın', portClose) səhvləri üçün geri zəng; // serialın bağlandığı liman üçün geri çağırma (); // serial portlarını serial.open (portName) siyahısına salın; // serial port açmaq} // Draw Function ----------------------- draw draw () {background (0); // qara fon} // Serial məlumatlarını burada şərh edin ---------- funksiyası serialEvent () {// serial portundan bir sətir oxuyun // vaqon qaytarma və yeni xətt əldə edənə qədər: var inString = serial. readStringUntil ('\ r / n'); // orada əslində bir ssetring olduğunu yoxlayın: if (inString.length> 0) {if (inString! == 'salam') {// əgər salam alsanız, bunu görməyin var sensors = split (inString, ', '); // if (sensorlar.length> 16) {// on altı element varsa (6 analoq, 10 rəqəmsal) simli vergül üzərində bölün // Sensor məlumatlarını burada istifadə edin:

}

} serial.write ('x'); // daha çox serial məlumatı tələb edən bir bayt göndərin}} // limanların siyahısını əldə edin: printList funksiyası (portList) {// portList, (var i = 0; i <portList.length; i ++) üçün serial port adları silsiləsidir. {// Konsolun siyahısını göstərin: çap (i + "" + portList ); }} function serverConnected () {print ('serverə qoşuldu.'); } function portOpen () {print ('serial port açıldı.')} function serialError (err) {print ('Serial portda bir şey səhv oldu' + səhv); } funksiyası portClose () {print ('Seriya portu bağlandı.'); } funksiyası closeCode () {serial.close (portName); sıfır qaytarma; } window.onbeforeunload = bağlanma kodu;

Bir dəfə skeleti xilas et. Bu dəyərləri ITP dərsliyində necə edildiyinə bənzər şəkildə istifadə edə bilərsiniz. 6 -cı addımda Arduino -dan göndərdiyimiz dəyərlər xətti 16 ədəddən ibarət bir sıra olaraq göndərilir. Aşağıda bu massivi təhlil etdiyimiz yer var.

// Seriya məlumatlarını burada şərh edin ----------

serialEvent () {// funksiyası serial portundan bir sətir oxuyun // vaqon qaytarma və yeni xətt əldə edənə qədər: var inString = serial.readStringUntil ('\ r / n'); // orada əslində bir ssetring olduğunu yoxlayın: if (inString.length> 0) {if (inString! == 'salam') {// əgər salam alsanız, bunu görməyin var sensors = split (inString, ', '); // if (sensorlar.length> 16) {/on altı element varsa (6 analoq, 10 rəqəmsal) // sətirləri vergüllər üzərində bölün // Sensor məlumatlarını burada istifadə edin:}} serial.write ('x'); // daha çox serial məlumatı tələb edən bir bayt göndərin}}

İndi işlədiyini görmək üçün proqramımızı işlədə bilərik!

Addım 9: Proqramınızı işə salın

Proqramınızı İşlətmək
Proqramınızı İşlətmək

İndi işlədiyini görmək üçün proqramımızı işlədə bilərik. Əvvəlki sənədimizdəki skeleton.js faylını istifadə edərək ya öz oyununuzu yarada bilərsiniz, ya da burada tapdığınız sadə Boru oyunundan istifadə edə bilərsiniz.

ITP Laboratoriyasına bənzər şəkildə proqramımızı icra etmək üçün aşağıdakı addımları izləyəcəyik.

  • İstifadə etməyi planlaşdırdığınız nəzarətçi (lər) ilə Arduino'yu qoşun.
  • P5. seriya nəzarətini açın
  • P5 eskiz portunu istifadə etdiyinizə dəyişdirin (skeleti istifadə edirsinizsə, bu 3 -cü sətirdədir)
  • P5 eskizinizə bağlantı verən HTML faylını açın

Şəkillər və ya yüklənmiş şriftlər kimi kənar medianız varsa, bunu bir serverdə işə salmaq istəyəcəksiniz. İstəyirsinizsə, sadə bir yerli python serveri işlədə bilərsiniz.

Addım 10: İrəli gedin

Daha irəli getmək və bunun üçün daha çox oyun inkişaf etdirmək üçün burada tapılan p5.play formasından müxtəlif nümunələri izləyə bilərsiniz. Aşağıda yaratdığım daha mürəkkəb bir oyunun nümunəsidir. Bu 1 vs 1 tank atıcı oyunudur. Bunun üçün bütün mənbələri GitHub -da tapa bilərsiniz.