Skip to content

Latest commit

 

History

History
167 lines (120 loc) · 13.6 KB

README.md

File metadata and controls

167 lines (120 loc) · 13.6 KB

Eric's Spraakassistent

Inhoudsopgave

Beschrijving

Eric's Spraakassistent is een website waarmee een tekst met enkel spraakopdrachten gemanipuleerd kan worden. Onder andere selecteren, kopiëren, plakken, schrijven, downloaden en weghalen van de tekst behoren tot de mogelijkheden.

Probleemstelling / User scenario

Een kennis van Eric beschikt niet over de fijne motoriek die nodig is om gemakkelijk te kunnen kopiëren en plakken. Om dit probleem op te lossen, kreeg ik de opdracht om haar te laten kopiëren en plakken middels spraak. Zo wordt het mogelijk voor haar om deze handelingen relatief snel uit te voeren.

Exclusive Design Principles

Study situation
Study situation gaat over het bestuderen van de situatie van één specifiek persoon, zoals de lichamelijke mogelijkheden en obstakels van de persoon in kwestie. Door de situatie te bestuderen, heb ik o.a. de onderstaande verbetering in het ontwerp gerealiseerd.

  • Zo klein mogelijk aantal benodigde klikken.

Prioritise identity
Prioritise identity gaat over het personaliseren van het product voor één specifiek persoon, door aandachtig te luisteren naar de persoon in kwestie en diegene beter te leren kennen. Door de identiteit prioriteit te geven, heb ik o.a. de onderstaande verbeteringen in het ontwerp gerealiseerd.

  • Eric's naam in de titel.
  • Light mode in plaats van dark mode.
  • Kleurenpalet bestaat uit Eric's favoriete kleuren: groen en geel.
  • Rolstoel die met een vaart onderaan het scherm langsrijdt zodra de naam "Eric" wordt genoemd.

Ignore conventions
Ignore conventions gaat over het loslaten van theoretische ontwerpregels, en het prioriteren van een ontwerp dat voor één specifiek persoon het beste werkt. Door conventies te negeren, heb ik o.a. de onderstaande verbeteringen in het ontwerp gerealiseerd.

  • Automatisch starten met opnemen zodra de website wordt geopend.
  • Niet automatisch stoppen met opnemen na verloop van tijd.

Add nonsense
Ignore conventions gaat over het toevoegen van (in het eerste opzicht) nutteloze functies, als open deur voor nieuwe inzichten. Of simpelweg omdat het leuk is. Door onzin toe te voegen, heb ik o.a. de onderstaande verbetering in het ontwerp gerealiseerd.

  • Rolstoel die met een vaart onderaan het scherm langsrijdt zodra de naam "Eric" wordt genoemd.

Poster

Gebruikershandleiding en functies

Na het vragen om toestemming om de microfoon te gebruiken, begint Eric's Spraakassistent automatisch met opnemen. De tussentijdse resultaten van de spraakassistent worden als grijze tekst getoond in het transcript. Na een aantal seconden heeft de spraakassistent besloten wat er daadwerkelijk gezegd is, kleurt de tekst zwart en wordt het spraakcommando uitgevoerd. De tekst in het tekstveld kan zowel met spraakcommando's worden gemanipuleerd als handmatig. Alle mogelijke spraakcommando's staan in een lijst op de pagina. Tijdens het eerste bezoek worden er een aantal instructies getoond, die kunnen worden weggeklikt en altijd nog kunnen worden bekeken door middel van een knop links onderin de pagina. Het is mogelijk om de taal waarin gesproken wordt aan te passen, zodat het transcript accurater wordt. Daarnaast kan er aangevinkt worden dat de geselecteerde tekst automatisch gekopieërd wordt. Deze twee opties, evenals de tekst in het tekstveld en of de instructies getoond moeten worden (alleen bij het eerste bezoek), worden opgeslagen in de localStorage, zodat ze bij een verversing van de pagina niet verloren gaan.

Live demo

https://erics-spraakassistent.onrender.com

Installatie

Om te bekijken, bezoek de website. Om lokale wijzigingen aan te brengen, clone de repository en bewerk de bestanden in een IDE.

Checklist

De voltooide taken zijn te vinden in de commit messages. De volgende taken konden niet binnen de gestelde tijd worden voltooid, maar zouden leuk zijn om te hebben.

  • Vertaalmachine implementeren.
  • Geselecteerde tekst aanpasbaar maken.
  • Google Docs implementeren.
  • Website omzetten naar een Chrome Extensie.
  • "Volgende" en "vorige" bij "selecteer ... tot ..." efficiënter maken.
  • Website volledig bestuurbaar met spraak maken.
  • Spraakcommando's versleepbaar maken.
  • 's Avonds automatisch veranderen naar dark mode.
  • "Maak ongedaan" optie toevoegen.
  • "Tot" vervangen door "tot en met".

