Document Details

VividStream

Uploaded by VividStream

Tags

software design human-computer interaction ux design

Full Transcript

Chapter 13 INTERACTION DESIGN IN PRACTICE 13.1 Introduction 13.2 AgileUX 13.3 Design Patterns 13.4 Open Source Resources 13.5 Tools for Interaction Design Objectives The main goals of the chapter are to accomplish the following: • • • • • Describe some of the key trends in practice related to in...

Chapter 13 INTERACTION DESIGN IN PRACTICE 13.1 Introduction 13.2 AgileUX 13.3 Design Patterns 13.4 Open Source Resources 13.5 Tools for Interaction Design Objectives The main goals of the chapter are to accomplish the following: • • • • • Describe some of the key trends in practice related to interaction design. Enable you to discuss the place of UX design in agile development projects. Enable you to identify and critique interaction design patterns. Explain how open source and ready-made components can support interaction design. Explain how tools can support interaction design activities. 13.1 Introduction As our interviewee at the end of Chapter 1, Harry Brignull, remarked, the field of interaction design changes rapidly. He says, “A good interaction designer has skills that work like expanding foam.” In other words, the practice of interaction design is quite messy, and keeping up with new techniques and developments is a constant goal. When placed within the wider world of commerce and business, interaction designers face a range of pressures, including restricted time and limited resources, and they need to work with people in a wide range of other roles, as well as stakeholders. In addition, the principles, techniques, and approaches introduced in other chapters of this book need to be translated into practice, that is, into real situations with sets of real users, and this creates its own pressures. Many different names may be given to a practitioner conducting interaction design activities, including interface designer, information architect, experience designer, usability engineer, and user experience designer. In this chapter, we refer to user experience designer and user experience design because these are most commonly found in industry to describe someone who performs the range of interaction design tasks such as interface design, user evaluations, information architecture design, visual design, persona development, and prototyping. 472 13 INTERACTION DESIGN IN PRACTICE Other chapters of this book may have given the impression that designers create their designs from scratch, with little or no help from anyone except users and immediate colleagues, but in practice, user experience (UX) designers draw on a range of support. Four main areas of support that impact the job of UX designers are described in this chapter. • Working with software and product development teams operating an agile model of development (introduced in Chapter 2, “The Process of Interaction Design”) has led to technique and process adaptation, resulting in agileUX approaches. • Reusing existing designs and concepts is valuable and time-saving. Interaction design and UX design patterns provide the blueprint for successful designs, utilizing previous work and saving time by avoiding “reinventing the wheel.” • Reusable components—from screen widgets and source code libraries to full systems, and from motors and sensors to complete robots—can be modified and integrated to generate prototypes or full products. Design patterns embody an interaction idea, but reusable components provide implemented chunks of code or widgets. • There is a wide range of tools and development environments available to support designers in developing visual designs, wireframes, interface sketches, interactive prototypes, and more. This chapter introduces each of these four areas. In this video, Kara Pernice suggests three challenges for UX in practice. It is available at https://www.youtube.com/watch?v=qV5lLjmL278. Here is a concrete view of what a UX designer does in practice: https://www.interaction-design.org/literature/article/7-ux-deliverables-whatwill-i-be-making-as-a-ux-designer BOX 13.1 Technical Debt in UX Technical debt is a term commonly used in software development, coined originally by Ward Cunningham in 1992, which refers to making technical compromises that are expedient in the short term but that create a technical context that increases complexity and cost in the long term. As with financial debt, technical debt is acceptable as a short-term approach to overcoming an immediate shortfall, provided that the debt will be repaid quickly. Leaving a debt for longer results in significant extra costs. Technical debt can be incurred unintentionally, but pressures associated with time and complexity also lead to design trade-offs that may prove to be expensive in the longer term. 13.2 AGILEUX UX debt is created much like technical debt in the sense that trade-offs are made for the needs of the project. To address technical debt, a discipline of refactoring is needed, that is, correcting any pragmatic trade-offs quickly after the immediate pressure has receded. Significant difficulties arise if these trade-offs are not identified, understood, and corrected in a timely manner. Two interrelated situations can lead to significant user experience debt that is then extremely costly to correct. • If an organization did not, in the past, understand the value of good user experience design and products or software systems with poor user experiences persist. This can be particularly prevalent for internal systems and products, where the drive for a good user experience is less acute than for externally marketed products that face more competition from other providers. • If an organization has a large portfolio of products, each of which was developed independently. This can be the result of acquisitions and mergers of companies, each with their own UX brand, leading to a proliferation of designs. In severe cases, UX debt can lead to the revamping of infrastructure and complete renewal of products. For an interesting take on UX debt, see this article: https://www.nngroup .com/articles/ux-debt. 13.2 AgileUX Since the rise of agile software development during the 2000s, UX designers have been concerned about the impact that it will have on their own work (Sharp et al., 2006), and the debate is ongoing (McInerney, 2017). AgileUX is the collective label given to efforts that aim to resolve these concerns by integrating techniques and processes from interaction design and those from agile methods. While agile software development and UX design have some characteristics in common such as iteration, a focus on measurable completion criteria, and user involvement, agileUX requires a reorganization and some rethinking of UX design activities and products. A recent reflection on the evolution of agileUX concluded that integrating agile and UX requires mutual team understanding across three dimensions, and those dimensions are variably understood (Da Silva et al., 2018): the “process and practice” dimension is understood; the “people and social” dimension is nearly understood; but the “technology and artifact” dimension—that is, use of technology to coordinate teams’ activities and artifacts to mediate teams’ communication—has yet to be properly understood. A key aspect is for agile development teams to understand that user experience design is not a role but is a discipline and mind-set. This account makes it clear that using agileUX in practice is far from straightforward. The key is to find a suitable balance that preserves both the research and reflection 473 474 13 INTERACTION DESIGN IN PRACTICE needed for good UX design, as well as rapid iterations that incorporate user feedback and allow technical alternatives to be tested. In a plan-driven (waterfall) software development process, requirements are specified as completely as possible before any implementation begins. In an agile software development process, requirements are specified only in enough detail for implementation to begin. Requirements are then elaborated as implementation proceeds, according to a set of priorities that change on a regular basis in response to changing business needs. To integrate UX design into an agile workflow, it also needs to progress in a similar fashion. Reprioritization may happen as frequently as every two weeks, at the beginning of each iterative cycle. The shift from developing complete requirements up front to “just-in-time” or just enough requirements aims to reduce wasted effort, but it means that UX designers (along with their software engineer colleagues) have had to rethink their approach. All of the techniques and principles that UX designers use are just as relevant, but how much of each activity needs to be completed at what point in the iterative cycle and how the results of those activities feed into implementation need to be adjusted in an agile development context. This can be unsettling for designers, as the design artifacts are their main deliverable and hence may be viewed as finished, whereas for agile software engineers, they are consumables and will need to change as implementation progresses and requirements become elaborated. Consider the group travel organizer example introduced in Chapter 11, and assume that it is being developed using agileUX. Four epics (large user stories) for the product are identified in Chapter 11, as follows: 1. As a <group traveler>, I want <to choose from a range of potential vacations that suit the group’s preferences> so that <the whole group can have a good time>. 2. As a <group traveler>, I want <to know the visa restrictions for everyone in the group> so that <visas can be arranged for everyone in the group in plenty of time>. 3. As a <group traveler>, I want <to know the vaccinations required to visit the chosen destination> so that <vaccinations can be arranged for everyone in the group in plenty of time>. 4. As a <travel agent>, I want <up-to-date information displayed> so that <my clients receive accurate information>. At the beginning of the project, these epics will be prioritized, and the central goal of the product (to identify potential vacations) will be the top priority. This will then initially be the focus of development activities. To allow users to choose a vacation, epic 4, supporting the travel agent to update travel details, will also need to be implemented (otherwise travel details will be out of date), so this is also likely to be prioritized. Establishing the detailed requirements and the design of the other two areas will be postponed until after a product that allows users to choose a vacation has been delivered. Indeed, once this product is delivered, the customer may decide that offering help for vaccinations and visas does not result in sufficient business value for it to be included at all. In this case, referring users to other, more authoritative sources of information may be preferable. Conducting UX activities within an agile framework requires a flexible point of view that focuses more on the end product as the deliverable than on the design artifacts as deliverables. It also requires cross-functional teams where specialists from a range of disciplines, including UX design and engineering, work closely together to evolve an understanding of both the users and their context, as well as the technical capabilities and practicalities of the technology. In particular, agileUX requires attention to three practices, each of which is elaborated in the following sections. 13.2 AGILEUX • What user research to conduct, how much, and when • How to align UX design and agile working practices • What documentation to produce, how much, and when Source: Leo Cullum / Cartoon Stock 13.2.1 User Research The term user research refers to the data collection and analysis activities necessary to characterize the users, their tasks, and the context of use before product development begins. Field studies and ethnography are often used in these investigations, but agile development works on short “timeboxes” of activity (up to four weeks in length, but often only two weeks in length) and hence does not support long periods of user research. (Different names are given by different agile methods to the iteration, or timeframe, the most common being sprint, timebox, and cycle.) Even a month to develop a set of personas or to conduct a detailed investigation into online purchasing habits (for example) is too long for some agile development cycles. User-focused activities evaluating elements of the design, or interviews to clarify requirements or task context, can be done alongside technical development (see the parallel tracks approach discussed in a moment), but planning to conduct extensive user research once iterative development starts will result in shallow user research, which is impossible to react to, as there just isn’t enough time. One way to address this is for user research to be conducted before the project begins, or indeed before it is announced, as suggested by Don Norman (2006), who argues that it is better to be on the team that decides which project will be done at all, hence avoiding the constraints caused by limited timeboxes. This period is often called iteration zero (or Cycle 0, as you’ll see later in Figure 13.2), and it is used to achieve a range of up-front activities including software architecture design as well as user research. Another approach to conducting user research for each project is to have an ongoing program of user research that revises and refines a company’s knowledge of their users over a longer time span. For example, Microsoft actively recruits users of their software to sign up and take part in user research that is used to inform future developments. In this case, the specific data gathering and analysis needed for one project would be conducted during iteration zero, but done in the context of a wider understanding of users and their goals. 475 476 13 INTERACTION DESIGN IN PRACTICE ACTIVITY 13.1 Consider the “one-stop car shop” introduced in Activity 11.4. What kind of user research would be helpful to conduct before iterative development begins? Of these areas, which would be useful to conduct in an ongoing program? Comment Characterizing car drivers and the hybrid driving experience would be appropriate user research before iterative development begins. Although many people drive, the driving experience is different depending on the car itself and according to the individual’s capabilities and experiences. Collecting and analyzing suitable data to inform the product’s development is likely to take longer than the timebox constraints would allow. Such user research could develop a set of personas (maybe one set for each class of car) and a deeper understanding of the hybrid driving experience. Car performance and handling is constantly evolving, however, and so an understanding of the driving experience would benefit from ongoing user research. Lean UX (see Box 13.2) takes a different approach to user research by focusing on getting products into the market and capturing user feedback on products that are in the marketplace. It specifically focuses on designing and developing innovative products. BOX 13.2 Lean UX (Adapted from Gothelf and Seiden (2016)) Lean UX is designed to create and deploy innovative products quickly. It is linked to agileUX because agile software development is one of its underlying philosophies and it champions the importance of providing a good user experience. Lean UX builds upon UX design, design thinking, agile software development, and the Lean Startup ideas (Ries, 2011). All four perspectives emphasize iterative development, collaboration between all stakeholders, and cross-functional teams. Lean UX is based on tight iterations of build-measure-learn, a concept central to the lean startup idea, which in turn was inspired by the lean manufacturing process from Japan. The lean UX process is illustrated in Figure 13.1. It emphasizes waste reduction, the importance of experimentation to learn, and the need to articulate outcomes, assumptions, and hypotheses about a planned product. Moving the focus from outputs (for example, a new smartphone app) to outcomes (for example, more commercial activity through mobile channels) clarifies the aims of the project and provides metrics for defining success. The importance of identifying assumptions was discussed in Chapter 3, “Conceptualizing Interaction.” An example assumption might be that young people would rather use a smartphone app to access local event information than any other media. Assumptions can be expressed as hypotheses that can be put to the test more easily through research or by building a minimum viable product (MVP) that can be released to the user group.

Use Quizgecko on...
Browser
Browser