pdf 2.7 MB - Tietojenkäsittelytieteen laitos

Simulointipohjainen
käyttöliittymäsuunnittelu
Sari A. Laakso
Helsinki 13.1.2015
Kurssin luentomoniste
HELSINGIN YLIOPISTO
Tietojenkäsittelytieteen laitos
Sisältö
1 Käyttöliittymän ominaisuudet ........................................ 1
1.1 Käyttötilanteet ohjelmiston käyttöönottovaiheessa .............. 1
1.2 Erityyppiset käyttöliittymäongelmat (Kuva-arkisto)................. 2
Tehokkuus ............................................................................ 3
Opittavuus ............................................................................ 3
Sekundääriset ongelmat ......................................................... 4
Kulmakivet ........................................................................... 5
Puuttuva toiminnallisuus tai tietosisältö ................................... 5
1.3 Määritelmiä kirjallisuudesta................................................... 6
1.4 Simulointimenetelmien idea .................................................. 7
1.5 Esimerkki tehokkuusongelmasta (Asiakasrekisteri) ................. 9
2 Käyttöliittymän arviointi ............................................... 10
2.1 Simulointitestaus ................................................................. 10
Vaihe 1. Testitapausten selvittäminen ..................................... 11
Vaihe 2. Vaihtoehtojen ja loppuratkaisun selvittäminen ............12
Vaihe 3. Oikean polun selvittäminen ....................................... 13
Vaihe 4. Kuvasarjan laatiminen .............................................. 15
Vaihe 5. Testitulokset ........................................................... 18
Muita simulointipohjaisia asiantuntija-arviomenetelmiä............. 22
2.2 Käytettävyystestaus ............................................................ 23
Testitehtävät ........................................................................24
Testikäyttäjät ....................................................................... 26
Muut testivalmistelut ............................................................ 27
Testitilanteen ohjaaminen ..................................................... 27
Testitulokset ........................................................................ 30
Kustannustehokas testaus .....................................................33
3 Käyttötilanteet ............................................................. 34
3.1 Käyttötilanteet testitapauksina............................................ 34
3.2 GDD:n käyttötilanteet .......................................................... 36
3.3 Käyttötilanteiden kerääminen haastatteluilla ...................... 38
4 Käyttöliittymän suunnittelu .......................................... 40
4.1 Erilaisia suunnitteluprosesseja ............................................ 41
4.2 GUIDe-malli ja GDD-suunnitteluprosessi ............................. 44
4.3 Käyttöliittymän piirtäminen GDD:llä .................................... 47
Suunnitteluperiaatteet .......................................................... 48
Simulointi ............................................................................ 49
Ongelmalistan käyttö ............................................................53
Esimerkki 1: PDA-bussiaikataulut ........................................... 55
Esimerkki 2: Kirjastohakujärjestelmä ...................................... 64
Lähteitä ........................................................................... 74
Simulointipohjainen käyttöliittymäsuunnittelu
Käyttöliittymän
ominaisuudet
Viimeistään ohjelmiston
käyttöönottovaiheessa järjestelmän
avulla ryhdytään tekemään oikeita
työtehtäviä ja suorittamaan
todellisia käyttötilanteita. Tällöin
puutteet ohjelmiston
hyödyllisyydessä ja
käytettävyydessä tulevat
viimeistään esille.
Käyttötilanteet ohjelmiston
käyttöönottovaiheessa
Monesti ohjelmisto toteutetaan ja otetaan käyttöön ilman
minkäänlaista käyttötilanteiden suorittamiseen (todellisen työn
tekemiseen) perustuvaa arviointia tai testausta.
Tällöin ohjelmiston käyttökelpoisuus tavallaan testataan vasta
kentällä, ja ongelmien korjaaminen on kallista.
Sari A. Laakso (2015)
Sari A. Laakso (2015)
1
Simulointipohjainen käyttöliittymäsuunnittelu
Käyttötilanteet ohjelmiston
käyttöönottovaiheessa
Esimerkkejä ongelmista:
Työtehtävien suorittaminen on vaivalloista ja aikaavievää.
Kaikki työnkulut eivät edes ’mene läpi’, vaan osa vaiheista on
suoritettava kiertoteitse paperilla tai muilla ohjelmistoilla.
Järjestelmästä puuttuu toimintoja.
Järjestelmästä puuttuu työtehtävissä tarvittavaa tietosisältöä, tai
tiedot on organisoitu käyttäjän työtehtävän kannalta väärin.
Käyttäjät eivät keksi, miten järjestelmää pitäisi käyttää.
Käyttäjät tekevät turhaan virheitä, ja koulutukseen kuluu paljon
resursseja.
Järjestelmässä ylläpidetään toimintoja tai tietoja, joita kukaan
käyttäjä ei oikeasti missään tilanteessa tarvitse.
Sari A. Laakso (2015)
Erityyppiset käliongelmat
Esimerkki: Kuva-arkisto
Kuvatoimittaja täydentää Paavo Lipposesta kertovaa lehtijuttua
sopivilla kuvilla.
Sari A. Laakso (2015)
Sari A. Laakso (2015)
2
Simulointipohjainen käyttöliittymäsuunnittelu
Tehokkuus:
1. Mekaaninen työ: Käyttäjä joutuu tekemään valtavasti
turhia edestakaisia navigointitoimenpiteitä.
2. Kognitiivinen työ: Käyttäjä joutuu pitämään mielessään
tähän mennessä löytämiään hyviä vaihtoehtoja ja
poissuljettuja vaihtoehtoja sekä näiden sijainteja.
Sopivien kuvien valitsemisen monivaiheinen polku:
Back
Back
Sari A. Laakso (2015)
Back
Opittavuus: Käyttäjä ei ymmärrä ohjelman
toimintalogiikkaa eikä keksi, mitä ohjelman toiminnot
tarkoittavat ja miten niitä käytetään.
Sari A. Laakso (2015)
Sari A. Laakso (2015)
3
Simulointipohjainen käyttöliittymäsuunnittelu
Erityyppiset käliongelmat
Sekundääriset ongelmat
Käyttäjän tekemien virheiden korjaamisesta seuraava turha
työ on eri asia kuin ensisijaisiin tehokkuusongelmiin sisältyvä
turha työ (mekaaninen tai kognitiivinen). Virheen korjaamiseksi
vaadittu turha työ on seurausta toisesta ongelmasta, kun taas
varsinainen turha työ sisältyy sisäänrakennettuna vaatimuksena
tehtävän suorittamiseen.
Sekundääriset ongelmat johtuvat jostain toisesta ongelmasta:
Virheet johtuvat tyypillisesti tehokkuusongelmista (esim. turha
kognitiivinen työ) tai opittavuus- tai muistettavuusongelmista.
Muistettavuusongelmien takana on opittavuusongelmia.
Käyttäjän tyytyväisyys syntyy osin kaikkien neljän osa-alueen
pohjalta (tehokkuus, opittavuus, muistettavuus, virheet). Lisäksi
tyytyväisyyteen vaikuttavat mm. visuaalinen ulkoasu ja ylipäätään
käyttöliittymän esteettisyys. Näihin emme perehdy tällä kurssilla,
mutta ne on tärkeää tiedostaa ja ottaa huomioon muilla tavoin.
Sari A. Laakso (2015)
Opittavuus: Käyttäjän on vaikea päätellä neljästä
samantapaisesta printteripainikkeesta, mistä tulostuisi
hänen tarvitsemansa iso kuva.
Muistettavuus: Vaikka
hän onnistuu löytämään
oikean painikkeen ja
ylittämään opittavuuskynnyksen, seuraavallakin
kerralla on vaikea muistaa
(palauttaa mieleen), mikä
oli oikea toiminto.
=>
Edellisten seurauksia:
Em. opittavuus- ja
muistettavuusongelmien
takia käyttäjä helposti
valitsee väärän toiminnon
(virhe) ja joutuu
palaamaan takaisin
yrittämään uudelleen
(turhaa työtä).
Sari A. Laakso (2015)
Sari A. Laakso (2015)
4
Simulointipohjainen käyttöliittymäsuunnittelu
Erityyppiset käliongelmat
Kulmakivet
Nielsenin esittämät neljä ensimmäistä käytettävyyden osaaluetta (tehokkuus, opittavuus, muistettavuus, virheet)
näyttävät palautuvan kahteen kulmakiveen:
Tehokkuus: mekaaninen ja kognitiivinen työ
Opittavuus
Muissa osa-alueissa näkyvät ilmiöt (virheet, muistettavuus, osin
miellyttävyys) ovat valtaosin seurausta näistä.
Opittavuus- ja muistettavuusongelmien sekä virheiden määrä
saadaan minimoitua optimoimalla tehokkuus.
Tehokas käyttöliittymä sisältää vain vähän opittavuuskynnyksiä
(työvaiheita on vähän ja käyttäjä on koko ajan yhdessä paikassa).
Käyttäjän on helppo korjata myös inhimillisten erehdysten
seuraukset, koska kaikki näkyy koko ajan ja käyttäjä voi säätää eitoivotut seuraukset samantien takaisin.
Sari A. Laakso (2015)
Puuttuva toiminnallisuus tai tietosisältö: Ohjelmasta
puuttuu toimintoja tai tietoja, joita käyttäjä tarvitsisi
työnkulkunsa osaksi.
Yksittäisten kuvien poimimistoiminto
(ns. ostoskori) puuttuu:
=>
Seurauksia:
Käyttäjän on keksittävä
kiertoteitä tehtävänsä
hoitamiseksi, esim.
tulostettava valitsemiaan
kuvia paperille ja haettava
myöhemmin samoja kuvia
kuvanumeron avulla
(turha työ). Työtä tulee
valtavasti ja riski virheille
kasvaa.
Sari A. Laakso (2015)
Sari A. Laakso (2015)
5
Simulointipohjainen käyttöliittymäsuunnittelu
Määritelmiä kirjallisuudesta
Käytettävyyden osa-alueet (Nielsen)
Käyttökelpoisuus (usefulness)
1. Hyödyllisyys (utility): Voiko tehdä oikeaa asiaa?
Onko järjestelmässä sellaiset toiminnot ja tietosisältö (Nielsen: vain toiminnot),
että työtehtävien tekeminen ’menee läpi’ – vaikka vaikeasti ja vaivalloisestikin?
Jos oikean asian pystyy tekemään jotenkin:
2. Käytettävyys (usability): Onko tekeminen sujuvaa?
Tehokkuus
(efficiency)
Opittavuus
Onko turhia vaiheita, onko turhaa
kognitiivista työtä
(learnability)
Keksiikö käyttäjä, mitä pitäisi tehdä ja
mitä tiedot tarkoittavat
Muistettavuus
Onko selvää, kun on kerran keksinyt
(memorability)
Virhealttius
(errors)
Houkuttaako käli virhetoimintoihin, ja
miten käyttäjä selviytyy virheistä
Tyytyväisyys
Kokeeko käyttäjä käytön miellyttävänä
(satisfaction)
[Nielsen93, s. 25;
Nielsen03]
Sari A. Laakso (2015)
Ero Nielsenin määritelmään:
Tehokkuus sidottu työn määrään
Huomaa, että olemme aiemmin määritelleet tehokkuuden
käyttäjältä vaadittavan mekaanisen ja kognitiivisen työn
määrän avulla (vrt. usage patterns [Hornbæk 2006, s. 85]).
Nielsen (ks. esim. [Nielsen 1993, s. 30-31]) sitoo tehokkuuden
tehtävän suorittamiseen kuluvaan aikaan, esim. kuinka monta
minuuttia testikäyttäjältä kuluu käyttötilanteen suorittamiseen
(vrt. task completion time [Hornbæk 2006, s. 84].
Ensimmäinen perustuu käyttötilanteen suorittamisessa
vaadittujen resurssien analysoimiseen ilman testikäyttäjiä:
tietynlainen käyttöliittymäratkaisu vaatii käyttäjältä tietyt
toimenpiteet ja ’miettimistyön’, olipa käyttäjä millainen
tahansa. Jälkimmäinen perustuu testikäyttäjien avulla
saatavaan mitattavaan aineistoon: paljonko aikaa käyttäjiltä
oikeasti meni.
Sari A. Laakso (2015)
Sari A. Laakso (2015)
6
Simulointipohjainen käyttöliittymäsuunnittelu
Määritelmiä kirjallisuudesta
ISO-standardi
ISO 9241-11 –standardissa käytettävyys on määritelty laajemmin:
Usability = Extent to which a product can be used by specified users
to achieve specified goals (vrt. käyttötilanteet) with effectiveness,
efficiency and satisfaction in a specified context of use.
Vastineet
vapaasti
käännetty;
termit on
yhdistetty
tällä kurssilla
käytettyihin
käsitteisiin.
Effectiveness: the accuracy and completeness with which specified users
can achieve specified goals in particular environments
Tuloksellisuus: kuinka täsmällisesti ja kattavasti käyttäjä pystyy
tekemään työnsä; onnistuuko eteen tulevien käyttötilanteiden
suorittaminen kokonaan ja loppuun asti (vaikka olisi työlästä)
Efficiency: the resources expended in relation to the accuracy and
completeness of goals achieved
Tehokkuus (kustannustehokkuus): kuinka paljon mekaanista ja
kognitiivista työtä käyttäjän on tehtävä tilanteen suorittamiseksi
Satisfaction: the comfort and acceptability of the work system to its
users and other people affected by its use
Tyytyväisyys: kuinka miellyttävä ja mieluinen järjestelmä on käyttäjille
ja niille ihmisille, joihin sen käyttäminen vaikuttaa
Sari A. Laakso (2015)
Simulointimenetelmien idea
Kulmakivistä suunnittelumenetelmä
Tällä kurssilla opeteltava simulointitestaus ja
simulointipohjainen suunnittelumenetelmä GDD perustuvat
tuloksellisuuden ja tehokkuuden (effectiveness, efficiency
[ISO9241-11]) maksimointiin käyttötilanteita vasten (vrt.
”specified goals”, [ISO9241-11]). Opittavuus huomioidaan
vasta lopuksi. Tämä riittää tuottamaan hyvän käyttöliittymän.
Käyttötilanteiden suorittamisessa tarvittavat toiminnot ja
tietosisältö (toiminnalliset vaatimukset ja
tietosisältövaatimukset) tulevat simuloinnin kuluessa esille
”itsestään”, kun suunnittelija/arvioija hakee tilanteelle parasta
loppuratkaisua ja pyrkii keskittymään tehokkuuden
optimointiin. Hän valitsee sellaisia toimintoja ja tietosisältöä,
jotka tukevat käyttötilannetta mahdollisimman suoraviivaisesti.
Tehokkuudella ja opittavuudella operoidaan siten, että…
ensiksi optimoidaan tehokkuus (mekaaninen ja kognitiivinen) ja
vasta lopuksi korjaillaan opittavuutta, jos tarpeen.
Sari A. Laakso (2015)
Sari A. Laakso (2015)
7
Simulointipohjainen käyttöliittymäsuunnittelu
Simulointimenetelmien idea
Kohti objektiivisuutta
Riittävän optimaalinen käyttöliittymäratkaisu on mahdollista
löytää käyttötilanteita vasten varsin objektiivisesti. Kun
käyttötilanteet on valittu, niitä pystytään tukemaan paremmin
tai huonommin erilaisilla käyttöliittymäratkaisuilla.
Käyttöliittymäratkaisun arviointi muuttuu epämääräiseksi
mielipidekysymykseksi heti, jos käyttötilanteet otetaan pois ja
käyttöliittymiä tai sen osia yritetään tarkastella ilman
käyttötilanteiden simulointia.
Simuloitaessa erilaisten mielipiteiden esitteleminen alkaa
muuttua tarpeettomaksi ja korvautuu yhteisellä
ongelmanratkaisulla, kun simulointia seuraavat henkilöt
pyrkivät optimoimaan käsillä olevan tehtävän suorittamista
käyttöliittymän avulla.
Sari A. Laakso (2015)
Simulointimenetelmien idea
Toimintojen ja tietosisällön rooli
Käytettävyyttä ei voida lisätä virheellisesti määritellyn
tietosisällön tai toiminnallisuuden päälle.
Tietosisällön ja toiminnallisuuden määrittely on osa
käyttöliittymäsuunnittelua, ja se sisältyy tällä kurssilla
käsiteltäviin simulointimenetelmiin.
Sari A. Laakso (2015)
Sari A. Laakso (2015)
8
Simulointipohjainen käyttöliittymäsuunnittelu
Esimerkki tehokkuusongelmasta:
Asiakasrekisteri
Tämän esimerkkijärjestelmän (asiaskasrekisteröinnin sovellus) kaikki
toiminnot suunniteltiin ilman käyttötilanteita. Osa toiminnoista saatiin
vanhasta merkkipohjaisesta järjestelmästä.
Aluksi laadittiin hierarkkisesti organisoitu toimintoluettelo, jonka
pohjalta käyttöliittymä suunniteltiin. Eri hierarkiahaarojen toiminnot
päätyivät tyypillisesti omiin ikkunoihinsa.
Tämän tuloksena yhden käyttötilanteen suoritus (työnkulku) kulkee
monen eri ikkunan kautta. Suorituspolku on pitkä ja monimutkainen =>
sekä käyttöliittymän tehokkuus että opittavuus ovat huonoja.
Sari
AnttiA.
Latva-Koivisto,
Laakso (2015)Sari A. Laakso (2006)
Esimerkkijärjestelmä ja kuva: [Kolehmainen06]
Asiakasrekisteri
(jatkuu)
Tässä tarkastellaan yhden
tyypillisen, yksinkertaisen
käyttötilanteen
suorittamista em.
sovelluksella.
Kuvan tilanteessa käyttäjä
lisää uuden asiakkaan
asiakasrekisteriin.
Kuvaan on visualisoitu
tehtävän suorittamisessa
tarvittavat näytöt ja
näyttöjen välinen
navigointitarve.
Esimerkkijärjestelmä ja kuva: [Kolehmainen06]
Sari
AnttiA.
Latva-Koivisto,
Laakso (2015)Sari A. Laakso (2006)
Sari A. Laakso (2015)
9
Simulointipohjainen käyttöliittymäsuunnittelu
Käyttöliittymän arviointi
Testauksen tarkoituksena on löytää
mahdollisimman paljon käyttöliittymän
ongelmakohtia tai esimerkiksi asettaa erilaisia
käyttöliittymäratkaisuja
paremmuusjärjestykseen.
Käytettävyystestaus on hyvin tunnettu,
kirjallisuudessa kuvattu testausmenetelmä,
jossa testikäyttäjät käyttävät arvioitavaa
järjestelmää. Simulointitestaus on
kehitteillä oleva menetelmä, jonka suorittaa
asiantuntija, ilman testikäyttäjiä.
Molemmissa menetelmissä testitapauksena on
realistisia käyttötilanteita (työtehtäviä), joita
lähdetään suorittamaan.
Simulointitestaus
Simulointitestaus on kehitteillä oleva
käyttöliittymän arviointimenetelmä, joka
on käytössä joissain yrityksissä (lisätietoja:
Sari A. Laakso, salaakso@cs.helsinki.fi).
Menetelmässä on yhteisiä piirteitä
muiden, käyttötilanteiden suorittamiseen
perustuvien menetelmien kanssa.
Menetelmä löytää tehokkuusongelmien
lisäksi puuttuvaa tietosisältöä ja
toiminnallisuutta. Kantavana ideana on
paikantaa päätöksenteossa tarvittava
tieto ja minimoida turha työ
(mekaaninen ja kognitiivinen työ).
Sari A. Laakso (2015)
10
Simulointipohjainen käyttöliittymäsuunnittelu
Simulointitestauksen tekeminen
Yleiskuva menetelmästä
Lähtökohdaksi arvioija selvittää jonkin tosielämässä käyttäjälle
eteen tulevan konkreettisen käyttötilanteen.
Arvioija selvittää, mikä olisi valitussa käyttötilanteessa
käyttäjälle paras loppuratkaisu riippumatta siitä, millä
järjestelmillä tilanne hoidetaan.
Seuraavaksi arvioija selvittää, mikä on käyttöliittymän tarjoama
oikea polku parhaan loppuratkaisun saavuttamiseksi:
Mitkä mekaaniset toimenpiteet käyttäjän pitää tehdä
Mitkä kognitiiviset toimenpiteet käyttäjän pitää tehdä:
• mitkä näytöltä poimittavat tiedon palaset vaikuttavat hänen
päätöksentekoonsa,
• mitä tiedonkäsittelyä hänen on tehtävä päässään, esim. laskutoimituksia,
vaihtoehtojen suhteuttamista toisiinsa ja päätösten tekemistä.
Arvioija laatii oikeasta suorituspolusta kuvasarjan.
Arvioija poimii kuvasarjasta käyttöliittymän
parannusehdotuksen tai raportoi ongelmakohdat.
Sari A. Laakso (2015)
Vaihe 1:
Testitapausten selvittäminen
Lähtökohdaksi arvioija selvittää ne konkreettiset käyttötilanteet, joita
käyttäjän pitäisi pystyä järjestelmällä suorittamaan. Tähän käytetään
käyttäjien työn havainnointia, kontekstuaalisia haastatteluja ja erillisiä
käyttäjähaastatteluja.
Käyttötilanteet jäsennetään niin, että tilanteen lähtöasetelma,
aktivoitumishetki, ongelman virittävä ristiriita ja erityisesti käyttäjän
tietämys ja puuttuva tietämys tulevat selvästi esille.
Simulointitestaukseen arvioija valitsee tarkasteltavaksi yhden
käyttötilanteen kerrallaan.
Sari A. Laakso (2015)
Sari A. Laakso (2015)
11
Simulointipohjainen käyttöliittymäsuunnittelu
Vaihe 2: Vaihtoehtojen ja
loppuratkaisun selvittäminen
Arvioija selvittää, mitkä ovat käyttötilanteen päätöksentekovaiheessa
relevantit vaihtoehdot, joiden välillä käyttäjän päätöksenteko
tapahtuu. Esimerkiksi baletin väliaikatarjoilutilanteessa arvioidaan,
mitkä leivokset voisivat tulla kyseeseen valitun käyttäjän tilanteessa, tai
Pariisin matkaoppaan valintatilanteessa tutkitaan, mitkä kirjat sopisivat
tähän tarkoitukseen parhaiten. Arvioija valitsee vähintään kolme hyvää
vaihtoehtoa. Ei ole merkitystä, minkälaisen käyttäjän mieltymyksiin
arvioija asettuu, mutta on tärkeää, että kyseessä on realistinen ja
riittävän tyypillinen asetelma.
Arvioija selvittää (käyttöliittymästä riippumatta) käyttötilanteeseen
mahdollisimman hyvän loppuratkaisun: mihin relevanteista
vaihtoehdoista käyttäjän juuri tässä tilanteessa kannattaisi päätyä, jos
hän tietäisi kaiken sen, mikä tilanteessa on keskeistä tietää.
Jos tilanteen suorittamiseen ei sisälly lainkaan päätöksentekoa, arvioija
selvittää pelkän loppuratkaisun. (Yleensä tällöin käyttötilanteen
suorittaminen voidaan automatisoida eli käyttöliittymä voidaan tältä
osin poistaa.)
Sari A. Laakso (2015)
Vaihe 2 (jatkuu)
Loppuratkaisun selvittämisestä
Arvioijan on hankittava mahdollisimman kattavasti kaikki todelliseen
tarjontaan liittyvä tieto, jotta hän pystyy päättelemään, mikä olisi
käsillä olevassa tilanteessa käyttäjälle paras (mahdollisimman hyvä)
loppuratkaisu.
Arvioijan tietämys on tässä eri asia kuin todellisen loppukäyttäjän
tietämys realistisessa käyttötilanteessa.
Järjestelmän avulla selville saatava paras ratkaisu voi olla eri kuin
todellisuudessa paras loppuratkaisu. Menetelmässä haetaan
todellisuudessa parasta (mahdollisimman hyvää)
loppuratkaisua.
Jos järjestelmän avulla selville saatava paras ratkaisu on huonompi kuin
muilla keinoilla löytyvä ratkaisu, se saattaa johtua esimerkiksi
käyttöliittymän tietosisältöongelmasta: järjestelmässä ei ole sellaista
tietosisältöä, jonka avulla käyttäjä voisi löytää tilanteeseensa
paremman ratkaisun.
Sari A. Laakso (2015)
Sari A. Laakso (2015)
12
Simulointipohjainen käyttöliittymäsuunnittelu
Vaihe 3:
Oikean polun selvittäminen
Arvioija selvittää käyttötilannetta simuloimalla, mikä on
käyttöliittymän tarjoama mahdollisimman yksinkertainen
toimenpidepolku relevanttien vaihtoehtojen vertailemiseksi ja
tilanteen suorittamiseksi loppuun:
Mitkä toimenpiteet käyttäjältä vaaditaan (mekaaninen työ)?
Arvioija merkitsee tarvittavat toimenpiteet näyttökuviin.
Missä kohdissa käyttäjän on poimittava tietoja näytöltä, vertailtava
vaihtoehtoja mielessään ja tehtävä päätöksiä (kognitiivinen työ)?
Arvioija merkitsee näyttökuviin, mitä tiedon palasia käyttäjä
hyödyntää päätöksenteossaan:
• Mitkä tiedon palaset vaikuttivat päätöstä tehdessä siihen, että
käyttäjä poimi tämän vaihtoehdon relevanttien joukkoon.
• Mitkä tiedon palaset vaikuttivat siihen, että käyttäjä päätti
sivuuttaa tämän vaihtoehdon.
• Kuinka käyttäjä hakee puuttuvan tietosisällön toisesta
järjestelmästä.
HUOM. Arvioija ei itse toimi tässä testikäyttäjänä vaan asiantuntijana.
Sari A. Laakso (2015)
Vaihe 3 (jatkuu)
Menetelmän olettama tietämys
Oikean polun suorittamisessa simuloidaan sellaista käyttäjää,
jolla on
käyttöliittymän toimintalogiikasta epärealistisen täydellinen
tietämys (ei simuloida todellisen käyttäjän mahdollista realistista
harhailua ja väärien toimintojen käynnistämistä),
mutta käyttöliittymän tietosisällöstä realistinen tietämys
(esimerkiksi käyttäjä ei voi etukäteen tietää, onko ravintolassa tilaa
haluttuna iltana, tai käyttäjä tietää, että McDonald’s tarjoaa
hampurilaisia ja pikaruokaa).
Tarkoituksena on selvittää ensisijaisesti hyödyllisyys- ja
tehokkuusongelmia, ei opittavuusongelmia.
Vrt. esim. kognitiivinen läpikäynti, jossa oikeaa suorituspolkua
tarkastellaan käyttäjän ensimmäisen käyttökerran näkökulmasta eli
käyttäjä ei tunne käyttöliittymän toimintalogiikkaa lainkaan
Opittavuusongelmia.
Menetelmät olettavat eri ääripäät toimintalogiikan tuntemuksesta.
Sari A. Laakso (2015)
Sari A. Laakso (2015)
13
Simulointipohjainen käyttöliittymäsuunnittelu
Vaihe 3 (jatkuu)
Arvioijan vs. käyttäjän tietämys
Arvioija
selvittää
toimenpiteet,
joilla
käyttäjä saa
nämä
selville.
Sari A. Laakso (2015)
Vaihe 3 (jatkuu)
Päätöksentekokohdan vertailu
Kun testataan käyttäjän päätöksentekoa sisältäviä
vertailutilanteita, arvioijan tulee simuloida riittävän
kehittyneellä päätöksentekoprosessilla, jotta kognitiiviset
ongelmat (mm. mielessä pitämisen ongelmat) saadaan esiin:
Testisekvenssissä käyttäjän tulee osua vähintään kolmeen
relevanttiin vaihtoehtoon: käyttäjä punnitsee näitä keskenään ja
arvioi, mikä olisi paras tässä tilanteessa.
Käyttäjälle tulee eteen myös useita huonoja vaihtoehtoja, jotka
hän jättää sivuun.
Jos arvioija testaa epärealistisen yksinkertaista päätöksentekoa
(esim. käyttäjä menee Turkuun aamun ensimmäisellä junalla,
oli se mikä tahansa) tai valitsee pelkästään helppoja
erikoistapauksia (junia menee Kemijärvelle vain yksi päivässä),
keskeiset ongelmakohdat eivät nouse esille testauksessa.
Sari A. Laakso (2015)
Sari A. Laakso (2015)
14
Simulointipohjainen käyttöliittymäsuunnittelu
Vaihe 3 (jatkuu)
Simulointi loppuun asti
Simulointia ei pidä lopettaa vielä
tietokoneohjelman käytön
päättymiseen (esim. kun käyttäjä on
saanut varattua hotellihuoneen ja sulkee
ohjelman), vaan...
...se tulee viedä loppuun aina
tavoitteen saavuttamiseen asti
(esim. kunnes käyttäjä on ajanut autolla
perheineen hotelli Mesikämmeneen ja
mennyt huoneeseensa).
Lähde: www.scandic-hotels.fi
Käyttötilanteen loppupään simulointi voi
paljastaa yllättäviä ongelmakohtia
käyttöliittymästä. Esimerkiksi ajokartan
avulla ei oikeasti löydäkään perille, tai
hotellihuone ei vastaakaan sitä, mitä
varausjärjestelmä käyttäjälle lupasi.
Sari A. Laakso,
Laakso (2015)
Antti Latva-Koivisto (2006)
Lähde: www.juvander.fi/yhteystiedot/Company_Location.pdf
Vaihe 4:
Kuvasarjan laatiminen
Simulointitestauksen sisältämistä vaiheista kootaan kuvasarja, josta
näkyy käyttäjän jokainen toimenpide. Kuvasarja auttaa arvioimaan
käyttöliittymän ongelmakohtia, ja sen avulla on havainnollista esittää
simuloinnin tuloksia.
Kuvasarjan ensimmäisenä kuvana on järjestelmän alkutila, jossa
käyttäjä ei ole vielä tehnyt ensimmäistäkään toimenpidettä (esim.
etusivu www.matkahuolto.fi).
Jokaiseen kuvaan merkitään yksi käyttäjän toimenpide, joka on
tyypillisesti hiirellä klikkaaminen (merk. nuolikursorin kuvalla) tai tiedon
syöttäminen näppäimistöltä (ympäröi syötteet). Lisäksi merkitään
päätöksentekoon vaikuttavat tiedon palaset, jotka käyttäjä lukee
näytöltä.
Toimenpiteen seuraus eli järjestelmän reaktio esitetään seuraavassa
kuvassa. Jos käyttäjä esim. täyttää peräkkäin monta syötekenttää,
joihin ohjelma ei reagoi mitenkään, nämä toimenpiteet voidaan merkitä
samaan kuvaan. Aina, kun ohjelma reagoi käyttäjän toimenpiteeseen
jotenkin, otetaan uusi näyttökuva.
Sari A. Laakso (2015)
Sari A. Laakso (2015)
15
Simulointipohjainen käyttöliittymäsuunnittelu
Esimerkkikatkelma kuvasarjasta: www.matkahuolto.fi
Huom. Alareunan tekstit ovat ohjeita, jotka eivät tule mukaan itse kuvasarjaan.
Alkutilakuvana on sellainen näyttökuva,
jossa käyttäjä ei ole vielä tehnyt
ensimmäistäkään toimenpidettä.
(Alkutilakuvaan voit merkitä ensimmäisen
hiiren painalluksen nuolikursorin
kuvalla.)
Näyttö avautuu tämän näköisenä, kun
käyttäjä on tehnyt edellisen kuvan
toimenpiteen eli painanut hiirellä
Aikataulut-linkkiä vasemmasta reunasta.
Tähän kuvaan merkitään ympäröinnillä
kentät, joihin käyttäjä seuraavaksi
syöttää tietoja.
Sari A. Laakso (2006)
Esimerkkikatkelma kuvasarjasta (sivu 2/3)
Tässä käyttäjä on syöttänyt ympyröityihin
kenttiin ”helsinki” ja ”tampere” ja vaihtanut
päivämäärän. (Tähän kuvaan voit merkitä
myös Hae-painikkeen, koska ohjelma ei
reagoi ennen sitä. Yhtä hyvin voit merkitä
Hae-painikkeen vasta seuraavaan kuvaan.)
Kun käyttäjä on edellisessä kuvassa
painanut Hae-painiketta, näytölle ilmestyy
yllä näkyvä punainen teksti ja pari
pudotusvalikkoa. Seuraavaksi käyttäjä
painaa uudelleen Hae-painiketta.
Sari A. Laakso (2006)
Sari A. Laakso (2015)
16
Simulointipohjainen käyttöliittymäsuunnittelu
Esimerkkikatkelma kuvasarjasta (sivu 3/3)
Käyttäjä vertailee
bussien tuloaikoja
ja suhteuttaa niitä
lähtöaikoihin ja
vaihtoihin. Hän
valitsee klo 10.40
saapuvan bussin,
koska se on perillä
sopivaan aikaan
eikä vaihtoa ole.
Seuraavaksi käyttäjä vierittää sivua
alaspäin nähdäkseen ennen puoltapäivää
perillä olevat bussit. Merkitse raahaus
nuolikursorilla ja katkoviivalla, joka
kuvaa raahaamisen suuntaa ja pituutta.
Sari A. Laakso (2006)
Tässä käyttäjä vertailee eri busseja ja
yrittää päättää, millä bussilla hänen
kannattaisi mennä. Merkitse tärkeimmät
päätöksentekoon vaikuttavat tiedot
kuvaan punaisella katkoviivalla. Kirjoita
viereen tekstillä, mitä käyttäjä vertailee,
minkä hän valitsee ja miksi. Merkitse
valittu bussi punaisella ympyröinnillä.
Vaihe 4 (jatkuu)
Vertailumerkinnöillä valintapäätökset
Vertailumerkintöjen tekeminen auttaa löytämään sellaisia
käyttöliittymän ongelmakohtia, jotka liittyvät käyttäjän mielessä
tapahtuvaan vaihtoehtojen vertailemiseen ja päätöksentekoon.
Vertailumerkinnöillä ympäröidään päätöksenteossa vaikuttavat
yksittäiset tiedon palaset eli ne kohteet (sanat, kuvat, taulukon solut
jne.), joiden perusteella käyttäjä päättelee, että kyseinen vaihtoehto on
hyvä tai huono. Älä ympäröi kaikkea dataa, jota käyttäjä voisi näytöltä
lukea tai katsoa, vaan ainoastaan ne tiedon palaset, jotka juuri tässä
käyttötilanteessa vaikuttavat valintapäätökseen.
Puuttuvan tietosisällön voit simuloida haettavaksi toisesta
järjestelmästä. Käytä ensisijaisesti arvioitavaa järjestelmää, mutta jos
jokin tilanteen suorittamisessa tarvittava tieto puuttuu sieltä kokonaan,
sisällytä kuvasarjaan toisen järjestelmän käyttö, josta käyttäjä poimii
tarvittavan tiedon, esimerkiksi kännykän kalenteri tai Google Maps.
Sari A. Laakso (2015)
Sari A. Laakso (2015)
17
Simulointipohjainen käyttöliittymäsuunnittelu
Vaihe 4 (jatkuu)
Käyttäjän toimenpiteet
Merkitse käyttäjältä vaadittavat toimenpiteet näyttökuviin seuraavasti:
Sari A. Laakso (2015)
Vaihe 5:
Testitulokset
Testitulokset voidaan poimia vertailumerkinnöillä varustetusta
kuvasarjasta. Menetelmän esille tuomista tuloksista voidaan
poimia käyttötarkoituksen mukaan…
1. tilanteen virittämä optimiratkaisu (ns. parannusehdotus) tai
2. käyttöliittymän ongelmakohdat: puuttuvaan tietosisältöön tai
toiminnallisuuteen liittyvät ongelmat sekä tehokkuusongelmat.
Sari A. Laakso (2015)
Sari A. Laakso (2015)
18
Simulointipohjainen käyttöliittymäsuunnittelu
5.1 Tuloksena optimiratkaisu
Suoraan parannusehdotukseen
Optimaalisen käyttöliittymäratkaisun näet poimimalla
relevanttien vaihtoehtojen välisessä vertailussa tarvitut tiedon
palaset, jotka arvioija kerää sekä arvioitavasta järjestelmästä
että muista ulkoisista järjestelmistä (puuttuva tietosisältö).
Tietosisältö: Ensiksi kaikki simulointisekvenssissä tarvitut tiedon
palaset organisoidaan samalle näytölle kerralla näkyviin.
Toiminnot: Seuraavaksi muodostetaan yksinkertaisin mahdollinen
toimenpidesekvenssi, jolla käyttäjä voi säätää em. tiedot esiin
järjestelmän alkutilasta käsin, samalla näytöllä.
(Toimenpidesekvenssin logiikan on oltava aukoton. Järjestelmä ei
voi maagisesti arvata, että käyttäjälle pitäisi näyttää juuri tämä
data nyt.)
Optimiratkaisu muodostuu periaatteessa samalla tavalla kuin
GDD-suunnittelumenetelmässä, ks. päätöksentekolähtöinen
simulointi: ks. s. 49 alempi kalvo ja selitykset s. 50-51).
Ratkaisu virittyy käyttötilanteesta ’itsestään’.
Sari A. Laakso (2015)
5.2 Tuloksena käliongelmia
Ensin läpimeno, sitten tehokkuus
Ensin katsotaan, meneekö käyttötilanteen suorittaminen läpi,
eli onko järjestelmällä mahdollista selvittää paras
loppuratkaisu:
Aukot tietosisällössä
Aukot toiminnoissa
Jos tilanteen suoritus menee läpi, arvioidaan käytettävyyttä:
Tehokkuusongelmat eli käyttäjältä vaadittu tarpeeton työ
• Mekaaninen tehokkuus = turhat toimenpiteet
• Kognitiivinen tehokkuus = turha miettimistyö ja mielessä pitäminen
(Opittavuutta ei arvioida tässä menetelmässä)
Sari A. Laakso (2015)
Sari A. Laakso (2015)
19
Simulointipohjainen käyttöliittymäsuunnittelu
5.2 Tuloksena käliongelmia
Aukot tietosisällössä ja toiminnoissa
Jo oikeaa polkua selvitettäessä (vaiheessa 3) ongelmat
puuttuvassa tietosisällössä tai toiminnallisuudessa tulevat ilmi:
Onko tavoite ylipäätään mahdollista saavuttaa järjestelmän
avulla, vai puuttuuko tarvittavia tietoja tai toimintoja:
Tehtävän suorittamisessa tarvittavan tiedon esille kaivamiseen
tarvitaan ulkoista tietolähdettä, kuten toista ohjelmaa tai
paperilähdettä, tai muuten suoritus ei etene (esim. Stockmannin
myymälän katuosoitteen selvittäminen Reittiopasta varten
Googlella; potilaan hoitotietojen etsiminen arkistomapista).
Tehtävän suorittamisessa tarvitaan ulkoista apuvälinettä, kuten
muistiinpanopaperia tai itse tehtyä Excel-taulukkoa.
Tavoitetta ei voida saavuttaa loppuun asti järjestelmän avulla, vaan
suoritus katkeaa kesken kokonaan tai epäoptimaalisesta kohdasta
(esim. hotellihuoneiden hinnat ja varaustilanteen voi selvittää,
mutta huoneen varaaminen on tehtävä puhelimella tai menemällä
paikan päälle; ajo-ohjetta hotelliin ei ole lainkaan).
Tehtävää ei voi tehdä ollenkaan, ei edes osittain.
Sari A. Laakso (2015)
5.2 Tuloksena käliongelmia
Tehokkuusongelmat (mekaaninen työ)
Käytön tehokkuutta heikentävät turhat toimenpiteet,
esimerkkejä:
Järjestelmä pakottaa käyttämään käsillä olevan tilanteen kannalta
turhia toimintoja tai pakottaa navigoimaan turhan mutkan (tai
turhien välisivujen) kautta.
Toimintoja on käynnisteltävä vuorotellen eri paikoista, mikä
aiheuttaa edestakaisen navigoinnin kahden tai useamman näytön
välillä.
Käyttäjän on syötettävä sama tieto tai valinta kahteen tai
useampaan kertaan eri paikkoihin taikka tehtävä samat säädöt
monta kertaa, kun ohjelma unohtaa ne välillä.
Käyttäjän on syötettävä sellainen tieto, jonka järjestelmä voisi
hakea automaattisesti toisesta järjestelmästä.
Sari A. Laakso,
Laakso (2015)
Antti Latva-Koivisto (2006)
Sari A. Laakso (2015)
20
Simulointipohjainen käyttöliittymäsuunnittelu
5.2 Tuloksena käliongelmia
Tehokkuusongelmat (kognitiivinen työ)
Käytön tehokkuutta heikentävä turha kognitiivinen työ eli
’miettimistyö’, esimerkkejä:
Käyttäjän on pideltävä mielessään vertailtavia vaihtoehtoja, koska
vaihtoehdot on esitetty käyttöliittymässä eri paikoissa eikä niitä ole
mahdollista saada samanaikaisesti näkyville.
Kun käyttäjä löytää itselleen sopivia vaihtoehtoja (esimerkiksi
sopivia hotellivaihtoehtoja Tukholmasta), hänen on yritettävä pitää
löytämänsä hyvät vaihtoehdot mielessään sen sijaan, että ohjelma
muistaisi ne.
Käyttäjän on pideltävä mielessään eri vaihtoehtojen ominaisuuksia,
jotka vaikuttavat hänen päätöksentekoonsa, esimerkiksi keväällä
järjestettävien seminaarien sisältöjä ja kokoontumisaikoja.
Käyttäjän pitää laskea päässä jotakin sen perusteella, mitä näytöllä
näkyy (esim. elokuvan päättymisajan laskeminen lisäämällä kesto
alkamisaikaan tai ensi viikon torstain päivämäärän laskeminen
näytöllä näkyvän tämän päivän päiväyksen perusteella).
Sari A. Laakso,
Laakso (2015)
Antti Latva-Koivisto (2006)
5.2 Tuloksena käliongelmia
Opittavuusongelmat jätetään huomiotta
Simulointitestauksessa ei keskitytä opittavuusongelmiin. Ne
kyllä näkyvät polun simuloinnissa ’esteinä’, jotka arvioija voisi
halutessaan poimia muistiin. Miksi näitä ei kerätä?
Ensisijainen syy: Valtaosa alkuperäisistä opittavuusongelmista
yleensä häviää samalla, kun tehokkuusongelmat korjataan.
Opittavuusongelmista ei ole juuri mitään apua paremman ratkaisun
suunnittelussa (jos käyttöliittymässä on myös tehokkuusongelmia).
Simulointivaiheessa opittavuusongelmiin keskittyminen on
arvioijalle helppoa, mutta se heikentää hänen kykyään paikantaa
keskeiset tehokkuusongelmat. Arvioijan tarkkaavaisuus kohdistuu
tulosten kannalta hyödyttömiin pikkuseikkoihin, eivätkä keskeiset
ilmiöt nouse simuloinnin aikana esille.
Entäpä jos nimenomaan opittavuusongelmista tarvitaan tietoa?
Opittavuusongelmien paikantamiseen on olemassa
simulointitestausta luotettavampia menetelmiä, kuten kognitiivinen
läpikäynti, käytettävyysläpikäynti ja käytettävyystestaus.
Sari A. Laakso (2015)
Sari A. Laakso (2015)
21
Simulointipohjainen käyttöliittymäsuunnittelu
Millaisia opittavuusongelmat ovat
Näitä arvioija ei poimi
Opittavuus = Mitkä toimenpiteet tai niiden seuraukset ovat
vaikeita keksiä tai ymmärtää? Esimerkkejä:
Toimenpiteitä, joita on vaikea keksiä:
• Kohde, johon liittyvät toimenpiteet eivät ole näkyvissä, esim.
kuva tai tekstinpätkä, josta ei voi tajuta, että sitä voisi klikata.
• Toimintopainikkeen tai linkin harhaanjohtava otsikko, joka...
• ei vaikuta oikealta, vaikka todellisuudessa on se oikea, tai
• vaikuttaa houkuttavalta, mutta johtaa väärään paikkaan.
• Käyttöliittymän komponentin sisältöä huonosti kuvaava otsikko:
käyttäjä ei keksi, mitä esimerkiksi syötekenttään pitäisi kirjoittaa
ja missä muodossa.
Toimenpiteiden seurauksia, joita on vaikea ymmärtää:
• Ohjelman antama vaikeaselkoinen palaute, josta käyttäjä ei
ymmärrä, mitä ohjelma teki, esimerkiksi lähtikö viesti nyt vai ei.
• Huono virheilmoitus, josta käyttäjä ei ymmärrä, mitä tapahtui
tai mikä on ongelmana tai miten ongelmaa pääsee korjaamaan.
Sari A. Laakso (2015)
Muita simulointipohjaisia
asiantuntija-arviomenetelmiä
Kognitiivisella läpikäynnillä (cognitive walkthrough; ks.
esim. [Lewis97]) arvioidaan ensisijaisesti jokaisen
toimenpideaskelen opittavuutta: keksiikö käyttäjä, mikä
toimenpide seuraavaksi pitäisi tehdä. Arvioija simuloi käyttäjän
toimenpiteitä vaihe vaiheelta ja vastaa jokaisen toimenpiteen
yhteydessä neljään apukysymykseen.
Myös heuristisessa läpikäynnissä (heuristic walkthrough)
[Sears97] arvioija tarkastelee käyttäjän toimenpidesekvenssiä,
mutta neljän apukysymyksen lisäksi hän etsii ongelmia
käyttämällä Nielsenin tarkistuslistaa [Nielsen94].
Sari A. Laakso,
Laakso (2015)
Antti Latva-Koivisto (2006)
Sari A. Laakso (2015)
22
Simulointipohjainen käyttöliittymäsuunnittelu
Käytettävyystestaus
Käytettävyystestissä (usability test)
testikäyttäjille annetaan oikeita
työtehtäviä, joista he yrittävät
suoriutua järjestelmän avulla. Näin
saadaan selville ensisijaisesti
käytettävyysongelmia.
Kirjallisuutta käytettävyystestauksesta:
[Nielsen93, luku 6], [Rubin94],
[Lauesen05, luvut 1.4 ja 13]
Kuva:
Käytettävyystestausta Helsingin yliopiston
tietojenkäsittelytieteen laitoksen Käyttöliittymätkurssilla keväällä 1999.
Käytettävyystestaus
Menetelmä
Käytettävyystestissä jäljitellään todellista työntekotilannetta:
testikäyttäjä etsii sopivaa suoritustapaa, jolla hän saisi
testitehtävässä kuvatun tilanteen hoidettua.
Testikäyttäjät valitaan järjestelmän todellisesta kohderyhmästä.
Testin ohjaaja antaa testikäyttäjälle oikeita käyttötilanteita
vastaavia testitehtäviä.
Testikäyttäjä suorittaa tehtäviä itsenäisesti parhaaksi katsomallaan
tavalla ilman testin ohjaajan apua.
Testin ohjaaja tai joku toinen testiä seuraava henkilö tekee
havaintoja käyttäjän toimenpiteistä ja ajatuksista sekä tulkitsee
niistä käyttöliittymän ongelmakohtia.
Sari A. Laakso,
Laakso (2015)
Antti Latva-Koivisto (2006)
Sari A. Laakso (2015)
23
Simulointipohjainen käyttöliittymäsuunnittelu
Testitehtävät
Tehtävät todellisia käyttötilanteita
Käytettävyystestin testitehtävät vastaavat simulointitestauksen
testitapauksia, vaikka ne kirjoitetaankin hieman erilaiseen
muotoon.
Testitehtävät ovat realistisia käyttötilanteita, joita järjestelmän
oikeille käyttäjille tulee eteen heidän työssään [Rubin94, s.
179].
Käyttäjälle annetaan testitehtävässä vain tavoite (lähtötilanne).
Tehtävänkuvauksessa ei pidä antaa minkäänlaisia vihjeitä
toiminnoista, joiden avulla tehtävää suoritetaan [Rubin94, s.
180].
Sari A. Laakso,
Laakso (2015)
Antti Latva-Koivisto (2006)
Testitehtävät
Tehtävien valinta ja muu aineisto
Testitehtävien tulisi koostua käyttäjien yleisimmistä tavoitteista
ja käyttötilanteista [Rubin94, s. 102].
Testi kannattaa aloittaa lyhyellä ja suoraviivaisella tehtävällä,
jotta käyttäjä kokee saavansa jotain tehdyksi ja pääsee hyvin
alkuun [Nielsen93, s. 186]. Monivaiheiset ja hankalat tehtävät
kannattaa sijoittaa testin loppuosaan, jotta niitä on mahdollista
pudottaa pois, jos aika ei riitä.
Testitehtävien yhteydessä tulee käyttää todellisuutta vastaavaa
aineistoa (dokumentteja, taulukkoja ym.). Epärealistisen
yksinkertaisella aineistolla tehty testi ei paljasta kaikkia
ongelmia, joita esimerkiksi hyvin laajan aineiston käsittelyssä
voi olla.
Sari A. Laakso,
Laakso (2015)
Antti Latva-Koivisto (2006)
Sari A. Laakso (2015)
24
Simulointipohjainen käyttöliittymäsuunnittelu
Testitehtävät
Esim: VR:n junalippuautomaatti 1/2
Hyödyllinen tehtävä:
Ongelmallisia tehtäviä:
Olet pääsiäislomaa edeltävänä
perjantaina Helsingin
rautatieasemalla. Ensi
keskiviikkona aiot lähteä
pääsiäisen viettoon vanhempiesi
luokse Pieksämäelle viimeisen
luentosi jälkeen, joka päättyy
klo 16 keskustassa
Porthaniassa. Ajattelit hankkia
itsellesi junalipun pääsiäistä
varten jo nyt, koska tiedät
junien olevan silloin usein
täynnä.
Selvitä, mihin aikaan
Pieksämäelle menee junia
pääsiäislomien aikoihin. Selvitä
myös hinnat sekä
opiskelijalipuista että
normaalihintaisista aikuisten ja
lasten lipuista. Hanki lopuksi
lippu johonkin haluamaasi
junaan.
Selvitä, montako junaa menee
arkisin Helsingistä Pieksämäelle.
Kuinka monta niistä on
InterCity-junia?
Sari A. Laakso,
Laakso (2015)
Antti Latva-Koivisto (2006)
Testitehtävät
Esim: VR:n junalippuautomaatti 2/2
Hyödyllinen tehtävä:
Ongelmallisia tehtäviä:
Asut Riihimäellä, mutta olet ollut
tänään käymässä Helsingissä.
Tapasit kavereitasi ja kävitte
ostoksilla. Nyt kello on 18.45,
kun saavut väsyneenä Helsingin
rautatieasemalle. Tiedät, että
junia Riihimäelle menee tosi
usein, ja ajattelit mennä kotiin
seuraavalla sopivalla junalla.
Hanki itsellesi junalippu.
Osta junalippu tänään klo
19.04 Helsingistä Riihimäelle
lähtevään junaan.
Osta opiskelijalippu
ensimmäiseen klo 18.45
jälkeen Helsingistä Riihimäelle
lähtevään junaan.
Selvitä, mikä on nopein juna
Helsingistä Riihimäelle arkisin
ma-pe. Mitkä ovat lippuhinnat
nopeimpaan junaan?
Sari A. Laakso,
Laakso (2015)
Antti Latva-Koivisto (2006)
Sari A. Laakso (2015)
25
Simulointipohjainen käyttöliittymäsuunnittelu
Testikäyttäjät
Käyttäjät oikeasta kohderyhmästä
Testikäyttäjät on tärkeää valita testattavan tuotteen todellisesta
kohderyhmästä ([Rubin94, s. 119], [Nielsen93, s. 169]).
Väärän kohderyhmän käyttäjillä testaaminen voi johtaa siihen,
ettei todellisen käytön kannalta keskeisimpiä ongelmia saada
selville.
Softan kehittäjän 25-vuotias nörttikaveri voi nauttien selviytyä
käsittämättömästä toimintoviidakosta, jossa “luodaan hierarkkisia
profiileja” ja “säädetään IMAP-asetuksia”, mutta tuotteen
ensisijaiseen kohderyhmään kuuluva käyttäjä ei välttämättä onnistu
lukemaan sähköpostejaan ollenkaan.
Kohderyhmään kuulumattomalta testikäyttäjältä voi puuttua työn
tekemiseen tarvittavia tietoja ja taitoja. Esimerkiksi kuva-arkiston
käytettävyystesteihin tarvitaan testikäyttäjiksi kuvatoimittajia, jotka
tietävät, millä perusteilla kuvia todellisessa työssä lehteen valitaan.
Sari A. Laakso,
Laakso (2015)
Antti Latva-Koivisto (2006)
Testikäyttäjät
Käyttäjien lukumäärä
Jos testaat yhtä
käyttöliittymää, 3-5
käyttäjää on yleensä
riittävä määrä.
Mitä useammalla
käyttäjällä testaat, sitä
useammin samat
ongelmat toistuvat.
Testaukseen käytetyt
lisäresurssit tuovat enää
vain vähän lisää hyötyä.
Lähde: [Nielsen00]
Sari A. Laakso,
Laakso (2015)
Antti Latva-Koivisto (2006)
Sari A. Laakso (2015)
26
Simulointipohjainen käyttöliittymäsuunnittelu
Muut testivalmistelut
Testitila ja pilottitesti
Erillistä käytettävyyslaboratoriota ei tarvita, vaan testi voidaan
järjestää esim. tavallisessa työhuoneessa [Nielsen93, s. 200].
Testihuone lavastetaan oleellisilta osin todellista
käyttöympäristöä vastaavaksi. Esimerkiksi matkatoimistossa
käytettävän järjestelmän testauksessa voisi olla hyödyllistä
lavastaa jotakin seuraavanlaista:
asiakaspalvelutiski ja asiakkaiden käyntejä,
puhelin ja asiakkaiden puhelinsoittoja ja
matkatoimistossa käytettäviä paperiesitteitä ja muuta materiaalia.
Ennen varsinaisia testejä kannattaa järjestää ns. pilottitesti eli
harjoittelutesti, jonka tuloksia ei oteta huomioon varsinaisissa
testituloksissa. Pilottitestin tarkoituksena on harjoitella testin
läpivientiä ja korjata jäljellä olevat ongelmat testitehtävistä,
testin ohjauksesta ja testattavan prototyypin toiminnasta
[Nielsen93, s. 174-175].
Sari A. Laakso,
Laakso (2015)
Antti Latva-Koivisto (2006)
Testitilanteen ohjaaminen
Ennen testin aloittamista
Yritä saada testin alku rennoksi ja luontevaksi. Käyttäjät ovat
usein hermostuneita aloittaessaan testin, kun he eivät tiedä,
mitä tuleman pitää. Usein he kokevat myös valtavia
suorituspaineita, joita tarkkailun kohteena oleminen vielä lisää
entisestään [Nielsen93, s. 181].
Kerro testikäyttäjälle ennen testin aloittamista seuraavat
toimintaperiaatteet [Nielsen93, s. 188; Rubin94, s. 148-149]:
Emme testaa sinua, vaan tätä ohjelmaa. Tarkoituksena on löytää
ohjelmasta niin paljon ongelmia kuin mahdollista.
Jos haluat, voit lopettaa testin milloin tahansa.
Jos testi videokuvataan: Emme ole kuvaamassa sinua, vaan kamera
on sitä varten, jotta muistaisimme jälkeenpäin testitilanteessa esille
tulleet asiat.
Pyytäisin ajattelemaan ääneen, mitä olet tekemässä [Nielsen93,
s. 195].
Sari A. Laakso,
Laakso (2015)
Antti Latva-Koivisto (2006)
Sari A. Laakso (2015)
27
Simulointipohjainen käyttöliittymäsuunnittelu
Testitilanteen ohjaaminen
Testitilanteen alussa
Kerro käyttäjälle lyhyesti, millaisesta ohjelmasta testissä on
kyse, ja kuvaile testitehtävien taustatilanne lyhyesti:
Järjestelmän tarkoitus noin yhdellä lauseella, esim. “Tällä ohjelmalla
käsitellään kodinkoneliikkeeseen tulevia asiakasvalituksia.”
Kuka käyttäjä on ja missä hän kuvitellusti on, esim. “Olet juuri
tullut ensimmäisenä työpäivänäsi kodinkoneliikkeen valitustiskille
töihin. Jotkut asiakkaasi tulevat tähän tiskille esittämään
valituksensa ja osa soittaa sinulle puhelimella.”
Jos testiympäristöön kuuluu esim. puhelin, kerro siitä käyttäjälle
ennen testin alkua, esim. “Tuo puhelin on tässä testissä oma
työpuhelimesi. Jos se soi, voit vastata siihen omalla nimelläsi.”
Tarkoituksena on saada käyttäjän sovellusalueeseen ja
testiasetelmaan (mutta ei itse käyttöliittymään!) liittyvä
tietämys todellista tilannetta vastaavaksi.
Järjestelmän toimintaa ei pidä esitellä käyttäjälle etukäteen, jos
käyttäjä ei tositilanteessakaan saisi koulutusta ennen käyttöä.
Sari A. Laakso (2015)
Testitilanteen ohjaaminen
Testitehtävien antaminen käyttäjälle
Anna testitehtävät käyttäjälle yksi kerrallaan.
Kuvaile testitehtävän sisältämä esimerkkitilanne käyttäjälle
suullisesti vapaamuotoisesti.
Yleensä testitehtävä kannattaa antaa käyttäjälle myös
paperilapulla [Nielsen93, s. 186], jottei hänen tarvitsisi pitää
mielessään tehtävässä annettuja tietoja.
Siirry tehtävästä toiseen huomaamattomasti kuvailemalla uutta
tilannetta. Älä kommentoi käyttäjän suoriutumista tehtävästä
[Nielsen93, s. 190], koska käyttäjän kykyjä ei olla nyt
testaamassa.
Sari A. Laakso,
Laakso (2015)
Antti Latva-Koivisto (2006)
Sari A. Laakso (2015)
28
Simulointipohjainen käyttöliittymäsuunnittelu
Testitilanteen ohjaaminen
Ulkopuoliset tarkkailijat
Testitilassa voi olla testikäyttäjän ja testin ohjaajan lisäksi
muita henkilöitä (esim. 1-2 henkilöä tarkkailemassa tai
tekemässä muistiinpanoja), mutta he eivät saa häiritä testiä tai
osallistua testin kulkuun [Nielsen93, s. 190].
Yleensä ulkopuolisten tarkkailijoiden on parempi seurata testiä
testihuoneen ulkopuolella esim. TV-ruudulta tai yksisuuntaisen
peilin läpi (jos testi järjestetään käytettävyyslaboratoriossa).
Sari A. Laakso,
Laakso (2015)
Antti Latva-Koivisto (2006)
Testitilanteen ohjaaminen
Neuvomisen välttäminen
Älä neuvo tai auta käyttäjää tehtävän tekemisessä äläkä anna
minkäänlaisia vihjeitä tehtävän suorittamisesta [Nielsen93, s.
183; Rubin94, s. 216, 222].
Jos käyttäjä esimerkiksi keksii uusia tai yllättäviä
toimintatapoja, anna hänen tehdä toimenpiteet itse loppuun asti.
• Älä ‘vedätä’ tai johdattele ennalta suunniteltuun suoritustapaan.
• Älä näytä yllättyneeltä tai ala hämmästellä tilannetta, vaikka
käyttäjä tekisi jotain täysin odottamatonta [Rubin94, s. 220].
Jos käyttäjä kysyy sinulta suoraan ohjelman toiminnasta, esim.
”Tulostaako tämä, jos painan nyt tästä?”, esitä vastakysymys
[Nielsen93, s. 196], esimerkiksi ”Mitä arvelisit? Miltä se sinusta
vaikuttaa? Voit kokeilla vapaasti kaikkea.”
Testin ohjaajalla on monesti suuri houkutus käyttäjän
neuvomiseen testin aikana, mutta neuvominen pilaa helposti
testin tulokset (vrt. [Nielsen93, s. 183]).
Sari A. Laakso,
Laakso (2015)
Antti Latva-Koivisto (2006)
Sari A. Laakso (2015)
29
Simulointipohjainen käyttöliittymäsuunnittelu
Testitulokset
Ongelmien havainnointi
Käyttöliittymäongelmia löytyy hyvin, kun testaaja lähtee siitä
oletuksesta, että testikäyttäjä toimii aina järkevästi. Kaikki
testin aikana havaitut käyttäjän virheet ja ongelmat tehtävissä
johtuvat lähtökohtaisesti käyttöliittymän ongelmista ja
puutteista, eivätkä käyttäjästä. Tavoitteena on löytää
tuotteesta syy käyttäjän kohtaamille ongelmille [Rubin94, s.
276].
Käyttäjän kohtaamien ongelmien syitä eli käyttöliittymän vikoja
voidaan päätellä
käyttäjän tekemistä toimenpiteistä,
käyttäjän reaktioista ja
ääneenajattelusta [Nielsen93, s. 195].
Sari A. Laakso,
Laakso (2015)
Antti Latva-Koivisto (2006)
Testitulokset
Toimenpiteiden taltioiminen 1/2
Yritä saada toimenpiteet talteen tekemällä heti testin aikana käsin
muistiinpanoja.
Käyttösekvenssin voi kirjoittaa muistiin yksinkin, mutta sitä on kuormittavaa
tehdä testin ohjaamisen ohella.
Monesti on käytännöllistä pyytää työkaveria avuksi ohjaamaan testiä tai
tekemään muistiinpanoja. Hyvien muistiinpanojen tekeminen on vaativampaa
kuin testin ohjaus.
Videokamera on hyvä lähinnä varajärjestelynä: videonauhalta voit
jälkeenpäin tarkistaa käyttäjän tekemisiä tai puheita, jos et ehtinyt nähdä,
mitä käyttäjä teki jossakin tärkeässä kohdassa.
Merkitse muistiin ensisijaisesti se, mitä käyttäjä oikeasti teki (todelliset
tapahtumat). Testin aikana tehdyt tulkinnat voivat osoittautua
myöhemmin virheellisiksi tai hyödyttömiksi. Jos alkuperäistä
tapahtumadataa ei ole tallessa, tulkintoja ei voida myöhemmin muuttaa
vastaamaan testissä ilmennyttä uutta dataa.
Vrt. Lauesenin esimerkki käytettävyystestin muistiinpanoista
[Lauesen05, s. 440].
Sari A. Laakso,
Laakso (2015)
Antti Latva-Koivisto (2006)
Sari A. Laakso (2015)
30
Simulointipohjainen käyttöliittymäsuunnittelu
Testitulokset
Toimenpiteiden taltioiminen 2/2
Esimerkki YTV:n Reittioppaan käytettävyystestin muistiinpanoista:
Ote käyttösekvenssistä ja käyttäjän ääneenajattelusta:
…Käyttäjä painoi Hae. Avasi Mistä-pudotuslistan, jossa annettu kaksi eri
Unikkotietä. “Ahaa, kaks Unikkotietä, Hesassa ja Vantaalla. Mä vaihdan
tuoksi Vantaan Unikkotieksi.” Valitsi Vantaan Unikkotien, klikkasi
Vaihda, järjestelmä tyhjensi kentän. “Mitä ihmettä, mitä nyt tapahtu?”
Kirjoittaa uudelleen Unikkotie 6, painaa Hae, valitsee Vantaan
Unikkotien, klikkaa Hae.
Sari A. Laakso (2006)
(2015)
Testitulokset
Ongelmien jäsentäminen 1/2
Käyttöliittymän ongelmakohdat nimetään kuvaavasti, ja
ongelmat perustellaan käyttäjän toimenpiteistä ja
ääneenajattelusta tehdyillä havainnoilla.
Esimerkki jäsentelystä:
Ongelma 1: <Kuvaava otsikko>
Mitä käyttäjä pyrki saamaan aikaan (tavoite/alitavoite)?
Mitä käyttäjä teki (toimenpiteet) ja mitä hän sanoi (ääneenajattelu)?
Mitä käyttäjän olisi pitänyt tehdä?
Mikä ongelma tästä seurasi käyttäjälle?
Ongelman syy käyttöliittymässä?
Sari A. Laakso (2015)
Sari A. Laakso (2015)
31
Simulointipohjainen käyttöliittymäsuunnittelu
Testitulokset
Ongelmien jäsentäminen 2/2
Ongelma 1:
Käyttäjä etsi ruokapaikkoja Neste 24 h –linkin rekisteröitymisen takaa.
Mitä käyttäjä pyrki saamaan aikaan (tavoite/alitavoite)? Esim. käyttäjä yritti selvittää, miltä
Nesteen asemilta ylipäätään saa ruokaa.
Mitä käyttäjä teki (toimenpiteet) ja mitä hän sanoi (ääneenajattelu)? Käyttäjä valitsi
yläreunan päävalikosta Neste 24 h –linkin ja sanoi: ”Täällä on varmaan kaikki palvelut.” Mutisi
tyytymättömänä: ”Pitääkö tännekin rekisteröityä.” Jatkoi valitsemalla Rekisteröidy tästä.
Mitä käyttäjän olisi pitänyt tehdä? Hänen olisi pitänyt valita oikeasta reunasta Karttapalvelu
tai Neste Oil -asemahaku taikka lähteä liikkeelle yläreunan päävalikostavalitsemalla Neste Oil asemaverkosto.
Mikä ongelma tästä seurasi käyttäjälle? Hän yritti pitkään (yli 10 minuuttia) selvittää, miten
hän saisi käyttäjätunnuksen Nesteen sivustolle, eikä saanut mitään tietoa ruokaa tarjoavista
huoltoasemista. Hän unohti alkuperäisen tavoitteensa ja ryhtyi selvittämään rekisteröitymistä.
Ongelman syy käyttöliittymässä? Neste 24 h -linkin otsikko vaikutti kuvaavammalta
asemien ruokailupalvelujen selvittämiseen kuin mikään linkeistä Karttapalvelut, Neste Oil –
asemahaku tai Neste Oil -asemaverkosto . <- HUOMAA: Kun arvioit ongelman syytä
käyttöliittymässä, älä lähde siitä, että ohjeita puuttuu tai että käyttöliittymään pitäisi lisätä
ohjetekstejä. Yritä löytää ongelman varsinainen syy (tai syitä).
Sari A. Laakso (2015)
Testitulokset
Testissä näkyviä oireita ongelmista
Mahdollisia oireita käyttöliittymän ongelmista:
Käyttäjä ei onnistu tekemään testitehtävää.
Käyttäjä luulee tehneensä tehtävän kokonaan, mutta
todellisuudessa suoritus on keskeneräinen tai lopputulos on väärä.
Käyttäjä tekee suorituksessa virheen, kuten syöttää dataa väärään
kenttään [Rubin94, s. 276], esim. etunimen sukunimikenttään, tai
hävittää erehdyksessä aiemmin luomaansa dataa, esim. unohtaa
tallentaa tiedoston.
Käyttäjä tekee epäoptimaalisia toimenpiteitä, jotka poikkeavat
odotetusta oikeasta suoritustavasta [vrt. Rubin94, s. 276].
Käyttäjä käynnistää turhaan väärän toiminnon, avaa väärän
ikkunan tai menee väärälle sivulle, mutta huomaa virheensä saman
tien ja korjaa sen (esim. sulkee ikkunan, painaa Back).
Käyttäjä epäröi pitkään jossakin vaiheessa tehtävän suoritusta,
mutta suorittaa lopulta tehtävän oikein. (Pitkän epäröinnin aikana
käyttäjää kannattaa muistuttaa ääneenajattelusta.)
Käyttäjä valittaa ääneen jostakin ongelmasta.
Antti
Sari A.
Latva-Koivisto,
Laakso (2015)
Sari A. Laakso (2006)
Sari A. Laakso (2015)
32
Simulointipohjainen käyttöliittymäsuunnittelu
Testitulokset
Ongelmien vakavuuden arviointi
1. Puuttuva toiminnallisuus: Käyttöliittymällä ei pysty suorittamaan
testitehtävää. Esim: Käyttäjä yritti tulostaa alennuskoodit tehdäkseen
niihin omia merkintöjään, mutta järjestelmästä ei voi tulostaa koodeja.
2. Epäonnistunut tehtävän suoritus: Testikäyttäjä ei pystynyt
suorittamaan tehtävää itsenäisesti tai luuli (virheellisesti) tehneensä
tehtävän jo. Esim: Käyttäjä luuli tehneensä tehtävän ja tuloksen olevan
tallessa, mutta hänen olisi pitänyt vielä painaa Update-painiketta.
3. Selvästi häiritsevä ongelma: Käyttäjä ei osannut toimia
optimaalisella tavalla tai hän valitti suullisesti järjestelmän olevan
hankala tai kömpelö. Esim: Käyttäjä sanoi, että on täysin älytöntä
kulkea kuuden näytön läpi, jotta saisi täytettyä kymmenen kenttää.
4. Melko häiritsevä ongelma: Käyttäjä sai tehtävän suoritettua
pitkällisten yritysten jälkeen. Esim: Käyttäjä yritti haun käynnistämistä
monella eri tavalla ennen kuin keksi näytöltä opasteen ja painoi F10.
5. Vähäinen ongelma: Käyttäjä löysi ratkaisun muutaman lyhyen
yrityksen jälkeen. Esim: Käyttäjä yritti käynnistää haun ensin enterillä,
mutta huomasi sitten painaa F10-näppäintä.
[Lauesen05, s. 12-13]
Antti
Sari A.
Latva-Koivisto
Laakso (2015)
(2006)
Kustannustehokas testaus
Videoidut käytettävyystestit suurilla käyttäjämäärillä ovat
kalliita ja vievät paljon aikaa. Muu projekti voi ehtiä edetä jo
pitkälle, kun testejä vasta analysoidaan.
Monesti yhden laajan testin sijaan kannattaa kerätä nopeasti
tietoa pahimmista ongelmista järjestämällä monta kevyttä ja
edullista testiä. Testien välillä korjataan pahimmat ongelmat.
Järjestä testejä esim. tavallisessa työhuoneessa tai neukkarissa.
Valitse 3-4 todellista käyttäjää, mutta älä koodaaja-työkavereita.
Laadi testitehtäviksi aitoja tilannekuvauksia.
Tee ongelmakohdista muistiinpanot testin kuluessa, ja pura
muistiinpanot heti testin jälkeen. Voit hoitaa testit yksinkin, mutta
jos mahdollista, pyydä työkaveria avuksi joko muistiinpanojen
tekijäksi tai testin ohjaajaksi.
Sari A. Laakso (2006)
(2015)
Sari A. Laakso (2015)
33
Simulointipohjainen käyttöliittymäsuunnittelu
Käyttötilanteet
Käyttötilanteita tarvitaan sekä
testitapauksiksi että käyttöliittymän
suunnittelun syötteeksi.
Testitapauksena oleva käyttötilanne
kuvaa käyttötilanteen
lähtöasetelman ja motiivit mutta ei
vielä järjestelmän käyttöä (mitä
käyttäjä tekee ja miten järjestelmä
reagoi), koska juuri tätä on tarkoitus
ryhtyä testaamaan. Käyttötilanne
virittää aina jonkin ongelman, jonka
ratkaisemisessa tietojärjestelmän on
tarkoitus auttaa.
Käyttötilanteet testitapauksina
Esimerkki: Matkahuolto ja VR
Hyvä testitapaus on riippumaton testattavasta
järjestelmästä: testitapauksessa ei kuvata vielä järjestelmän
käyttöön liittyviä tehtäviä tai toimenpiteitä, vaan käyttöä
edeltävää tilanneasetelmaa.
Seuraavassa esimerkissä testitapaukseksi on valittu todellinen
tilanne, jossa Marko oli menossa kummipoikansa
syntymäpäiville Turkuun ja yritti selvittää, miten pääsisi sinne.
Käyttötilanne: Kummipojan syntymäpäiville Turkuun
Marko, 27-vuotias ravintolakokki, on maanantai-iltana kotonaan
Helsingin Kalliossa osoitteessa Kolmas linja 23. Hän on menossa ensi
lauantaina 4-vuotiaan kummipoikansa syntymäpäiväjuhliin Turkuun.
Juhlat alkavat klo 14 kummipojan kotona Rauhankadulla, joka sijaitsee
Turun keskustassa rautatie- ja linja-autoaseman lähellä.
Testataan nyt käyttöä simuloimalla, miten hyvin Matkahuollon
ja VR:n sivustot tukevat Markon tilannetta.
Sari A. Laakso,
Laakso (2015)
Antti Latva-Koivisto (2006)
Sari A. Laakso (2015)
34
Simulointipohjainen käyttöliittymäsuunnittelu
VR:n ja Matkahuollon sivustojen simulointitestaus
Sivusiirtymät menomatkan aikataulujen selviämiseen asti
Matkahuolto
VR
1
2
3
1
Antti Latva-Koivisto, Sari A. Laakso (2006)
Käyttötilanteet testitapauksina
Lähtötilanne, ei järjestelmän käyttöä
Lähtötilanne pysyy samana, vaikka tehtävän suoritustapaa ja
käyttöliittymää muutetaan (vrt. brief scenario, [Hackos98, s. 324]).
Käyttötilanne…
kuvailee tilanteen, joka käyttäjien pitää pystyä hoitamaan
käyttöliittymän avulla, mutta
ei kuvaa sitä, miten käyttäjät tekevät tämän tehtävän nykyisellä
käyttöliittymällä (mitä toimintoja käynnistävät, mitä tietoja katsovat
käyttöliittymästä, missä järjestyksessä jne.).
Sari A. Laakso,
Laakso (2015)
Antti Latva-Koivisto (2006)
Sari A. Laakso (2015)
35
Simulointipohjainen käyttöliittymäsuunnittelu
Käyttötilanteet testitapauksina
Lähtötilanne, ei järjestelmän käyttöä
Lähtötilanne:
Petteri on yliopiston päärakennuksessa viimeistelemässä
konferenssipaperiaan kahden työkaverinsa kanssa. On jo ilta klo 21.15, ja
kaikilla alkaa olla hirveä nälkä. Kirjoittaminen on vielä ihan kesken, ja sen
kanssa näyttää menevän myöhään. Kellään ei ole mukana mitään
syötävää.
Ei järjestelmän käyttöä:
Petteri avaa hampurilaisravintolan tilauspalvelun ja valitsee 6
megaburgeria ja kolmet isot ranskalaiset. Sitten hän syöttää osoitteen ja
painaa tilauspainiketta. Näytön alareunaan ilmestyy viesti: ”Tilaus
lähetetty, saapuu puolen tunnin kuluttua.”
Testitapauksen sisältämä lähtötilannekuvaus on syöte
testaukselle.
Vasta testauksen aikana selvitetään, miten käyttäjä pääsee
tavoitteeseensa käyttöliittymän avulla. Käytön kuvaus on
siis testauksen tuotos.
Sari A. Laakso,
Laakso (2015)
Antti Latva-Koivisto (2006)
GDD:n käyttötilanteet
Ei päätöksiä ja kiinnitettyjä ratkaisuja
Lähtötilanne, jonka seassa on käyttäjän tekemiä päätöksiä ja
kiinnitettyjä ratkaisuja (alleviivattu):
Helsinkiläinen kardiologi Terhi on menossa kuuntelemaan ensi viikon
torstaina Turussa klo 12 alkavaa Urheilijan sydän –seminaaria. Hän on
katsonut Matkahuollon verkkopalvelusta bussien aikatauluja ja ostanut
liput. Koska seminaari alkaa klo 12, hän valitsi tarpeeksi varhaisen bussin,
joka lähtee Helsingistä jo klo 8. Seminaarin viimeinen esitys pidetään klo
17.15-17.45, joten hän päätyi klo 18.30 lähtevään bussiin. Lopuksi hän
tilasi ostamansa liput sähköpostiinsa ja tulosti ne myös paperille
varmuuden vuoksi. Hän tietää, että seminaaripaikka on keskustassa
osoitteessa Brahenkatu 10 noin viiden minuutin kävelymatkan päässä linjaautoasemasta.
Miten korjataan:
Siirrä tilanteen aktivoitumishetki niin varhaiseksi, ettei käyttäjä ole
vielä tehnyt päätöksentekoon tähtääviä toimenpiteitä (esim. ”on katsonut
bussien aikatauluja”, ”valinnut klo 6.42 lähtevän bussin”).
Poista kiinnitetyt ratkaisut (esim. lippujen tilaaminen sähköpostiin).
Sari A. Laakso (2015)
Sari A. Laakso (2015)
36
Simulointipohjainen käyttöliittymäsuunnittelu
GDD:n käyttötilanteet
Käyttäjän tavoite (motiivi)
GDD:n vaatimaan käyttötilannekuvaukseen sisältyy käyttäjän
tavoite (motiivi): mitä hän on yrittämässä tehdä ja miksi?
Testauksen kannalta ei ole juurikaan merkitystä, mikä motiivi
tilanteessa on, kunhan se on realistinen ja riittävän tyypillinen.
Jos motiivi puuttuu, testaaja ei pysty ottamaan huomioon
tilanteeseen tyypillisesti vaikuttavia tekijöitä. Tästä seuraa, ettei
testauksella saada esiin kaikkia keskeisiä, todellisessa tilanteessa
eteen tulevia ongelmia. Esimerkki:
Käyttötilanne: Ensi viikon torstaina Turkuun
Helsinkiläinen kardiologi Terhi on menossa ensi viikon torstaina
Turkuun. Perillä pitää olla klo 12, ja paluu on klo 18.
Puuttuvan motiivin takia aikatauluhaun testauksesta menisi
ongelmitta läpi huono käyttöliittymäratkaisu, joka näyttäisi kerralla
vain ensimmäisen paluubussin (esim. klo 18 lähtevän), vaikka
monissa todellisissa tilanteissa Terhin kannattaisikin valita
myöhemmin (esim. klo 18.30 tai klo 19) lähtevä bussi.
Antti
Sari A.
Latva-Koivisto,
Laakso (2015)
Sari A. Laakso (2006)
GDD:n käyttötilanteet
”Käyttäjä haluaa” -ongelma
Testitapausta laatiessa kannattaa
välttää ylimalkaista ilmausta
”Käyttäjä haluaa/haluaisi/tahtoo”,
koska tällöin testitapauksen motiivi
jää epäselväksi eivätkä kaikki
todellisen tilanteen ongelmat tule
esille (vrt. edellinen kalvosivu).
Koska testitapauksesta ei selviä,
mihin haluaminen perustuu, osa
”haluamisesta” voi olla
epärealistista tai koko testitapaus
voi osoittautua virheelliseksi tai niin
epätyypilliseksi, ettei sillä kannata
testata.
Haluamisen takana olevan
informaation saat esille yleensä
kysymällä ”miksi”.
Ei käyttäjän haluamista:
Helsinkiläinen kardiologi Terhi on
menossa ensi viikon torstaina
Turkuun. Hän haluaa olla perillä
klo 12 ja haluaa lähteä takaisin
klo 18.
Kuvaa tilannetta ja syitä
haluamisen takana:
Helsinkiläinen kardiologi Terhi on
menossa ensi viikon torstaina
kuuntelemaan Turussa klo 12
alkavaa Urheilijan sydän –
seminaaria, joka alkaa
liikuntalääketieteen
erikoislääkärin tilannekatsauksella
(klo 12-13). Päivän viimeinen
esitys pidetään klo 17.15-17.45...
Sari A. Laakso (2006)
(2015)
Sari A. Laakso (2015)
37
Simulointipohjainen käyttöliittymäsuunnittelu
Käyttötilanteiden kerääminen
haastatteluilla
GDD:ssä käyttäjähaastattelujen tarkoituksena on kerätä pelkästään
konkreettisia tilanneasetelmia, joissa näkyy motiivi ja käyttäjän
keskeinen tietämys tai puuttuva tietämys. (Samalla tavalla kerätyt
tilanteet sopivat myös käytettävyystestauksen tai muiden
arviointimenetelmien syötteeksi.)
Keskeisin vaikeus haastatteluissa: käyttäjät yleistävät asioita.
He yrittävät puhua kaikkien käyttäjien puolesta sen sijaan, että he kertoisivat
omista kokemuksistaan.
He tekevät yhteenvetoja aiemmin sattuneista tilanteista tai kertovat niistä
niin yleisellä tasolla, ettei kertomuksista saa aikaan käyttötilannekuvauksia.
Haastattelijan tulee houkuttaa käyttäjä konkretisoimaan:
Kohdenna kysymys konkreettiseen tapahtumaan: “Milloin sinulle viimeksi
kävi niin? Mitä silloin tapahtui? …”
Jos haastateltava ei anna esimerkkejä, kannattaa itse laatia nopeasti
esimerkki ja pyytää häntä korjaamaan keksittyä esimerkkiä.
Sari A. Laakso (2015)
GDD:n käyttäjähaastattelut
Käyttäjä välttelee esimerkkejä
Haastattelija kysyy liian yleisesti eikä saa mitään selville:
Käytätkö usein yliopiston verkkosivuja? Mihin tarkoitukseen?
”Kyllä minä oikeastaan aika usein katson erilaisia ammattiasioita
yliopiston sivuilta.”
Millaisia ammattiasioita?
”Aivan kaikenlaisia.”
Antaisitko esimerkin?
”No siis ne voivat olla aivan mitä tahansa.”
Kertoisitko yhden?
”Se riippuu ihan tilanteesta.”
Millä tavalla se riippuu tilanteesta?
”Jollain viikolla voi olla kiire ja silloin en välttämättä käytä
ollenkaan… Joskus kun on vähän tyhjää aikaa, rupean selvittämään
sitten jotain käytännön asiaa.”
Millaista käytännön asiaa?
”Sellaista, mikä olisi hyvä hoitaa mutta on jäänyt...”
Sari A. Laakso (2015)
Sari A. Laakso (2015)
38
Simulointipohjainen käyttöliittymäsuunnittelu
GDD:n käyttäjähaastattelut
Haastattelija houkuttaa konkretiaan
Haastattelija kohdistaa kysymyksen äskettäiseen hetkeen:
Käytätkö usein yliopiston verkkosivuja? Mihin tarkoitukseen?
”Kyllä minä oikeastaan aika usein katson erilaisia ammattiasioita
yliopiston sivuilta.”
Milloin viimeksi katsoit jotakin ammattiasiaa verkosta?
”Taisi olla eilen...”
Mitä katsoit?
”Henkilöstöhallinnon sivuja.”
Mitä etsit sieltä?
”Että mitä liitteitä virkahakemuksessa pitää olla ja milloin on
deadline.”
Miksi?
”No joo, siis... Laitoksella on assistentin virka auki ja olen miettinyt,
että voisin hakea...” jne. [Nyt haastattelija pääsee selvittelemään
ensimmäistä konkreettista tilannetta.]
Sari A. Laakso (2015)
GDD:n käyttäjähaastattelut
Unicafe-esimerkki
Kun olet päässyt kiinni esimerkkitilanteeseen (”Milloin viimeksi…?”),
jatka selvittämällä, miksi ko. henkilö teki niin kuin teki (motiivi).
Esimerkki: Unicafe-käyttäjähaastattelu verkkosivujen kehittämiseksi
Milloin viimeksi olet syönyt Unicafessa? Missä? <- KIINNI TILANTEESEEN
Miksi menit sinne? <- ALETAAN HAKEA MOTIIVIA
Mitä teit juuri sitä ennen? Missä olit? Miksi? <- MOTIIVIN HAKU JATKUU
Minne olit sen jälkeen menossa? Miksi?
Seuraavalla sivulla on esimerkki käyttäjältä selvitetystä Unicafetilanteesta (alkuperäisen tilanteen selvittäjä on Joonas Gustafsson, 2004;
editoitu luentomateriaaliin sopivaksi).
Huomaa, että todellisessa tilanteessa kyseinen haastateltava oli vain
yksinkertaisesti kävellyt Ylioppilasaukion Unicafehen ja katsonut siellä
ruokalistaa ja valinnut sieltä parhaan tai vähiten huonon vaihtoehdon.
Käyttötilannekuvauksessa ei kiinnitetä toteumaa ja juututa siihen, esim.
käyttäjä tietää Ylioppilasaukion ja menee sinne. Käyttöliittymän
suunnittelussa GDD:llä selvitetään ensiksi, minne käyttäjän tässä
tilanteessa olisi oikeasti kannattanut mennä (saattaa olla eri kuin
Ylioppilasaukio).
Sari A. Laakso (2015)
Sari A. Laakso (2015)
39
Simulointipohjainen käyttöliittymäsuunnittelu
Unicafe-esimerkki
Joonas Gustafsson, 2004 (lyhennelmä)
Kt 1: Lounasta ennen leffaa
Mikon tavoite 1: Mikko on kaverinsa
kanssa menossa Kinopalatsiin katsomaan
13.30 alkavaa Super Size Me -elokuvaa.
Minne Mikon oikeasti kannattaisi mennä?
Millä perusteella pystyy valitsemaan?
Mikon tavoite 2: Mikko ei ole syönyt
vielä aamupäivällä mitään. Hän on
tottunut käymään keskustassa erityisesti
Ylioppilasaukion ruokalassa. Hän ei
kuitenkaan tiedä, onko siellä tänään
mitään erityisen hyvää pöperöä.
Tilatietoja:
Nyt on ke 20.10. klo 12.15. Mikko on
lähdössä kotoaan Leppävaarasta.
Leffa alkaa Kinopalatsissa klo 13.30.
Ylioppilasaukion Unicafen ruokalista:
Broilerperhonen, lämmin kasvis
Uunilohta valkoviinissä
Broileria hunaja-sinappikastikkeessa
Soijabolognese-spagetti
Sari A. Laakso (2015)
(2006)
Rautatieasema
Kinopalatsi
Käyttöliittymän suunnittelu
Käyttöliittymän systemaattista tuottamista on
toistaiseksi tutkittu varsin vähän. Esimerkkejä
systemaattisista suunnitteluprosesseista ovat
mm. Lauesenin ja Cooperin prosessit sekä
Carrollin skenaariopohjainen suunnittelu.
Tällä kurssilla käsitellään Interacta Designissa
ja Helsingin yliopiston tietojenkäsittelytieteen
laitoksella kehitettyyn GUIDe-malliin sisältyvää
simulointipohjaista GDD-suunnitteluprosessia
(lisätietoja: Sari A. Laakso, salaakso@cs.helsinki.fi),
jossa on yhtymäkohtia kaikkien edellä
mainittujen prosessien kanssa.
Sari A. Laakso (2015)
40
Simulointipohjainen käyttöliittymäsuunnittelu
Erilaisia suunnitteluprosesseja
Lauesen, Carroll ja Cooper
Hyvien käyttöliittymäratkaisujen syntymistä ja systemaattista
luomista on tutkittu todella vähän. Tällä hetkellä
kirjallisuudessa kuvattuja menetelmiä ovat lähinnä seuraavat:
Søren Lauesenin järjestelmällisesti etenevässä Virtual Windows menetelmässä [Lauesen01, Lauesen05] käyttöliittymä suunnitellaan
ensin pelkän tietosisällön avulla ja toiminnallisuus lisätään
näyttökuviin vasta suunnittelun loppuvaiheessa.
Scenario-Based Design [Carroll00] -menetelmässä käyttöliittymää
suunnitellaan kirjoittamalla tekstimuotoisia skenaarioita eli tarinoita
siitä, miten kuviteltu käyttäjä toimisi järjestelmän kanssa.
Alan Cooperin Goal-Directed Design [Cooper03] –menetelmässä
kuvataan tulevia käyttäjiä ja heidän korkean tason tavoitteitaan.
Sen jälkeen näiden käyttäjien näkökulmasta kirjoitetaan
tekstimuotoisia käyttöskenaarioita, joiden sisältämät tiedot ja
toiminnot lopulta organisoidaan käyttöliittymän näkymiksi ja
komponenteiksi.
Copyright
Sari
A. Laakso,
Laakso
© 2006
(2015)
Antti
/ Antti
Latva-Koivisto
Latva-Koivisto
(2006)
Erilaisia suunnitteluprosesseja
Lauesenin Virtual Windows
Lauesenin Virtual Windows –menetelmässä käyttöliittymä
suunnitellaan ensin pelkän tietosisällön avulla, ja toiminnot
lisätään vasta suunnittelun loppuvaiheessa.
Ensin selvitetään käyttäjän tehtävät (tasks), jotka järjestelmällä
pitäisi voida tehdä, ja niistä kirjoitetaan tekstimuotoiset kuvaukset.
Sitten tietosisältö jaetaan ns. virtuaali-ikkunoihin simuloimalla
käyttäjän tehtäviä ja soveltamalla Lauesenin antamia
suunnittelusääntöjä. Tietosisältöä voidaan katsoa tässä vaiheessa
myös esimerkiksi tietomallin kuvauksesta.
Virtuaali-ikkunoista piirretään visualisoituja oikean näköisiä
näyttökuvia. Näissä graafisissa virtuaali-ikkunoissa ei kuitenkaan
ole vielä lainkaan toimintoja eikä niitä ole sovitettu mahtumaan
lopulliseen näyttökokoon (voivat olla liian pieniä tai isoja näytölle).
Lopuksi virtuaali-ikkunoihin lisätään toiminnot ja virtuaali-ikkunat
sovitetaan lopulliseen näyttökokoon. Tämä tehdään taas
simuloimalla käyttäjän tehtäviä.
Antti
Sari A.
Latva-Koivisto,
Laakso (2015)
Sari A. Laakso (2006)
Sari A. Laakso (2015)
41
Simulointipohjainen käyttöliittymäsuunnittelu
Erilaisia suunnitteluprosesseja
Carrollin skenaariomenetelmä
Carrollin skenaariomenetelmässä [Carroll00] käyttöliittymää
suunnitellaan ensisijaisesti tekstimuodossa, ja siirtyminen
tekstiskenaarioista näyttökuviin jää osin avoimeksi.
Aluksi tehdään skenaarioiden laatimisen pohjaksi kenttätutkimusta:
käyttäjien haastatteluja ja heidän nykyisen toimintansa tarkkailua.
Tekstimuotoisten skenaarioiden avulla tehdään rinnan
käyttöliittymäsuunnittelua ja työnkulkujen uudelleensuunnittelua.
Käyttäjän työnkulun etenemistä ja käyttöliittymän toimintalogiikkaa
ideoidaan ja kuvataan skenaarioina, joita kirjoitetaan moneen
kertaan (iteratiivinen suunnittelu). Käyttöliittymän tietosisältöä tai
toiminnallisuutta ei systemaattisesti visualisoida näyttökuvina, kuten
Lauesenin prosessissa, mutta apuna voidaan käyttää kuviakin.
Kun skenaarioiden kirjoittamisen yhteydessä tulee esille erilaisia
suunnitteluratkaisuja, niitä verrataan ns. väittämillä (claims).
Väittämiin kirjataan ratkaisuvaihtoehtojen hyvät ja huonot puolet,
jotta niitä voidaan verrata keskenään.
Sari A. Laakso,
Laakso (2015)
Antti Latva-Koivisto (2006)
Erilaisia suunnitteluprosesseja
Cooperin Goal-Directed Design
Cooperin Goal-Directed Design -menetelmässä [Cooper03, s.
16-20, 39-90] kuvataan tulevia käyttäjiä ja heidän tavoitteitaan
sekä laaditaan keskeisimmistä tilanteista skenaariokuvauksia.
Aluksi tehdään tulevista käyttäjistä ns. persoonakuvauksia mm.
käyttäjähaastattelujen ja –tarkkailujen perusteella. Jokaiselle
persoonalle selvitetään/luodaan korkean tason tavoitteet.
Seuraavaksi laaditaan käyttöskenaarioita (context scenarios)
hieman vastaavaan tapaan kuin Carrollinkin menetelmässä.
Skenaariossa kuvataan käyttäjän kannalta mahdollisimman hyvä
toteuma tulevalla järjestelmällä, mutta se myös kiinnittää jo
karkealla tasolla uuden järjestelmän toimintoja ja käyttöliittymän
suunnitteluratkaisuja.
Skenaarioista tulkitaan käyttöliittymässä tarvittavat toiminnot ja
tiedot. Sen jälkeen ne organisoidaan käyttöliittymän näkymiksi ja
paneeleiksi ”top-down” eli aloittaen karkeista näkymistä ja siirtyen
vähitellen kohti näytön yksityiskohtia.
Antti
Sari A.
Latva-Koivisto,
Laakso (2015)
Sari A. Laakso (2006)
Sari A. Laakso (2015)
42
Simulointipohjainen käyttöliittymäsuunnittelu
Suunnitteluprosessin valinta
Lopputulos testataan käyttötilanteilla
Kaikille suunnittelumenetelmille yhteistä on se, että niiden
tuottama lopputulos aina viime kädessä testataan todellisilla
käyttötilanteilla, kun järjestelmä otetaan käyttöön ja käyttäjät
ryhtyvät ensimmäistä kertaa tekemään sillä todellista työtään.
Kaikki edellä kuvatut prosessit ottavat suunnittelussa huomioon
käyttäjien työtehtävät tai käyttäjille eteen tulevat
käyttötilanteet.
(Käyttäjien työnkulkuja optimoivat ainakin GDD-prosessi,
Carrollin skenaariomenetelmä sekä Cooperin prosessi.)
Sari A. Laakso (2006)
(2015)
Suunnitteluprosessin valinta
Käyttöliittymäratkaisun kiinnitys
Käyttöliittymäratkaisun kiinnittäminen eri menetelmissä:
Carrollin skenaariomenetelmässä ja Cooperin prosessissa
käyttöliittymän tietosisältöä ja toimintalogiikkaa kiinnitetään
tekstimuodossa skenaarioiden avulla.
Lauesenin Virtual Windowsissa ja GDD-prosessissa tietosisältö ja
toimintalogiikka kiinnitetään piirtämällä näyttöjä.
• Virtual Windowsissa kiinnitetään ensiksi tietosisältö, lopuksi toiminnot.
• GDD-prosessissa kiinnitetään sekä tietosisältö että toiminnot yhtä aikaa.
Käyttöskenaarioiden ja näyttökuvien etuna on se, että
järjestelmän vaatimuksia voidaan arvioida/testata jo varhain.
Skenaarioiden avulla käyttäjät saavat paremmin selville todellisia
tarpeitaan, koska he voivat simuloida järjestelmän toimintaa
mielessään [Go04]. Suunnittelijat voivat arvioida skenaarioiden
avulla suunnitteluratkaisuja ja paikantaa ongelmakohtia [Carroll94].
Näyttökuvien avulla järjestelmän toimintaa ja tietosisältöä voidaan
testata varhaisessa vaiheessa (esim. simulointitestaus tai
käytettävyystestaus).
Sari A. Laakso (2006)
(2015)
Sari A. Laakso (2015)
43
Simulointipohjainen käyttöliittymäsuunnittelu
GUIDe-malli ja
GDD-suunnitteluprosessi
GUIDe-malliin sisältyvä simulointipohjainen
GDD (Goal-Derived Design) on kehitteillä
oleva, joissain yrityksissä käyttöön sovellettu
käyttöliittymän suunnitteluprosessi (lisätietoja:
Sari A. Laakso, salaakso@cs.helsinki.fi).
GDD:ssa kantavana ajatuksena on käyttää
suunnittelussa samaa menettelyä kuin
testauksessa ja järjestelmän todellisessa
käytössä: käyttöliittymä suunnitellaan
käyttötilanneasetelmien pohjalta.
Tällä kurssilla opetellaan GDD-prosessista
yksinkertaistettua versiota, jossa mm.
tavoitepohjaiset käyttötapaukset on korvattu
yksinkertaisemmilla käyttötilannekuvauksilla.
GUIDen ja GDD:n periaatteet
Vaiheet ja idea
GUIDe-malli (Goals – User Interface Design – Implementation) [Laakso04]
määrittelee rungon vaatimusten kartoittamiselle ja
käyttöliittymän laatimiselle. Se rakentuu kolmesta karkeasta
vaiheesta:
käyttötilanteiden kerääminen vaatimuksiksi,
käyttöliittymäratkaisun generointi simulointipohjaisella
menetelmällä (Goal-Derived Design, GDD) sekä
3. käyttöliittymän ja sen vaatiman toiminnallisuuden ohjelmoiminen
em. vaiheiden jälkeen. Järjestelmää voidaan alkaa toteuttaa mitä
tahansa prosessia noudattaen, esim. XP:n tai Scrumin pohjalta.
1.
2.
GUIDe ja GDD perustuvat käyttötilannelähtöiseen
suunnitteluun.
Sari A. Laakso (2015)
Sari A. Laakso (2015)
44
Simulointipohjainen käyttöliittymäsuunnittelu
GUIDen ja GDD:n periaatteet
GUIDen päävaiheet
Käyttötilanteiden kerääminen
Aluksi selvitetään kenttätutkimusten avulla käyttötilanteet, joita on tarkoitus
tukea järjestelmän avulla. Nykykäytännöistä erotellaan niiden takana olevat
tavoitteet ja ongelman virittämä ristiriita.
Käyttötilanteet kategorisoidaan siten, että saman datan organisoinnin
virittämät tilanteet niputetaan yhteen. Suunnitteluun valitaan näistä
edustavat instanssit ja tarvittavat variaatiot.
Käyttöliittymäratkaisun generointi simuloimalla
Simuloitavaksi valitaan kerrallaan yksi käyttötilanne, jota ryhdytään
piirtämään auki käyttöliittymäksi (tietosisältö ja toiminnot). Piirtämisen
aikana kiinnitetään käyttötilanteelle mahdollisimman suoraviivainen
minimaalinen toteuma: sekä käyttöliittymäratkaisu että työnkulku.
Päätöksentekodata näytetään kerralla, ja käyttäjältä vaaditut säätämistoimet
tämän näkymän esille saamiseksi minimoidaan. Tehokkuus optimoidaan.
Kun muutaman käyttötilanteen suorittaminen ja niissä tarvittu
toimintalogiikka ja tietosisältö on piirretty samaan käyttöliittymään, viriää
mahdollisesti refaktorointitarve. Refaktorointi tähtää yksinkertaisempaan
ratkaisuun, joka kuitenkin virittyy samoista käyttötilanteista.
Sari A. Laakso (2015)
GUIDen ja GDD:n periaatteet
Vaatimusten selvittäminen
GUIDen kahden ensimmäisen vaiheen sisällä on samoja piirteitä kuin mm.
ketterässä ohjelmistokehityksessä: valitaan käyttötilanteita ja piirretään
niitä vastaavaa käyttöliittymäratkaisua yksi tilanne kerrallaan, vrt.
esim. käyttäjätarinat.
testivetoisessa kehityksessä (Test-Driven Development, TDD):
suunnittelu pohjautuu samoihin käyttötilanteisiin, jotka ovat myös
testitapauksia; tosin GUIDessa ne kategorisoidaan tietyllä tavalla ennen
suunnittelun aloittamista.
Lean-ohjelmistokehityksessä: sekä käyttöliittymäratkaisussa että
suunnitteluprosessissa tavoitellaan minimaalista ratkaisua, josta kaikki
roska (waste) on eliminoitu.
Sari A. Laakso (2015)
Sari A. Laakso (2015)
45
Simulointipohjainen käyttöliittymäsuunnittelu
GUIDen ja GDD:n periaatteet
Asiakkaan rooli
Yleensä asiakas osaa antaa tietoa saatujen käyttötilanteiden
selvittämistä, priorisointia ja järjestelmän rajaamista varten.
Asiakkaan edustajalta saadaan tietoa keskeisistä kohderyhmistä, joilta
käyttötilanteita kartoitetaan, ja hän pystyy hankkimaan kontakteja näiden
edustajiin. Hänellä saattaa olla tietoa siitä, miksi tiettyä käyttötilannetta tulisi
tukea tai miksi ei, tai tuetaanko ko. tilannetta nyt vai myöhemmin.
Asiakasta autetaan tämän tietämyksen käyttöön ottamiseksi, jotta hän voisi
tehdä oman liiketoimintansa kannalta mahdollisimman hyviä päätöksiä.
Sen sijaan GUIDessa oletaan, että tyypillisesti asiakas ei voi osata
selvittää ja kategorisoida käyttötilanteita (selvitämme nämä hänelle) eikä
laatia siirtymää valituista käyttötilanteista mahdollisimman optimaaliseen,
niitä tukevaan käyttöliittymäratkaisuun (teemme sen hänelle).
Tällä kurssilla opetellaan erityisesti näkemään tätä yhteyttä
käyttötilanteiden ja käliratkaisun välillä, koska se on
kriittinen taito, jonka hankkiminen vaatii vaivannäköä ja
harjoittelua. Myös käyttötilanteiden selvittäminen helpottuu
heti, kun tämä suunnittelutaito kehittyy.
Sari A. Laakso (2015)
GUIDen ja GDD:n periaatteet
Muuttuvat vaatimukset/käli
Ketterässä kehityksessä
(ilman GUIDea):
Vaatimukset ovat asiakkaan
vastuulla.
Muuttuvia vaatimuksia pidetään
normaalina ilmiönä, ja ne otetaan
vastaan osana ohjelmiston
kehitysprosessia.
Asiakkaalta saadut muutokset
tehdään toimivaan ohjelmaan.
GUIDessa:
Vaatimusten selvittäminen on
käyttöliittymätiimin vastuulla, ja
asiakas toimii avustavan
asiantuntijan roolissa.
Vaatimusten muuttuminen
nähdään pääosin illuusiona, joka
syntyy siitä, ettei kukaan pyri
selvittämään (tai osaa selvittää)
niitä systemaattisesti, jolloin ne
näyttävät muuttuvan.
Käyttöliittymä muuttuu
käyttötilanteiden pohjalta kälin
suunnitteluvaiheessa, eikä mitään
vielä ohjelmoida.
Sari A. Laakso (2015)
Sari A. Laakso (2015)
46
Simulointipohjainen käyttöliittymäsuunnittelu
GUIDen ja GDD:n periaatteet
Muuttuvat vaatimukset/käli
GUIDessa muutoksia vaatimuksiin tulee,
jos jonkin osapuolen jokin keskeinen käyttötilanne on epähuomiossa jäänyt
selvittämättä (=selvitystyössä tapahtunut virhe/puute), tai
jos asiakkaan liiketoimintamalli muuttuu (esim. lounasravintola päättääkin
alkaa toimittaa ruokia myös kotiinkuljetuksella, tai lastentarvikekauppa
ryhtyykin vuokraamaan hoitovälineitä myymisen sijaan).
GUIDessa muuttuvien vaatimusten määrä minimoidaan.
Jäljelle jäävät vain ne muutokset, jotka johtuvat inhimillisen virheen
korjaustarpeesta tai joita olisi ollut mahdotonta saada selville etukäteen.
Muutoksia ei synny siitä, että asiakas ei alussa tiedä riittävän täsmällisesti,
mitä hän haluaa, tai siitä, että hän tietää paremmin vasta sitten, kun näkee,
mihin hänen vaatimuksensa on johtanut. GUIDessakin tätä pidetään
”normaalina” lähtötilanteena, mutta se ratkaistaan selvitystyöllä.
GDD-prosessilla tuotettu käyttöliittymäratkaisu voi muuttua,
jos joku onnistuu löytämään vielä suoraviivaisemman ratkaisun kuin se, jonka
suunnittelija osasi optimoida käyttötilanteiden pohjalta
(=käyttöliittymäsuunnittelijan inhimillinen virhe/puute).
Sari A. Laakso (2015)
Käyttöliittymän piirtäminen
GDD:lla
Suunnitteluun otetaan yksi käyttötilanne
kerrallaan.
Vain käsillä olevaan tilanteeseen liittyvää
tietosisältöä ja toimintoja piirretään näkyviin
tehokkuutta optimoiden. Mieleen tulevat
muut toiminnot, ideat, uhkat ja huolet
kirjataan muistiin ongelmalistalle ja
sivuutetaan.
Näyttökoko oletetaan rajattoman suureksi.
Usein kynällä paperille piirtäminen on nopein
tapa tässä vaiheessa: suunnittelijan
kognitiiviset resurssit kohdistuvat
ensisijaisesti vaikeimpaan älylliseen työhön.
Sari A. Laakso (2015)
47
Simulointipohjainen käyttöliittymäsuunnittelu
Kälin piirtäminen GDD:lla
Suunnitteluperiaatteet 1-7
Käytä simuloinnin aikana seuraavia suunnitteluperiaatteita:
1.
Vain tässä käyttötilanteessa tarvittavat tiedot ja toiminnot
piirretään käyttöliittymään, ei mitään muuta. Loput ongelmalistalle.
2.
Kaikki tiedot ja käyttöliittymän osat näytetään kerralla – sen
sijaan, että järjestelmä pihtaa niitä ja käyttäjä pyytelee.
3.
Käyttäjä pysyy yhdessä näkymässä koko ajan – sen sijaan, että
hän kuljeksii järjestelmässä ympäriinsä näytöltä toiselle.
4.
Käyttäjä säätää näkymää ja järjestelmä reagoi ”lennossa”.
5.
Editointi paikallaan: Käyttäjä editoi tökkäsemällä suoraan sinne,
missä kohde näkyy.
6.
Päätöksentekoa simuloitaessa käyttäjän tulee osua vähintään
kolmeen relevanttiin vaihtoehtoon: käyttäjä punnitsee näitä
keskenään ja arvioi, mikä olisi paras tässä tilanteessa. Käyttäjälle
tulee eteen myös huonoja vaihtoehtoja, jotka hän jättää sivuun.
7.
[Valmiit ratkaisumallit (design patterns). Vähitellen suunnittelija
alkaa tunnistaa simuloinnissa toistuvia, hyviä ratkaisumalleja.]
Sari A. Laakso (2015)
Kälin piirtäminen GDD:lla
Suunnitteluperiaatteiden toiminta
Suunnitteluperiaate 1 varmistaa, ettei järjestelmään synny ylimääräisiä
tietoja tai toimintoja, joita ei tarvita missään käyttötilanteessa. Lisäksi
sillä pyritään varmistamaan, että tarvittavat toiminnot ja tietosisältö on
suunniteltu aina niitä hyödyntävien käyttötilanteiden näkökulmasta eikä
yleisesti ripottelemalla ympäri järjestelmää (jolloin alkaa syntyä pitkiä
vaivalloisia polkuja ja tehokkuus heikentyy).
Suunnitteluperiaatteilla 2-5 pyritään optimoimaan mekaanista
tehokkuutta jättämällä kaikki tarpeettomat suoritusvaiheet pois.
Periaatteella 6 optimoidaan päätöksentekokohtien kognitiivista
tehokkuutta (joskin samalla saadaan optimoitua myös näiden kohtien
mekaaninen tehokkuus). Käyttäjältä pyritään poistamaan tarpeeton,
tietojärjestelmän käytöstä syntyvä kognitiivinen työ, joka kuormittaa ja
häiritsee varsinaista päätöksentekoa. Tarkoitus on vapauttaa
mahdollisimman paljon kognitiivisia resursseja itse päätöksen
prosessointiin.
Sari A. Laakso (2015)
Sari A. Laakso (2015)
48
Simulointipohjainen käyttöliittymäsuunnittelu
Kälin piirtäminen GDD:lla
Simulointi lyhyesti (tälläkin pärjää)
Ota käyttötilanne 1 ja piirrä sen suorittaminen mahdollisimman
suoraviivaisesti paperille siten, että noudatat annettuja
suunnitteluperiaatteita, jotka auttavat optimoimaan tehokkuutta.
Lopuksi simuloi tilanne alusta loppuun vielä pari kertaa
yksityiskohtaisesti ja yritä poistaa turhia toimenpiteitä tai kognitiivista
työtä, jos sellaisia ongelmia on ratkaisuun jäänyt.
Ota käyttötilanne 2 ja yritä simuloida sen suorittaminen olemassa
olevalla käyttöliittymällä samoin kuin edellä. Tee tarvittavat muutokset
ja simuloi pariin kertaan. Lopuksi simuloi käyttötilanne 1, jotta voit
korjata, jos se meni rikki.
Ota käyttötilanne 3 ja yritä simuloida se edellisten sekaan. Tee
tarvittavat muutokset. Simuloi edelliset uudelleen.
Ota käyttötilanne 4 jne.
Sari A. Laakso (2015)
Kälin piirtäminen GDD:lla
Simulointi päätöksentekolähtöisesti
Tässä kuvataan 3-vaiheinen simulointitapa, jossa käyttötilanteen
päätöksentekonäkymä rakennetaan aina ensin. Käytä annettuja
suunnitteluperiaatteita.
Vaiheet:
1. Aloita piirtämällä käyttötilanteen keskeltä pelkkä
päätöksentekonäkymä.
2. Piirrä puuttuva alkupää: Piirrä käyttäjältä vaadittavat toimenpiteet
järjestelmän alkutilasta em. päätöksentekonäkymään.
3. Piirrä puuttuva loppupää: Piirrä käyttäjältä vaadittavat
toimenpiteet päätöksentekonäkymästä käyttötilanteen
suorittamisen loppuun asti.
Sari A. Laakso (2015)
Sari A. Laakso (2015)
49
Simulointipohjainen käyttöliittymäsuunnittelu
Kälin piirtäminen GDD:lla
Vaihe 1: Päätöksentekonäkymä
Piirrä käyttötilanteen 1 päätöksentekonäkymä näkyviin vertailussa
tarvittavan tietosisällön osalta: mitä tietoa kohteista näytetään ja
miten, jotta käyttäjä voisi vertailla relevantit vaihtoehdot ja päätyä
parhaaseen lopputulokseen.
Kun valitset tietosisältöä ja sijoitat sitä näytölle, simuloi jatkuvasti käyttäjän
toimintaa: mitä sellaista tietoa hän lukee, mikä vaikuttaa hänen
päätöksentekoonsa. Sijoita näytölle ainoastaan tällaista tietosisältöä (sitä,
mikä merkittiin simulointitestauksessa vertailumerkinnöillä).
Kiinnitä erityistä huomiota suunnitteluperiaatteeseen 6: Päätöksentekoa
simuloitaessa käyttäjän tulee osua vähintään kolmeen relevanttiin
vaihtoehtoon: käyttäjä punnitsee näitä keskenään ja arvioi, mikä olisi paras
tässä tilanteessa. Käyttäjälle tulee eteen myös huonoja vaihtoehtoja, jotka
hän jättää sivuun.
Käytä realistista dataa, jota tulee olla realistisen suuri määrä.
Lähtökohtaisesti mitään toiminnallisuutta ei tarvita. Vasta kun jonkin
toiminnon tuottama mekaaninen työ on ainoa keino vähentää
kognitiivista työtä, lisää ko. toiminto (esim. vertailukori hyvien
vaihtoehtojen poimimiseksi, mahdollisuus merkitä hylättyjä
vaihtoehtoja visuaalisesti, …).
Sari A. Laakso (2015)
Kälin piirtäminen GDD:lla
Vaihe 2: Alkutilasta päätöksentekoon
Kun vaiheen 1 päätöksentekonäkymä on valmis, piirrä järjestelmän
alkutila erilliselle paperille (kyseessä on sama näyttö, eri tila).
Koska teit vaiheessa 1 ensimmäisen käyttötilanteen päätöksentekonäkymän,
tutki ensin, voisiko ko. näkymä olla suoraan järjestelmän alkutila, jolloin ei
tarvittaisi mitään toiminnallisuutta tämän säätämiseksi näkyviin. Huomaa
kuitenkin, että järjestelmä ei voi ”arvata”, mitkä kohteet juuri tämä käyttäjä
tässä käyttötilanteessa tarvitsisi (esim. mitkä kirjaston kirjat tai mitkä
autokaupan autot). Järjestelmä ei saa toimia maagisesti tai
epädeterministisesti.
Näytä alkutilassa maksimaalisen paljon sellaista dataa, josta käyttäjälle on
hyötyä juuri tässä tilanteessa.
Laadi minimaalinen joukko toimenpiteitä, joiden avulla käyttäjä pystyy
säätämään alkutilasta esille vaiheen 1 päätöksentekonäkymän.
Pidä käyttäjä koko ajan ”samassa paikassa” ja anna hänen vain säätää
näkymää (suorakäsittely, vrt. Direct Manipulation, esim. [Shneiderman98]).
Vältä navigointitarvetta viimeiseen asti.
Sari A. Laakso (2015)
Sari A. Laakso (2015)
50
Simulointipohjainen käyttöliittymäsuunnittelu
Kälin piirtäminen GDD:lla
Vaihe 3: Päätöksenteosta loppuun
Piirrä minimaalinen joukko toimenpiteitä, jotka tarvitaan
käyttötilanteen loppuun saattamiseksi päätöksenteon jälkeen
(esim. tilauksen lähettäminen, tuki paikan päälle pääsemiseksi).
Simuloi käyttötilanteen suorittamisen loppuhäntä (esim. miten
käyttäjä osaa kävellä bussipysäkiltä perille lomahotelliinsa tai
messupaikalle).
Sari A. Laakso (2015)
Kälin piirtäminen GDD:lla
Seuraavat käyttötilanteet
Kun valitset variaatioita samasta tilanteesta:
Kokeile ensin, onnistuuko variaation simulointi suoraan edellisten
tilanteiden tuottamalla käyttöliittymällä. Jos ei, laadi tarvittavat
minimaaliset muutokset tietosisältöön ja toiminnallisuuteen.
Kun valitset aidosti eri kategorian käyttötilanteen:
Kun mukaan tulee eri kategorian käyttötilanne, siitä seuraa erilainen
datan organisointi eli selvästi toisenlainen päätöksentekonäkymä kuin
aiemmin piirtämäsi näkymät.
Piirrä ensin näkyviin uusi datanäkymä vastaavalla tavalla simuloimalla kuin
”Kt 1:n päätöksentekonäkymä”. Kokeile sitten simuloimalla, onko nämä
mahdollista yhdistää yhdeksi näkymäksi niin, ettei kummankaan
päätöksenteko häiriinny. Jos ei, säilytä uusi näkymä erillisenä. Voit sijoittaa
sen esimerkiksi omalle välilehdelle (tab) aiemman rinnalle.
Piirrä käyttötilanne loppuun vastaavasti kuin ”Kt 1:n piirtäminen loppuun”.
Alkutilana on nyt se alkutila, jonka olet jo aiemmin laatinut. Nyt on lisättävä
minimaalinen joukko säätämistoimenpiteitä, joilla käyttäjä päätyy uuteen
datanäkymään. Parhaassa tapauksessa aiemmin laaditut säätimet toimivat
tässäkin.
Sari A. Laakso (2015)
Sari A. Laakso (2015)
51
Simulointipohjainen käyttöliittymäsuunnittelu
Kälin piirtäminen GDD:lla
Kohti realistista näyttökokoa
Kun olet piirtänyt tuen kaikille valitsemillesi käyttötilanteille ja
refaktoroinut ratkaisua tarvittaessa, lopputuloksena on suuri näyttö,
joka on jäsennetty ehkä parille välilehdelle. Miten tämä saadaan
sovitettua tietokoneen näytölle tai jopa pieneen puhelimeen?
Simuloi jokaisen kategorian keskeisiä käyttötilanteita yksi kerrallaan ja
paikanna päätöksentekokohtien kriittiset vaiheet, joissa käyttäjä
pitää mielessään vertailtavia tietoja tai työstää vaiheittain etenevää
prosessia kohti ratkaisua.
Säilytä kerralla näkyvissä ne tiedot, joita käyttäjä hyödyntää
vertailussa (muussa tapauksessa hän joutuisi pitämään niitä
mielessään tai navigoimaan edestakaisin näyttöjen välillä). Tee
näyttöjaot kognitiivisesti kuormittavien kohtien väliin.
Jos on tarpeen sovittaa todella pienelle näytölle, joudut katkaisemaan
myös ”huonoista kohdista”. Yritä tällöin pitää samalla näytöllä ne tiedot,
joiden pirstaloiminen kasvattaa mielessä pitämisen kuormaa eniten.
Selvitä simuloimalla, missä ne ovat.
Sari A. Laakso (2015)
GDD-suunnitteluprosessi
Yhteenveto: Simuloiminen, testaus ja refaktorointi
Toimenpide a. Piirrä yksi käyttötilanne kerrallaan dataa ja toimintoja
näkyviin ’yhteen suureen ikkunaan’.
Käyttötilanne 1
1.1 Piirrä kt 1 käyttöliittymäratkaisuksi simuloimalla käyttösekvenssiä vaihe vaiheelta.
1.2 Simuloi ilmeisimmät variaatiot.
Käyttötilanne 2
2.1 Editoi kt 2 edelliseen käyttöliittymään mukaan simuloimalla sitä vaihe vaiheelta.
2.2 Simuloi ilmeisimmät variaatiot.
2.3 Testaa käyttöliittymää simuloimalla edellinen käyttötilanne 1.
Käyttötilanne 3
3.1 Editoi kt 3 mukaan simuloimalla.
3.2 Simuloi ilmeisimmät variaatiot.
3.3 Testaa käyttöliittymää simuloimalla edelliset käyttötilanteet 1 ja 2.
Käyttötilanne 4
...
Toimenpide b. Testaa käyttötilanneketjut (vain mielekkäät tositilanteet).
Simuloi esim. ketju 2, 1, 2, 4, 2, 2, 4.
Simuloi esim. ketju 1, 1, 3.
Toimenpide c. Refaktoroi käyttöliittymää tarvittaessa.
Sari A. Laakso (2006)
Sari A. Laakso (2015)
52
Simulointipohjainen käyttöliittymäsuunnittelu
Kälin piirtäminen GDD:lla
Esimerkki paperiprotosta
Simuloinnin aikana
näyttökuvia kannattaa
piirtää nopeasti kynällä
paperille. Varo
katkaisemasta
simulointiprosessia
turhaan.
Ne osat, joita on aidosti
nopeampaa tehdä
esimerkiksi PowerPointilla
kuin käsin piirtämällä,
voidaan tehdä
tietokoneella ja tulostaa
piirrosten joukkoon.
Esimerkki paperille laaditun näyttökuvan yhdestä sivusta:
WWWTopi (kurssi-ilmot ja opintojen suunnittelu)
Sari A. Laakso (2015)
Kälin piirtäminen GDD:lla
Ongelmalistan käyttö
Pysyttele tiukasti vain yhden käyttötilanteen piirtämisessä
kerrallaan. Kerää ongelmalistaa, jos kesken piirtämisen
mieleesi tulee…
uhka tai huoli, esim. mitäpä jos joku väärinkäyttää järjestelmää tai
jos käyttäjä vahingossa tuhoaa jotain tai jos käyttäjä ei keksi, miten
tätä käytetään (opittavuusuhka), tai jos käyttäjä pelästyy tms.
käyttäjän tai asiakkaan hypoteettinen tunnetila,
jokin muu käyttötilanne, joka pitäisi huomioida,
toiminto, jota saatetaan tarvita muissa tilanteissa, tai
muissa tilanteissa ongelmalliseksi osoittautuvia ratkaisuja.
Jos suunnittelija kesken piirtämisen huolestuu uhkatilanteista
tai ryhtyy miettimään muissa käyttötilanteissa tarvittavia
toimintoja, piirtäminen etenee hitaasti ja käyttöliittymästä tulee
helposti sellainen, ettei sen avulla olekaan suoraviivaista hoitaa
yhtään käyttötilannetta.
Sari A. Laakso,
Laakso (2015)
Antti Latva-Koivisto (2006)
Sari A. Laakso (2015)
53
Simulointipohjainen käyttöliittymäsuunnittelu
Kälin piirtäminen GDD:lla
Ongelmalistan purkaminen 1/2
Kun simulointi etenee, ongelmalistalle kerätyt kohteet yleensä
alkavat vähentyä, koska uusien käyttötilanteiden mukaanotto
ratkaisee aiempia ongelmia ”itsestään”.
Kun olet piirtänyt kaikki käyttötilanteet mukaan ratkaisuun, käy
ongelmalista läpi. Vedä yli ne ongelmat, jotka tuli jo hoidettua
uusien tilanteiden simuloinnin yhteydessä.
Käy jäljelle jääneet ongelmat läpi. Jos listalla on...
…uhka tai huoli: Selvitä, mihin käyttötilanteeseen se liittyy ja onko
uhka todellinen vai kuviteltu. Ota tarvittaessa yhteyttä
asiakkaaseen (kysyäksesi esim. liiketoiminnan tavoitteista) tai
käyttäjiin (kysyäksesi esim. käyttötilanteista tai nykykäytännöistä)
tai muihin asiantuntijoihin. Jos uhka on todellinen, ota se huomioon
ja korjaa ratkaisua. Selvitä, onko se mahdollista hoitaa esim.
tarjoamalla perumismahdollisuus tai parantamalla opittavuutta.
Sari A. Laakso (2015)
Kälin piirtäminen GDD:lla
Ongelmalistan purkaminen 2/2
…uusi toiminto, jota arvelet jonkun käyttäjän tarvitsevan: Etsi yksi
konkreettinen käyttötilanne, jossa kyseistä toimintoa voitaisiin
tarvita. Jos sellaista ei löydy, jätä toiminto sivuun. Jos löytyy, katso
nyt hetken ajan pelkästään löytämääsi käyttötilannetta ja piirrä sen
tukemiseksi mahdollisimman suoraviivainen ratkaisu. Paras ratkaisu
ei välttämättä olekaan alunperin mieleesi tullut toiminto.
…uusia käyttötilanteita: Kokeile ensin simuloimalla, onnistuuko
niidenkin tekeminen. Jos ei onnistu, mutta tilannetta olisi syytä
tukea, ota uusi käyttötilanne suunnitteluun mukaan.
…käyttöliittymän aiheuttama ongelma jonkin muun kuin
suunnittelussa mukana olevan käyttötilanteen kannalta: Selvitä
ensiksi, mikä tämä muu tilanne on. Sen jälkeen arvioi, onko haitta
todellinen. Jos sen korjaaminen heikentää muiden käyttötilanteiden
suorittamista, haarukoi sopiva kompromissiratkaisu simuloimalla
kaikkia ongelmaan liittyviä käyttötilanteita nopeasti peräkkäin.
Antti
Sari A.
Latva-Koivisto,
Laakso (2015)
Sari A. Laakso (2006)
Sari A. Laakso (2015)
54
Simulointipohjainen käyttöliittymäsuunnittelu
GDD-suunnitteluprosessi
Esimerkki 1: PDA-bussiaikataulut
Tässä esimerkissä demotaan GDDsuunnitteluprosessin etenemistä.
Suunnittelun kohdelaitteena on PDA:
Syöttölaitteena on kynä.
Laitteessa on GPS-paikannus, joka tietää
laitteen sijainnin noin viiden metrin
tarkkuudella.
Kuva:
www.infosatellite.com/news/
2002/03/a140302mmo2_xda.html
Sari A. Laakso (2003)
Tässä käyttöliittymä on luentomateriaalin
tiivistämisen vuoksi piirretty pienelle
näytölle, vaikka todellisuudessa
suunnittelu tehtäisiin ensin ilman
näyttörajoitteita. Esimerkistä kuitenkin
näkyy selvästi, miten tietosisältö ja
erityisesti toiminnot kertyvät
käyttöliittymään simuloinnin edetessä.
Bussipysäkki
Käyttötilanteet
Kt 1 ja 2
Kt 1: Tältä pysäkiltä vanhempien
luo Paloheinään
Kt 2: Tältä pysäkiltä
eläinlääkäriin Kannelmäkeen
Joonaksen tavoite: Joonas on Töölön
tullin bussipysäkillä klo 15.55. Hän on
menossa pitkästä aikaa tapaamaan
Paloheinässä asuvia vanhempiaan.
Hannan tavoite: Hanna on koiransa
kanssa Töölön tullin bussipysäkillä klo
15.55. Eläinlääkärin vastaanotto on
Kannelmäessä klo 16.30.
Tilatietoja:
Ma 7.7. klo 15.55 Joonas on
Töölön tullin bussipysäkillä
(Mannerheimintie 71)
Tilatietoja:
Ma 7.7. klo 15.55 Hanna on koiransa
kanssa Töölön tullin bussipysäkillä
(Mannerheimintie 71)
Hän on juuri käynyt ostoksilla
Hän on juuri käynyt ostoksilla
Hänen vanhempansa ovat asuneet
viimeiset 20 vuotta Paloheinässä
osoitteessa Raiviontie 2
Hän on varannut eläinlääkärin
mäyräkoiralleen Kannelmäkeen
(Soittajantie 1) klo 16.30:ksi
Hän tietää, että bussilla 63 pääsee
Mannerheimintien pysäkeiltä
vanhempien luo
Hän on käynyt siellä kerran
aiemminkin tuttavan autokyydillä
Hän tietää, että busseja 63 menee
noin kymmenen minuutin välein
Hän tietää, että busseja menee
Kannelmäkeen melko usein, muttei
tiedä Kannelmäen bussien numeroita
Sari
Copyright
A. Laakso
© 2004
(2003)
/ Sari A. Laakso
Sari A. Laakso (2015)
55
Simulointipohjainen käyttöliittymäsuunnittelu
Käyttötilanteet
Bussipysäkki
Kt 3
Kt 3: Kahvilasta isovanhempien
luo Takkulaan
Jannen tavoite: Janne on Tullinpuomin
Shellillä kahvilla klo 15.55. Hän on
menossa iltapäivällä tervehtimään
Takkulassa asuvia isovanhempiaan.
Tilatietoja:
Ma 7.7. klo 15.55 Janne on
Tullinpuomin Shellillä kahvilla
Hänen isovanhempansa ovat asuneet
viimeiset 15 vuotta Espoon
Takkulassa (Takkulantie 6)
Tullinpuomin Shellin kahvio
Bussi 346
(300 m)
Bussi 345
(1 km)
Hän tietää, että busseilla 345 ja 346
pääsee Mannerheimintien pysäkeiltä
isovanhempien kotiin
Hän tietää, että bussi 345 jää
kauemmas (noin 1 km:n kävely),
mutta bussilla 346 pääsee aivan
lähelle (muutama sata metriä)
Sari
Copyright
A. Laakso
© 2004
(2003)
/ Sari A. Laakso
Isovanhempien koti
Kartta: pathfinder3.meridian.fi/ytv/fi/
Bussiaikatauluesimerkki
GDD-demoon valitut käyttötilanteet
Kt 1: Joonas vanhempien luo Paloheinään
Piirrä käyttöliittymäratkaisuksi simuloimalla vaihe vaiheelta.
Simuloi ilmeisimmät variaatiot.
Kt 2: Hanna eläinlääkäriin Kannelmäkeen
Editoi kt 2 mukaan edelliseen käyttöliittymään simuloimalla.
Simuloi ilmeisimmät variaatiot.
Testaa simuloimalla edellinen käyttötilanne 1.
Käyttötilanneketjut (ei välttämätöntä testata juuri tässä vaiheessa)
Testaa ketju 2->1.
Kt 3: Janne isovanhempien luo Takkulaan
Editoi kt 3 mukaan edelliseen käyttöliittymään simuloimalla.
(Simuloi ilmeisimmät variaatiot. Jätetty tästä pois.)
Testaa simuloimalla edelliset käyttötilanteet 1 ja 2.
Sari
Copyright
A. Laakso
© 2004
(2003)
/ Sari A. Laakso
Sari A. Laakso (2015)
56
Simulointipohjainen käyttöliittymäsuunnittelu
Kt 1: Joonas vanhempien luo
Piirrä käyttöliittymäratkaisu simuloimalla
Seuraavat bussit tältä pysäkiltä
Nyt klo 15:55
Bussi
16
16.30
40
16.11
42 15.59
43
16.07
63 15.58
231
16.00
248
16.08
261
16.10
315
16.05
324 15.56
345
16.13
346 15.59
360
16.08
363
16.03
452
16.03
453 15.58
472
16.10
485
16.09
495 15.59
Tässä päätöksentekonäkymä
sijoitetaan suoraan etusivulle,
koska muita käyttötilanteita ei
vielä ole suunnittelussa mukana.
Yhtään toimintoa tai
navigointiaskelta ei vielä tarvita.
Sari
Copyright
A. Laakso
© 2004
(2003)
/ Sari A. Laakso
Kt 1: Joonas vanhempien luo
Simuloi ilmeisimmät variaatiot
Seuraavat bussit tältä pysäkiltä
Nyt klo 15:55
Bussi
16
16.30
40
16.11
42 15.59
43
16.07
63 15.58
231
16.00
248
16.08
261
16.10
315
16.05
324 15.56
345
16.13
346 15.59
360
16.08
363
16.03
452
16.03
453 15.58
472
16.10
485
16.09
495 15.59
Variaatio 1
Joonaksen vanhemmat asuvat
Vantaalla osoitteessa Emännänkuja 1.
Joonas tietää, että busseilla 453, 472
ja 485 pääsee vanhempien kotitalolle.
Sari
Copyright
A. Laakso
© 2004
(2003)
/ Sari A. Laakso
Sari A. Laakso (2015)
57
Simulointipohjainen käyttöliittymäsuunnittelu
Kt 2: Hanna eläinlääkäriin
Yritä tehdä kt 2 suoraan edellisellä kälillä
Seuraavat bussit tältä pysäkiltä
Nyt klo 15:55
Bussi
16
16.30
40
16.11
42 15.59
43
16.07
63 15.58
231
16.00
248
16.08
261
16.10
315
16.05
324 15.56
345
16.13
346 15.59
360
16.08
363
16.03
452
16.03
453 15.58
472
16.10
485
16.09
495 15.59
Ensin katsotaan, sattuisiko edellinen
käyttöliittymä toimimaan suoraan
tässäkin käyttötilanteessa 2.
Ongelma: Hanna ei selviytyisi
Kannelmäkeen eläinlääkäriin Joonaksen
käyttöliittymäratkaisulla ollenkaan!
Piirrämme uuden datanäkymän: mitä
Hannan tilanteessa tarvitaan? Hänelle on
näytettävä ne bussit, jotka menevät
oikeaan paikkaan (selvitetään oikea
vastaus: 42 ja 43). Eläinlääkärin
vastaanottoaika on 16.30, joten hyvissä
ajoin sitä ennen on oltava perillä
(saapumisaika).
Sari
Copyright
A. Laakso
© 2004
(2003)
/ Sari A. Laakso
Piirretään ensin seuraavan sivun kolmas
näkymä, minkä jälkeen mahdollisimman
vähillä säädöillä etusivulta reitti sinne
(kaksi ensimmäistä näyttökuvaa).
Kt 2: Hanna eläinlääkäriin
Editoi kt 2 edelliseen käliin mukaan
Bussit tältä pysäkiltä
Kohdeosoite tai -paikka Kaupunki
Bussit tältä pysäkiltä
Kohdeosoite tai -paikka Kaupunki
Bussit tältä pysäkiltä
Kohdeosoite tai -paikka Kaupunki
Sari A. Laakso (2003)
Sari A. Laakso (2015)
58
Simulointipohjainen käyttöliittymäsuunnittelu
Kt 2: Hanna eläinlääkäriin
Simuloi ilmeisimmät variaatiot
Bussit tältä pysäkiltä
Kohdeosoite tai -paikka Kaupunki
Bussit tältä pysäkiltä
Kohdeosoite tai -paikka Kaupunki
Editoidaan pieni
muutos.
Bussit tältä pysäkiltä
Kohdeosoite tai -paikka Kaupunki
Variaatio 1
Eläinlääkäriasema sijaitseekin
osoitteessa Soittajankuja 4.
Myös Vantaalla on Soittajankuja.
Sari A. Laakso (2003)
Testaa edelliset tilanteet
Testaa simuloimalla kt 1
Testitulos: Kt 1 toimii edelleen hyvin.
Bussit tältä pysäkiltä
Kohdeosoite tai -paikka Kaupunki
Sari
Copyright
A. Laakso
© 2004
(2003)
/ Sari A. Laakso
Sari A. Laakso (2015)
59
Simulointipohjainen käyttöliittymäsuunnittelu
Käyttötilanneketjut
Testaa ketju: Kt 2->Kt 1
Bussit tältä pysäkiltä
Kohdeosoite tai -paikka Kaupunki
Bussit tältä pysäkiltä
Kohdeosoite tai -paikka Kaupunki
Bussit tältä pysäkiltä
Kohdeosoite tai -paikka Kaupunki
Sari A. Laakso (2003)
Käyttötilanneketjut
Testaa ketju: Kt 2->Kt 1
Bussit tältä pysäkiltä
Kohdeosoite tai -paikka Kaupunki
Bussit tältä pysäkiltä
Kohdeosoite tai -paikka Kaupunki
Ketjun testauksessa
ilmeni tarve uudelle
tyhjennä-toiminnolle.
Lisätään se.
Bussit tältä pysäkiltä
Kohdeosoite tai -paikka Kaupunki
Sari A. Laakso (2003)
Sari A. Laakso (2015)
60
Simulointipohjainen käyttöliittymäsuunnittelu
Kt 3: Janne Takkulaan
Yritä tehdä kt 3 suoraan edellisellä kälillä
Ongelma: Entinen käli ei toimi, koska
Janne on nyt Shellin kahviossa, eikä lähin
pysäkki ole se, jolta hänen tietämänsä
bussit 345 ja 346 menevät Takkulaan.
Laite näyttää väärää pysäkkiä ja pelkkiä
ensimmäisiä busseja.
Bussit tältä pysäkiltä
Kohdeosoite tai -paikka Kaupunki
Takkulaan menevät
bussit 345 ja 346
Lähin pysäkki, jonka
busseja laite näyttää
Shellin kahvio
Sari
Copyright
A. Laakso
© 2004
(2003)
/ Sari A. Laakso
Kt 3: Janne Takkulaan
Editoi kt 3 edelliseen käliin mukaan
Tehdään uusi
datanäkymä.
Se pystytään
integroimaan
entiseen.
Pysäkiltä Töölön tulli, keskustaan
Pysäkiltä Töölön tulli, keskustaan
Pysäkiltä Töölön tulli, pohjoiseen
Kohdeosoite tai -paikka Kaupunki
Kohdeosoite tai -paikka Kaupunki
Kohdeosoite tai -paikka Kaupunki
Olet tässä
Sari A. Laakso (2003)
Sari A. Laakso (2015)
61
Simulointipohjainen käyttöliittymäsuunnittelu
Testaa edelliset tilanteet
Testaa simuloimalla kt 1
Testituloksena ongelma: Joonaksen
pitäisi päästä lähtemään tältä pysäkiltä,
jolle hän on saapunut, mutta laite
näyttää sen pysäkin busseja, jonka
käyttäjä on valinnut edellisellä kerralla.
Pysäkiltä Töölön tulli, keskustaan
Kohdeosoite tai -paikka Kaupunki
Suoraviivaisin tapa päästä takaisin kiinni
lähimpään pysäkkiin? (Tarvitaan myös
Hannan kt 2:ssa.)
Sari
Copyright
A. Laakso
© 2004
(2003)
/ Sari A. Laakso
Käyttäjä voisi valita Pysäkiltä-valikosta
lähimmän pysäkin käsin, joten tämä
tilanne on mahdollista suorittaa
nykyisenkin kälin avulla. Päätämme
kuitenkin suoraviivaistaa lähimmässä
pysäkissä kiinni pysymistä, ja lisäämme
uuden toiminnon, koska emme keksi,
miten voisimme suoraviivaistaa olemassa
olevaa valikkovalintaa.
Testaa edelliset tilanteet
Korjaa kt 1:n käyttöliittymää
Pysäkiltä Töölön tulli, kesk
Lähin
Kohdeosoite tai -paikka Kaupunki
Lisätään
mahdollisuus
pysyä kiinni
lähimmässä
pysäkissä.
Pysäkiltä Töölön tulli, pohj
Lähin
Kohdeosoite tai -paikka Kaupunki
Sari
Copyright
A. Laakso
© 2004
(2003)
/ Sari A. Laakso
Sari A. Laakso (2015)
62
Simulointipohjainen käyttöliittymäsuunnittelu
Testaa edelliset tilanteet
Testaa simuloimalla kt 1
Testitulos: Kt 1 toimii riittävän hyvin.
Pysäkiltä Töölön tulli, pohj
Lähin
Kohdeosoite tai -paikka Kaupunki
Huomio: Niin kauan kuin Joonaksella on
Lähin-checkbox valittuna ja hakukenttä
tyhjänä, hän pääsee edelleen
tavoitteeseensa suorinta mahdollista
tietä: vain vilkaisemalla laitetta
tekemättä mitään.
Muissa tilanteissa (riippuen edeltävästä
käyttötilanteesta) hän joutuu
• klikkaamaan Lähin-checkboxin päälle
ja/tai
• tyhjentämään hakuehtokentän.
Sari
Copyright
A. Laakso
© 2004
(2003)
/ Sari A. Laakso
Testaa edelliset tilanteet
Testaa simuloimalla kt 2
Pysäkiltä Töölön tulli, pohj
Lähin
Pysäkiltä Töölön tulli, pohj
Lähin
Kohdeosoite tai -paikka Kaupunki
Kohdeosoite tai -paikka Kaupunki
Sari
Copyright
A. Laakso
© 2004
(2003)
/ Sari A. Laakso
Sari A. Laakso (2015)
63
Simulointipohjainen käyttöliittymäsuunnittelu
Käyttötilanneketjut
Testaa ketju: Kt 3 -> Kt 1 -> Kt 2 -> ...
Pysäkiltä Töölön tulli, pohj
Lähin
Kohdeosoite tai -paikka Kaupunki
Testausta voitaisiin jatkaa uudella
käyttötilanteiden ketjulla, minkä jälkeen
käyttöliittymään integroitaisiin uusi
käyttötilanne 4.
Sari
Copyright
A. Laakso
© 2004
(2003)
/ Sari A. Laakso
GDD-suunnitteluprosessi
Esimerkki 2: Kirjastohaku
Tässä esimerkissä suunniteltavana
käyttöliittymänä on yliopiston
tietojenkäsittelytieteen laitoksen (TKTL)
kirjastojärjestelmä.
Lähtökohtana on käyttötilanteita, joiden
pohjalta käyttöliittymää piirretään GDDsuunnitteluprosessin mukaisesti tilanne
kerrallaan.
TKTL:n vanha
kirjastohakujärjestelmä
Huom. Kaikkia simuloinnin välivaiheita ei
ole piirretty näkyviin tässä esimerkissä.
Esimerkin tarkoitus on havainnollistaa,
miten tietosisältö ja toiminnallisuus
kertyvät järjestelmään, kun uusia
käyttötilanteita simuloidaan mukaan.
Sari A. Laakso (2015)
64
Simulointipohjainen käyttöliittymäsuunnittelu
Kirjastoesimerkki
Käyttötilanne 1
Kt 1: Cardin visualisointikirja omasta lähikirjastosta
Tutkijan tavoite: Hannu Toivonen tietää, että Cardin kirjassa
olisi hyviä glyyfiesimerkkejä hänen Tutkimustiedonhallinnan
peruskurssin luentoaan varten, mutta hänellä ei ole Cardin kirjaa.
Tilatietoja:
Tänään on ma 1.9. klo 9.30.
Luento on ti 9.9. klo 10-12.
Cardin kirja: Information Visualization
Hannu on aiemminkin lukenut Cardin kirjaa, mutta hänellä ei
ole omaa kappaletta kirjasta.
Omassa tietojenkäsittelytieteen laitoksen (TKTL)
lähikirjastossa on 3 kpl, joista 1 on lainassa Inkeri Verkamolla
ja 2 hyllyssä.
Sari A. Laakso (2003)
(2015)
Käyttötilanne 1 (Cardin kirja lähikirjastosta)
Kirjan haku
Kansi Tekijä(t)
Kirjan nimi
Vuosi Hyllyssä
Hae card
Card Remy, Dumas Eric,
Mevel Franck
The Linux Kernel Book
1998
1
Card Stuart, Mackinlay
Jock, Shneiderman Ben
Readings in Information
Visualization: Using Vision to
Think
1999
2
Card Stuart, Moran
Thomas, Newell Allen
The Psychology of HumanComputer Interaction
1983
1
Cardelli Luca
Typeful Programming
1989
Cardenas Alfonso
Research Foundations in Object- 1990
Oriented and Semantic
Database Systems
1
Iyer Balakrishna, Ricard
Gray, Varman Peter
An Efficient Percentile
Partitioning Algorithm for
Parallel Sorting
1989
2
Sari A. Laakso (2003)
Sari A. Laakso (2015)
65
Simulointipohjainen käyttöliittymäsuunnittelu
Kirjastoesimerkki
Käyttötilanne 2
Kt 2: Kaikki Cardin visualisointikirjat lainassa
Tutkijan tavoite: Hannu Toivonen tietää, että Cardin kirjassa
olisi hyviä glyyfiesimerkkejä hänen Tutkimustiedonhallinnan
peruskurssin luentoaan varten, mutta hänellä ei ole Cardin kirjaa.
Tilatietoja:
Tänään on ma 1.9. klo 9.30.
Luento on ti 9.9. klo 10-12.
Cardin kirja: Information Visualization
Hannu on aiemminkin lukenut Cardin kirjaa, mutta hänellä ei
ole omaa kappaletta kirjasta.
Omassa tietojenkäsittelytieteen laitoksen (TKTL)
lähikirjastossa on 3 kpl, jotka kaikki ovat lainassa:
Juha Tainalla,
Inkeri Verkamolla ja
Hannu Erkiöllä.
Sari A. Laakso (2003)
(2015)
Käyttötilanne 2 (kaikki lainassa)
Kirjan haku
Hyllyssä Lainassa
Kansi Tekijä(t)
Kirjan nimi
Pvm
Pvm
Vuosi
Lainaaja
Lainaaja
Puhelin
Puh.
Hae card
Hae
Card Remy, Dumas Eric,
Mevel Franck
The Linux Kernel Book
1998
1
Card Stuart, Mackinlay
Jock, Shneiderman Ben
Readings in Information
Visualization: Using Vision to
Think
1999
2
Card Stuart, Moran
Thomas, Newell Allen
The Psychology of HumanComputer Interaction
1983
1
Cardelli Luca
Typeful Programming
1989
Cardenas Alfonso
Research Foundations in Object- 1990
Oriented and Semantic
Database Systems
1
Iyer Balakrishna, Ricard
Gray, Varman Peter
An Efficient Percentile
Partitioning Algorithm for
Parallel Sorting
2
1989
18.3.03
31.3.03
15.5.03
Juha Taina
44 226
Inkeri Verkamo 44 219
Hannu Erkiö
44 253
10.6.03
12.7.03
Petri Myllymäki 44 173
Mikael Jokela 44 628
Sari
Copyright
A. Laakso
© 2003
(2003)
/ Sari A. Laakso
Sari A. Laakso (2015)
66
Simulointipohjainen käyttöliittymäsuunnittelu
Kirjastoesimerkki
Käyttötilanne 3
Kt 3: Waren visualisointikirjaa ei kirjastossa
Tutkijan tavoite: Hannu Toivonen tietää, että Waren kirjassa
olisi Tietokonegrafiikan kurssille hyviä esimerkkejä rinnakkaiskoordinaattien käytöstä, mutta hänellä ei ole Waren kirjaa.
Tilatietoja:
Tänään on ma 1.9. klo 9.30.
Luento on ti 9.9. klo 10-12.
Waren kirja: Information Visualization
Hannu on aiemminkin lukenut Waren kirjaa, mutta hänellä ei
ole omaa kappaletta kirjasta.
Omassa tietojenkäsittelytieteen laitoksen (TKTL)
lähikirjastossa ei ole kirjasta lainakappaleita ollenkaan.
Hannu ja hänen opiskelijansa tarvitsevat kirjaa
todennäköisesti myöhemminkin, koska kirja on mm. hänen
Tietokonegrafiikka-kurssinsa oheismateriaalina.
Sari A. Laakso (2003)
(2015)
Käyttötilanne 3 (kirjaa ei ole kirjastossa ollenkaan)
Kirjan haku
Hyllyssä Lainassa
Kansi Tekijä(t)
Kirjan nimi
Lainapvm Lainaajan nimi
Vuosi
Puhelin
Hae ware
Hae
Neeser Fredy, Ware
Malcom
Design of a V.34 modem for a
real-time multitasking DSP
operating system
1995
1
Putnam Lawrence, Myers
Ware
Measures for excellence :
reliable software on time, within
budget
1992
1
Sari
Copyright
A. Laakso
© 2003
(2003)
/ Sari A. Laakso
Sari A. Laakso (2015)
67
Simulointipohjainen käyttöliittymäsuunnittelu
Kirjan haku
Hankintaehdotus
Hyllyssä Lainassa
Kansi Tekijä(t)
Kirjan nimi
Lainapvm Lainaajan nimi
Vuosi
Puhelin
Hae ware
Hae
Neeser Fredy, Ware
Malcom
Design of a V.34 modem for a
real-time multitasking DSP
operating system
1995
1
Putnam Lawrence, Myers
Ware
Measures for excellence :
reliable software on time, within
budget
1992
1
Sari
Copyright
A. Laakso
© 2003
(2003)
/ Sari A. Laakso
Kirjan haku
Hankintaehdotus
Tee hankintaehdotus kirjastoon
Pvm
24.10.03
Tekijä(t)
Ware Colin
Kirjan nimi
Information visualization:
perception for design
Lähetä kirjastoon
Tyhjennä
Lähetetyt hankintaehdotukset
Pvm
Tekijä(t)
Kirjan nimi
Hankittava kirja
Kustantaja
Morgan Kaufmann
Painopaikka
San Diego, CA, USA
Painovuosi
Painos
2000
ISBN
1-55860-511-8
1.
?
Hinta-arvio
Tarvittavien lainakappaleiden lkm
2
Perustelut
Tietokonegrafiikka-kurssin oheismateriaalia.
Lähdemateriaaliksi Visualisointi-seminaariin.
Käsitellyt hankintaehdotukset
Tila
Tekijä(t)
Kirjan nimi
Sari
Copyright
A. Laakso
© 2003
(2003)
/ Sari A. Laakso
Sari A. Laakso (2015)
68
Simulointipohjainen käyttöliittymäsuunnittelu
Hankintaehdotus
Kirjan haku
Tee hankintaehdotus kirjastoon
Pvm
Tekijä(t)
Kirjan nimi
24.10.03
Lähetetyt hankintaehdotukset
Pvm
Tekijä(t)
Kirjan nimi
24.10.03
Ware Colin
Information visualization:
perception for design
Hankittava kirja
Kustantaja
Morgan Kaufmann
Painopaikka
San Diego, CA, USA
Painovuosi
Painos
2000
ISBN
1-55860-511-8
1.
?
Hinta-arvio
Tarvittavien lainakappaleiden lkm
2
Perustelut
Tietokonegrafiikka-kurssin oheismateriaalia.
Lähdemateriaaliksi Visualisointi-seminaariin.
Käsitellyt hankintaehdotukset
Tila
Tekijä(t)
Kirjan nimi
Sari
Copyright
A. Laakso
© 2003
(2003)
/ Sari A. Laakso
Kirjastoesimerkki
Käyttötilanne irti järjestelmästä
Älä kiinnitä käyttötilanteessa ratkaisutapoja. Esim. ”kirjan
varaaminen” ei koskaan ole käyttäjän tavoite, vaan kiinnitetty
ratkaisutapa (tehtävä tai toiminto).
Miksei kirjan varaamista pidä kiinnittää käyttötilanteessa?
Laaditaan ensin varauksen tekemisen tarpeeseen osuva kunnollinen
käyttötilanneasetelma ja katsotaan, millainen käyttöliittymäratkaisu
siitä seuraa: Otetaan pohjaksi aiempi käyttötilanne 2, mutta
tehdään siitä uusi käyttötilanne 4 asettelemalla tarjonta niin, että
omassa lähikirjastossa kaikki kirjat ovat varattuja, mutta kirjaa olisi
saatavana muissa kirjastoissa.
Piirretään käyttötilannetta 4 optimoiva käyttöliittymäratkaisu. Se vie
nyt päätöksentekokohdan kartalle (vahva sijaintiriippuvuus), jos
oletamme työnkulun pysyvän ennallaan (”liiketoimintamalli” ei
muutu).
Copyright © 2006 / Sari A. Laakso
Sari A. Laakso (2015)
69
Simulointipohjainen käyttöliittymäsuunnittelu
Kirjastoesimerkki
Käyttötilanne 4
Kt 4: Cardin visualisointikirja yliopiston muissa kirjastoissa
Tutkijan tavoite ja ongelma: Hannu Toivonen pitää Tutkimustiedonhallinnan peruskurssin luennon taas ensi viikolla, mutta hänellä
ei ole sopivia glyyfiesimerkkejä vielä. Hän tietää, että Cardin kirjassa
olisi hyviä esimerkkejä ja kuvia, mutta hänellä ei ole kirjaa.
Tilatietoja:
Tänään on ma 1.9. klo 9.30. Luento on ti 9.9. klo 10-12.
Tarvittava kirja
Hannu on aiemmin lukenut kirjaa, mutta hänellä ei ole omaa kappaletta.
Hannu muistaa, että kirjan nimi on jokin ’Information Visualization’ ja yksi
tekijöistä on Card.
Kirjan todelliset lähdetiedot: Card Stuart, MacKinlay Jock, Shneiderman Ben,
Readings in Information Visualization: Using Vision to Think.
Kirjan saatavuus
Ero kt2:een
Omassa TKTL:n lähikirjastossa on 3 kpl, kaikki lainassa.
Lääketieteellisen kirjastossa on 3 kpl: lainassa 2, saatavilla 1.
Hannu ei ole aiemmin käynyt siellä, ei tiedä kirjaston sijaintia.
Kasvatustieteellisen ja psykologian kirjastoissa 2 kpl, kaikki lainassa.
Copyright © 2006 / Sari A. Laakso
Kirjan haku
Omat varaukseni
Hankintaehdotus
Kansi Tekijä(t)
Kirjan nimi
Vuosi
Kirjan saatavuus
Hae
(Lainassa olevien lkm sulkeissa)
card
The Linux Kernel Book
Card Remy,
Dumas Eric, Mevel
Franck
1998
Readings in Information
Card Stuart,
Visualization: Using Vision to
Mackinlay Jock,
Shneiderman Ben Think
1999
Tietojenkäsittelytiede (3)
Teollisuuskatu 23, ark. 9-16
Esko Ukkonen
p. 44 226
18.3.03
Inkeri Verkamo
p. 44 219
Card Stuart,
Moran Thomas,
Newell Allen
The Psychology of HumanComputer Interaction
1983
Cardelli Luca
Typeful Programming
1989
31.3.03
Lääketieteellinen (2)
Hannu Erkiö
p. 44 253
Haartmaninkatu 3, ark. 10-16
Saatavilla:
1
15.5.03
Varaa
Psykologia (2 lainassa)
Siltavuorenpenger 20 A, ark. 9-15
1990
Cardenas Alfonso Research Foundations in
Object-Oriented and Semantic
Database Systems
Iyer Balakrishna,
Ricard Gray,
Varman Peter
An Efficient Percentile
Partitioning Algorithm for
Parallel Sorting
1989
Kasvatustieteellinen (2 lainassa)
Bulevardi 18, ark. 8-18
Löytyi 26 / 48 559 kirjaa
Sari A. Laakso (2015)
70
Simulointipohjainen käyttöliittymäsuunnittelu
Kirjan haku
Omat varaukseni
Hankintaehdotus
Voimassa olevat varaukset
Tietojenkäsittelytiede
Teollisuuskatu 23
Lääketieteellinen
Haartmaninkatu 3, ark. 10-16
Ratkaisun suoraviivaistaminen?
Varatut kirjat
Card, Mackinlay, Shneiderman:
Readings in Information
Visualization: Using Vision to
Think.
Varattuna ma 10.11. – ke 12.11.
Suurin ylimääräinen työ syntyy nyt
kirjan noutamisesta.
Peru varaus
Kirjan haku
Hankintaehdotus
Kansi Tekijä(t)
Kirjan nimi
Hae
Lähikirjasto (TKTL)
Vuosi Hyllyssä Lainassa
Muut kirjastot
Hyllyssä Toimitusaika
(lainassa)
card
The Linux Kernel Book
Card Remy,
Dumas Eric, Mevel
Franck
1998
1
Readings in Information
Card Stuart,
Visualization: Using Vision to
Mackinlay Jock,
Shneiderman Ben Think
1999
2
1
Card Stuart,
Moran Thomas,
Newell Allen
The Psychology of HumanComputer Interaction
1983
Cardelli Luca
Typeful Programming
1989
Cardenas Alfonso Research Foundations in
Object-Oriented and Semantic
Database Systems
Löytyi 26Iyer
/ 48Balakrishna,
559 kirjaa
An Efficient Percentile
18.3.03 Juha
Esko Taina
Ukkonen 44 226
31.3.03 Inkeri Verkamo 44 219
15.5.03 Hannu Erkiö 44 253
1 (6)
Tänään ma
10.11. klo 15
mennessä
(3)
10.6.03 Petri Myllymäki 44 173
12.7.03 Mikael Jokela 44 628
1990
1
1989
2
Tilaa sisäpostissa
Omat tilaukseni
Tekijä(t)
Kirjan nimi
Toimitus
Peru tilaus
Sari A. Laakso (2015)
71
Simulointipohjainen käyttöliittymäsuunnittelu
Työnkulkumallit
Varaus-tehtävä on kiinnitetty ratkaisu
Työnkulkumalli 1
Työnkulkumalli 2
Hannu tilaa vapaana
olevan lainakappaleen
kirjastosta työpaikalleen.
Kirja toimitetaan
sisäpostissa perille vielä
saman päivän aikana.
Hannu palauttaa kirjan
lähettämällä sen kirjan
mukana tulevilla ohjeilla
takaisin kirjastoon.
Hannu noutaa vapaana
olevan lainakappaleen
kirjastosta.
Hannu käy
palauttamassa kirjan
kirjastoon.
Varaus-tehtävä (task) on
tässä tapauksessa
mielekäs, jotta Hannu ei
lähtisi kirjastoon turhaan.
Tässä työnkulussa erillistä
Varaus-tehtävää ei enää ole.
Copyright © 2006 / Sari A. Laakso
Työnkulkumallin vaihtaminen
Päätöksenteko muuttuu
Noutamismenettelyssä
Hannu tarvitsee kartalle
suhteutettuja kirjastoja
päätöksentekonsa tueksi:
Sisäpostimenettelyssä on
samantekevää, missä kirjasto
sijaitsee:
Copyright © 2006 / Sari A. Laakso
Sari A. Laakso (2015)
72
Simulointipohjainen käyttöliittymäsuunnittelu
GDD-suunnitteluprosessi
Tuloksena hyödyllisyys ja käytettävyys
Käyttötilanteiden simuloinnin avulla
piirretystä käyttöliittymästä nähdään
tarvittava tietosisältö ja
toiminnot.
Konkreettisista käyttötilanteista
saadut toiminnalliset
vaatimukset on kuvattu
ymmärrettävässä ja
testauskelpoisessa muodossa.
Sari A. Laakso (2003)
(2015)
Sari A. Laakso (2015)
73
Lähteitä
Bias91
Bias R. G.,
Walkthroughs: efficient collaborative testing.
IEEE Software, Vol. 8, No. 5, 1991, s. 94-95.
Broadbent75
Broadbent D.,
The magic number seven after twenty years.
Teoksessa Kennedy R., Wilkes A. (toim.), Studies in long term
memory. Wiley, New York, 1975, s. 253-287.
Card99
Card S. K., Mackinlay J., Shneiderman B. (toim.),
Readings in Information Visualization: Using Vision to Think.
Morgan Kaufmann, San Francisco, CA, USA, 1999.
Carroll94
Carroll J. M.,
Making Use A Design Representation.
Communications of the ACM, Vol. 37, No. 12, December 1994, s. 2935.
Carroll00
Carroll J.M.,
Making Use. Scenario Based Design of HumanComputer Interactions.
The MIT Press, USA, 2000.
Cato01
Cato J.,
User-Centered Web Design.
Pearson Education, 2001.
Cooper95
Cooper A.,
About Face: The Essentials of User Interface Design.
IDG Books, USA, 1995.
Cooper03
Cooper A., Reimann R. M.,
About Face 2.0. The Essentials of Interaction Design.
Wiley Publishing, Inc., Indianapolis, Indiana, 2003.
Cowan01
Cowan N.,
The magical number 4 in short-term memory: A reconsideration of
mental storage capacity.
Behavioral and Brain Sciences, 24, 2001, s. 87-185.
www.bbsonline.org/documents/a/00/00/04/46/bbs0000044600/bbs.cowan.html
Dubberly87
Dubberly H., Mitch D.,
The Knowledge Navigator.
Apple Computer, videonauha. Esiintyy videolla Myers B. A. (toim),
HCI’92 Special Video Program.
Go04
Go K., Carroll J. M.,
The Blind Men and the Elephant: Views of Scenario-Based System
Design.
interactions, November/December 2004, s. 44-53.
74
Goldstein02
Goldstein E. B.,
Sensation and Perception.
Wadsworth Publishing, 6th edition, 2002.
Hackos98
Hackos J., Redish J. C.,
User and Task Analysis for Interface Design.
John Wiley & Sons, USA, 1998.
Hornbæk06
Hornbæk K.,
Current practice in measuring usability: Challenges to usability studies
and research.
International Journal of Human-Computer Studies, Vol. 64, No. 2,
2006, s. 79-102.
ISO9241-11
International Organization of Standardization, Ergonomic
Requirements for Office Work with Visual Display Terminals (VDTs),
Part 11: Guidance on usability (ISO 9241-11:1998), 1998.
Jacobson92
Jacobson I.,
Object-oriented software engineering: a use case driven approach.
Addison-Wesley, 1992.
Kolehmainen06
Kolehmainen A.,
Ohjelmistolle asetettavien käytettävyysvaatimusten määrittely.
Pro gradu –tutkielma, Helsingin yliopisto, tietojenkäsittelytieteen laitos,
sarja C-2006-46, 2006.
Laakso00
Laakso S. A., Laakso K.-P., Saura A.,
Improved Scroll Bars.
ACM CHI 2000 conference proceedings, Extended Abstracts, s. 97-98.
www.cs.helsinki.fi/u/salaakso/papers/CHI2000-ImprovedScrollbars.PDF
Laakso04
Laakso S. A., Laakso K.-P.,
Hyvän käyttöliittymän varmistaminen GUIDe-prosessimallilla.
Helsingin yliopisto, Tietojenkäsittelytieteen laitos, julkaisematon
artikkeli, päivitetty 3.10.2004.
www.cs.helsinki.fi/u/salaakso/papers/GUIDe-suomeksi.pdf
www.cs.helsinki.fi/u/salaakso/papers/GUIDe-suomeksi.html
Lauesen01
Lauesen S., Harning M.B.,
Virtual Windows: Linking User Tasks, Datamodels, and Interface
Design.
IEEE Software, July/August 2001, s. 67-75.
www.itu.dk/people/slauesen/Papers/VirtualWindowsIEEE.pdf
Lauesen02
Lauesen S.,
Software Requirements. Styles and Techniques.
Pearson Education Ltd, 2002.
Lauesen05
Lauesen S.,
User Interface Design. A Software Engineering Perspective.
Pearson Education Ltd, 2005.
75
Lewis97
Lewis C., Wharton C.,
Cognitive Walkthroughs.
Teoksessa Helander M., Landauer T., Pradhu P. (toim.), Handbook of
Human-Computer Interaction. Elsevier Science B.V., Netherlands,
1997, s. 717-732.
Miller56
Miller G. E.,
The Magical Number Seven, Plus or Minus Two: Some Limits on Our
Capacity for Processing Information.
The Psychological Review, 1956, vol. 63, s. 81-97
www.well.com/user/smalin/miller.html
Nielsen93
Nielsen J.,
Usability Engineering.
Academic Press, New York, 1993.
Nielsen94
Nielsen J.,
Heuristic evaluation.
Teoksessa Nielsen J., Mack R.L. (toim.), Usability inspection methods.
Wiley, New York, USA, 1994, s. 25-62.
Nielsen00
Nielsen J.,
Why You Only Need to Test With 5 Users.
Alertbox, March 19, 2000.
www.useit.com/alertbox/20000319.html
Nielsen03
Nielsen J.,
Usability 101: Introduction to Usability.
Alertbox, August 25, 2003.
www.useit.com/alertbox/20030825.html
Norman90
Norman D.,
The Design of Everyday Things.
Doubleday, New York, 1990.
(Alkuperäinen painos nimellä The Psychology of Everyday Things,
Basic Books, New York, 1988; suomenkielinen versio nimellä Miten
avata mahdottomia ovia)
Peterson59
Peterson L. R., Peterson M. J.,
Short-term retention of individual verbal items.
Journal of Experimental Psychology, Vol. 58, 1959, s. 193-198.
Preece94
Preece J.,
Human-Computer Interaction.
Addison-Wesley, Wokingham, UK, 1994.
Rubin94
Rubin J.,
Handbook of Usability Testing: How to Plan, Design, and Conduct
Effective Tests.
John Wiley & Sons, 1994.
Sears97
Sears A.,
Heuristic Walkthroughs: Finding the Problems Without the Noise.
International Journal of Human-Computer Interaction, Vol. 9, No. 3,
1997, s. 213-234.
76
Shneiderman98
Shneiderman B.,
Designing the User Interface.
Addison-Wesley, 3rd edition, 1998.
Shneiderman00
Shneiderman B., Kang H.,
Direct Annotation: A Drag-and-Drop Strategy for Labeling Photos.
International Conference on Information Visualisation (IV2000),
London, England, 2000.
www.cs.umd.edu/hcil/photolib/paper/DirectAnnotation7.doc
Tufte83
Tufte E. R.,
The Visual Display of Quantitative Information.
Graphics Press, USA, 1983.
Tufte90
Tufte E. R.,
Envisioning Information.
Graphics Press, USA, 1990.
Ware00
Ware C.,
Information Visualization: Perception for Design.
Morgan Kaufmann, San Francisco, CA, 2000.
Williamson92
Williamson C., Shneiderman B.,
The dynamic HomeFinder: Evaluating dynamic queries in a real-estate
information exploration system.
ACM SIGIR’92 conference proceedings, 1992, s. 338-346.
77