Licentie

Dit project is gelicenseerd onder de GPL-3.0 licentie.

Testverslagen

Versie 1

Datum: 21 april 2022
Code: GitHub

Tijdens de eerste test lag de focus voornamelijk op kennismaken met Eric en laten zien wat ik tot nu toe had. Nadat ik dit gedemonstreerd had, ging Eric zelf de spraakassistent uitproberen. Hij reageerde enthousiast en kwam met de onderstaande verbeterpunten en suggesties.

  • Moet de website automatisch starten met opnemen?

    • Ja. Nog wel een stop- en startknop om de privacy mee te kunnen waarborgen.
  • Hoe moet hij iets selecteren? Is hij daar tevreden mee? Is een optie om tekst te selecteren middels spraak interessant?

    • Eric kan prima selecteren, maar de mogelijkheid om te selecteren middels spraak is zeker interessant voor een kennis van hem die beperkter is.
  • Is een vertaalmachine interessant?

    • Ja, dat is altijd leuk.
  • Zijn er nog overige opmerkingen?

    • De tussentijdse resultaten zijn te afleidend, in de uiteindelijke versie is het fijner als de gebruiker enkel ziet dat er geluisterd wordt. De tussentijdse resultaten kunnen beter in de console worden gelogd.
    • Zoeken naar meerdere instanties van hetzelfde woord zou handig zijn, net als grote stukken tekst op een pagina selecteren en kopiëren middels spraak. Op de positie van de geselecteerde tekst iets aanpassen is ook handig.
    • Implementatie van Google Docs is de moeite waard om te onderzoeken (voornamelijk Google Sheets, dat gebruikt Eric veel). Opmaak meenemen (of juist niet) is belangrijk bij het plakken.
    • Feedback van Koop: Is het interessant om de voice assistant in een Chrome Extensie om te zetten? Dat is persoonlijk genoeg (prioritise identity).
    • Voorkeur voor de Nederlandse taal, maar tweetalig is nóg beter.
    • Liever één hele solide functie dan meerdere half-werkende functies.

Voor de tweede test ga ik de website automatisch laten starten met opnemen, een stop- en startknop toevoegen, de tussentijdse resultaten leegmaken zodra er een nieuw spraakcommando wordt uitgesproken en zoeken naar meerdere instanties van hetzelfde woord ondersteunen.

Later ga ik eventueel een vertaalmachine implementeren, grote stukken tekst op een pagina selecteren ondersteunen, de geselecteerde tekst aanpasbaar maken, Google Docs implementeren, de website omzetten naar een Chrome Extensie en de spraakassistent tweetalig maken.

Versie 2

Datum: 28 april 2022
Code: GitHub

Tijdens de tweede test heb ik de eerste paar minuten niets gezegd, om de pijnpunten van de website te achterhalen. Een ander verschil met de eerste test was het apparaat waarop de website getoond werd, dit maal gebruikte hij namelijk zijn eigen Windows-laptop. Hij was wederom positief verrast. Tijdens de eerste test had hij verteld dat hij graag wilde dat de spraakassistent automatisch begon met opnemen, maar nu kwam hij hierop terug. Toen ik vroeg waarom hij dit liever niet wilde, legde hij uit dat hij het niet fijn vond dat er een kans was dat de gebruiker niet weet dat de website aan het opnemen is. Om dit te voorkomen, stelde hij voor om een melding hiervan bovenaan de website te tonen. Zo blijft de website toch toegankelijk, omdat de gebruiker niet hoeft te klikken, maar kan hij/zij niet missen dat de microfoon aanstaat. Hier stemde hij mee in. De onderstaande takenlijst heb ik opgesteld tijdens en na de tweede test, aan de hand van Eric's verbeterpunten en suggesties.

  • Instructies verduidelijken en wachttijd na spraakcommando's melden.
  • Meteen kopiëren na selecteren (optioneel, eventueel een checkbox van maken).
  • Spraakcommando's "kopieer geselecteerde tekst" en "selecteer" niet laten botsen (optioneel).
  • Mogelijk om te selecteren van ... tot ..., met ondersteuning voor "volgende" en "vorige".
  • Vermelden dat de website spraak opneemt bovenaan de pagina.

Voor de derde test ga ik alle bovenstaande taken uitvoeren. Daarnaast ga ik grote stukken tekst op een pagina selecteren ondersteunen en de spraakassistent tweetalig maken.

Versie 3

Datum: 12 mei 2022
Code: GitHub

