The present disclosure relates generally to providing a user interface with an indication of a user's previous interactions with the user interface.
In many applications, a user may explore various manipulations of data or engage in a sequence of interactions with the user interface to arrive at a particular result that is displayed in the user interface. When a user interface presents a user with many distinct possibilities for interaction, and the user's task requires exploration of many such possibilities in different sequences and/or combinations, it can be difficult for the user to (1) recall which sequence of actions they used to create a current interface state, (2) compare interface states resulting from different sequences of interactions, (3) know when a user has recreated a prior interface state and what actions followed on previous occasions, (4) easily revisit a previously created interface state, (5) understand the most direct way to create an interface state, (6) communicate interface sates and interaction sequences to others, (7) understand how the user's interactions relate to the interactions of others in the same interface.
Interaction history can be provided as a stack of interface states that grows with each user action. The user can move to the prior stack state by issuing an “undo” command. More than one “undo” command may be issued and a user may utilize a “redo” command to move up the stack including to the top of the stack. However, if at any point in a sequence of “undo” commands the user performs a new interface action, this action replaces the undone actions and becomes the new top of the stack and most recently modified state of the interface. In this sense, a history stack is destructive because a user's interactions can permanently delete prior interface states. History stacks also can have a maximum size in some implementations. The oldest states can be deleted for each new state once this limit is reached.
A history list is a visual representation of an interaction history. It can show a history stack, or a chronological list of states in the order they were visited. If a state is recreated through the interface or revisited by selecting its visual representation in the history list, a new copy of the state is added to the tail of the list. This type of interaction history, however, recreates the same interface many times, and this can generate an excessively large history to store. Furthermore, the interface history of the history list is undifferentiated and lengthy, which can be difficult for users to navigate.
Thus, user interfaces of many applications can be improved to address the deficiencies identified above.
According to an implementation, a system is provided that includes a non-transitory memory for storing instructions and one or more hardware processors coupled thereto. The one or more hardware processors may be configured to execute the instructions to cause the system to perform the following operations. An indication of a first one or more actions in a user interface of an application may be received. The indication of the first one or more actions may be determined to correspond to a first state in a first path. The first state may include a visual change from an initial appearance of the user interface of the application. The first path may correspond to a first sequence of one or more user interactions with the user interface of the application. An indication of the first state and an indication of the first path may be displayed in the user interface. Subsequent to receiving the indication of the first one or more actions, an indication of a second one or more actions in the user interface of the application may be received. The indication of the second one or more actions may be determined to correspond to a second state in the first path of the first sequence of one or more user interactions with the user interface of the application. An indication of the second state may be displayed in the user interface. The indication of the first path may be updated to indicate that it includes the second state. The user interface may be determined to have returned to the first state. Subsequent to receiving the indication of the second one or more actions, an indication of a third one or more actions in the user interface of the application may be received. The indication of the third one or more actions may be determined to correspond to a third state in a second path. The second path may correspond to a second sequence of one or more user interactions with the user interface of the application and may include the first state and the third state. An indication of the third state and an indication of the second path may be displayed in the user interface.
In some configurations, the operations performed by the system may also include visually distinguishing a portion of the indication of the second path corresponding to the first state and a portion of the second path corresponding to the third state. Furthermore, the user interface of the application may be modified to reflect the first state or second state based upon which state is currently selected.
In some configurations an indication may be received to bookmark the second state. A selection of the bookmark may be received. The user interface may be presented or displayed with visual changes associated with the first state and the second state.
In some configurations, a number of successor states may be determined for at least one of the first state, the second state, and the third state. An indication of the number of successor states may be displayed for at least one of the first state, the second state, and the third state. The indication of the number of successor states may be associated with the first state, the second state, or the third state.
In some configurations, the system may provide navigation controls for the first path. The navigation controls may be selectable by a user, and can rewind or forward the user interface of the application through states associated with the first path.
In an implementation, a computer-implemented method is provided which comprises a series of processes. An indication of a first one or more actions in a user interface of an application may be received. The indication of the first one or more actions may be determined to correspond to a first state in a first path. The first state may include a visual change from an initial appearance of the user interface of the application. The first path may correspond to a first sequence of one or more user interactions with the user interface of the application. An indication of the first state and an indication of the first path may be displayed in the user interface. Subsequent to receiving the indication of the first one or more actions, an indication of a second one or more actions in the user interface of the application may be received. The indication of the second one or more actions may be determined to correspond to a second state in the first path of the first sequence of one or more user interactions with the user interface of the application. An indication of the second state may be displayed in the user interface. The indication of the first path may be updated to indicate that it includes the second state. The user interface may be determined to have returned to the first state. Subsequent to receiving the indication of the second one or more actions, an indication of a third one or more actions in the user interface of the application may be received. The indication of the third one or more actions may be determined to correspond to a third state in a second path. The second path may correspond to a second sequence of one or more user interactions with the user interface of the application and may include the first state and the third state. An indication of the third state and an indication of the second path may be displayed in the user interface.
In some configurations, the disclosed method may also include visually distinguishing a portion of the indication of the second path corresponding to the first state and a portion of the second path corresponding to the third state. Furthermore, the user interface of the application may be modified to reflect the first state or second state based upon which state is currently selected.
In some configurations an indication may be received to bookmark the second state. A selection of the bookmark may be received. The user interface may be presented or displayed with visual changes associated with the first state and the second state.
In some configurations, a number of successor states may be determined for at least one of the first state, the second state, and the third state. An indication of the number of successor states may be displayed for at least one of the first state, the second state, and the third state. The indication of the number of successor states may be associated with the first state, the second state, or the third state.
In some configurations, the disclosed method may provide navigation controls for the first path. The navigation controls may be selectable by a user, and can rewind or forward the user interface of the application through states associated with the first path.
In an implementation, a non-transitory computer readable medium is provided that can store machine readable instructions that, when executed by one or more processors, cause the one or more processors to performs various operations including the following. An indication of a first one or more actions in a user interface of an application may be received. The indication of the first one or more actions may be determined to correspond to a first state in a first path. The first state may include a visual change from an initial appearance of the user interface of the application. The first path may correspond to a first sequence of one or more user interactions with the user interface of the application. An indication of the first state and an indication of the first path may be displayed in the user interface. Subsequent to receiving the indication of the first one or more actions, an indication of a second one or more actions in the user interface of the application may be received. The indication of the second one or more actions may be determined to correspond to a second state in the first path of the first sequence of one or more user interactions with the user interface of the application. An indication of the second state may be displayed in the user interface. The indication of the first path may be updated to indicate that it includes the second state. The user interface may be determined to have returned to the first state. Subsequent to receiving the indication of the second one or more actions, an indication of a third one or more actions in the user interface of the application may be received. The indication of the third one or more actions may be determined to correspond to a third state in a second path. The second path may correspond to a second sequence of one or more user interactions with the user interface of the application and may include the first state and the third state. An indication of the third state and an indication of the second path may be displayed in the user interface.
In some configurations, the disclosed operation may also include visually distinguishing a portion of the indication of the second path corresponding to the first state and a portion of the second path corresponding to the third state. Furthermore, the user interface of the application may be modified to reflect the first state or second state based upon which state is currently selected.
In some configurations an indication may be received to bookmark the second state. A selection of the bookmark may be received. The user interface may be presented or displayed with visual changes associated with the first state and the second state.
In some configurations, a number of successor states may be determined for at least one of the first state, the second state, and the third state. An indication of the number of successor states may be displayed for at least one of the first state, the second state, and the third state. The indication of the number of successor states may be associated with the first state, the second state, or the third state.
In some configurations, the disclosed operations may provide navigation controls for the first path. The navigation controls may be selectable by a user, and can rewind or forward the user interface of the application through states associated with the first path.
Additional features, advantages, and embodiments of the disclosed subject matter may be set forth or apparent from consideration of the following detailed description, drawings, and claims. Moreover, it is to be understood that both the foregoing summary and the following detailed description are exemplary and are intended to provide further explanation without limiting the scope of the claims.
The accompanying drawings, which are included to provide a further understanding of the disclosed subject matter, are incorporated in and constitute a part of this specification. The drawings also illustrate embodiments of the disclosed subject matter and together with the detailed description serve to explain the principles of embodiments of the disclosed subject matter. No attempt is made to show structural details in more detail than may be necessary for a fundamental understanding of the disclosed subject matter and various ways in which it may be practiced.
The following discussion is directed to various exemplary implementations. However, one possessing ordinary skill in the art will understand that the implementations disclosed herein have broad application, and that the discussion of any implementation is meant only to be an example of that implementation, and not intended to suggest that the scope of the disclosure, including claims is limited to that implementation.
The disclosed implementations can provide a state-based history based on the capture, representation, and navigation of a user's exploratory interactions with a user interface of an application. For example, a list of user interface states labelled with the action that created them may be displayed. Selection of a labelled state may return the user interface to that state.
The disclosed implementations can provide a compressed, branching history through state merging. In the event that the system detects that a prior interface state has been recreated, it can automatically navigate the interaction history back to that state. This can ensure that each state is represented in a single, identifiable place. Performing an interface action that creates a new successor state can automatically create a new branch while maintaining the last branch, indicating that the user is exploring a new path through the possible states of the interface. Recreating a prior interface state may create a cycle in the history graph, which may refer to a visual representation of user interface states. By automatically navigating back to the prior state in the list of interface states when this occurs, the structure may become a tree. Extracting the list of paths from each leaf of the tree (e.g., an interface state) back to the root state (e.g., the initial user interface state) can create a list-of-lists structure (paths of state sequences) for a simple and compact representation of a potentially complex interaction history further complicated by high redundancy. Individual states of an interaction path can also be expanded to show all existing successors to that state across all paths, and the expanded states can be selected to enable indirect path switching in a single list.
Computing the shortest path to each state from observed state transitions can also be performed. The list-of-lists representation described above may include an indication of the context in which each state was initially created. In some instances, a state may be created through fewer interactions, creating cycles in the underlying history graph. Shortest path algorithms can be applied to this graph of observed state transitions to compute the simplest specification of a state, e.g., a descriptive legend or a simplified representation of provenance. An example shortest path algorithm may include Dijkstra's algorithm, which can produce the shortest-path tree and may be optimized through the use of a Fibonacci heap. A shortest path algorithm may solve the single-source shortest path source problem (e.g., the shortest path to each state from an initial state). As applied in the instant application, the path taken by an individual to create a given state of the application user interface, may be more convoluted than how the given state could be created knowing what the initial and end states are. The produced shortest path may provide the same end state, but with fewer intervening steps. Thus, it can be communicated to other users with greater ease and/or clarity. Other shortest path algorithms may be applied and are well known.
Another feature disclosed herein is intelligent state suggestions from collective and personal interaction history. In some instances, an interface may be used by multiple people. An aggregate interaction history can be computed based on the probability of next-state-creation across all users of the interface. A user can navigate this collective history to understand the distribution of common and uncommon explorations. Similarly, across multiple sessions of interaction with multiple interfaces by the same person, predictive interface “walkthroughs” can be created by combining the user's historic likelihood of performing certain actions (e.g., sorting on a particular column) with the interface's support for those actions.
Also provided is retrospective bookmarking of history states for annotation, sharing, and presentation. By maintaining a complete interaction history, a user can revisit any prior state, discover a new value in that state, and bookmark it for future use. The value in the state may include both a numeric or discrete value as well as a subjective value. For example, a subjective value may be that the particular view in a given state is valuable from an evidence or communication perspective. In contrast, “snapshot”-based bookmarking systems require the user to see the value in an interface state when they create it, since subsequent actions modify the state and prevent the old state from being bookmarked. The list of bookmarks captured from interaction history can reordered, modified, annotated, saved, loaded, and shared with others as an interactive presentation of curated interface states. Bookmarked interface states can also be shared individually, with their interaction provenance acting as a descriptive legend for interpretation and further exploration.
A state may be predefined for a given application. For example, a developer of visual components for the application may determine what actions are to be considered a state. Similarly, a state may be predefined as a collection of actions. The determination of what constitutes a state may be an abstraction layer for the application or system. In a photo editing application, changing the color of a photo or adding a layer may be predefined as a state. In a web browsing application, a word search or selection of a particular web link may be considered a state. Thus, the definition of what constitutes a state may vary between different application types, and even based upon the developer of the application.
In some configurations, a hash code may be generated for each state. The hash code may be stored in a table and/or stored to a computer readable medium, database, etc. The stored hash code may be stored/communicated to a server via the application, a device upon which the application is operating (e.g., a computer, a mobile device, a smartwatch, a server, etc.), and/or a web-based service. For example, collection of users may perform the same first state when editing a photo such as adjusting the contrast of the image to within a range. Each time a user performs this process, the application may communicate the state to a server or database, which may increment a counter for that state, and/or determine the specific contrast adjustment to determine a range or average of the contrast applied to an image. One or more states and/or bookmarks (e.g., a collection of specific states) may be shared with other users or aggregated to generate a database of states associated with particular actions taken by users of the application. For example, in a photo editing application, the collection of tracked actions among users may indicate that many users adjust the brightness/contrast of an image to a certain range of settings. The photo editing application may, upon opening a photo captured by a user, provide a suggested state for the user that automatically adjusts the brightness/contrast of the user's photo based upon the aggregated data analysis. Thus, given how a user interacts with the application, the disclosed implementations may provide an indication of one or more next actions that other users have been determined to take based upon the actions taken by the user.
The connections between paths 125 may be indicated, for example, through a circular icon on each state that show the number of successor states across all paths 130 when there is more than one successor. The disclosed implementations are not limited to example representation of the successor states illustrated in
It will be appreciated that the present disclosure is not limited to any specific visual indication to communicate to the user which path is active. For example, a visual indication may be a color change, highlighting, addition of text, flashing the path, drawing an arrow or other similar visual cue, etc. In
The examples provided herein are merely for explanation and are not intended to limit the scope of possible representations for the history board, paths, states, and/or application interfaces. In some configurations, the history board 105 is displayed apart from the application interface 102. In some configurations, the history board 105 is displayed above, below, to the left of, or on top of the application interface 102. In some configurations, the layout of the history board 105 may differ from the examples provided herein. For example, the paths 125 may be illustrated at the top of the history board 105 and the states such as 110, 127 may be displayed at the bottom of the history board 105. In some configurations, the paths are displayed as a separate interface element from the representation of the states themselves. Other configurations regarding the color, visual representation, and layout of the history board 105 and elements thereof are contemplated herein.
A path 125 may refer to a collection of one or more user interface states.
The bookmarks tab 120 may provide a visual indication of bookmarked states in a re-orderable list to which new bookmarks may be appended. Each bookmark can be captioned with explanatory text that can be displayed in the history board 110. A bookmark can show its build steps, which may refer to the shortest path in the observed state transition graph from the initial state to the bookmarked state. Build steps can be replayed directly from the bookmark or used to specify the start of a build sequence. Build steps can provide an even shorter and more idealized form of provenance than paths, whose structure aims to balance the need for clear provenance with the need for user orientation during exploratory analysis.
The examples illustrated in
Regardless of the configuration of the memory(ies) and processor(s), a series of instructions may be executed by the system.
An indication of a first one or more actions in a user interface of an application may be received at 610. An action may refer to any interaction with a user interface including discrete and non-discrete actions as explained earlier. Different types of applications may have different application interfaces, but there may be overlap between some functions. For example, a web browsing application may have forward/backward commands, search terms, bookmarking, universal resource locator entry, sharing a web page, html reading/editing, plug-in functions that augment a web-browser's functionality (e.g., ad-blocking, image preview, etc.), reload function, a user profile, etc. In contrast, a photo editing application may have features directed to cropping a photo, adjusting color-/gray-scale of a photo, sharing a photo, adding text or shapes, organizing layers, etc. The disclosed implementations are not limited to any particular application type. Actions may be recorded in a table in the form of a hash code or as a labeled term. The table may be stored remotely (e.g., on board the computing device) or remotely. The table may be updated with each action or periodically. A developer of an application, for example, may define actions that are to be recorded and/or exclude actions from being recorded. An indication of an action may refer to receipt of input from an input device such as a touchscreen, a camera, a keyboard, a mouse, or the like by the computing device.
The indication of the one or more actions may be determined to correspond to a first state in a first path at 620. A state, therefore, may refer to a combination one or more actions. For example, in
At 630, an indication of the first state and an indication of the first path may be displayed in the user interface. An indication of the first state and first path may refer to a visual display of such on the computing device. An example of such indications is provided in
Subsequent to receiving the indication of the first one or more actions at 610, an indication of a second one or more actions in the user interface of the application may be received at 640. At this stage, the user may perform additional interactions with an application's user interface. These actions may be recorded as described above. The indication of the second one or more actions may be determined to correspond to a second state in the first path of the first sequence of one or more user interactions with the user interface of the application at 650. As above, what constitutes a state may be predefined for each application or the system upon which the application is being operated. A path may reflect one or more states for the current exploration of the application. Each state in the path may be revisited. Here, the second state may be associated with the first path. Thus, both the first state and the second path may be a part of the same exploratory path. An indication of the second state may be displayed, and the indication of the first path may be updated to indicate that it comprises the second state at 660. For example, the indication of the second state may be visually displayed on the screen such as the states illustrated in the history board of the examples provided in
As described earlier, any state may be bookmarked, and any current appearance of the user interface for the application may be bookmarked to create a state. For example, adjustment of column widths may not be ordinarily identified as a state. If the user bookmarks the state after adjusting column widths, however, the state of the user interface may be stored and recalled at a later date by retrieving the bookmark. In some instances, an action such as adjusting column widths may be appended to the current state, rather than generate a new state. For example, if a user has sorted by column A, adjusts column widths, and then saves the state as a bookmark, the bookmark may record as a state sorting by column A and adjusting column widths as one state. As described earlier, each state may be retained in a hash table, or the like. The table may be shared with other users, a developer, a platform.
At 670, the user interface may be determined to have returned to the first state. For example, the user may have selected the indication of the first state in the first path, or the user may have performed one or more actions that caused the system to return to the first state. Rather than add a new indication of the reversion to the first state (e.g., as a third state), which may complicate the history board, the system may indicate that the first state is now active as shown in the examples provided in
Subsequent to receiving the indication of the second one or more actions, an indication of a third one or more actions in the user interface of the application may be received at 680. The indication of the second one or more actions, as with other indications herein, may refer to receiving input into the application, and this input may result in a visual change to the user interface of the application. The indication of the third one or more actions may be determined to correspond to a third state in a second path at 690. The second path may correspond to a second sequence of one or more user interactions with the user interface of the application and may include the first state and the third state. An indication of the third state and an indication of the second path may be displayed in the user interface at 695. As illustrated in the examples provided in
As an example, a first action may be sorting column A, and this may be determined to be a first state. A second action may be filtering results to display only those related to holographic computing, and this may be determined to be a second state. Both the first state and the second state may be a part of the first path. The first path, therefore, may show the combined display of sorting by column A, and then filtering for holographic computing. At 670, in this example, the user may have moved undone the filtering for holographic computing, or have simply clicked the first state to return the user interface to the state. At 680, to continue in this example, the user may have performed a new interaction with the user interface (e.g., a third action), such as add a new column D, which is recognized as a third state at 690. In this case, since the third state builds upon the first state (e.g., sorting column A), but branches from the second state (e.g., filtering), it may be represented as a second path at 700. Thus, the second path may include a visual representation of the first state and the third state.
As shown in the example provided in
Embodiments of the presently disclosed subject matter may be implemented in and used with a variety of component and network architectures.
The bus 21 allows data communication between the central processor 24 and the memory 27, which may include ROM or flash memory (neither shown), and RAM (not shown), as previously noted. The RAM is generally the main memory into which the operating system and application programs are loaded. The ROM or flash memory can contain, among other code, the Basic Input-Output system (BIOS) which controls basic hardware operation such as the interaction with peripheral components. Applications resident with the computer 20 are generally stored on and accessed via a computer readable medium, such as a hard disk drive (e.g., fixed storage 23), an optical drive, floppy disk, or other storage medium 25.
The fixed storage 23 may be integral with the computer 20 or may be separate and accessed through other interfaces. A network interface 29 may provide a direct connection to a remote server via a telephone link, to the Internet via an internet service provider (ISP), or a direct connection to a remote server via a direct network link to the Internet via a POP (point of presence) or other technique. The network interface 29 may provide such connection using wireless techniques, including digital cellular telephone connection, Cellular Digital Packet Data (CDPD) connection, digital satellite data connection or the like. For example, the network interface 29 may allow the computer to communicate with other computers via one or more local, wide-area, or other networks. Many other devices or components (not shown) may be connected in a similar manner (e.g., digital cameras or speakers). Conversely, all of the components shown in
More generally, various embodiments of the presently disclosed subject matter may include or be embodied in the form of computer-implemented processes and apparatuses for practicing those processes. Embodiments also may be embodied in the form of a computer program product having computer program code containing instructions embodied in non-transitory and/or tangible media, such as floppy diskettes, CD-ROMs, hard drives, USB (universal serial bus) drives, or any other machine readable storage medium, wherein, when the computer program code is loaded into and executed by a computer, the computer becomes an apparatus for practicing embodiments of the disclosed subject matter. Embodiments also may be embodied in the form of computer program code, for example, whether stored in a storage medium, loaded into and/or executed by a computer, or transmitted over some transmission medium, such as over electrical wiring or cabling, through fiber optics, or via electromagnetic radiation, wherein when the computer program code is loaded into and executed by a computer, the computer becomes an apparatus for practicing embodiments of the disclosed subject matter.
When implemented on a general-purpose microprocessor, the computer program code segments configure the microprocessor to create specific logic circuits. In some configurations, a set of computer-readable instructions stored on a computer-readable storage medium may be implemented by a general-purpose processor, which may transform the general-purpose processor or a device containing the general-purpose processor into a special-purpose device configured to implement or carry out the instructions. Embodiments may be implemented using hardware that may include a processor, such as a general purpose microprocessor and/or an Application Specific Integrated Circuit (ASIC) that embodies all or part of the techniques according to embodiments of the disclosed subject matter in hardware and/or firmware. The processor may be coupled to memory, such as RAM, ROM, flash memory, a hard disk or any other device capable of storing electronic information. The memory may store instructions adapted to be executed by the processor to perform the techniques according to embodiments of the disclosed subject matter.
The foregoing description, for purpose of explanation, has been described with reference to specific embodiments. However, the illustrative discussions above are not intended to be exhaustive or to limit embodiments of the disclosed subject matter to the precise forms disclosed. Many modifications and variations are possible in view of the above teachings. The embodiments were chosen and described in order to explain the principles of embodiments of the disclosed subject matter and their practical applications, to thereby enable others skilled in the art to utilize those embodiments as well as various embodiments with various modifications as may be suited to the particular use contemplated.
This application claims priority to U.S. provisional patent application No. 62/653,777 filed on Apr. 6, 2018, the entire contents of which is hereby incorporated by reference.
Number | Date | Country | |
---|---|---|---|
62653777 | Apr 2018 | US |