Innehållsförteckning:
2025 Författare: John Day | [email protected]. Senast ändrad: 2025-01-23 15:11
PROBLEMET
Som vi vet har trenden med samarbetsutrymmen accelererat under de senaste åren, tillsammans med spetsteknik som definierar valet av det specifika samarbetsutrymmet som passar dina behov.
En av de viktigaste funktionerna som erbjuds är delade mötesrum som erbjuds medlemmarna i samarbetsutrymmet, som hanteras av en (vanligtvis) enkel kalenderplattform.
Ett problem uppstår när människor schemaläggs tenderar att vara dynamiska.
Man kan boka ett rum och tro att han kanske behöver det och inte vill missa tidsluckan.
Även om man inte skulle använda den här tidsluckan så småningom, kommer han inte att bry sig om att meddela och avbryta den för andras skull, tyvärr är det mänsklig natur.
HUR LÖSER VI DET?
Med hjälp av IoT -teknik - kontroll av ljud och rörelse i ett särskilt mötesrum, kontrollerar vi varje visst tidsintervall om ett rum är bokat och faktiskt upptaget eller inte:
1. Om det inte är bokat, gör ingenting.
2. Om det är bokat, kontrollera om det finns någon rörelse eller ljud.
Om det finns, gör ingenting.
Om ingenting upptäcktes, skicka ett varningsmeddelande (via e -post) till användaren som bokade rummet som frågar om rummet fortfarande används. såvida inte användaren förklarar att han fortfarande använder rummet ändras rumsstatusen till "Tillgänglig".
* Här integrerade vi vårt projekt med Google Kalender för att generalisera det så mycket som möjligt.
Steg 1: Hårdvara och protokoll behövs
1. Vi använde NOSEMCU så att vi kunde uppdatera saker dynamiskt med hjälp av WIFI -anslutningen.
2. Mikrofonsensor som "läser" bruset i rummet.
3. PIR -sensor som kontrollerar om det finns någon rörelse.
För programvara och serveranvändning, förutom koden i Arduino, använde vi Google Script och Zapier för att stödja vårt system online. Du kan se flödet i den tillagda bilden (och PDF).
Vi använde Zapier för att ansluta appar och automatisera våra arbetsflöden (som IFTTT) och vi använde Google Script för att hjälpa oss att kommunicera med Google Kalender. Skriptet vi skrev producerar händelseskaparens e -post så att vi kan skicka det med Zapier och kontrollera om användaren bad om att få behålla rummet (genom att spara lite information i Google Kalkylark) innan han tar bort händelsen.
Steg 2: Anslut mikrofonen och PIR -sensorn
Vi ville kontrollera de genomsnittliga värdena som mikrofonen postar till NODEMCU när människor pratar (klart, i varje rum hade olika bakgrundsljud). Vi gjorde några tester och insåg att den genomsnittliga ljudnivån är det rum vi arbetade i är någonstans över 50.
PIR -sensorn ger bara HIGH eller LOW -värden så vi kontrollerade bara den känslighetsnivå som är den mest exakta för rummet vi kontrollerade. Denna guide var ganska hjälpsam.
VÅRA ANSLUTNINGAR:
Mikrofon - som på bilden PIR -sensor: GND> GND, OUT> D7, VCC> VN (5V)
Steg 3: Skapa arbetsflödet i Zapier
För att veta om rummet faktiskt är tomt eller fortfarande används (och användarna är till exempel paus), skulle vi vilja skapa ett flöde som säkerställer det, direkt efter att NodeMCU avfyrar en Webhook till Zapier som meddelar att rummet är tomt:
(1) TRIGGER - CATCH HOOKZapier fångar Webhook (som kommer att skickas av NODEMCU)
(2) ACTION - GETZapier skickar en annan Webhook för att hämta händelsedata;> Den kallar (kör) ett GoogleScript - GetCurrentEmailEventID (förklaring i följande steg), för att hämta den aktuella händelsesdata - händelsens namn, händelse -ID, användarmail.
(3) FILTER - FORTSÄTT ENDAST OM
Fortsätt bara till nästa steg om det finns en händelse (någon händelse) som för närvarande händer i kalendern (RUM ÄR UPPTAGET), annars stannar det när rummet är ledigt.
(4) ÅTGÄRD - GMAILZapier skickar ett e -postmeddelande via Gmail till användaren som bokade rummet (fick denna information i steg 2)
(5) ÅTGÄRD - FÖRDRÖJNING Låt användaren få tid att svara på e -postmeddelandet. - Om användaren klickar på länken: ring (kör) GoogleScript - ApproveCurrentEvent (Därför tas rummet bort från listan "Rum att radera" och rummet är fortfarande markerat som upptaget.)
(6) ÅTGÄRD - FÅ Efter 5 minuter ringer (körs) Zapier GoogleScript - DeleteCurrentEvent- Om användaren inte klickade på länken
Kontrollerar om rums -ID finns i listan "Rum att radera"
det tar bara bort händelsen.
Steg 4: Google Scripts
När vi integrerade hela systemet var GoogleScripts det triviala valet av en IDE. Därför använde vi relevanta Google -bibliotek. Skulle ändras enligt rumsbokningsplattformen.
(1) GetCurrentEmailEventID
Körs av ett Webhook -samtal.
Använda en viss förskjutning för att eliminera eventuell missavbokning, få aktuell händelsedata.
(2) ApproveCurrentEvent
Körs med ett användarklick.
I händelse av en användares godkännande av att rummet fortfarande används, raderas händelse -ID från "Rum att radera". Vi använde ett Google -blad, någon annan form av en lista kan vara relevant här.
(3) DeleteCurrentEvent
Körs av ett Webhook -samtal.
Söker efter relevant händelse -ID i listan (Google -blad) och raderar händelsen från kalendern.
Steg 5: Anslut flödet med Arduino -koden
Den bifogade koden ansluter till de sensorer vi kontrollerade för några steg sedan till onlinesystemet (Google -kalender i vårt fall). Det kontrollerar om rummet är upptaget och om det inte är det skickar det en HTTP -begäran (en Webhook) som startar borttagning av begäran om att ta bort på Zapier.
Steg 6: Granskning, slutsatser och framtida skalning
Den största utmaningen vi var tvungna att ta itu med är att täcka alla kantärenden när vi beslutar att frigöra ett mötesrum. Vi var sedan tvungna att skapa en tillståndsmaskin med tanke på alla möjliga fall, så att ett fel inte uppstår och rummet kommer att ställas in som tillgängligt endast när det borde.
Till exempel, om rummet är bokat för någon grupp som för närvarande inte finns där (till exempel paus), men fortfarande behöver det, kommer NODEMCU att upptäcka att rummet är ledigt> PROBLEM.
Sedan var vår lösning att mejla användaren som bokade rummet (vilket inte var enkelt att räkna ut) ett meddelande som ger möjlighet att fortsätta hålla rummet.
Om användaren inte svarade under en viss tid (vi ställde in det till 5 minuter, men det kan enkelt ändras), tar vi bort händelsen från kalendern (och frigör rummet).
På så sätt lyckades vi så småningom hantera alla möjliga scenarier och skapa ett fungerande system.
VÅRA SYSTEMBEGRÄNSNINGAR:
1. De använda sensorerna måste vara mycket exakta och känsliga.
2. Rumsstorleken är begränsad till sensorns radie/räckvidd.
3. Vi måste förlita oss på användarens lyhördhet.
4. Vårt system är byggt med flera plattformar (Google -kalender, Gmail, Zapier etc.) och måste använda deras tjänst för att prestera.
5. För att skala denna tjänst för flera rum (i stället för dubblering av hela systemet) krävs ytterligare hantering med rums -ID.
6. Systemet är bara automatiskt och det finns inget manuellt alternativ för att avboka en rumsbokning.
FRAMTIDA UTVECKLING:
Vi skulle definitivt skala upp systemet på två sätt:
1. Möjlighet att arbeta med andra kalenderplattformar (så att alla samarbetsföretag kan använda den).
2. Möjlighet att hantera flera rum, golv och platser.
Vi tror att denna typ av skala kommer att ta 2-3 månader att generalisera, testa och lägga till flera rum (golv etc.).
Dessutom, med en obegränsad mängd pengar och resurser skulle vi använda bättre sensorer med ett större intervall, tillsammans med att anpassa dem till det angivna rummet - med tanke på räckvidd, radie, mängd sensorer etc. Ett steg som skulle göra varje system längre att installera, självklart.
Rekommenderad:
Escape Room Arduino: 6 steg (med bilder)
Escape Room Arduino: Detta projekt handlar om att skapa en Escape Room -prototyp med hjälp av arduino por elektroniska komponenter, en grundläggande kunskap om dess kodning. Detta utrymningsrum kommer att ha fem faser att täcka: (Det kan vara annorlunda för alla) 1. Preassure -sensor - LEDNär du
Hands Free Room Lights Control: 10 steg
Hands Free Room Lights Control: Som i filmen " Mission Impossible " säger " Desperata tider kräver desperata åtgärder " min bror som går i klass 10 fick en idé att styra lamporna i köket med telefonen istället för att använda omkopplare och orsaken
Hörselskadad dörrklocka Room Light Hack: 7 steg (med bilder)
Hörselskadade Doorbell Room Light Hack: Problem: min pappa är registrerad som döv och min mamma är hörselskadad och på grund av detta har de ofta svårt att höra dörrklockan. Detta kan också vara ett problem för många andra. De köpte en blinkande dörrklocka för att hjälpa dem med
Escape Room Codegenerator: 4 steg
Escape Room Codegenerator: För att projektet skulle kunna utvecklas till en maskin för att utveckla den som används i ett utrymningsrum. Tanken på denna maskin är att den kan köpas på en knapp som kan användas för att hantera lampor för hand, så kommer den att
DIY -- Clap Controlled Room Light: 3 steg
DIY || Clap Controlled Room Light: Har du någonsin undrat att styra dina hushållsapparater med en CLAP? Då är du på rätt ställe! Här ska jag visa dig hur du kan styra alla hushållsapparater - rumsljus, fläkt, TV eller ljudsystem med bara en klapp. Detta projekt är baserat på