Tijdens de derde test begon ik met het laten zien aan Eric van de vorige twee versies, om zijn geheugen op te frissen. Vervolgens liet ik zien wat de huidige stand van zaken is, en welke feedback ik allemaal in deze derde versie heb verwerkt. Hij wist inmiddels dat de spraakcommando's niet gecombineerd en helemaal juist uitgesproken moeten worden, om het gewenste resultaat te krijgen. Na mijn uitleg liet ik hem de spraakassistent gebruiken, en dit ging verbazingwekkend goed. Zowel hij als Vasilis waren onder de indruk van de technische mogelijkheden ervan. De onderstaande vragen had ik voorbereid, met zijn antwoorden eronder vermeld.

  • Is het vervelend voor de kennis van Eric dat knoppen handmatig moeten worden ingedrukt, en niet via spraakcommando's bestuurd kunnen worden?

    • Nee, voor haar niet. Maar een website die volledig met spraak kan worden bestuurd is wel een interessant concept.
  • Staan de spraakcommando's goed onder de instructies?

    • Opzich wel, maar het zou nog fijner zijn als ze op de pagina zelf zouden staan en daar versleept zouden kunnen worden naar een plek naar keuze.
  • Is Eric tevreden over de opneem-knop?

    • Ja.
  • Wat is Eric's favoriete kleur?

    • Hij houdt van meerdere kleuren, maar groen en geel zijn momenteel zijn favoriet.
  • Wat is Eric's hobby's?

  • Rijden (door het bos), lezen, film kijken, muziek luisteren en concerten bezoeken.

  • Houdt Eric van light of dark mode?

    • Light mode, maar als het automatisch veranderd naar dark mode in de avond vind hij dat fijn.
  • Vind Eric het leuk als er qua nonsense een rolstoel langs komt rijden onderaan het scherm?

    • Jazeker! Zijn rolstoel is zijn identiteit.
  • Is de functie om geselecteerde tekst aan te passen belangrijk?

    • Ja, dat zou de website nóg bruikbaarder maken.
  • Is het nodig dat in de pop-up staat dat de geselecteerde tekst gekopieerd is als de checkbox aanstaat?

    • Ja.
  • Zijn er nog overige opmerkingen?

    • Het zou nog handiger zijn als er ook een "maak ongedaan" optie is.
    • Als er "tot" in het woord/de zin zit die geselecteerd moet worden gaat het niet goed. Alternatief: "tot" vervangen door "tot en met", dat vermindert de kans hierop. Een eigen taal voor de spraakcommando's zou dit probleem ook oplossen, maar hierbij is de leercurve te groot.

Voor het eindproduct ga ik het kleurenpalet aanpassen naar Eric's favoriete kleuren: groen en geel, een rolstoel langs laten rijden onderaan het scherm en in de pop-up zetten dat de geselecteerde tekst gekopieerd is als de checkbox aanstaat.

Later ga ik eventueel "volgende" en "vorige" bij "selecteer ... tot ..." efficiënter maken, de website volledig bestuurbaar met spraak maken, de spraakcommando's versleepbaar maken, 's avonds automatisch veranderen naar dark mode, geselecteerde tekst aanpasbaar maken, een "maak ongedaan" optie toevoegen en "tot" vervangen door "tot en met".

Conclusie

De testen hebben ontzettend bijgedragen aan het verbeteren van het ontwerp, aangezien ik minstens drie kwart van mijn aanpassingen heb gebaseerd op de feedback van Eric. Soms verschilde zijn feedback van keer tot keer of was ik het er zelf niet mee eens. Meestal negeerde ik het dan of veranderde ik iets kleins en keek ik of hij het de week erna nog miste. Als ik er echt nieuwsgierig naar was, vroeg ik hier specifiek naar. Een volgende keer zou ik minder voordoen en uitleg geven vooraf, zodat de testresultaten breder toepasbaar zijn (bezoekers van de website krijgen immers ook geen voorbeeld en/of uitleg). Daarnaast zou ik de tester vragen om hardop te denken, dat was ik namelijk de afgelopen weken vergeten.

Do's en don't's
In mijn ervaring is het belangrijk om voorafgaand aan de test vragen op te stellen en/of vast te stellen wat belangrijk is om op te letten. Ook het goed voorbereiden van de test (website op Heroku hebben staan, notitieboekje klaar hebben liggen, etc.) is van waarde, want zo voelt de tester dat jij zijn/haar tijd respecteert en bespaar jij zelf ook tijd. Als de tester zelf een oplossing voor een probleem voorstelt, is het nuttig om door te vragen naar het onderliggende probleem, in plaats van deze oplossing klakkeloos over te nemen. Wat écht niet kan, is de tester het gevoel geven dat hij/zij iets fout doet. Als er iets fout gaat, is dit namelijk meestal de fout van het ontwerp, niet van de tester.