Top Banner
Computer the machine the program runs on often split between clients & servers Human-Computer Interaction (HCI) Human the end-user of a program the others in the organization Interaction the user tells the computer what they want the computer communicates results
18

Computer –the machine the program runs on –often split between clients & servers Human-Computer Interaction (HCI) Human –the end-user of a program –the.

Jan 12, 2016

Download

Documents

William Walton
Welcome message from author
This document is posted to help you gain knowledge. Please leave a comment to let me know what you think about it! Share it to your friends and learn new things together.
Transcript
Page 1: Computer –the machine the program runs on –often split between clients & servers Human-Computer Interaction (HCI) Human –the end-user of a program –the.

• Computer– the machine the program runs on– often split between clients & servers

Human-Computer Interaction (HCI)

• Human– the end-user of a program– the others in the organization

• Interaction– the user tells the computer what they want– the computer communicates results

Page 2: Computer –the machine the program runs on –often split between clients & servers Human-Computer Interaction (HCI) Human –the end-user of a program –the.

HCI Approach to UI Design

Design

Organizational & Social Issues

Technology Humans

Tasks

Page 3: Computer –the machine the program runs on –often split between clients & servers Human-Computer Interaction (HCI) Human –the end-user of a program –the.

Why is HCI Important?• Major part of work for “real” programs– approximately 50%

• Bad user interfaces cost– money

• 5% satisfaction -> up to 85%profits• finding problems early makes them easier to fix

– reputation of organization (e.g., brand loyalty)– lives possibly

• User interfaces hard to get right– people are unpredictable– intuition of designers often wrong

Page 4: Computer –the machine the program runs on –often split between clients & servers Human-Computer Interaction (HCI) Human –the end-user of a program –the.

Who Builds UIs?

• A team of specialists (ideally)– graphic designers– interaction / interface designers– information architects– technical writers– marketers– test engineers– usability engineers– software engineers– users

Page 5: Computer –the machine the program runs on –often split between clients & servers Human-Computer Interaction (HCI) Human –the end-user of a program –the.

How to Design and Build UIs

• UI Development process

• Usability goals

• User-centered design

• Task analysis & contextual inquiry

• Rapid prototyping

• Evaluation

• Programming

Page 6: Computer –the machine the program runs on –often split between clients & servers Human-Computer Interaction (HCI) Human –the end-user of a program –the.

User Interface Development Process

DesignExploration

Evaluate Execute

Proposal:Demos/Lo Fi Prototypes(How)

Work together torealize the designin detail.

Evaluate withCustomers

DesignDiscovery

Customers, Products,Business, Marketing

Customers, Products,Business, Marketing

Customers, Products,Business, Marketing

Design Definition:- Design Problem Statement- Targeted User Roles (Who)- Targeted User Tasks (What)- Design Direction Statements

Specification:Hi Fidelity, Refined Design - Based on customer feedback - Foundation in product reality - Refined Design description

Storyboard

Customers: - Roles (Who) - Tasks (What) - Context (Stories)Marketing: - Business Priorities - MessagesTechnology: - Products - ArchitectureDesign: - Leading/competing technologies

Review & Iterate

based on slide by Sara Redpath, IBM & Thyra Trauch, Tivoli

Page 7: Computer –the machine the program runs on –often split between clients & servers Human-Computer Interaction (HCI) Human –the end-user of a program –the.

Iteration

Design

Prototype

Evaluate

At every stage!

Page 8: Computer –the machine the program runs on –often split between clients & servers Human-Computer Interaction (HCI) Human –the end-user of a program –the.

Design

• Design is driven by requirements– what the artifact is for– not how it is to be implemented– e.g., PDA not as important as “mobile” app.

• A design represents the artifact– for UIs these representations include (?)

• screen sketches or storyboards• flow diagrams/outline showing

task structure• executable prototypes

– representations simplify

Write essay start word processor write outline fill out outlineStart word processor find word processor icon double click on iconWrite outline write down high-level ideas

.

.

.

Page 9: Computer –the machine the program runs on –often split between clients & servers Human-Computer Interaction (HCI) Human –the end-user of a program –the.

Web Design RepresentationsSite Maps Storyboards

Schematics Mock-ups

Page 10: Computer –the machine the program runs on –often split between clients & servers Human-Computer Interaction (HCI) Human –the end-user of a program –the.

Usability

According to the ISO:The effectiveness, efficiency, and satisfaction with which specified users achieve specified goals in particular environments

• This does not mean you have to create a “dry” design or something that is only good for novices – it all depends on your goals

Page 11: Computer –the machine the program runs on –often split between clients & servers Human-Computer Interaction (HCI) Human –the end-user of a program –the.

Usability Goals

– Learnable• faster the 2nd time & so on

– Memorable• from session to session

– Flexible• multiple ways to

accomplish tasks

– Efficient• perform tasks quickly

– Robust• minimal error rates• good feedback so user can recover

– Pleasing• high user satisfaction

– Fun

• Set goals early & later use to measure progress• Goals often have tradeoffs, so prioritize• Example goals

Page 12: Computer –the machine the program runs on –often split between clients & servers Human-Computer Interaction (HCI) Human –the end-user of a program –the.

User-centered Design“Know thy User”

• Cognitive abilities– perception– physical manipulation– memory

• Organizational / job abilities • Keep users involved throughout– developers working with target users– think of the world in users terms– understanding work process– not technology-centered/feature driven

Page 13: Computer –the machine the program runs on –often split between clients & servers Human-Computer Interaction (HCI) Human –the end-user of a program –the.

Task Analysis & Contextual Inquiry

• Observe existing work practices

• Create examples and scenarios of actual use

• “Try-out”new ideas before building software

?

Page 14: Computer –the machine the program runs on –often split between clients & servers Human-Computer Interaction (HCI) Human –the end-user of a program –the.

Rapid Prototyping

• Build a mock-up of design so you can test

• Low fidelity techniques– paper sketches– cut, copy, paste

• Interactive prototyping tools– HTML, Visual Basic,

HyperCard, Director, Flash, DENIM, etc.

• UI builders– Visual Studio .NET,

JBuilder…

Fantasy Basketball

Page 15: Computer –the machine the program runs on –often split between clients & servers Human-Computer Interaction (HCI) Human –the end-user of a program –the.

ESP

Evaluation

• Test with real users (participants)– w/ interactive prototype– low-fi with paper

“computer”

• Build models

• Low-cost techniques– expert evaluation– walkthroughs – online testing

Page 16: Computer –the machine the program runs on –often split between clients & servers Human-Computer Interaction (HCI) Human –the end-user of a program –the.

Programming

• Toolkits

• UI Builders

• Event models

• Input / Output models

• etc.

We will focus on design constraints imposed by these technologies

Page 17: Computer –the machine the program runs on –often split between clients & servers Human-Computer Interaction (HCI) Human –the end-user of a program –the.

Goals

1) Learn to design, prototype, & evaluate UIs– the needs & tasks of prospective users– cognitive/perceptual constraints that affect design– technology & techniques used to prototype UIs– techniques for evaluating a user interface design– importance of iterative design for usability

2) Understand where technology is going & what UIs of the future might be like

Page 18: Computer –the machine the program runs on –often split between clients & servers Human-Computer Interaction (HCI) Human –the end-user of a program –the.

Further ReadingIntroduction to HCI

• Web Sites– useit.com– HCIindex at http://degraaff.org/hci/

• Organizations– ACM SIGCHI, BayCHI, UPA, Stanford PCD Seminar