1. Introduction
1.1. Definition
1.1.1. The study of how humans interact with the computer systems
1.2. User interface
1.2.1. Is the part of computer system which interact with users to use this system and achieve the goal
1.2.2. As the 'bridge' between users and system
1.3. Introduction to user interface design
1.3.1. A good user interface design should:
1.3.1.1. Easy to use
1.3.1.2. Easy to learn
1.3.1.3. Allow users to achieve goal w/ minimum frustration
1.3.2. Usability
1.3.2.1. i. Effectiveness
1.3.2.2. ii. Satisfaction
1.3.2.3. iii. Efficiency
1.3.2.4. Important to consider the context which used by the specified user
1.3.2.5. Usability is important in relation to design a good or bad interface
1.3.3. Poor design interface
1.3.3.1. Effect of poor designed interface:
1.3.3.1.1. a. User frustration and dissatisfaction
1.3.3.1.2. b. Loss of productivity, efficiency and money
1.3.3.1.3. c. Safety issues
1.3.3.1.4. d. Small irritations
1.4. User-Centered Design
1.4.1. An approach to user interface design and development
1.4.2. Principles:
1.4.2.1. Active involvement of users
1.4.2.2. An appropriate allocation of function between user and system
1.4.2.3. Iteration of design solutions
1.4.2.4. Multidisciplinary design teams
1.4.3. Activities:
1.4.3.1. Understand and specify the context of use
1.4.3.2. Specify the user and organizational requirements
1.4.3.3. Produce design solutions
1.4.3.4. Evaluate designs with users against requirements
1.5. Evaluation
1.5.1. When evaluation?
1.5.1.1. Early in the life cycle, (validate & predict)
1.5.1.1.1. To validate user's requirement
1.5.1.1.2. Predict the usability of the product
1.5.1.2. Later in the life cycle, (check & assess)
1.5.1.2.1. To assess how well the interface meets the users' needs
1.5.1.2.2. Check the usability of the nearly completed system
1.5.2. How to evaluate?
1.5.2.1. Observation
1.5.2.2. Interviewing/talking/asking questions
1.5.2.3. Make predictions
2. 1. Requirement phase
2.1. LU 2: Requirements Gathering Techniques
2.1.1. Observation
2.1.1.1. Direct Observation
2.1.1.1.1. Field studies
2.1.1.1.2. Controlled studies
2.1.1.2. Indirect Observation
2.1.1.2.1. Use video recording as it provide permanent record of the observation
2.1.1.2.2. Take more time to analysis, users feel awkward
2.1.2. Interview
2.1.2.1. Structured Interview
2.1.2.1.1. Pre-determined questions asked in sequence
2.1.2.1.2. No scope for additional topics,
2.1.2.2. Flexible Interview
2.1.2.2.1. Explore more topic for discuss
2.1.2.2.2. Less formal, interviewer free to explore additional topic
2.1.3. Surveys and Questionnaires
2.1.3.1. Use unambiguous questions, statements to gather information
2.1.3.2. Open questions
2.1.3.2.1. Free to respond related to question
2.1.3.2.2. Provide richer data although take more time to analyze
2.1.3.3. Closed questions
2.1.3.3.1. Only answer in a predefined way
2.1.3.3.2. Easier to analyze
2.2. LU 3: Users and Domain
2.2.1. Users
2.2.1.1. Primary users
2.2.1.1.1. Interact directly with the application
2.2.1.2. Secondary users
2.2.1.2.1. Interact with the application through primary user
2.2.1.3. Design based on -physical characteristics & psychological characteristics, physical limitations
2.2.2. User Profile, Personas
2.2.2.1. Describe users and characteristics
2.2.2.2. Analysis- process of taking information gathered and final conclusion translate to requirement
2.2.2.3. Persona- precise description of user based on imaginary examples
2.2.3. User's needs
2.2.3.1. Felt needs
2.2.3.1.1. Hidden/slow in identified
2.2.3.1.2. User not understand what they need
2.2.3.2. Expressed needs
2.2.3.2.1. What people say they want
2.3. LU 4: Tasks and Work
2.3.1. Tasks
2.3.1.1. Goal
2.3.1.1.1. End result to be achieved
2.3.1.2. Task
2.3.1.2.1. Structured set of related activities that are undertaken in some sequence
2.3.1.3. Action
2.3.1.3.1. Individual step/operation that needs to be done
2.3.2. Characteristics
2.3.2.1. Use to describe the task
2.3.2.2. Information gathered through interviews, observations, consulting documentations
2.3.3. Task Analysis
2.3.3.1. Process of examining the way where people perform their tasks
2.3.3.2. Work analysis
2.3.3.2.1. Horizontal pictures of how moves across people
2.3.3.2.2. describe how a group people cooperate to get the job done
2.3.3.3. Job analysis
2.3.3.3.1. Vertical pictures of all the type of work performed by particular individuals
2.3.3.3.2. Observe the responsibility of individual worker
2.3.3.4. Clues to analysis:
2.3.3.4.1. 1. Observe users
2.3.3.4.2. 2. Work around
2.3.3.4.3. 3. Artifact
2.3.3.5. Technique:
2.3.3.5.1. Task scenario
2.3.3.5.2. Concrete Use Case
2.3.3.5.3. Essential Use Case
2.3.3.5.4. Use Scenario
2.3.4. Mental models
2.3.4.1. Definition
2.3.4.1.1. an explanation of someone's thought process about how something works in the real world
2.3.4.2. Structural model
2.3.4.2.1. Structure of how a particular device or system works
2.3.4.2.2. Assume user has internalized in memory
2.3.4.2.3. e.g: LRT routes
2.3.4.3. Functional model
2.3.4.3.1. User has internalized procedural knowledge about how to use device or system
2.3.4.3.2. Developed from past knowledge
2.3.4.3.3. e.g.:How to get on and off the train
2.3.5. Environmental Considerations
2.3.5.1. Physical
2.3.5.1.1. Sufficient lighting? Dusty? Dirty?
2.3.5.2. Safety
2.3.5.2.1. Health & safety issue, hazards, pollutions, stress level
2.3.5.3. Social
2.3.5.3.1. Do they depend/help/distract each other?
2.3.5.4. Organizational
2.3.5.4.1. Purpose,mission and aims of the organizational
2.3.5.5. User support
2.3.5.5.1. Provide training/experts to guide novices
2.4. *LU 5: User Interface Design Knowledge
2.4.1. Psychological principles
2.4.1.1. 1. Users see what they expect to see
2.4.1.1.1. Principle of consistency
2.4.1.1.2. Principle of exploiting prior knowledge
2.4.1.2. 2. Users have difficulty focusing on more than one activity at a time
2.4.1.2.1. Principle of perceptual organization
2.4.1.2.2. Principle of importance
2.4.1.3. 3. It is easier to perceive a structured layout, (PC2S2)
2.4.1.3.1. Law of proximity
2.4.1.3.2. Law of similarity
2.4.1.3.3. Law of closure
2.4.1.3.4. Law of continuity
2.4.1.3.5. Law of symmetry
2.4.1.3.6. Figure-ground segregation
2.4.1.3.7. Banner blindness
2.4.1.4. 4. It is easier to recognize something than to recall it
2.4.1.4.1. Principle of recognition
2.4.2. Experience principles, (V.A.F)
2.4.2.1. Principles of visibility (WHAT)
2.4.2.1.1. Obvious what a control is used for
2.4.2.1.2. Start from the goal to be achieved
2.4.2.2. Principle of affordance (HOW)
2.4.2.2.1. Obvious how a control is used
2.4.2.2.2. Give suggestion on how to operate the system
2.4.2.3. Principle of feedback (WHEN)
2.4.2.3.1. Obvious when a control has been used
2.4.2.3.2. Receive feedback by the user about the improvement of the system
2.5. LU 6: Usability Requirements and Prototyping
2.5.1. Usability requirements
2.5.1.1. Process of compromise between different constraints and trade-offs
2.5.1.2. Qualitative
2.5.1.2.1. Describe desired features
2.5.1.2.2. Subjective
2.5.1.3. Quantitative
2.5.1.3.1. Usability metrics
2.5.1.4. Early views of usability
2.5.1.4.1. Bennett(1984)
2.5.1.4.2. Tyldesley (1988)
2.5.1.5. Modern of usability
2.5.1.5.1. Quesenbery's 5Es
2.5.1.6. Constraints that may affect
2.5.1.6.1. Costs/budgets/timescales
2.5.1.6.2. Technology available, interoperability with hardware and software
2.5.1.6.3. Stakeholder's agenda
2.5.1.6.4. Contradictory requirements
2.5.1.6.5. Organizational policies
2.5.1.7. Requirements specification
2.5.1.7.1. User Characteristics
2.5.1.7.2. Tasks and task characteristics
2.5.1.7.3. Various environmental factors
2.5.1.7.4. Usability requirements
2.5.1.7.5. Statements of constraints, trade-offs and any requirements negotiations
2.5.2. Prototyping
2.5.2.1. Incomplete design of an product/system
2.5.2.2. Can be used in 2 ways:
2.5.2.2.1. Early stage in design process
2.5.2.2.2. Later in design process
2.5.2.3. Purpose
2.5.2.3.1. To check feasibility of ideas with users
2.5.2.3.2. Test the usefulness of the application
2.5.2.3.3. Allow user contribute ideas to design
2.5.2.3.4. To validate and negotiate requirements
2.5.2.4. Type of prototype
2.5.2.4.1. Low-fidelity
2.5.2.4.2. High-fidelity
3. 3. Evaluation phase
3.1. LU 16 - Why Evaluate the Usability of User Interface Designs?
3.1.1. A.K.A. usability testing, user testing, user try-out, inspection
3.1.2. Usability evaluation helps to
3.1.2.1. To understand the user's experience.
3.1.2.2. Identify difficulties / problems & find ways to improve.
3.1.2.3. If UI meets requirements specified.
3.1.3. Why evaluate usability of UI designs?
3.1.3.1. To assess the dimensions of usability (Quesenbery's 5Es).
3.1.3.1.1. 1. Effective
3.1.3.1.2. 2. Efficient
3.1.3.1.3. 3. Engaging
3.1.3.1.4. 4. Error tolerant
3.1.3.1.5. 5. Easy to learn
3.1.3.2. Explore particular areas of concern in relation to usability.
3.1.3.3. Consider user's environment (actual / simulated).
3.1.4. Activities of usability evaluation
3.1.4.1. Process includes: (iterative process)
3.1.4.1.1. 1. Evaluation strategy
3.1.4.1.2. 2. Evaluation plan
3.1.4.1.3. 3. Evaluation sessions
3.1.4.1.4. 4. Analyze & interpret data
3.1.4.1.5. 5. Make changes / conduct further evaluation (if needed)
3.1.4.2. 3 possible situations:
3.1.4.2.1. 1. Usability requirements are MET
3.1.4.2.2. 2. UNSURE IF usability requirements are MET
3.1.4.2.3. 3. Usability requirements are NOT MET
3.1.4.3. Techniques:
3.1.4.3.1. 1. User observations
3.1.4.3.2. 2. Inspections of UI
3.1.4.3.3. 3. Other evaluation techniques
3.1.5. What happens in user observation evaluation session?
3.1.5.1. 1. Welcome
3.1.5.1.1. Explain the purpose of the evaluation and their role.
3.1.5.1.2. Obtain consent, don't make them feel pressure to do so.
3.1.5.1.3. Pre-test questionnaires (expectations).
3.1.5.1.4. Commercial product test, keep it confidential by signing NDA (Non disclosure agreement).
3.1.5.2. 2. Main part
3.1.5.2.1. Ask participants to complete tasks.
3.1.5.2.2. Observe & record.
3.1.5.3. 3. Completed task
3.1.5.3.1. Ask for participant's views on experience / complete post-test questionnaires.
3.1.5.4. 4. Closing
3.1.5.4.1. Make the participants feel appreciated.
3.2. LU 17 - Deciding on What You Need to Evaluate: The Strategy
3.2.1. Purpose of evaluation:
3.2.1.1. 1. Establish whether system meets usability requirements.
3.2.1.2. 2. Exploring concerns.
3.2.2. Types of usability requirements:
3.2.2.1. 1. Qualitative, (immeasurable)
3.2.2.1.1. Described desired features.
3.2.2.1.2. Subjective.
3.2.2.1.3. Not always easy to measure / quantify.
3.2.2.2. 2. Quantitative, (can be counted)
3.2.2.2.1. Explicit measures (percentages, timings, numbers, ratings).
3.2.2.2.2. A.K.A usability metrics.
3.2.2.2.3. Consider the type of user (novice vs expert).
3.2.3. Type of data to collect:
3.2.3.1. 1. Qualitative data
3.2.3.1.1. Data w/out numeric content
3.2.3.2. 2. Quantitative data
3.2.3.2.1. Numeric data derived from taking measurements
3.2.4. What am I evaluating???
3.2.4.1. Low fidelity
3.2.4.1.1. Limited to asking about proposed navigation, choice of colours (qualitative requirements).
3.2.4.1.2. Story board / content diagram.
3.2.4.2. High fidelity
3.2.4.2.1. Involves interactivity, detailed evaluation (quantitative measurement).
3.2.4.2.2. Interactive software prototype.
3.2.5. Constraints to be considered:
3.2.5.1. Money
3.2.5.2. Timescales
3.2.5.3. Availability of usability equipment
3.2.5.3.1. i.e.: Recording devices
3.2.5.4. Availability of participants & costs of recruiting them
3.2.5.5. Availability of evaluators
3.2.6. Document evaluation strategy
3.2.6.1. Basically a report after doing evaluation session.
3.2.6.2. - Specific concerns to ask users about.
3.2.6.3. - Data to collect.
3.2.6.4. - Prototype to be tested.
3.2.6.5. - Constraints.
3.3. LU 18 - Planning Who, What, When and Where
3.3.1. WHO? Choosing your users
3.3.1.1. Repeated session to get variety of views.
3.3.1.2. Aiming for real users (target user for the system).
3.3.1.3. 5 participants is sufficient.
3.3.1.3.1. More participants = more data to analyze
3.3.1.3.2. In case fails to turn up, recruit floaters (proxy).
3.3.1.3.3. Offer incentives afterwards.
3.3.1.4. How to look for real user?
3.3.1.4.1. Depends on circumstances.
3.3.1.5. Users working along / in pairs
3.3.1.5.1. In some situation, the participant needed an interpreter, but keep in mind to speak to the participant not the interpreter.
3.3.2. WHEN? Creating timetable
3.3.2.1. Duration: 30 to 90 mins.
3.3.2.1.1. Longer session = tired participant = ineffective evaluation
3.3.2.2. Based on working hours: 8 hrs per day.
3.3.2.3. Create timetable sooner, easier to keep track.
3.3.3. WHAT? Prepare task descriptions
3.3.3.1. Write task scenarios in plain language, simplified for evaluation.
3.3.3.2. Decide which task to administer, not feasible to evaluate all tasks.
3.3.3.3. No. of tasks influenced by:
3.3.3.3.1. 1. Complexity of individual tasks descriptions
3.3.3.3.2. 2. Time allocated for evaluation sessions
3.3.3.3.3. 3. Functionality provided by system / prototype
3.3.3.4. Task cards
3.3.3.4.1. Card w/ task description
3.3.3.4.2. Bring along during evaluation, easy to order tasks.
3.3.4. WHERE? Decide where to do evaluation
3.3.4.1. 1. Field studies
3.3.4.1.1. Environment within which the users work as well as the system.
3.3.4.1.2. Do in natural settings = understand what people do naturally & how products mediate their activities.
3.3.4.2. 2. Controlled studies
3.3.4.2.1. Evaluation at a place other than user's work environment.
3.3.5. Create checklists for all of the above.
3.4. LU 19 - Deciding How to Collect Data
3.4.1. Quantitative data (retrospective protocol)
3.4.1.1. Timing and logging actions
3.4.1.1.1. Use stopwatch / clock to record time related usability metrics.
3.4.1.1.2. Complex tasks, record the whole session.
3.4.1.1.3. Keep track of user's actions
3.4.1.1.4. No provision for aligning notes / comments from participant w/ log of actions.
3.4.2. Qualitative data
3.4.2.1. Observes and listen what participants have to say and do
3.4.2.1.1. 1. Think aloud and offering help
3.4.2.1.2. 2. Take notes when observing users
3.4.3. Conducting post-session discussion
3.4.3.1. Ask participant's further questions about experiences
3.4.3.2. Let participants to give overall feedbacks (reflection).
3.4.3.3. Reassure participants if something doesn't go as plan, never blame them!
3.4.3.4. Intermediate approach, break task into smaller subtasks (5 to 10 mins).
3.4.3.4.1. Include both thinking aloud and retrospective protocol.
3.4.4. Questionnaires
3.4.4.1. Advantages:
3.4.4.1.1. Easy to collect quantitative data.
3.4.4.2. Disadvantages:
3.4.4.2.1. Difficult to design well.
3.4.4.2.2. Predicts topic that users will want to tell.
3.4.4.2.3. Closed questions are easy to analyze but gives little info.
3.4.4.3. Interview them first to probe answers (trigger the participants to think).
3.4.5. Tech. to help recording
3.4.5.1. 1. Video recording
3.4.5.1.1. As backups, in case any observations / notes were missed.
3.4.5.2. 2. Audio recording
3.4.5.2.1. Less intrusive.
3.4.5.2.2. Difficult in relating what user & system are doing.
3.4.5.3. 3. Eye-tracking equipment
3.4.5.3.1. Record exactly what user is looking at.
3.4.5.3.2. Distinguish between glancing and fixing.
3.4.5.3.3. Difficult to set up.
3.4.5.3.4. Analyse frequently view parts of screen.
3.4.5.4. All in all, let the participant choose which they find comfortable.
3.5. LU 20 - Final Preparations for the Evaluation
3.5.1. NDA (Non-disclosure agreements)
3.5.1.1. In case system is proprietary or confidential in nature, ask participants to keep evaluation session confidential.
3.5.2. Consent form
3.5.2.1. Require agreement from participants to take part in evaluation and also permission to record evaluation.
3.5.3. Roles of evaluators
3.5.3.1. Good facilitator = good evaluating session
3.5.3.2. Ensure purpose of evaluation is fulfilled.
3.5.4. Roles & responsibilities of team members
3.5.4.1. Note-taker
3.5.4.1.1. Take note and observe what's happening during evaluation.
3.5.4.2. Equipment operator
3.5.4.2.1. In charge of equipment to reset to initial state.
3.5.4.3. Observer
3.5.4.4. Meeter & greeter
3.5.4.4.1. Access to facilities, refreshments, keep participants entertained if evaluations are running late. (an usher of some sort)
3.5.4.5. Recruiter
3.5.4.5.1. Finds participants and obtains permission to go to participants’ home work environment if field study.
3.5.4.6. Lone evaluator
3.5.4.6.1. All done by one person = allocate more time
3.5.5. Pilot test
3.5.5.1. Way of evaluating the evaluation session & ensure it works prior to a full-scale evaluation.
3.5.5.2. Process of debugging, testing evaluation material, planned time schedule, suitability of task descriptions, running of session.
3.5.5.3. Let participants use the almost complete functioning prototype.
3.6. LU 21 - Analysis and Interpretation of User Observation Evaluation Data
3.6.1. Analysis data
3.6.1.1. 1. Collating data
3.6.1.1.1. Source of data
3.6.1.1.2. Collect notes from all participant
3.6.1.2. 2. Summarize data
3.6.1.2.1. Extract key comments from data
3.6.1.3. 3. Review data to identify usability problems
3.6.1.3.1. If met requirement, analysis done
3.6.1.3.2. If not met, process of analysis continue
3.6.1.3.3. Usability defect
3.6.1.4. Quantitative data
3.6.1.4.1. Method to summarize data
3.6.1.5. Qualitative data
3.6.1.5.1. Insights data
3.6.1.5.2. Arrange data to a coding scheme
3.6.2. Interpret data
3.6.2.1. Decide what caused defect
3.6.2.1.1. Severity rating for usability defect
3.6.2.2. Prioritise recommended changes
3.7. LU 22 - Inspections of the User Interface
3.7.1. Nielsen's heuristics
3.7.1.1. Visibility of system status
3.7.1.1.1. Always update about the system
3.7.1.2. Match between system and real world
3.7.1.2.1. Use users' language
3.7.1.3. User control and freedom
3.7.1.3.1. Give clear instruction likes "undo" button
3.7.1.4. Consistency and standards
3.7.1.5. Error prevention
3.7.1.6. Recognition rather than recall
3.7.1.6.1. Provide visible instruction
3.7.1.7. Flexibility and efficiency of use
3.7.1.8. Aesthetic and minimalist design
3.7.1.8.1. Only put important information
3.7.1.9. Help users to recognize, diagnose and recover from errors
3.7.1.10. Help and documentation
3.7.1.10.1. Provide help and documentation
3.7.2. How to conduct heuristic evaluation?
3.7.2.1. Use recording when evaluation session with inspector
3.7.2.2. Set location of evaluation session
3.7.2.3. Collect evaluation form to analysis data
3.7.3. Consider benefits and limitation of HE
3.7.4. Usability inspection variations
3.7.4.1. Participatory heuristics evaluation
3.7.4.1.1. System status
3.7.4.1.2. User control and freedom
3.7.4.1.3. Consistency and relevancy
3.7.4.1.4. Error recognition and recovery
3.7.4.1.5. Task and work support
3.7.4.2. Review guideline
3.7.4.3. Standard inspections
3.7.4.4. Cognitive walkthrough
3.7.4.5. Peer reviews
3.8. LU 23 - Variations and More Comprehensive Evaluations
3.8.1. Element to compare user observation and heuristic evaluation
3.8.1.1. Observe
3.8.1.2. Compare
3.8.1.3. Listen
3.8.1.4. Measure
3.8.2. Get opinion without product by
3.8.2.1. Focus groups
3.8.2.2. Card sort
3.8.3. Evaluate without people by
3.8.3.1. Accessibility checkers & HTML validators
3.8.3.2. Usability checkers
3.8.3.3. Hybrid methods
4. 2. Design phase
4.1. LU 7 - Work Reengineering and Conceptual Design
4.1.1. Work reengineering - identifying how a UI can best support users’ work. (task allocation)
4.1.1.1. Automation makes possible.
4.1.1.2. Supports business goals.
4.1.1.3. Minimize retraining by having new product tap.
4.1.2. Task allocation - deciding how various tasks will be shared between the user and the computer system
4.1.2.1. Designer needs to decide:
4.1.2.1.1. Who or what kind of data/knowledge necessary to accomplish a task.
4.1.2.1.2. Who or what will physically accomplish the task.
4.1.2.2. Use scenarios & essential use cases - for task allocation process
4.1.2.2.1. Use scenarios > essential UC > concrete UC
4.1.2.2.2. Use scenarios focus on the users and how they will carry out their tasks.
4.1.2.2.3. Essential UC does not contain any specific details. (e.g. tech used / task details)
4.1.2.2.4. Concrete UC added details to the essential UC.
4.1.2.2.5. Conceptual design - establishes underlying structure & organisation of the UI.
4.2. LU 8 - Design Guidance and Design Rationale
4.2.1. Sources of design guidance
4.2.1.1. 1. Design principles
4.2.1.1.1. 4 important design principles:
4.2.1.2. 2. Design rules
4.2.1.3. 3. Standards
4.2.1.3.1. A set of internationally agreed design principles/ approaches that define standards for UI design.
4.2.1.3.2. Standards doc. are official & publicly available.
4.2.1.3.3. International Organization for Standardization (ISO)
4.2.1.4. 4. Style guides
4.2.1.4.1. A description of the required interaction styles and the user interface controls, covering both the required look (appearance) and feel (behavior).
4.2.1.4.2. 2 types:
4.2.1.5. 5. Guidelines
4.2.1.5.1. Limitations:
4.2.2. Design for accessibility
4.2.2.1. 7 Principles of universal design to support accessibililty
4.2.2.1.1. 1. Equitable use
4.2.2.1.2. 2. Flexibility in use
4.2.2.1.3. 3. Simple & intuitive use
4.2.2.1.4. 4. Perceptible info
4.2.2.1.5. 5. Error tolerance
4.2.2.1.6. 6. Low physical effort
4.2.2.1.7. 7. Size & space for approach & use
4.2.2.2. 14 general principles of accessible design according to W3C
4.2.2.2.1. 1. Provide alt. to auditory & visual content.
4.2.2.2.2. 2. Don't rely on colour alone.
4.2.2.2.3. 3. Use markup & style sheets.
4.2.2.2.4. 4. Clarify usage of natural language.
4.2.2.2.5. 5. Create table that transform gracefully.
4.2.2.2.6. 6. Ensure pages featuring new tech. transform gracefully.
4.2.2.2.7. 7. Ensure user control of time-sensitive content (gif).
4.2.2.2.8. 8. Ensure direct accessibility of embedded UI.
4.2.2.2.9. 9. Design for device-independence.
4.2.2.2.10. 10. Use interim solutions (temporary accessibility).
4.2.2.2.11. 11. Use W3C tech. & guidelines.
4.2.2.2.12. 12. Provide context & orientation info.
4.2.2.2.13. 13. Provide clear navigation mechanism.
4.2.2.2.14. 14. Ensure that doc. are clear & simple.
4.2.3. Design rationale - design decision made & reason(s) why the decision was made.
4.2.3.1. The reasons & benefits for documenting it:
4.2.3.1.1. Provide info to justify.
4.2.3.1.2. Provide explicit representation
4.2.3.1.3. Provide systematic & principled way of doing things
4.2.3.1.4. Provide record
4.2.3.1.5. Provide documentation for people to understand
4.2.3.1.6. Provide ability to reuse parts of the UI
4.3. LU 9 - Interaction Design
4.3.1. Human Action Cycle, Norman (1998)
4.3.1.1. The cycle shows the way users perform actions and tasks to achieve their goals.
4.3.1.2. Adapted for understanding interaction process.
4.3.1.2.1. Form goal > Formulates tasks > Specifies actions > Does actions > Perceive outcome > Interprets outcome > Evaluates outcome
4.3.1.3. 3 main stages :
4.3.1.3.1. 1. Goal formation
4.3.1.3.2. 2. Execution stage
4.3.1.3.3. 3. Evaluation stage
4.3.2. Norman & Draper's view (1986)
4.3.2.1. Used to communicate the designer’s understanding of the system, while reflecting an awareness of the user’s existing mental model
4.3.2.2. Consists of:
4.3.2.2.1. Designer's model
4.3.2.2.2. User's model
4.3.2.2.3. System image
4.3.3. Use metaphors to develop accurate mental models
4.3.3.1. Figure of speech / analogy of some sort.
4.3.3.1.1. i.e.: The trash icon on the desktop resembles a trashcan irl. / the paper in MS Word.
4.3.3.2. All UIs are artificial environments created by the computer, which we can understand only because of our experience of the physical world
4.3.3.2.1. Users might not be familiar of certain metaphors due to age/culture differences
4.3.3.3. Should be iterative and user centered.
4.3.3.4. UI must be usable w/ or w/out metaphors.
4.4. LU 10 - Interaction Styles
4.4.1. The ways a user can communicate with a computer system (and vice versa), in term of appearance and behaviour of UI components.
4.4.2. Types of interaction styles:
4.4.2.1. Command line
4.4.2.1.1. First interactive dialog style to be commonly used.
4.4.2.1.2. Pros:
4.4.2.1.3. Cons:
4.4.2.2. Menu selection
4.4.2.2.1. A set of options from which the user must choose.
4.4.2.2.2. Offer cues for user recognition rather than forcing the users to recall the syntax of a command. (Recognize > recall)
4.4.2.2.3. Name & icons should be self-explanatory
4.4.2.3. Form-fill
4.4.2.3.1. Allow for easy movement around the form and for some fields to be left blank.
4.4.2.3.2. Include correction facilities.
4.4.2.3.3. Mimic predictable order.
4.4.2.3.4. Guidelines:
4.4.2.4. Direct manipulation
4.4.2.4.1. Allows user to interact directly w/ UI objects.
4.4.2.4.2. i.e.: Drag a file from one folder to another.
4.4.2.4.3. WYSIWYG - what you see is what you get.
4.4.2.5. Anthropomorphic
4.4.2.5.1. Aims to interact with users in the same way that humans interact with each other.
4.4.2.5.2. Requires an understanding of hardware, software and how humans communicate with each other.
4.4.2.5.3. Why we need it?
4.5. LU 11 - Choosing Interaction Devices (hardware) and Interaction Elements (Software)
4.5.1. Hardware components
4.5.1.1. I/O devices
4.5.1.1.1. Keyboard / keypads / buttons
4.5.1.1.2. Pointing devices
4.5.1.1.3. Screens
4.5.1.1.4. Loudspeakers
4.5.1.1.5. Head mount display (HMD)
4.5.1.1.6. Stereoscopic displays
4.5.2. Software components
4.5.2.1. Text
4.5.2.1.1. Small files.
4.5.2.1.2. Can be manipulate easily.
4.5.2.1.3. Less ambiguous.
4.5.2.1.4. Factors affect legibility:
4.5.2.2. Colour
4.5.2.2.1. Why?
4.5.2.2.2. Intrinsic brightness
4.5.2.3. Images
4.5.2.3.1. Reasons:
4.5.2.3.2. Type of images:
4.5.2.4. Moving images
4.5.2.4.1. Animations & video clips
4.5.2.5. Sound
4.5.2.5.1. Useful as an output when people cannot easily see a visual prompt.
4.5.2.5.2. Requires when:
4.5.2.5.3. Sound effects can:
4.5.2.5.4. Michaelis & Wiggins (1982) - speech outputs is most effective when the message:
4.5.2.5.5. Sound is not good at conveying detailed information unless accompanied by text, video or still images. (concatenation prob.)
4.6. LU 12 - Moving from Choosing Components into Design Areas
4.6.1. Principles of good layout
4.6.1.1. 1. Create natural groupings
4.6.1.1.1. Group together all menus and icons relating to particular concept.
4.6.1.1.2. Make visible boundary around grouped menus / icons.
4.6.1.2. 2. Separate currently active components
4.6.1.2.1. The tab bars of a browser, active windows will be at the top while title bar will be highlighted. (hover effect)
4.6.1.3. 3. Emphasize important components
4.6.1.3.1. Stress on components that really matter.
4.6.1.3.2. Panic button is red colour.
4.6.1.4. 4. Use white space effectively
4.6.1.4.1. Areas on screen that do not contain any other software components.
4.6.1.4.2. Clarify the layout of the UI better.
4.6.1.5. 5. Make controls visible
4.6.1.5.1. Obvious function
4.6.1.5.2. Complements psychological principle, recognize > recall
4.6.1.6. 6. Balance aesthetics & usability
4.6.1.6.1. Coloured mobile phones targeted at teenagers
4.6.1.6.2. The limited coloured range of MacBooks.
4.6.2. Design areas
4.6.2.1. GUI
4.6.2.1.1. Choose and combine the correct widgets.
4.6.2.2. Web
4.6.2.3. Embedded systems
4.6.2.3.1. Technological convergence - merging of different design areas.
4.7. *LU 13 - Designing a Graphical User Interface (GUI)
4.7.1. Appearance of widgets in diff. pieces of software
4.7.1.1. Different OS has different widgets
4.7.1.1.1. i.e.: MacOS vs Windows OS
4.7.2. Choosing widgets to strucutre the interaction
4.7.2.1. 1. Primary windows
4.7.2.1.1. Often corresponds to the main task objects in conceptual design.
4.7.2.1.2. Acts as a base to which the user keeps returning. (Launch pad)
4.7.2.2. 2. Secondary windows
4.7.2.2.1. Complements primary window.
4.7.2.2.2. Provide additional functionality and support for the user.
4.7.2.3. 3. Tabs
4.7.2.3.1. For classifying the properties of a task object represented by a window.
4.7.2.3.2. Organize data = less complete screens.
4.7.3. Choosing widgets to control interaction
4.7.3.1. 1. Menus
4.7.3.1.1. Drop down menus
4.7.3.1.2. Cascading menus
4.7.3.1.3. Roll-up menus
4.7.3.1.4. Pop-up menus
4.7.3.2. 2. Tool bars
4.7.3.2.1. A program can have a selection of different tool bars each for different areas in the program’s functionalities. (The top thingy in MS Word)
4.7.3.2.2. Can be made invisible / hidden.
4.7.3.2.3. Desirable properties (Horton, 1991):
4.7.3.3. 3. Command button
4.7.3.3.1. Used for controlling operations of dialog boxes.
4.7.3.3.2. Issues to be considered:
4.7.4. Choosing widgets to enter information
4.7.4.1. 1. Option buttons
4.7.4.1.1. A.K.A . radio button, can only select one.
4.7.4.2. 2. Check boxes
4.7.4.2.1. When user required to choose more than one.
4.7.4.3. 3. List boxes
4.7.4.3.1. Allow user to choose from large no. of options (country of origin).
4.7.4.4. 4. Text boxes
4.7.4.4.1. Use if it is not possible to anticipate user input or if you do not wish to constrain choice.
4.7.4.4.2. List box + Text box = combo box
4.7.5. Combining GUI widgets
4.7.5.1. i.e.: Your typical sign in page.
4.8. *LU 14 - Designing for the Web
4.8.1. *Design principles for websites (HOMERUN), Nielsen (2000)
4.8.1.1. 1. High quality content
4.8.1.1.1. Provide info / function that target users want.
4.8.1.2. 2. Often updated
4.8.1.2.1. Update content regularly
4.8.1.3. 3. Minimal download time
4.8.1.3.1. Slow download pages = frustration
4.8.1.3.2. Avoid unnecessary graphics / videos / animations.
4.8.1.4. 4. Ease of use
4.8.1.4.1. User can find what they need quickly and easily .
4.8.1.5. 5. Relevant to user's needs
4.8.1.5.1. Allow user to carry out the tasks they want to perform.
4.8.1.6. 6. Unique to online medium
4.8.1.6.1. Benefits of using a website vs. hardcopy.
4.8.1.7. 7. Net-centric corporate culture
4.8.1.7.1. Good websites can be the difference between success or failure .
4.8.2. Designing websites
4.8.2.1. 3 specific areas for designing websites:
4.8.2.1.1. Designing the website structure
4.8.2.1.2. Help users to know where they are
4.8.2.1.3. Help users to navigate around the site
4.8.2.2. Navigation aids
4.8.2.2.1. Provide users with an overview of the site structure and enable them to move around the site.
4.8.2.2.2. Link + link = navigation aids
4.8.3. Designing home page & interior page
4.8.3.1. 1. Home page
4.8.3.1.1. The first page you'll see when opening a website.
4.8.3.2. 2. Interior page
4.8.3.2.1. Other pages within site once home page is left.
4.8.4. Design issues for webpages
4.8.4.1. 1. Widgets on webpages
4.8.4.2. 2. Scrolling
4.8.4.2.1. Scrolling horizontally = interrupts reading flow
4.8.4.3. 3. Design for diff. screens & platform
4.8.4.3.1. Handheld devices = small screen issue
4.8.4.3.2. Visually impaired = larger type size
4.8.4.3.3. Specify image-safe area
4.8.4.4. 4. Use screen area effectively
4.8.4.4.1. White space, emphasizing info structure
4.8.4.4.2. > 50% screen content
4.8.4.5. 5. Improve download time
4.8.4.5.1. Cut down unnecessary content
4.8.4.6. 6. Design for accessibility
4.8.4.6.1. Low vision
4.8.5. Writing content of webpages
4.8.5.1. 1. Keep text to minimum
4.8.5.2. 2. Enable users to scan to pick important points
4.8.5.2.1. Meaningful headings
4.8.5.2.2. Include bulleted & numbered lists
4.8.5.2.3. Emphasize important issues & topics
4.8.5.3. 3. Divide long blocks of text into separate sections
4.8.5.3.1. Split into sections
4.8.5.3.2. Associate links
4.8.5.3.3. Split text into chunks
4.9. *LU 15 - Design of Embedded Computer Systems and Small Devices
4.9.1. Design of embedded computer systems
4.9.1.1. 1. Safety critical systems
4.9.1.1.1. Computer systems in which human and environmental safety are of paramount concern.
4.9.1.1.2. Take into account hazards that may arise & how users can be supported.
4.9.1.2. 2. Information Appliances (IA)
4.9.1.2.1. An application specialising in information, designed to perform specific task and the ability to share info among themselves.
4.9.1.3. Design guidelines:
4.9.1.3.1. 1. To select vs to type
4.9.1.3.2. 2. Be consistent
4.9.1.3.3. 3. Consistency between platforms
4.9.1.3.4. 4. Design stability
4.9.1.3.5. 5. Provide feedbacks
4.9.1.3.6. 6. Forgiveness
4.9.1.3.7. 7. Use metaphors
4.9.1.3.8. 8. Clickable graphics should look clickable
4.9.1.3.9. 9. Icons to clarify concepts
4.9.1.4. Guidelines specific to manufacturer
4.9.1.4.1. Follow the guidelines provided to create 3rd party app.
4.9.1.5. Guidelines for kiosks
4.9.1.5.1. Error tolerant
4.9.1.5.2. Easy to learn
4.9.1.5.3. Used by everyone
4.9.2. Guide to Mobile app UI design
4.9.2.1. 1. Minimize cognitive load
4.9.2.1.1. Less friction & user's confusion = higher chances user to retain the app.
4.9.2.2. 2. Optimize interactions for the medium
4.9.2.2.1. Consider the different constraints for desktops and handheld devices.
4.9.2.2.2. Designed elements should look like how they behave.
4.9.2.3. 3. Design finger-friendly tap targets
4.9.2.3.1. The case of "fat fingers", hehehehe
4.9.2.3.2. Make actionable elements in mobile interfaces big enough & w/ proper spacing in between.
4.9.2.3.3. Rule of thumb: design controls that have touch area of 7-10 mm.
4.9.2.3.4. Consider thumb zone
4.9.2.4. 4. Design for interruption
4.9.2.4.1. Allow users to re-engage w/ an app when they return to it after interruption.
4.9.2.4.2. Doesn't refresh notifications automatically.
4.9.2.5. 5. Intuitive gestures
4.9.2.5.1. Only use gestures that are most natural for an app.
4.9.2.5.2. When visible control is replaced w/ a gesture = increase learning curve for app
4.9.2.6. 6. Make the app appear fast w/ skeleton screens
4.9.2.6.1. Mobile app must be fast and responsive, but it may not be possible at all time, due to Internet connection.
4.9.2.6.2. It doesn't involve data loading hence user's attention can focus on the progress instead of wait time.
4.9.2.7. 7. Design zero state
4.9.2.7.1. The state in which nothing has yet to occur.
4.9.2.7.2. Provide direction & guidance for getting up & running w/ the app.
4.9.2.7.3. Never show a blank canvas or dead-end interface.
4.9.2.7.4. Make error message readable & helpful.
4.9.2.8. 8. Use functional animation to improve interaction
4.9.2.8.1. Make the interface alive and responsive.
4.9.2.8.2. Visible system status.
4.9.2.8.3. Visual sign of progress = sense of control over app
4.9.2.9. 9. Role of animation in mobile app
4.9.2.9.1. Navigational transition
4.9.2.9.2. Visual feedback
4.9.2.10. 10. Humanize digital experience
4.9.2.10.1. Personalization
4.9.2.10.2. Delightful animation
4.9.2.11. 11. Push the value
4.9.2.11.1. Each notification should be valuable & well-timed.
4.9.2.11.2. Avoid sending too many notifications in short period
4.9.2.11.3. Time your notification
4.9.2.11.4. Consider other channels to deliver your message
4.9.3. UI Design Guide for Wearable technologies UI design
4.9.3.1. 1. Design for glanceability
4.9.3.1.1. Info being designed for short moments of interaction.
4.9.3.1.2. Only display crucial info on the screen.
4.9.3.2. 2. Design for context
4.9.3.2.1. Context is the backbone for a wearable device.
4.9.3.2.2. Provide info in a glance.
4.9.3.2.3. Utilise built-in device sensor (Geolocation).
4.9.3.3. 3. Design lightweight interactions
4.9.3.3.1. User interaction as short as possible (not more than 10 secs).
4.9.3.3.2. Minimize interaction & simple interface.
4.9.3.3.3. Offer quick response & voice input features.
4.9.3.4. 4. Design a clear minimalistic interface
4.9.3.4.1. Able to read whatever displayed on the screen.
4.9.3.4.2. Able to interact with it while in moving condition.
4.9.3.4.3. Sharp contrast.
4.9.3.4.4. Simple typography.
4.9.3.4.5. Enough space between elements.
4.9.3.5. 5. Minimize interruption
4.9.3.5.1. Info pushed to a user via wearable should be filtered.
4.9.3.5.2. Minimal frequency of notifications.
4.9.3.5.3. Allow user to configure timing & types of notifications they want to receive.
4.9.3.6. 6. Opt for more privacy
4.9.3.6.1. Be aware of which way the device is facing and display content accordingly.
4.9.3.6.2. Vibrate first, display second.
4.9.3.7. 7. Leverage non-visual user interface
4.9.3.7.1. Voice input to compose text message / schedule activities.
4.9.3.8. 8. Interaction w/ other devices is important
4.9.3.8.1. Wearable devices should not be an isolated devices.
4.9.3.8.2. Integrate a wearable with existing devices in the digital ecosystem of a user.
4.9.3.9. 9. Design for offline usage
4.9.3.9.1. Provide core functionality in offline mode.
4.9.3.10. 10. Check what is viable
4.9.3.10.1. Consider both the capabilities and limitations of the platform when designing apps for wearables.
4.9.3.10.2. Use software development kit (SDK) as design guidance.