Cuprins:
- Pasul 1: derulați ansamblul bot
- Pasul 2: Instalați pachete și Codebase
- Pasul 3: Configurarea instanței Slack
- Pasul 4: Creați un canal Slack și invitați robotul la canal
- Pasul 5: Descărcați codul sursă SlackPiBot și configurați
- Pasul 6: Configurați Crontabs pentru a porni automat la pornire:
- Pasul 7: Opțional: adăugați o ieșire de difuzor USB
- Pasul 8: Opțional: adăugați butoane cu fir la robot pentru a șterge mesajele
- Pasul 9: Trageți totul împreună și trimiteți ieșirea către Pi
- Pasul 10: Opțional: integrare IFTT
2025 Autor: John Day | [email protected]. Modificat ultima dată: 2025-01-13 06:58
Acest proiect combină un Raspberry Pi cu un kit Pimoroni Scroll Bot (modificat cu butoane), Slack și IFTT pentru notificări vizuale și sonore atunci când videoclipurile de pe YouTube sunt postate la un abonament!
Modificările butoanelor la kit sunt opționale, precum și difuzorul pentru a anunța sosirea unui nou videoclip.
Puteți utiliza, de asemenea, acest lucru pentru a trimite orice mesaj către bot prin slăbire, înaintând „bot” partea din față a mesajului, cum ar fi „bot hello world”. „bot clear” va șterge ecranul.
Pasul 1: derulați ansamblul bot
Completați instrucțiunile pentru asamblarea Pimoroni Scroll Bot:
learn.pimoroni.com/tutorial/sandyj/assembl…
Pasul 2: Instalați pachete și Codebase
Instalați pachete audio:
sudo apt-get update & sudo apt-get upgrade -y
sudo apt-get install mpg123
Instalați pachete Python:
pip instala balon
pip install psutil pip install slackclient
Urmați tutorialul de la Pimoroni pentru Noțiuni introductive despre Scroll Hat:
learn.pimoroni.com/tutorial/sandyj/getting…
care include descărcarea eșantionului de cod sursă și resurse:
curl https://get.pimoroni.com/scrollphathd | bash
Deoarece ecranul este montat cu capul în jos în kitul robotului, trebuie să decomentați codul pentru a roti ecranul la 180:
$ sed -i 's / # scrollphathd.rotate (grade = 180) /scrollphathd.rotate (grade = 180) / g' /home/pi/Pimoroni/scrollphathd/examples/web-api.py
Pasul 3: Configurarea instanței Slack
Pentru ca scriptul să comunice cu Slack, veți avea nevoie de o cheie API bot.
Începeți conectându-vă la pagina web a echipei Slack (https://my.slack.com/services/new/bot) și alegeți un nume de utilizator pentru botul dvs., apoi copiați simbolul API furnizat.
Pasul 4: Creați un canal Slack și invitați robotul la canal
Puteți utiliza canalul general de slack sau, dacă preferați, puteți crea un canal de slack separat.
În cazul meu am folosit # robot-claire-control
Trebuie să-ți inviți robotul în canal sau nu va vedea mesajele trimise.
Pasul 5: Descărcați codul sursă SlackPiBot și configurați
Descărcați codul sursă slackPiBot din git:
git clone
Actualizați linia 29 cu cheia API:
slack_client = SlackClient ("xoxb-YOUR-API-KEY-AICI")
Actualizați linia 34 cu numele robotului dvs.:
dacă user.get ('nume') == "robot-claire":
Pasul 6: Configurați Crontabs pentru a porni automat la pornire:
Configurarea crontabs pentru a porni automat la pornire:
crontab -e
Adăugați următoarele în partea de jos a crontab-ului:
@reboot python /home/pi/Pimoroni/scrollphathd/examples/web-api.py@reboot python /home/pi/slackPiBot/check_button.py @reboot python /home/pi/slackPiBot/forever.py / home / pi / slackPiBot / slackPiBot.py >> /home/pi/slackPiBot/outputLog.txt 2> & 1
Pasul 7: Opțional: adăugați o ieșire de difuzor USB
Pentru acest proiect, folosesc un difuzor USB de la US Robotics - disponibil pe Amazon sau eBay.
Dacă utilizați ceva similar, va trebui să schimbați dispozitivul implicit de sunet al sistemului, editând configurația alsa (/usr/share/alsa/alsa.conf). Schimbați următoarele rânduri:
defaults.ctl.card 1defaults.pcm.card 1
1 fiind indexul dispozitivului dvs. Pentru a găsi ID-ul dispozitivului dispozitivului USB, rulați aplay -l și căutați ID-ul cardului.
Pasul 8: Opțional: adăugați butoane cu fir la robot pentru a șterge mesajele
Acest pas este opțional, dar foarte recomandat pentru a șterge mesajele de pe ecran.
Am adăugat două butoane la robotul meu, dar în acest proiect folosesc doar GPIO17.
Scriptul check_button.py care rulează la boot interogă GPIO17 la fiecare câteva milisecunde și, dacă este apăsat, trimite un HTTP POST la scriptul ecranului de eșantionare pentru a goli ecranul.
Pasul 9: Trageți totul împreună și trimiteți ieșirea către Pi
Există 4 scripturi care funcționează împreună pentru acest proiect:
/home/pi/Pimoroni/scrollphathd/examples/web-api.py/home/pi/slackPiBot/check_button.py/home/pi/slackPiBot/forever.py /home/pi/slackPiBot/slackPiBot.py
Scriptul web-api este furnizat de Pimoroni și este o aplicație web simplă pentru a controla ecranul cu comenzi POST.
Scriptul python check_button sondează pinii GPIO și când butonul este apăsat, trimite un HTTP POST către scriptul web-api.py.
Scriptul forever.py dă startul scriptului slackPiBot.py pentru a se asigura că, dacă există erori neacoperite sau se deconectează de la slack, scriptul este repornit pentru a evita lipsa mesajelor.
Scriptul slackPiBot.py se conectează la slack și monitorizează canalul pentru mesajele care încep cu „bot” sau postări din IFTT. Dacă există o potrivire, acesta va trimite un HTTP POST către scriptul web-api.py și va fi afișat pe ecran.
Pasul 10: Opțional: integrare IFTT
Acest proiect a fost conceput pentru a-mi alerta copiii cu privire la videoclipurile postate de persoanele pe care le urmăresc pe youtube, deoarece sunt prea tineri pentru a avea propriul iPhone sau iPad. Am realizat acest lucru prin crearea de rețete IFTT care trimit o notificare către canalul de control slack după ce a fost postat un videoclip.
Wiki instructabile face acest lucru complicat de văzut într-un singur pas, dar capturile de ecran de mai sus arată rezultatul final.