The disclosed embodiments relate generally to electronic devices with touch-sensitive surfaces, and more particularly, to electronic devices with touch-sensitive surfaces that use two or more simultaneous user inputs to manipulate user interface objects.
The use of touch-sensitive surfaces as input devices for computers and other electronic computing devices has increased significantly in recent years. Exemplary touch-sensitive surfaces include touch pads and touch screen displays. Such surfaces are widely used to manipulate user interface objects on a display.
Exemplary manipulations include adjusting the position and/or size of one or more user interface objects, as well as associating metadata with one or more user interface objects. Exemplary user interface objects include digital images, video, text, icons, and other graphics. A user may need to perform such manipulations on user interface objects in a file management program (e.g., Finder from Apple Computer, Inc. of Cupertino, Calif.), an image management application (e.g., Aperture or iPhoto from Apple Computer, Inc. of Cupertino, Calif.), a digital content (e.g., videos and music) management application (e.g., iTunes from Apple Computer, Inc. of Cupertino, Calif.), a drawing application, a presentation application (e.g., Keynote from Apple Computer, Inc. of Cupertino, Calif.), a word processing application (e.g., Pages from Apple Computer, Inc. of Cupertino, Calif.), a website creation application (e.g., iWeb from Apple Computer, Inc. of Cupertino, Calif.), a disk authoring application (e.g., iDVD from Apple Computer, Inc. of Cupertino, Calif.), or a spreadsheet application (e.g., Numbers from Apple Computer, Inc. of Cupertino, Calif.).
But existing methods for performing these manipulations are cumbersome and inefficient. For example, using a sequence of mouse-based inputs to select one or more user interface objects and perform one or more actions on the selected user interface objects is tedious and creates a significant cognitive burden on a user. Existing methods that use simultaneous inputs to perform these manipulations are also cumbersome and inefficient. In addition, existing methods take longer than necessary, thereby wasting energy. This latter consideration is particularly important in battery-operated devices.
Accordingly, there is a need for computing devices with faster, more efficient methods and interfaces for manipulating user interface objects using two or more simultaneous user inputs, such as two simultaneous inputs on a track pad or touch screen, or simultaneous inputs from a touch-sensitive surface and a mouse. Such methods and interfaces may complement or replace conventional methods for manipulating user interface objects. Such methods and interfaces reduce the cognitive burden on a user and produce a more efficient human-machine interface. For battery-operated computing devices, such methods and interfaces conserve power and increase the time between battery charges.
The above deficiencies and other problems associated with user interfaces for computing devices with touch-sensitive surfaces are reduced or eliminated by the disclosed devices. In some embodiments, the device is a desktop computer. In some embodiments, the device is portable (e.g., a notebook computer, tablet computer, or handheld device). In some embodiments, the device has a touchpad. In some embodiments, the device has a touch-sensitive display (also known as a “touch screen” or “touch screen display”). In some embodiments, the device has a graphical user interface (GUI), one or more processors, memory and one or more modules, programs or sets of instructions stored in the memory for performing multiple functions. In some embodiments, the user interacts with the GUI primarily through finger contacts and gestures on the touch-sensitive surface. In some embodiments, the functions may include image editing, drawing, presenting, word processing, website creating, disk authoring, spreadsheet making, game playing, telephoning, video conferencing, e-mailing, instant messaging, workout support, digital photographing, digital videoing, web browsing, digital music playing, and/or digital video playing. Executable instructions for performing these functions may be included in a computer readable storage medium or other computer program product configured for execution by one or more processors.
In accordance with some embodiments, a method is performed at a computing device with a touch screen display. The method includes: simultaneously displaying on the touch screen display: a plurality of user interface objects, and at least one destination object; and detecting a first input by a user on a destination object. The method further includes, while continuing to detect the first input by the user on the destination object: detecting a second input by the user on a first user interface object displayed at an initial first user interface object position on the touch screen display; and, in response to detecting the second input by the user on the first user interface object, performing an action on the first user interface object. The action is associated with the destination object.
In accordance with some embodiments, a computing device includes a touch screen display, one or more processors, memory, and one or more programs. The one or more programs are stored in the memory and configured to be executed by the one or more processors. The one or more programs include instructions for: simultaneously displaying on the touch screen display: a plurality of user interface objects, and at least one destination object. The programs also include instructions for detecting a first input by a user on a destination object. The programs further include instructions for, while continuing to detect the first input by the user on the destination object, detecting a second input by the user on a first user interface object displayed at an initial first user interface object position on the touch screen display; and, in response to detecting the second input by the user on the first user interface object, performing an action on the first user interface object. The action is associated with the destination object.
In accordance with some embodiments, a computer readable storage medium has stored therein instructions which when executed by a computing device with a touch screen display, cause the device to: simultaneously display on the touch screen display: a plurality of user interface objects, and at least one destination object. The instructions also cause the device to detect a first input by a user on a destination object. While continuing to detect the first input by the user on the destination object, the instructions also cause the device to detect a second input by the user on a first user interface object displayed at an initial first user interface object position on the touch screen display; and, in response to detecting the second input by the user on the first user interface object, perform an action on the first user interface object. The action is associated with the destination object.
In accordance with some embodiments, a graphical user interface on a computing device with a touch screen display, a memory, and one or more processors to execute one or more programs stored in the memory includes a plurality of user interface objects, and at least one destination object. A first input by a user on a destination object is detected. While continuing to detect the first input by the user on the destination object: a second input by the user on a first user interface object, displayed at an initial first user interface object position on the touch screen display, is detected; and, in response to detecting the second input by the user on the first user interface object, an action is performed on the first user interface object. The action is associated with the destination object.
In accordance with some embodiments, a computing device includes: a touch screen display; means for simultaneously displaying on the touch screen display: a plurality of user interface objects, and at least one destination object. The device also includes means for detecting a first input by a user on a destination object. The device further includes, while continuing to detect the first input by the user on the destination object, means for detecting a second input by the user on a first user interface object displayed at an initial first user interface object position on the touch screen display; and, means, responsive to detecting the second input by the user on the first user interface object, for performing an action on the first user interface object. The action is associated with the destination object.
In accordance with some embodiments, an information processing apparatus for use in a computing device with a touch screen display includes: means for simultaneously displaying on the touch screen display: a plurality of user interface objects, and at least one destination object. The apparatus also includes means for detecting a first input by a user on a destination object. The apparatus further includes, while continuing to detect the first input by the user on the destination object, means for detecting a second input by the user on a first user interface object displayed at an initial first user interface object position on the touch screen display; and, means, responsive to detecting the second input by the user on the first user interface object, for performing an action on the first user interface object. The action is associated with the destination object.
In accordance with some embodiments, a method is performed at a computing device with a touch screen display. The method includes: simultaneously displaying on the touch screen display a plurality of user interface objects, and at least one destination object; and detecting a first input by a user on a destination object. The method further includes, while continuing to detect the first input by the user on the destination object: detecting a second input by the user or a series of inputs by the user on two or more user interface objects in the plurality of user interface objects, wherein the two or more user interface objects are displayed at respective initial user interface object positions on the touch screen display; and, in response to detecting the second input by the user or series of inputs by the user on the two or more user interface objects, performing an action on each of the two or more user interface objects. The action is associated with the destination object.
In accordance with some embodiments, a computing device includes a touch screen display, one or more processors, memory, and one or more programs. The one or more programs are stored in the memory and configured to be executed by the one or more processors. The one or more programs include instructions for: simultaneously displaying on the touch screen display: a plurality of user interface objects, and at least one destination object. The programs also include instructions for detecting a first input by a user on a destination object. The programs further include instructions for, while continuing to detect the first input by the user on the destination object: detecting a second input by the user or a series of inputs by the user on two or more user interface objects in the plurality of user interface objects, wherein the two or more user interface objects are displayed at respective initial user interface object positions on the touch screen display; and, in response to detecting the second input by the user or series of inputs by the user on the two or more user interface objects, performing an action on each of the two or more user interface objects. The action is associated with the destination object.
In accordance with some embodiments, a computer readable storage medium has stored therein instructions which when executed by a computing device with a touch screen display, cause the device to: simultaneously display on the touch screen display: a plurality of user interface objects, and at least one destination object. The instructions also cause the device to detect a first input by a user on a destination object. The instructions further cause the device to, while continuing to detect the first input by the user on the destination object: detect a second input by the user or a series of inputs by the user on two or more user interface objects in the plurality of user interface objects, wherein the two or more user interface objects are displayed at respective initial user interface object positions on the touch screen display; and, in response to detecting the second input by the user or series of inputs by the user on the two or more user interface objects, perform an action on each of the two or more user interface objects. The action is associated with the destination object.
In accordance with some embodiments, a graphical user interface on a computing device with a touch screen display, a memory, and one or more processors to execute one or more programs stored in the memory includes a plurality of user interface objects and at least one destination object. A first input by a user on a destination object is detected. While continuing to detect the first input by the user on the destination object: a second input by the user is detected or a series of inputs by the user on two or more user interface objects in the plurality of user interface objects are detected, wherein the two or more user interface objects are displayed at respective initial user interface object positions on the touch screen display; and, in response to detecting the second input by the user or series of inputs by the user on the two or more user interface objects, an action is performed on each of the two or more user interface objects. The action is associated with the destination object.
In accordance with some embodiments, a computing device includes: a touch screen display; means for simultaneously displaying on the touch screen display: a plurality of user interface objects, and at least one destination object. The device further includes means for detecting a first input by a user on a destination object. The device also includes, while continuing to detect the first input by the user on the destination object: means for detecting a second input by the user or a series of inputs by the user on two or more user interface objects in the plurality of user interface objects, wherein the two or more user interface objects are displayed at respective initial user interface object positions on the touch screen display; and means, responsive to detecting the second input by the user or series of inputs by the user on the two or more user interface objects, for performing an action on each of the two or more user interface objects. The action is associated with the destination object.
In accordance with some embodiments, an information processing apparatus for use in a computing device with a touch screen display includes: means for simultaneously displaying on the touch screen display: a plurality of user interface objects, and at least one destination object. The apparatus further includes means for detecting a first input by a user on a destination object. The apparatus also includes, while continuing to detect the first input by the user on the destination object: means for detecting a second input by the user or a series of inputs by the user on two or more user interface objects in the plurality of user interface objects, wherein the two or more user interface objects are displayed at respective initial user interface object positions on the touch screen display; and means, responsive to detecting the second input by the user or series of inputs by the user on the two or more user interface objects, for performing an action on each of the two or more user interface objects. The action is associated with the destination object.
In accordance with some embodiments, a method is performed at a computing device with a touch screen display. The method includes: simultaneously displaying on the touch screen display a plurality of user interface objects and at least one destination object. The method also includes detecting a first input by a user on a first user interface object at a first location on the touch screen display. The method further includes, while continuing to detect the first input by the user: detecting movement of the first input by the user across the touch screen display to a second location on the touch screen display; moving the first user interface object in accordance with the movement of the first input by the user across the touch screen display to the second location on the touch screen display; detecting a second input by the user on a second user interface object displayed at an initial second user interface object position on the touch screen display; and, in response to detecting the second input by the user on the second user interface object, displaying an animation of the second user interface object moving from the initial second user interface object position to the second location.
In accordance with some embodiments, a computing device includes a touch screen display, one or more processors, memory, and one or more programs. The one or more programs are stored in the memory and configured to be executed by the one or more processors. The one or more programs include instructions for: simultaneously displaying on the touch screen display: a plurality of user interface objects, and at least one destination object. The programs also include instructions for detecting a first input by a user on a first user interface object at a first location on the touch screen display. The programs further include instructions for, while continuing to detect the first input by the user: detecting movement of the first input by the user across the touch screen display to a second location on the touch screen display; moving the first user interface object in accordance with the movement of the first input by the user across the touch screen display to the second location on the touch screen display; detecting a second input by the user on a second user interface object displayed at an initial second user interface object position on the touch screen display; and, in response to detecting the second input by the user on the second user interface object, displaying an animation of the second user interface object moving from the initial second user interface object position to the second location.
In accordance with some embodiments, a computer readable storage medium has stored therein instructions which when executed by a computing device with a touch screen display, cause the device to: simultaneously display on the touch screen display: a plurality of user interface objects, and at least one destination object. The instructions also cause the device to detect a first input by a user on a first user interface object at a first location on the touch screen display. The instructions further cause the device to, while continuing to detect the first input by the user: detect movement of the first input by the user across the touch screen display to a second location on the touch screen display; move the first user interface object in accordance with the movement of the first input by the user across the touch screen display to the second location on the touch screen display; detect a second input by the user on a second user interface object displayed at an initial second user interface object position on the touch screen display; and, in response to detecting the second input by the user on the second user interface object, display an animation of the second user interface object moving from the initial second user interface object position to the second location.
In accordance with some embodiments, a graphical user interface on a computing device with a touch screen display, a memory, and one or more processors to execute one or more programs stored in the memory includes a plurality of user interface objects and at least one destination object. A first input by a user on a first user interface object is detected at a first location on the touch screen display. While continuing to detect the first input by the user: movement of the first input by the user across the touch screen display to a second location on the touch screen display is detected; the first user interface object is moved in accordance with the movement of the first input by the user across the touch screen display to the second location on the touch screen display; a second input by the user on a second user interface object, displayed at an initial second user interface object position on the touch screen display, is detected; and, in response to detecting the second input by the user on the second user interface object, an animation of the second user interface object moving from the initial second user interface object position to the second location is displayed.
In accordance with some embodiments, a computing device includes: a touch screen display; and means for simultaneously displaying on the touch screen display: a plurality of user interface objects, and at least one destination object. The device also includes means for detecting a first input by a user on a first user interface object at a first location on the touch screen display. The device further includes, while continuing to detect the first input by the user: means for detecting movement of the first input by the user across the touch screen display to a second location on the touch screen display; means for moving the first user interface object in accordance with the movement of the first input by the user across the touch screen display to the second location on the touch screen display; means for detecting a second input by the user on a second user interface object displayed at an initial second user interface object position on the touch screen display; and, means, responsive to detecting the second input by the user on the second user interface object, for displaying an animation of the second user interface object moving from the initial second user interface object position to the second location.
In accordance with some embodiments, an information processing apparatus for use in a computing device with a touch screen display includes: means for simultaneously displaying on the touch screen display a plurality of user interface objects and at least one destination object; and means for detecting a first input by a user on a first user interface object at a first location on the touch screen display. The apparatus further includes, while continuing to detect the first input by the user: means for detecting movement of the first input by the user across the touch screen display to a second location on the touch screen display; means for moving the first user interface object in accordance with the movement of the first input by the user across the touch screen display to the second location on the touch screen display; means for detecting a second input by the user on a second user interface object displayed at an initial second user interface object position on the touch screen display; and, means, responsive to detecting the second input by the user on the second user interface object, for displaying an animation of the second user interface object moving from the initial second user interface object position to the second location.
In accordance with some embodiments, a method is performed at a computing device with a touch screen display. The method includes: simultaneously displaying on the touch screen display a plurality of user interface objects and at least one destination object. The method also includes detecting a first input by a user on a first user interface object at a first location on the touch screen display. The method further includes, while continuing to detect the first input by the user: detecting movement of the first input by the user across the touch screen display to a second location on the touch screen display; moving the first user interface object in accordance with the movement of the first input by the user across the touch screen display to the second location on the touch screen display; detecting a second input by the user or series of inputs by the user on two or more user interface objects in the plurality of user interface objects, wherein the two or more user interface objects are displayed at respective initial user interface object positions on the touch screen display; and, in response to detecting the second input by the user or series of inputs by the user on two or more user interface objects in the plurality of user interface objects, displaying animations of each respective user interface object in the two or more user interface objects moving from a respective initial user interface object position to the second location.
In accordance with some embodiments, a computing device includes a touch screen display, one or more processors, memory, and one or more programs. The one or more programs are stored in the memory and configured to be executed by the one or more processors. The one or more programs include instructions for simultaneously displaying on the touch screen display a plurality of user interface objects and at least one destination object. The programs also include instructions for detecting a first input by a user on a first user interface object at a first location on the touch screen display. The programs further include instructions for, while continuing to detect the first input by the user: detecting movement of the first input by the user across the touch screen display to a second location on the touch screen display; moving the first user interface object in accordance with the movement of the first input by the user across the touch screen display to the second location on the touch screen display; detecting a second input by the user or series of inputs by the user on two or more user interface objects in the plurality of user interface objects, wherein the two or more user interface objects are displayed at respective initial user interface object positions on the touch screen display; and, in response to detecting the second input by the user or series of inputs by the user on two or more user interface objects in the plurality of user interface objects, displaying animations of each respective user interface object in the two or more user interface objects moving from a respective initial user interface object position to the second location.
In accordance with some embodiments, a computer readable storage medium has stored therein instructions which when executed by a computing device with a touch screen display, cause the device to simultaneously display on the touch screen display a plurality of user interface objects and at least one destination object. The instructions also cause the device to detect a first input by a user on a first user interface object at a first location on the touch screen display. The instructions further cause the device to, while continuing to detect the first input by the user: detect movement of the first input by the user across the touch screen display to a second location on the touch screen display; move the first user interface object in accordance with the movement of the first input by the user across the touch screen display to the second location on the touch screen display; detect a second input by the user or series of inputs by the user on two or more user interface objects in the plurality of user interface objects, wherein the two or more user interface objects are displayed at respective initial user interface object positions on the touch screen display; and, in response to detecting the second input by the user or series of inputs by the user on two or more user interface objects in the plurality of user interface objects, display animations of each respective user interface object in the two or more user interface objects moving from a respective initial user interface object position to the second location.
In accordance with some embodiments, a graphical user interface on a computing device with a touch screen display, a memory, and one or more processors to execute one or more programs stored in the memory includes a plurality of user interface objects and at least one destination object. A first input by a user is detected on a first user interface object at a first location on the touch screen display. While continuing to detect the first input by the user: movement of the first input by the user across the touch screen display to a second location on the touch screen display is detected; the first user interface object is moved in accordance with the movement of the first input by the user across the touch screen display to the second location on the touch screen display; a second input by the user or series of inputs by the user on two or more user interface objects in the plurality of user interface objects is detected, wherein the two or more user interface objects are displayed at respective initial user interface object positions on the touch screen display; and, in response to detecting the second input by the user or series of inputs by the user on two or more user interface objects in the plurality of user interface objects, animations of each respective user interface object in the two or more user interface objects moving from a respective initial user interface object position to the second location are displayed.
In accordance with some embodiments, a computing device includes: a touch screen display; and means for simultaneously displaying on the touch screen display a plurality of user interface objects and at least one destination object. The device also includes means for detecting a first input by a user on a first user interface object at a first location on the touch screen display. The device further includes, while continuing to detect the first input by the user: means for detecting movement of the first input by the user across the touch screen display to a second location on the touch screen display; means for moving the first user interface object in accordance with the movement of the first input by the user across the touch screen display to the second location on the touch screen display; means for detecting a second input by the user or series of inputs by the user on two or more user interface objects in the plurality of user interface objects, wherein the two or more user interface objects are displayed at respective initial user interface object positions on the touch screen display; and means, responsive to detecting the second input by the user or series of inputs by the user on two or more user interface objects in the plurality of user interface objects, for displaying animations of each respective user interface object in the two or more user interface objects moving from a respective initial user interface object position to the second location.
In accordance with some embodiments, an information processing apparatus for use in a computing device with a touch screen display includes: means for simultaneously displaying on the touch screen display a plurality of user interface objects and at least one destination object. The apparatus also includes means for detecting a first input by a user on a first user interface object at a first location on the touch screen display. The apparatus further includes, while continuing to detect the first input by the user: means for detecting movement of the first input by the user across the touch screen display to a second location on the touch screen display; means for moving the first user interface object in accordance with the movement of the first input by the user across the touch screen display to the second location on the touch screen display; means for detecting a second input by the user or series of inputs by the user on two or more user interface objects in the plurality of user interface objects, wherein the two or more user interface objects are displayed at respective initial user interface object positions on the touch screen display; and means, responsive to detecting the second input by the user or series of inputs by the user on two or more user interface objects in the plurality of user interface objects, for displaying animations of each respective user interface object in the two or more user interface objects moving from a respective initial user interface object position to the second location.
In accordance with some embodiments, a method is performed at a computing device with a touch screen display. The method includes simultaneously displaying on the touch screen display a plurality of user interface objects in an array. The plurality of user interface objects in the array is displayed in a first arrangement. A first user interface object in the plurality of user interface objects is displayed at a first size. The first arrangement comprises a first plurality of rows. The method further includes detecting simultaneous contacts by a plurality of fingers on the array. The simultaneous contacts have a corresponding centroid position at the first user interface object. The method also includes detecting a gesture made by the simultaneous contacts that corresponds to a command to zoom in by a user-specified amount; and, in response to detecting the gesture by the simultaneous contacts, enlarging the first user interface object to a second size larger than the first size on the touch screen display. The method further includes, after enlarging the first user interface object to the second size and while continuing to detect the simultaneous contacts on the touch screen display, determining an updated centroid position of the simultaneous contacts. The updated centroid position is located at a first vertical position on the touch screen display immediately prior to ceasing to detect the simultaneous contacts. The method also includes ceasing to detect the simultaneous contacts; and, in response to ceasing to detect the simultaneous contacts, displaying an animation of the plurality of user interface objects in the array rearranging to form a second arrangement. The second arrangement comprises a second plurality of rows different from the first plurality of rows. The first user interface object is displayed in a row in the second arrangement that includes the first vertical position on the touch screen display.
In accordance with some embodiments, a computing device includes a touch screen display, one or more processors, memory, and one or more programs. The one or more programs are stored in the memory and configured to be executed by the one or more processors. The one or more programs include instructions for simultaneously displaying on the touch screen display a plurality of user interface objects in an array. The plurality of user interface objects in the array is displayed in a first arrangement. A first user interface object in the plurality of user interface objects is displayed at a first size. The first arrangement comprises a first plurality of rows. The programs also include instructions for detecting simultaneous contacts by a plurality of fingers on the array. The simultaneous contacts have a corresponding centroid position at the first user interface object. The programs further include instructions for: detecting a gesture made by the simultaneous contacts that corresponds to a command to zoom in by a user-specified amount; in response to detecting the gesture by the simultaneous contacts, enlarging the first user interface object to a second size larger than the first size on the touch screen display; and, after enlarging the first user interface object to the second size and while continuing to detect the simultaneous contacts on the touch screen display, determining an updated centroid position of the simultaneous contacts. The updated centroid position is located at a first vertical position on the touch screen display immediately prior to ceasing to detect the simultaneous contacts. The program also includes instructions for: ceasing to detect the simultaneous contacts; and, in response to ceasing to detect the simultaneous contacts, displaying an animation of the plurality of user interface objects in the array rearranging to form a second arrangement. The second arrangement comprises a second plurality of rows different from the first plurality of rows, and the first user interface object is displayed in a row in the second arrangement that includes the first vertical position on the touch screen display.
In accordance with some embodiments, a computer readable storage medium has stored therein instructions which when executed by a computing device with a touch screen display, cause the device to simultaneously display on the touch screen display a plurality of user interface objects in an array. The plurality of user interface objects in the array is displayed in a first arrangement. A first user interface object in the plurality of user interface objects is displayed at a first size. The first arrangement comprises a first plurality of rows. The instructions also cause the device to detect simultaneous contacts by a plurality of fingers on the array. The simultaneous contacts have a corresponding centroid position at the first user interface object. The instructions further cause the device to: detect a gesture made by the simultaneous contacts that corresponds to a command to zoom in by a user-specified amount; in response to detecting the gesture by the simultaneous contacts, enlarge the first user interface object to a second size larger than the first size on the touch screen display; and, after enlarging the first user interface object to the second size and while continuing to detect the simultaneous contacts on the touch screen display, determine an updated centroid position of the simultaneous contacts. The updated centroid position is located at a first vertical position on the touch screen display immediately prior to ceasing to detect the simultaneous contacts. The instructions also cause the device to: cease to detect the simultaneous contacts; and, in response to ceasing to detect the simultaneous contacts, display an animation of the plurality of user interface objects in the array rearranging to form a second arrangement. The second arrangement comprises a second plurality of rows different from the first plurality of rows. The first user interface object is displayed in a row in the second arrangement that includes the first vertical position on the touch screen display.
In accordance with some embodiments, a graphical user interface on a computing device with a touch screen display, a memory, and one or more processors to execute one or more programs stored in the memory includes a plurality of user interface objects in an array. The plurality of user interface objects in the array is displayed in a first arrangement. A first user interface object in the plurality of user interface objects is displayed at a first size. The first arrangement comprises a first plurality of rows. Simultaneous contacts by a plurality of fingers are detected on the array. The simultaneous contacts have a corresponding centroid position at the first user interface object. A gesture made by the simultaneous contacts that corresponds to a command to zoom in by a user-specified amount is detected. In response to detecting the gesture by the simultaneous contacts, the first user interface object is enlarged to a second size larger than the first size on the touch screen display. After enlarging the first user interface object to the second size and while continuing to detect the simultaneous contacts on the touch screen display, an updated centroid position of the simultaneous contacts is determined. The updated centroid position is located at a first vertical position on the touch screen display immediately prior to ceasing to detect the simultaneous contacts. The simultaneous contacts cease to be detected. In response to ceasing to detect the simultaneous contacts, an animation of the plurality of user interface objects in the array rearranging to form a second arrangement is displayed. The second arrangement comprises a second plurality of rows different from the first plurality of rows. The first user interface object is displayed in a row in the second arrangement that includes the first vertical position on the touch screen display.
In accordance with some embodiments, a computing device includes: a touch screen display; and means for simultaneously displaying on the touch screen display a plurality of user interface objects in an array. The plurality of user interface objects in the array is displayed in a first arrangement. A first user interface object in the plurality of user interface objects is displayed at a first size. The first arrangement comprises a first plurality of rows. The device also includes means for detecting simultaneous contacts by a plurality of fingers on the array. The simultaneous contacts have a corresponding centroid position at the first user interface object. The device further includes: means for detecting a gesture made by the simultaneous contacts that corresponds to a command to zoom in by a user-specified amount; means, responsive to detecting the gesture by the simultaneous contacts, for enlarging the first user interface object to a second size larger than the first size on the touch screen display; and means for, after enlarging the first user interface object to the second size and while continuing to detect the simultaneous contacts on the touch screen display, determining an updated centroid position of the simultaneous contacts. The updated centroid position is located at a first vertical position on the touch screen display immediately prior to ceasing to detect the simultaneous contacts. The device also includes: means for means for ceasing to detect the simultaneous contacts; and, means, responsive to ceasing to detect the simultaneous contacts, for displaying an animation of the plurality of user interface objects in the array rearranging to form a second arrangement. The second arrangement comprises a second plurality of rows different from the first plurality of rows. The first user interface object is displayed in a row in the second arrangement that includes the first vertical position on the touch screen display.
In accordance with some embodiments, an information processing apparatus for use in a computing device with a touch screen display includes means for simultaneously displaying on the touch screen display a plurality of user interface objects in an array. The plurality of user interface objects in the array is displayed in a first arrangement. A first user interface object in the plurality of user interface objects is displayed at a first size. The first arrangement comprises a first plurality of rows. The apparatus also includes means for detecting simultaneous contacts by a plurality of fingers on the array. The simultaneous contacts have a corresponding centroid position at the first user interface object. The apparatus further includes: means for detecting a gesture made by the simultaneous contacts that corresponds to a command to zoom in by a user-specified amount; means, responsive to detecting the gesture by the simultaneous contacts, for enlarging the first user interface object to a second size larger than the first size on the touch screen display; and means for, after enlarging the first user interface object to the second size and while continuing to detect the simultaneous contacts on the touch screen display, determining an updated centroid position of the simultaneous contacts. The updated centroid position is located at a first vertical position on the touch screen display immediately prior to ceasing to detect the simultaneous contacts. The apparatus also includes: means for means for ceasing to detect the simultaneous contacts; and, means, responsive to ceasing to detect the simultaneous contacts, for displaying an animation of the plurality of user interface objects in the array rearranging to form a second arrangement. The second arrangement comprises a second plurality of rows different from the first plurality of rows. The first user interface object is displayed in a row in the second arrangement that includes the first vertical position on the touch screen display.
In accordance with some embodiments, a method is performed at a computing device with a touch screen display. The method includes simultaneously displaying on the touch screen display at least one destination object and at least a subset of a plurality of arrays of user interface objects. The method further includes detecting a first input by a user on the touch screen display; and, in response to detecting the first input by the user on the touch screen display, vertically scrolling the plurality of arrays on the touch screen display. The method further includes detecting a second input by the user on a single array in the plurality of arrays on the touch screen display; and, in response to detecting the second input by the user on the single array, horizontally scrolling user interface objects in the single array.
In accordance with some embodiments, a computing device includes a touch screen display, one or more processors, memory, and one or more programs. The one or more programs are stored in the memory and configured to be executed by the one or more processors. The one or more programs include instructions for simultaneously displaying on the touch screen display at least one destination object and at least a subset of a plurality of arrays of user interface objects. The programs also include instructions for: detecting a first input by a user on the touch screen display; and, in response to detecting the first input by the user on the touch screen display, vertically scrolling the plurality of arrays on the touch screen display. The programs further include instructions for: detecting a second input by the user on a single array in the plurality of arrays on the touch screen display; and, in response to detecting the second input by the user on the single array, horizontally scrolling user interface objects in the single array.
In accordance with some embodiments, a computer readable storage medium has stored therein instructions which when executed by a computing device with a touch screen display, cause the device to simultaneously display on the touch screen display at least one destination object and at least a subset of a plurality of arrays of user interface objects. The instructions also cause the device to: detect a first input by a user on the touch screen display; and in response to detecting the first input by the user on the touch screen display, vertically scroll the plurality of arrays on the touch screen display. The instructions further cause the device to: detect a second input by the user on a single array in the plurality of arrays on the touch screen display; and, in response to detecting the second input by the user on the single array, horizontally scroll user interface objects in the single array.
In accordance with some embodiments, a graphical user interface on a computing device with a touch screen display, a memory, and one or more processors to execute one or more programs stored in the memory includes at least one destination object and at least a subset of a plurality of arrays of user interface objects. A first input by a user on the touch screen display is detected. In response to detecting the first input by the user on the touch screen display, the plurality of arrays on the touch screen display is vertically scrolled. A second input by the user on a single array in the plurality of arrays on the touch screen display is detected. In response to detecting the second input by the user on the single array, user interface objects in the single array are horizontally scrolled.
In accordance with some embodiments, a computing device includes: a touch screen display; and means for simultaneously displaying on the touch screen display at least one destination object and at least a subset of a plurality of arrays of user interface objects. The device also includes: means for detecting a first input by a user on the touch screen display; and, means, responsive to detecting the first input by the user on the touch screen display, for vertically scrolling the plurality of arrays on the touch screen display. The device further includes: means for detecting a second input by the user on a single array in the plurality of arrays on the touch screen display; and, means, responsive to detecting the second input by the user on the single array, for horizontally scrolling user interface objects in the single array.
In accordance with some embodiments, an information processing apparatus for use in a computing device with a touch screen display includes means for simultaneously displaying on the touch screen display at least one destination object and at least a subset of a plurality of arrays of user interface objects. The apparatus also includes: means for detecting a first input by a user on the touch screen display; and, means, responsive to detecting the first input by the user on the touch screen display, for vertically scrolling the plurality of arrays on the touch screen display. The apparatus further includes: means for detecting a second input by the user on a single array in the plurality of arrays on the touch screen display; and, means, responsive to detecting the second input by the user on the single array, for horizontally scrolling user interface objects in the single array.
In accordance with some embodiments, a method is performed at a computing device with a touch screen display. The method includes: simultaneously displaying on the touch screen display at least one destination object and at least a subset of a plurality of arrays of user interface objects. The method further includes: detecting activation of a respective array name icon that corresponds to a respective array in the plurality of arrays, and, in response to detecting activation of the respective array name icon that corresponds to the respective array, displaying an animation of user interface objects in the respective array moving into a respective representative user interface object for the respective array. The method also includes: detecting movement of an input by the user from the array name icon to a destination object or an area associated with a destination object; and, moving the respective representative user interface object in accordance with the movement of the input by the user across the touch screen display to the destination object or the area associated with a destination object. The method further includes: detecting lift off of the input by the user from the touch screen display at the destination object or at the area associated with a destination object; and, in response to detecting lift off of the input by the user from the touch screen display at the destination object or at the area associated with the destination object, performing an action on the user interface objects in the respective array. The action is associated with the destination object.
In accordance with some embodiments, a computing device includes a touch screen display, one or more processors, memory, and one or more programs. The one or more programs are stored in the memory and configured to be executed by the one or more processors. The one or more programs include instructions for simultaneously displaying on the touch screen display at least one destination object and at least a subset of a plurality of arrays of user interface objects. The programs also include instructions for: detecting activation of a respective array name icon that corresponds to a respective array in the plurality of arrays; and, in response to detecting activation of the respective array name icon that corresponds to the respective array, displaying an animation of user interface objects in the respective array moving into a respective representative user interface object for the respective array. The programs further include instructions for: detecting movement of an input by the user from the array name icon to a destination object or an area associated with a destination object; and moving the respective representative user interface object in accordance with the movement of the input by the user across the touch screen display to the destination object or the area associated with a destination object. The programs also include instructions for: detecting lift off of the input by the user from the touch screen display at the destination object or at the area associated with a destination object; and, in response to detecting lift off of the input by the user from the touch screen display at the destination object or at the area associated with the destination object, performing an action on the user interface objects in the respective array. The action is associated with the destination object.
In accordance with some embodiments, a computer readable storage medium has stored therein instructions which when executed by a computing device with a touch screen display, cause the device to simultaneously display on the touch screen display at least one destination object and at least a subset of a plurality of arrays of user interface objects. The instructions also cause the device to: detect activation of a respective array name icon that corresponds to a respective array in the plurality of arrays; and, in response to detecting activation of the respective array name icon that corresponds to the respective array, display an animation of user interface objects in the respective array moving into a respective representative user interface object for the respective array. The instructions also cause the device to: detect movement of an input by the user from the array name icon to a destination object or an area associated with a destination object; and, move the respective representative user interface object in accordance with the movement of the input by the user across the touch screen display to the destination object or the area associated with a destination object. The instructions further cause the device to: detect lift off of the input by the user from the touch screen display at the destination object or at the area associated with a destination object; and, in response to detecting lift off of the input by the user from the touch screen display at the destination object or at the area associated with the destination object, perform an action on the user interface objects in the respective array. The action is associated with the destination object.
In accordance with some embodiments, a graphical user interface on a computing device with a touch screen display, a memory, and one or more processors to execute one or more programs stored in the memory includes at least one destination object and at least a subset of a plurality of arrays of user interface objects. Activation of a respective array name icon that corresponds to a respective array in the plurality of arrays is detected. In response to detecting activation of the respective array name icon that corresponds to the respective array, an animation of user interface objects in the respective array moving into a respective representative user interface object for the respective array is displayed. Movement of an input by the user from the array name icon to a destination object or an area associated with a destination object is detected. The respective representative user interface object is moved in accordance with the movement of the input by the user across the touch screen display to the destination object or the area associated with a destination object. Lift off of the input by the user from the touch screen display at the destination object or at the area associated with a destination object is detected. In response to detecting lift off of the input by the user from the touch screen display at the destination object or at the area associated with the destination object, an action on the user interface objects in the respective array is performed. The action is associated with the destination object.
In accordance with some embodiments, a computing device includes: a touch screen display; and means for simultaneously displaying on the touch screen display at least one destination object and at least a subset of a plurality of arrays of user interface objects. The device also includes: means for detecting activation of a respective array name icon that corresponds to a respective array in the plurality of arrays; and means, responsive to detecting activation of the respective array name icon that corresponds to the respective array, for displaying an animation of user interface objects in the respective array moving into a respective representative user interface object for the respective array. The device further includes: means for detecting movement of an input by the user from the array name icon to a destination object or an area associated with a destination object; and means for moving the respective representative user interface object in accordance with the movement of the input by the user across the touch screen display to the destination object or the area associated with a destination object. The device also includes: means for detecting lift off of the input by the user from the touch screen display at the destination object or at the area associated with a destination object; and, means, responsive to detecting lift off of the input by the user from the touch screen display at the destination object or at the area associated with the destination object, for performing an action on the user interface objects in the respective array. The action is associated with the destination object.
In accordance with some embodiments, an information processing apparatus for use in a computing device with a touch screen display includes means for simultaneously displaying on the touch screen display at least one destination object and at least a subset of a plurality of arrays of user interface objects. The apparatus also includes: means for detecting activation of a respective array name icon that corresponds to a respective array in the plurality of arrays; and means, responsive to detecting activation of the respective array name icon that corresponds to the respective array, for displaying an animation of user interface objects in the respective array moving into a respective representative user interface object for the respective array. The apparatus further includes: means for detecting movement of an input by the user from the array name icon to a destination object or an area associated with a destination object; and means for moving the respective representative user interface object in accordance with the movement of the input by the user across the touch screen display to the destination object or the area associated with a destination object. The apparatus also includes: means for detecting lift off of the input by the user from the touch screen display at the destination object or at the area associated with a destination object; and, means, responsive to detecting lift off of the input by the user from the touch screen display at the destination object or at the area associated with the destination object, for performing an action on the user interface objects in the respective array. The action is associated with the destination object.
In accordance with some embodiments, a method is performed at a computing device with a touch screen display. The method includes: simultaneously displaying on the touch screen display at least one destination object and at least a subset of a plurality of arrays of user interface objects; detecting activation of a menu category icon; and, in response to detecting activation of the menu category icon, displaying a plurality of representative user interface objects for respective arrays in a menu category that corresponds to the menu category icon.
In accordance with some embodiments, a computing device includes a touch screen display, one or more processors, memory, and one or more programs. The one or more programs are stored in the memory and configured to be executed by the one or more processors. The one or more programs include instructions for: simultaneously displaying on the touch screen display at least one destination object and at least a subset of a plurality of arrays of user interface objects; detecting activation of a menu category icon; and, in response to detecting activation of the menu category icon, displaying a plurality of representative user interface objects for respective arrays in a menu category that corresponds to the menu category icon.
In accordance with some embodiments, a computer readable storage medium has stored therein instructions which when executed by a computing device with a touch screen display, cause the device to: simultaneously display on the touch screen display at least one destination object and at least a subset of a plurality of arrays of user interface objects; detect activation of a menu category icon; and, in response to detecting activation of the menu category icon, display a plurality of representative user interface objects for respective arrays in a menu category that corresponds to the menu category icon.
In accordance with some embodiments, a graphical user interface on a computing device with a touch screen display, a memory, and one or more processors to execute one or more programs stored in the memory includes at least one destination object and at least a subset of a plurality of arrays of user interface objects. Activation of a menu category icon is detected. In response to detecting activation of the menu category icon, a plurality of representative user interface objects for respective arrays are displayed in a menu category that corresponds to the menu category icon.
In accordance with some embodiments, a computing device includes: a touch screen display; means for simultaneously displaying on the touch screen display at least one destination object and at least a subset of a plurality of arrays of user interface objects; means for detecting activation of a menu category icon; and, means, responsive to detecting activation of the menu category icon, for displaying a plurality of representative user interface objects for respective arrays in a menu category that corresponds to the menu category icon.
In accordance with some embodiments, an information processing apparatus for use in a computing device with a touch screen display includes: means for simultaneously displaying on the touch screen display at least one destination object and at least a subset of a plurality of arrays of user interface objects; means for detecting activation of a menu category icon; and, means, responsive to detecting activation of the menu category icon, for displaying a plurality of representative user interface objects for respective arrays in a menu category that corresponds to the menu category icon.
In accordance with some embodiments, a method is performed at a computing device with a touch screen display. The method includes: simultaneously displaying on the touch screen display at least one destination object and at least a subset of a plurality of arrays of user interface objects; detecting a first input by a user on a destination object; while continuing to detect the first input by the user on the destination object, detecting a second input by the user on an array name icon; and, in response to detecting the second input by the user on the array name icon, performing an action on all user interface objects in an array that corresponds to the array name icon. The action is associated with the destination object.
In accordance with some embodiments, a computing device includes a touch screen display, one or more processors, memory, and one or more programs. The one or more programs are stored in the memory and configured to be executed by the one or more processors. The one or more programs include instructions for: simultaneously displaying on the touch screen display at least one destination object and at least a subset of a plurality of arrays of user interface objects; detecting a first input by a user on a destination object; while continuing to detect the first input by the user on the destination object, detecting a second input by the user on an array name icon; and, in response to detecting the second input by the user on the array name icon, performing an action on all user interface objects in an array that corresponds to the array name icon. The action is associated with the destination object.
In accordance with some embodiments, a computer readable storage medium has stored therein instructions which when executed by a computing device with a touch screen display, cause the device to: simultaneously display on the touch screen display at least one destination object and at least a subset of a plurality of arrays of user interface objects; detect a first input by a user on a destination object; while continuing to detect the first input by the user on the destination object, detect a second input by the user on an array name icon; and, in response to detecting the second input by the user on the array name icon, perform an action on all user interface objects in an array that corresponds to the array name icon. The action is associated with the destination object.
In accordance with some embodiments, a graphical user interface on a computing device with a touch screen display, a memory, and one or more processors to execute one or more programs stored in the memory includes at least one destination object and at least a subset of a plurality of arrays of user interface objects. A first input by a user on a destination object is detected. While continuing to detect the first input by the user on the destination object, a second input by the user on an array name icon is detected. In response to detecting the second input by the user on the array name icon, an action is performed on all user interface objects in an array that corresponds to the array name icon. The action is associated with the destination object.
In accordance with some embodiments, a computing device includes: a touch screen display; means for simultaneously displaying on the touch screen display at least one destination object and at least a subset of a plurality of arrays of user interface objects; means for detecting a first input by a user on a destination object; while continuing to detect the first input by the user on the destination object, means for detecting a second input by the user on an array name icon; and, means, responsive to detecting the second input by the user on the array name icon, for performing an action on all user interface objects in an array that corresponds to the array name icon. The action is associated with the destination object.
In accordance with some embodiments, an information processing apparatus for use in a computing device with a touch screen display includes: means for simultaneously displaying on the touch screen display at least one destination object and at least a subset of a plurality of arrays of user interface objects; means for detecting a first input by a user on a destination object; while continuing to detect the first input by the user on the destination object, means for detecting a second input by the user on an array name icon; and, means, responsive to detecting the second input by the user on the array name icon, for performing an action on all user interface objects in an array that corresponds to the array name icon. The action is associated with the destination object.
Thus, computing devices with touch screen displays are provided with faster, more efficient methods and interfaces for manipulating user interface objects using two or more simultaneous user inputs, thereby increasing the effectiveness, efficiency, and user satisfaction with such devices. Such methods and interfaces may complement or replace conventional methods for manipulating user interface objects.
For a better understanding of the aforementioned embodiments of the invention as well as additional embodiments thereof, reference should be made to the Description of Embodiments below, in conjunction with the following drawings in which like reference numerals refer to corresponding parts throughout the figures.
FIGS. 8A-8UU illustrate exemplary user interfaces for manipulating user interface objects in a plurality of arrays of user interface objects in accordance with some embodiments.
Reference will now be made in detail to embodiments, examples of which are illustrated in the accompanying drawings. In the following detailed description, numerous specific details are set forth in order to provide a thorough understanding of the present invention. However, it will be apparent to one of ordinary skill in the art that the present invention may be practiced without these specific details. In other instances, well-known methods, procedures, components, circuits, and networks have not been described in detail so as not to unnecessarily obscure aspects of the embodiments.
It will also be understood that, although the terms first, second, etc. may be used herein to describe various elements, these elements should not be limited by these terms. These terms are only used to distinguish one element from another. For example, a first contact could be termed a second contact, and, similarly, a second contact could be termed a first contact, without departing from the scope of the present invention. The first contact and the second contact are both contacts, but they are not the same contact.
The terminology used in the description of the invention herein is for the purpose of describing particular embodiments only and is not intended to be limiting of the invention. As used in the description of the invention and the appended claims, the singular forms “a”, “an” and “the” are intended to include the plural forms as well, unless the context clearly indicates otherwise. It will also be understood that the term “and/or” as used herein refers to and encompasses any and all possible combinations of one or more of the associated listed items. It will be further understood that the terms “includes,” “including,” “comprises,” and/or “comprising,” when used in this specification, specify the presence of stated features, integers, steps, operations, elements, and/or components, but do not preclude the presence or addition of one or more other features, integers, steps, operations, elements, components, and/or groups thereof.
As used herein, the term “if” may be construed to mean “when” or “upon” or “in response to determining” or “in response to detecting,” depending on the context. Similarly, the phrase “if it is determined” or “if [a stated condition or event] is detected” may be construed to mean “upon determining” or “in response to determining” or “upon detecting [the stated condition or event]” or “in response to detecting [the stated condition or event],” depending on the context.
Embodiments of computing devices, user interfaces for such devices, and associated processes for using such devices are described. In some embodiments, the computing device is a portable communications device such as a mobile telephone that also contains other functions, such as PDA and/or music player functions. Exemplary embodiments of portable multifunction devices include, without limitation, the iPhone® and iPod Touch® devices from Apple, Inc. of Cupertino, Calif.
In the discussion that follows, a computing device that includes a display and a touch-sensitive surface is described. It should be understood, however, that the computing device may include one or more other physical user-interface devices, such as a physical keyboard, a mouse and/or a joystick.
The device supports a variety of applications, such as one or more of the following: a drawing application, a presentation application, a word processing application, a website creation application, a disk authoring application, a spreadsheet application, a gaming application, a telephone application, a video conferencing application, an e-mail application, an instant messaging application, a workout support application, a photo management application, a digital camera application, a digital video camera application, a web browsing application, a digital music player application, and/or a digital video player application.
The various applications that may be executed on the device may use at least one common physical user-interface device, such as the touch-sensitive surface. One or more functions of the touch-sensitive surface as well as corresponding information displayed on the device may be adjusted and/or varied from one application to the next and/or within a respective application. In this way, a common physical architecture (such as the touch-sensitive surface) of the device may support the variety of applications with user interfaces that are intuitive and transparent.
The user interfaces may include one or more soft keyboard embodiments. The soft keyboard embodiments may include standard (QWERTY) and/or non-standard configurations of symbols on the displayed icons of the keyboard, such as those described in U.S. patent application Ser. Nos. 11/459,606, “Keyboards For Portable Electronic Devices,” filed Jul. 24, 2006, and 11/459,615, “Touch Screen Keyboards For Portable Electronic Devices,” filed Jul. 24, 2006, the contents of which are hereby incorporated by reference in their entirety. The keyboard embodiments may include a reduced number of icons (or soft keys) relative to the number of keys in existing physical keyboards, such as that for a typewriter. This may make it easier for users to select one or more icons in the keyboard, and thus, one or more corresponding symbols. The keyboard embodiments may be adaptive. For example, displayed icons may be modified in accordance with user actions, such as selecting one or more icons and/or one or more corresponding symbols. One or more applications on the device may utilize common and/or different keyboard embodiments. Thus, the keyboard embodiment used may be tailored to at least some of the applications. In some embodiments, one or more keyboard embodiments may be tailored to a respective user. For example, one or more keyboard embodiments may be tailored to a respective user based on a word usage history (lexicography, slang, individual usage) of the respective user. Some of the keyboard embodiments may be adjusted to reduce a probability of a user error when selecting one or more icons, and thus one or more symbols, when using the soft keyboard embodiments.
Attention is now directed towards embodiments of portable devices with touch-sensitive displays.
It should be appreciated that the device 100 is only one example of a portable multifunction device 100, and that the device 100 may have more or fewer components than shown, may combine two or more components, or a may have a different configuration or arrangement of the components. The various components shown in
Memory 102 may include high-speed random access memory and may also include non-volatile memory, such as one or more magnetic disk storage devices, flash memory devices, or other non-volatile solid-state memory devices. Access to memory 102 by other components of the device 100, such as the CPU 120 and the peripherals interface 118, may be controlled by the memory controller 122.
The peripherals interface 118 couples the input and output peripherals of the device to the CPU 120 and memory 102. The one or more processors 120 run or execute various software programs and/or sets of instructions stored in memory 102 to perform various functions for the device 100 and to process data.
In some embodiments, the peripherals interface 118, the CPU 120, and the memory controller 122 may be implemented on a single chip, such as a chip 104. In some other embodiments, they may be implemented on separate chips.
The RF (radio frequency) circuitry 108 receives and sends RF signals, also called electromagnetic signals. The RF circuitry 108 converts electrical signals to/from electromagnetic signals and communicates with communications networks and other communications devices via the electromagnetic signals. The RF circuitry 108 may include well-known circuitry for performing these functions, including but not limited to an antenna system, an RF transceiver, one or more amplifiers, a tuner, one or more oscillators, a digital signal processor, a CODEC chipset, a subscriber identity module (SIM) card, memory, and so forth. The RF circuitry 108 may communicate with networks, such as the Internet, also referred to as the World Wide Web (WWW), an intranet and/or a wireless network, such as a cellular telephone network, a wireless local area network (LAN) and/or a metropolitan area network (MAN), and other devices by wireless communication. The wireless communication may use any of a plurality of communications standards, protocols and technologies, including but not limited to Global System for Mobile Communications (GSM), Enhanced Data GSM Environment (EDGE), high-speed downlink packet access (HSDPA), wideband code division multiple access (W-CDMA), code division multiple access (CDMA), time division multiple access (TDMA), Bluetooth, Wireless Fidelity (Wi-Fi) (e.g., IEEE 802.11a, IEEE 802.11b, IEEE 802.11g and/or IEEE 802.11n), voice over Internet Protocol (VoIP), Wi-MAX, a protocol for email (e.g., Internet message access protocol (IMAP) and/or post office protocol (POP)), instant messaging (e.g., extensible messaging and presence protocol (XMPP), Session Initiation Protocol for Instant Messaging and Presence Leveraging Extensions (SIMPLE), Instant Messaging and Presence Service (IMPS)), and/or Short Message Service (SMS), or any other suitable communication protocol, including communication protocols not yet developed as of the filing date of this document.
The audio circuitry 110, the speaker 111, and the microphone 113 provide an audio interface between a user and the device 100. The audio circuitry 110 receives audio data from the peripherals interface 118, converts the audio data to an electrical signal, and transmits the electrical signal to the speaker 111. The speaker 111 converts the electrical signal to human-audible sound waves. The audio circuitry 110 also receives electrical signals converted by the microphone 113 from sound waves. The audio circuitry 110 converts the electrical signal to audio data and transmits the audio data to the peripherals interface 118 for processing. Audio data may be retrieved from and/or transmitted to memory 102 and/or the RF circuitry 108 by the peripherals interface 118. In some embodiments, the audio circuitry 110 also includes a headset jack (e.g. 212,
The I/O subsystem 106 couples input/output peripherals on the device 100, such as the touch screen 112 and other input/control devices 116, to the peripherals interface 118. The I/O subsystem 106 may include a display controller 156 and one or more input controllers 160 for other input or control devices. The one or more input controllers 160 receive/send electrical signals from/to other input or control devices 116. The other input/control devices 116 may include physical buttons (e.g., push buttons, rocker buttons, etc.), dials, slider switches, joysticks, click wheels, and so forth. In some alternate embodiments, input controller(s) 160 may be coupled to any (or none) of the following: a keyboard, infrared port, USB port, and a pointer device such as a mouse. The one or more buttons (e.g., 208,
The touch-sensitive touch screen 112 provides an input interface and an output interface between the device and a user. The display controller 156 receives and/or sends electrical signals from/to the touch screen 112. The touch screen 112 displays visual output to the user. The visual output may include graphics, text, icons, video, and any combination thereof (collectively termed “graphics”). In some embodiments, some or all of the visual output may correspond to user-interface objects.
A touch screen 112 has a touch-sensitive surface, sensor or set of sensors that accepts input from the user based on haptic and/or tactile contact. The touch screen 112 and the display controller 156 (along with any associated modules and/or sets of instructions in memory 102) detect contact (and any movement or breaking of the contact) on the touch screen 112 and converts the detected contact into interaction with user-interface objects (e.g., one or more soft keys, icons, web pages or images) that are displayed on the touch screen. In an exemplary embodiment, a point of contact between a touch screen 112 and the user corresponds to a finger of the user.
The touch screen 112 may use LCD (liquid crystal display) technology, or LPD (light emitting polymer display) technology, although other display technologies may be used in other embodiments. The touch screen 112 and the display controller 156 may detect contact and any movement or breaking thereof using any of a plurality of touch sensing technologies now known or later developed, including but not limited to capacitive, resistive, infrared, and surface acoustic wave technologies, as well as other proximity sensor arrays or other elements for determining one or more points of contact with a touch screen 112. In an exemplary embodiment, projected mutual capacitance sensing technology is used, such as that found in the iPhone® and iPod Touch® from Apple, Inc. of Cupertino, Calif.
A touch-sensitive display in some embodiments of the touch screen 112 may be analogous to the multi-touch sensitive tablets described in the following U.S. Pat. Nos. 6,323,846 (Westerman et al.), 6,570,557 (Westerman et al.), and/or 6,677,932 (Westerman), and/or U.S. Patent Publication 2002/0015024A1, each of which is hereby incorporated by reference in its entirety. However, a touch screen 112 displays visual output from the portable device 100, whereas touch sensitive tablets do not provide visual output.
A touch-sensitive display in some embodiments of the touch screen 112 may be as described in the following applications: (1) U.S. patent application Ser. No. 11/381,313, “Multipoint Touch Surface Controller,” filed May 2, 2006; (2) U.S. patent application Ser. No. 10/840,862, “Multipoint Touchscreen,” filed May 6, 2004; (3) U.S. patent application Ser. No. 10/903,964, “Gestures For Touch Sensitive Input Devices,” filed Jul. 30, 2004; (4) U.S. patent application Ser. No. 11/048,264, “Gestures For Touch Sensitive Input Devices,” filed Jan. 31, 2005; (5) U.S. patent application Ser. No. 11/038,590, “Mode-Based Graphical User Interfaces For Touch Sensitive Input Devices,” filed Jan. 18, 2005; (6) U.S. patent application Ser. No. 11/228,758, “Virtual Input Device Placement On A Touch Screen User Interface,” filed Sep. 16, 2005; (7) U.S. patent application Ser. No. 11/228,700, “Operation Of A Computer With A Touch Screen Interface,” filed Sep. 16, 2005; (8) U.S. patent application Ser. No. 11/228,737, “Activating Virtual Keys Of A Touch-Screen Virtual Keyboard,” filed Sep. 16, 2005; and (9) U.S. patent application Ser. No. 11/367,749, “Multi-Functional Hand-Held Device,” filed Mar. 3, 2006. All of these applications are incorporated by reference herein in their entirety.
The touch screen 112 may have a resolution in excess of 100 dpi. In an exemplary embodiment, the touch screen has a resolution of approximately 160 dpi. The user may make contact with the touch screen 112 using any suitable object or appendage, such as a stylus, a finger, and so forth. In some embodiments, the user interface is designed to work primarily with finger-based contacts and gestures, which are much less precise than stylus-based input due to the larger area of contact of a finger on the touch screen. In some embodiments, the device translates the rough finger-based input into a precise pointer/cursor position or command for performing the actions desired by the user.
In some embodiments, in addition to the touch screen, the device 100 may include a touchpad (not shown) for activating or deactivating particular functions. In some embodiments, the touchpad is a touch-sensitive area of the device that, unlike the touch screen, does not display visual output. The touchpad may be a touch-sensitive surface that is separate from the touch screen 112 or an extension of the touch-sensitive surface formed by the touch screen.
In some embodiments, the device 100 may include a physical or virtual click wheel as an input control device 116. A user may navigate among and interact with one or more graphical objects (e.g., icons) displayed in the touch screen 112 by rotating the click wheel or by moving a point of contact with the click wheel (e.g., where the amount of movement of the point of contact is measured by its angular displacement with respect to a center point of the click wheel). The click wheel may also be used to select one or more of the displayed icons. For example, the user may press down on at least a portion of the click wheel or an associated button. User commands and navigation commands provided by the user via the click wheel may be processed by an input controller 160 as well as one or more of the modules and/or sets of instructions in memory 102. For a virtual click wheel, the click wheel and click wheel controller may be part of the touch screen 112 and the display controller 156, respectively. For a virtual click wheel, the click wheel may be either an opaque or semitransparent object that appears and disappears on the touch screen display in response to user interaction with the device. In some embodiments, a virtual click wheel is displayed on the touch screen of a portable multifunction device and operated by user contact with the touch screen.
The device 100 also includes a power system 162 for powering the various components. The power system 162 may include a power management system, one or more power sources (e.g., battery, alternating current (AC)), a recharging system, a power failure detection circuit, a power converter or inverter, a power status indicator (e.g., a light-emitting diode (LED)) and any other components associated with the generation, management and distribution of power in portable devices.
The device 100 may also include one or more optical sensors 164.
The device 100 may also include one or more proximity sensors 166.
The device 100 may also include one or more accelerometers 168.
In some embodiments, the software components stored in memory 102 may include an operating system 126, a communication module (or set of instructions) 128, a contact/motion module (or set of instructions) 130, a graphics module (or set of instructions) 132, a text input module (or set of instructions) 134, a Global Positioning System (GPS) module (or set of instructions) 135, and applications (or set of instructions) 136.
The operating system 126 (e.g., Darwin, RTXC, LINUX, UNIX, OS X, WINDOWS, or an embedded operating system such as VxWorks) includes various software components and/or drivers for controlling and managing general system tasks (e.g., memory management, storage device control, power management, etc.) and facilitates communication between various hardware and software components.
The communication module 128 facilitates communication with other devices over one or more external ports 124 and also includes various software components for handling data received by the RF circuitry 108 and/or the external port 124. The external port 124 (e.g., Universal Serial Bus (USB), FIREWIRE, etc.) is adapted for coupling directly to other devices or indirectly over a network (e.g., the Internet, wireless LAN, etc.). In some embodiments, the external port is a multi-pin (e.g., 30-pin) connector that is the same as, or similar to and/or compatible with the 30-pin connector used on iPod (trademark of Apple, Inc.) devices.
The contact/motion module 130 may detect contact with the touch screen 112 (in conjunction with the display controller 156) and other touch sensitive devices (e.g., a touchpad or physical click wheel). The contact/motion module 130 includes various software components for performing various operations related to detection of contact, such as determining if contact has occurred (e.g., detecting a finger-down event), determining if there is movement of the contact and tracking the movement across the touch-sensitive surface (e.g., detecting one or more finger-dragging events), and determining if the contact has ceased (e.g., detecting a finger-up event or a break in contact). The contact/motion module 130 receives contact data from the touch-sensitive surface. Determining movement of the point of contact, which is represented by a series of contact data, may include determining speed (magnitude), velocity (magnitude and direction), and/or an acceleration (a change in magnitude and/or direction) of the point of contact. These operations may be applied to single contacts (e.g., one finger contacts) or to multiple simultaneous contacts (e.g., “multitouch”/multiple finger contacts). In some embodiments, the contact/motion module 130 and the display controller 156 detects contact on a touchpad. In some embodiments, the contact/motion module 130 and the controller 160 detects contact on a click wheel.
The contact/motion module 130 may detect a gesture input by a user. Different gestures on the touch-sensitive surface have different contact patterns. Thus, a gesture may be detected by detecting a particular contact pattern. For example, detecting a finger tap gesture includes detecting a finger-down event followed by detecting a finger-up event at the same position (or substantially the same position) as the finger-down event (e.g., at the position of an icon). As another example, detecting a finger swipe gesture on the touch-sensitive surface includes detecting a finger-down event followed by detecting one or more finger-dragging events, and subsequently followed by detecting a finger-up event.
The graphics module 132 includes various known software components for rendering and displaying graphics on the touch screen 112 or other display, including components for changing the intensity of graphics that are displayed. As used herein, the term “graphics” includes any object that can be displayed to a user, including without limitation text, web pages, icons (such as user-interface objects including soft keys), digital images, videos, animations and the like.
In some embodiments, the graphics module 132 stores data representing graphics to be used. Each graphic may be assigned a corresponding code. The graphics module 132 receives, from applications etc., one or more codes specifying graphics to be displayed along with, if necessary, coordinate data and other graphic property data, and then generates screen image data to output to display controller 156.
The text input module 134, which may be a component of graphics module 132, provides soft keyboards for entering text in various applications (e.g., contacts 137, e-mail 140, IM 141, browser 147, and any other application that needs text input).
The GPS module 135 determines the location of the device and provides this information for use in various applications (e.g., to telephone 138 for use in location-based dialing, to camera 143 as picture/video metadata, and to applications that provide location-based services such as weather widgets, local yellow page widgets, and map/navigation widgets).
The applications 136 may include the following modules (or sets of instructions), or a subset or superset thereof:
Examples of other applications 136 that may be stored in memory 102 include other word processing applications, other image editing applications, drawing applications, presentation applications, JAVA-enabled applications, encryption, digital rights management, voice recognition, and voice replication.
In conjunction with touch screen 112, display controller 156, contact module 130, graphics module 132, and text input module 134, the contacts module 137 may be used to manage an address book or contact list, including: adding name(s) to the address book; deleting name(s) from the address book; associating telephone number(s), e-mail address(es), physical address(es) or other information with a name; associating an image with a name; categorizing and sorting names; providing telephone numbers or e-mail addresses to initiate and/or facilitate communications by telephone 138, video conference 139, e-mail 140, or IM 141; and so forth.
In conjunction with RF circuitry 108, audio circuitry 110, speaker 111, microphone 113, touch screen 112, display controller 156, contact module 130, graphics module 132, and text input module 134, the telephone module 138 may be used to enter a sequence of characters corresponding to a telephone number, access one or more telephone numbers in the address book 137, modify a telephone number that has been entered, dial a respective telephone number, conduct a conversation and disconnect or hang up when the conversation is completed. As noted above, the wireless communication may use any of a plurality of communications standards, protocols and technologies.
In conjunction with RF circuitry 108, audio circuitry 110, speaker 111, microphone 113, touch screen 112, display controller 156, optical sensor 164, optical sensor controller 158, contact module 130, graphics module 132, text input module 134, contact list 137, and telephone module 138, the videoconferencing module 139 may be used to initiate, conduct, and terminate a video conference between a user and one or more other participants.
In conjunction with RF circuitry 108, touch screen 112, display controller 156, contact module 130, graphics module 132, and text input module 134, the e-mail client module 140 may be used to create, send, receive, and manage e-mail. In conjunction with image management module 144, the e-mail module 140 makes it very easy to create and send e-mails with still or video images taken with camera module 143.
In conjunction with RF circuitry 108, touch screen 112, display controller 156, contact module 130, graphics module 132, and text input module 134, the instant messaging module 141 may be used to enter a sequence of characters corresponding to an instant message, to modify previously entered characters, to transmit a respective instant message (for example, using a Short Message Service (SMS) or Multimedia Message Service (MMS) protocol for telephony-based instant messages or using XMPP, SIMPLE, or IMPS for Internet-based instant messages), to receive instant messages and to view received instant messages. In some embodiments, transmitted and/or received instant messages may include graphics, photos, audio files, video files and/or other attachments as are supported in a MMS and/or an Enhanced Messaging Service (EMS). As used herein, “instant messaging” refers to both telephony-based messages (e.g., messages sent using SMS or MMS) and Internet-based messages (e.g., messages sent using XMPP, SIMPLE, or IMPS).
In conjunction with RF circuitry 108, touch screen 112, display controller 156, contact module 130, graphics module 132, text input module 134, GPS module 135, map module 154, and music player module 146, the workout support module 142 may be used to create workouts (e.g., with time, distance, and/or calorie burning goals); communicate with workout sensors (sports devices); receive workout sensor data; calibrate sensors used to monitor a workout; select and play music for a workout; and display, store and transmit workout data.
In conjunction with touch screen 112, display controller 156, optical sensor(s) 164, optical sensor controller 158, contact module 130, graphics module 132, and image management module 144, the camera module 143 may be used to capture still images or video (including a video stream) and store them into memory 102, modify characteristics of a still image or video, or delete a still image or video from memory 102.
In conjunction with touch screen 112, display controller 156, contact module 130, graphics module 132, text input module 134, and camera module 143, the image management module 144 may be used to arrange, modify (e.g., edit), or otherwise manipulate, label, delete, present (e.g., in a digital slide show or album), and store still and/or video images.
In conjunction with touch screen 112, display controller 156, contact module 130, graphics module 132, audio circuitry 110, and speaker 111, the video player module 145 may be used to display, present or otherwise play back videos (e.g., on the touch screen or on an external, connected display via external port 124).
In conjunction with touch screen 112, display system controller 156, contact module 130, graphics module 132, audio circuitry 110, speaker 111, RF circuitry 108, and browser module 147, the music player module 146 allows the user to download and play back recorded music and other sound files stored in one or more file formats, such as MP3 or AAC files. In some embodiments, the device 100 may include the functionality of an MP3 player, such as an iPod (trademark of Apple, Inc.).
In conjunction with RF circuitry 108, touch screen 112, display system controller 156, contact module 130, graphics module 132, and text input module 134, the browser module 147 may be used to browse the Internet, including searching, linking to, receiving, and displaying web pages or portions thereof, as well as attachments and other files linked to web pages.
In conjunction with RF circuitry 108, touch screen 112, display system controller 156, contact module 130, graphics module 132, text input module 134, e-mail module 140, and browser module 147, the calendar module 148 may be used to create, display, modify, and store calendars and data associated with calendars (e.g., calendar entries, to do lists, etc.).
In conjunction with RF circuitry 108, touch screen 112, display system controller 156, contact module 130, graphics module 132, text input module 134, and browser module 147, the widget modules 149 are mini-applications that may be downloaded and used by a user (e.g., weather widget 149-1, stocks widget 149-2, calculator widget 149-3, alarm clock widget 149-4, and dictionary widget 149-5) or created by the user (e.g., user-created widget 149-6). In some embodiments, a widget includes an HTML (Hypertext Markup Language) file, a CSS (Cascading Style Sheets) file, and a JavaScript file. In some embodiments, a widget includes an XML (Extensible Markup Language) file and a JavaScript file (e.g., Yahoo! Widgets).
In conjunction with RF circuitry 108, touch screen 112, display system controller 156, contact module 130, graphics module 132, text input module 134, and browser module 147, the widget creator module 150 may be used by a user to create widgets (e.g., turning a user-specified portion of a web page into a widget).
In conjunction with touch screen 112, display system controller 156, contact module 130, graphics module 132, and text input module 134, the search module 151 may be used to search for text, music, sound, image, video, and/or other files in memory 102 that match one or more search criteria (e.g., one or more user-specified search terms).
In conjunction with touch screen 112, display controller 156, contact module 130, graphics module 132, and text input module 134, the notes module 153 may be used to create and manage notes, to do lists, and the like.
In conjunction with RF circuitry 108, touch screen 112, display system controller 156, contact module 130, graphics module 132, text input module 134, GPS module 135, and browser module 147, the map module 154 may be used to receive, display, modify, and store maps and data associated with maps (e.g., driving directions; data on stores and other points of interest at or near a particular location; and other location-based data).
In conjunction with touch screen 112, display system controller 156, contact module 130, graphics module 132, audio circuitry 110, speaker 111, RF circuitry 108, text input module 134, e-mail client module 140, and browser module 147, the online video module 155 allows the user to access, browse, receive (e.g., by streaming and/or download), play back (e.g., on the touch screen or on an external, connected display via external port 124), send an e-mail with a link to a particular online video, and otherwise manage online videos in one or more file formats, such as H.264. In some embodiments, instant messaging module 141, rather than e-mail client module 140, is used to send a link to a particular online video. Additional description of the online video application can be found in U.S. Provisional Patent Application No. 60/936,562, “Portable Multifunction Device, Method, and Graphical User Interface for Playing Online Videos,” filed Jun. 20, 2007, and U.S. patent application Ser. No. 11/968,067, “Portable Multifunction Device, Method, and Graphical User Interface for Playing Online Videos,” filed Dec. 31, 2007, the content of which is hereby incorporated by reference in its entirety.
Each of the above identified modules and applications correspond to a set of executable instructions for performing one or more functions described above and the methods described in this application (e.g., the computer-implemented methods and other information processing methods described herein). These modules (i.e., sets of instructions) need not be implemented as separate software programs, procedures or modules, and thus various subsets of these modules may be combined or otherwise re-arranged in various embodiments. For example, video player module 145 may be combined with music player module 146 into a single module (e.g., video and music player module 152,
In some embodiments, the device 100 is a device where operation of a predefined set of functions on the device is performed exclusively through a touch screen 112 and/or a touchpad. By using a touch screen and/or a touchpad as the primary input/control device for operation of the device 100, the number of physical input/control devices (such as push buttons, dials, and the like) on the device 100 may be reduced.
The predefined set of functions that may be performed exclusively through a touch screen and/or a touchpad include navigation between user interfaces. In some embodiments, the touchpad, when touched by the user, navigates the device 100 to a main, home, or root menu from any user interface that may be displayed on the device 100. In such embodiments, the touchpad may be referred to as a “menu button.” In some other embodiments, the menu button may be a physical push button or other physical input/control device instead of a touchpad.
The device 100 may also include one or more physical buttons, such as “home” or menu button 204. As described previously, the menu button 204 may be used to navigate to any application 136 in a set of applications that may be executed on the device 100. Alternatively, in some embodiments, the menu button is implemented as a soft key in a GUI in touch screen 112.
In one embodiment, the device 100 includes a touch screen 112, a menu button 204, a push button 206 for powering the device on/off and locking the device, volume adjustment button(s) 208, a Subscriber Identity Module (SIM) card slot 210, a head set jack 212, and a docking/charging external port 124. The push button 206 may be used to turn the power on/off on the device by depressing the button and holding the button in the depressed state for a predefined time interval; to lock the device by depressing the button and releasing the button before the predefined time interval has elapsed; and/or to unlock the device or initiate an unlock process. In an alternative embodiment, the device 100 also may accept verbal input for activation or deactivation of some functions through the microphone 113.
Each of the above identified elements in
Attention is now directed towards embodiments of user interfaces (“UI”) that may be implemented on a portable multifunction device 100.
In some embodiments, user interface 400B includes the following elements, or a subset or superset thereof:
Although many of the examples which follow will be given with reference to inputs on a touch screen display 112 (where the touch sensitive surface and the display are combined), in some embodiments, the device detects inputs on a touch-sensitive surface that is separate from the display, as shown in
In the present example, as shown in
Additionally, while the following examples are given primarily with reference to finger inputs (e.g., finger contacts, finger tap gestures, finger swipe gestures), it should be understood that, in some embodiments, one or more of the finger inputs are replaced with input from another input device (e.g., a mouse based input or stylus input). For example, a swipe gesture may be replaced with a mouse click (e.g., instead of a contact) followed by movement of the cursor along the path of the swipe (e.g., instead of movement of the contact). As another example, a tap gesture may be replaced with a mouse click while the cursor is located over the location of the tap gesture (e.g., instead of detection of the contact followed by ceasing to detect the contact). Similarly, when multiple user inputs are simultaneously detected, it should be understood that multiple computer mice may be used simultaneously, or a mouse and finger contacts may be used simultaneously.
Attention is now directed towards embodiments of user interfaces (“UI”) and associated processes that may be implemented on a computing device with a touch screen display, such as device 300 or portable multifunction device 100.
FIGS. 8A-8UU illustrate exemplary user interfaces for manipulating user interface objects in a plurality of arrays of user interface objects in accordance with some embodiments. The user interfaces in these figures are used to illustrate the processes described below, including the processes in
FIGS. 8V-8AA illustrate exemplary user interfaces for selecting all of the user interface objects in an array (e.g., images D1-D16, D18-D36 in array 8052,
FIGS. 8AA-8DD illustrate exemplary user interfaces for displaying a plurality of representative user interface icons (e.g., representative images B1-r, D7-r, S33-r, F8-r, E45-r, V17-r, N5-r, L2-r, R11-r, H27-r and P6-r in FIGS. 8CC-8DD) in response to detecting activation (e.g., by tap gesture 8140 in FIG. 8AA) of a respective menu category icon (e.g., Events icon 8002 in FIG. 8AA).
FIGS. 8CC and 8EE illustrate exemplary user interfaces for responding to a user input (e.g., tap gesture 8142 in FIG. 8CC) on a representative user interface icon (e.g., representative image B1-r in FIG. 8CC for the Birthday array 8144) by displaying the corresponding array (e.g., 8144 in FIG. 8EE).
FIGS. 8FF-8JJ illustrate exemplary user interfaces for, while detecting a user input (e.g., contact 8146) with a destination object (e.g., “Adorable children” label icon 8032), responding to a user input (e.g., tap gesture 8148 in FIG. 8GG) on an array name icon (e.g., 8132) for an array (e.g., 8052) of user interface objects by performing an action associated with the destination object (e.g., 8032) on all of the user interface objects (e.g., images D1-D16, D18-D36) in the array 8052 of user interface objects). In this example, images D1-D16, D18-D36 in array 8052 would be given the label “Adorable children.”
FIGS. 8JJ-8LL illustrate exemplary user interfaces for undoing an action associated with a selected destination object (e.g., 8032) in response to detecting a user input (e.g., tap gesture 8150) on a residual image of a user interface object (e.g., shaded image D12 in FIG. 8JJ). In this example, image D12 will not be labeled “Adorable children” and the residual shaded image of D12 (FIG. 8JJ) is replaced by the original unshaded image of D12 (FIG. 8LL).
FIGS. 8MM-8NN illustrate exemplary user interfaces for responding to a plurality of user inputs with a plurality of destination objects (e.g., tap gestures 8158, 8160 and 8162 on icons 8006, 8008 and 8032, respectively), while continuing to detect a user input (e.g., contact 8154 in FIG. 8MM) with a user interface object (e.g., image B26), by performing plurality of actions (e.g., an action associated with each of the destination objects 8006, 8008 and 8032) on the user interface object (e.g., adding image B26 to the “Day at the zoo” array 8052 and the School garden array 8054 (FIG. 8NN), and adding the label “Adorable children” to image B26).
FIGS. 8NN-8QQ illustrate exemplary user interfaces for responding to a user input (e.g., double tap gesture 8164, FIG. 8NN) on a first user interface object (e.g., image D29) in an array (e.g., 8054) of user interface objects by displaying an enlarged representation of the first user interface object (e.g., image D29-f in FIG. 8OO), and then displaying an enlarged representation of a second user interface object (e.g., image D30-f in FIGS. 8PP-8QQ) that is adjacent to the first user interface object in the array in response to a user input (e.g., a swipe gesture that includes contact 8166 and movement 8168 of the contact, FIG. 8OO) on the enlarged representation of the first user interface object.
FIGS. 8OO and 8RR illustrate exemplary user interfaces for responding to a user input (e.g., press and hold gesture 8172 in FIG. 8OO) on an enlarged representation of a user interface object (e.g., image D29-f in FIG. 8OO) by displaying the enlarged representation of the user interface object (e.g., image D29-f in FIG. 8RR) in cover flow mode.
FIGS. 8SS-8UU illustrate exemplary user interfaces for responding to a user input (e.g., contact 8174 and subsequent movement 8176 of the contact in FIG. 8SS) on a user interface object (e.g., image D22) in an array (e.g., 8052) by replacing the current representative user interface object (e.g., representative image D7-r in FIG. 8SS) for the array (e.g. 8052) with a new representative user interface object (e.g., representative image D22-r in FIG. 8UU) that is a representation of the user interface object (e.g., image D22) on which the user input was detected.
As described below, the method 900 provides an intuitive way to manipulate user interface objects in response to multiple simultaneous user inputs at a computing device with a touch screen display. The method reduces the cognitive burden on a user when providing instructions to perform an action on one or more of the user interface objects, thereby creating a more efficient human-machine interface. For battery-operated computing devices, enabling a user to perform actions on one or more user interface objects faster and more efficiently conserves power and increases the time between battery charges.
The device simultaneously displays (902) on the touch screen display (e.g., 112 in
In some embodiments, the user interface objects (e.g., B1-B27, B1-r, D1-D36-r, etc.) are (904) digital images (e.g., photographic images and/or digital graphics). In some embodiments, the user interface objects are (906) digital content (e.g., digital images, videos, music albums or individual tracks, audio books, and/or podcasts). In some embodiments, the user interface objects are (908) electronic documents (e.g., word processing, spreadsheets, and/or presentation documents). In some embodiments, the user interface objects are (910) folders (e.g., user interface objects that represent a collection of other user interface objects in a hierarchical directory). For example, if user interface object B1 is a folder in a hierarchical directory structure, then selection and activation of user interface object B1 will display the contents of the folder (e.g., user interface objects associated with files at a lower level in the hierarchical directory).
In some embodiments, the destination object (e.g., label icon 5030) is (912) operable to associate metadata with one or more of the user interface objects. In some embodiments, the metadata is (914) stored with the first user interface object upon performance of an action (e.g., the metadata is stored in a data structure that corresponds to the user interface object). In some embodiments, the metadata is (916) stored, upon performance of an action, in a data structure that is separate from a data structure that corresponds to the user interface object (e.g., in a data structure associated with the destination object).
In some embodiments, the metadata comprises a representation of an event (e.g., metadata corresponding to event icons 5004, 5006, 5008, 5010, 5012, 5014, 5016, 5018, 5020, 5022, and 5024 in
In some embodiments, the metadata comprises (918) a label (e.g., a user-defined label or a user rating). For example, in
In some embodiments, the destination object represents (920) a set of user interface objects (e.g., a set of user interface objects with a common label, such as Little Wesley 5030 in
The device detects (930) a first input (e.g., contact 5054 in
Operations 934-966 are performed while the device continues (932) to detect the first input (e.g., contact 5054 in
The device detects (934) a second input (e.g., contact 5056 in
In some embodiments, the second input by the user is (936) a tap input (e.g., a tap gesture including contact 5056 and release of the contact). In some embodiments, the second input is a finger gesture and the response to the second finger gesture is initiated when a finger-down event (e.g., 5056 in
In some embodiments, the second input by the user is (938) a finger swipe gesture (e.g., contact 5058 and subsequent movement 5060 across the touch screen in
In response to detecting the second input (e.g. contact 5056 in
In some embodiments, the destination object corresponds (942) to a set of objects and the action performed is adding or preparing to add the first user interface object to the set of objects. For example, if the first contact was with a menu item that is representative of an event (e.g., “Birthday” icon 5004 in
In some embodiments, the destination object corresponds (948) to a folder and the action performed is adding or preparing to add the first user interface object to the folder. In some embodiments, the destination object corresponds (950) to a label (e.g., “Little Wesley” 5030 in
In some embodiments, the destination object corresponds (952) to a hide label (e.g., 5048 in
In some embodiments, the destination object (e.g., 5042 or 5046 in
In some embodiments, in response to detecting the second input by the user on the first user interface object, the device displays (956) an animation of the first user interface object moving from the initial first user interface object position into the destination object. For example,
In some embodiments, when the second input is a finger gesture, the animation and the response to the finger gesture are initiated when a finger-up event in the finger gesture is detected (e.g., when contact 5056 in
In some embodiments, while still detecting the first input (e.g., contact 5054 in
In some embodiments, the device detects (964) a third input by the user (e.g., a finger gesture such as a tap gesture 5066 in
In some embodiments, in response to detecting the third finger input (e.g., tap gesture 5066) by the user on the residual image (e.g., shaded image D5 in
After the device undoes the action performed on the first user interface object, the first user interface object is displayed at the initial first user interface object position, (e.g., image D5, as shown in
Note that details of the processes described above with respect to method 900 (e.g.,
As described below, the method 1000 provides an intuitive way to manipulate a plurality of user interface objects at a computing device with a touch screen display. The method reduces the cognitive burden on a user when simultaneously manipulating a plurality of user interface objects using simultaneous user inputs, thereby creating a more efficient human-machine interface. For battery-operated computing devices, enabling a user to manipulate user interface objects faster and more efficiently conserves power and increases the time between battery charges.
The device simultaneously displays (1002) on the touch screen display (e.g., 112 in
The device detects (1004) a first input by a user on a destination object (e.g., a thumb or other finger contact, a stylus contact, or a mouse input such as a mouse click when a cursor controlled by the mouse is over the destination icon). In some embodiments, the destination object is in a list of destination objects (e.g., a menu item in a sidebar menu or palette, which is easy to select with a thumb).
Operations 1008-1018 are performed while the device continues (1006) to detect the first input by the user on the destination object (e.g., contact 5070 on “Hide” icon 5048 in
The device detects (1008) a second input by the user or a series of inputs by the user on two or more user interface objects in the plurality of user interface objects. The two or more user interface objects are displayed at respective initial user interface object positions on the touch screen display. If both inputs are finger inputs, the finger that makes the first input (e.g., the first finger contact by the user) is different from the finger that makes the second input or series of inputs. For example, the device detects a series of tap gestures (e.g., tap gestures 5084 and 5088 as shown in
In response to detecting the second input by the user or series of inputs by the user on the two or more user interface objects, the device performs (1010) an action on each of the two or more user interface objects. The action is associated with the destination object. In some embodiments, the action is a preparatory action, such as preparing to perform an action that will occur upon detecting lift off of the first input (e.g., lift off of the first finger contact by the user) from the destination object.
In some embodiments, in response to detecting the second input by the user or series of inputs by the user on the two or more user interface objects, the device displays (1012) animations (e.g. as described in greater detail below with reference to
In some embodiments, in response to detecting the second input by the user or series of inputs by the user on the two or more user interface objects, the device displays (1014) a residual image (e.g., shaded user interface objects B5 and B12 in
For example, in
In this example, in response to detecting tap gesture 5072, the device displays an animation showing user interface object B5 resizing (e.g., from B5, to B5′, to B5″, to B5′″, and finally to B5″″ in
In this example, while the device continues to detect the first user input (e.g., contact 5070 in
As described in greater detail below with reference to
As another example of selecting multiple user interface objects, in
In this example, in response to detecting contact 5084, the device displays an animation showing user interface object D3 resizing (e.g., from D3, to D3′, to D3″, to D3′″, and finally to D3″″ in
The device also displays an animation in response to detecting the swipe gesture (e.g., contact 5092-1 and subsequent movement 5094 of the contact in
In this example, while the device continues to detect the first user input (e.g., contact 5082 in
In some embodiments, the device detects (1016) a third input by the user (e.g., a finger gesture such as a tap gesture 5098 on the residual image of D3 in
In some embodiments, the device displays (1018) an animation of the respective user interface object moving from the destination object back to the respective initial user interface object position (e.g., as shown in
For example, in
Similarly, in some embodiments, in response to a swipe gesture that includes contact with a plurality of residual images of user interface objects, the device will undo the action performed on the plurality of respective user interface object associated with the residual images of the user interface objects. For example, in
In some embodiments, after the device undoes the action performed on the respective user interface objects (e.g., D18, D21, D24, D30, D33, and D36 in
As described below, the method 1100 provides an intuitive way to form and manipulate a group of user interface objects and perform actions on the group of user interface objects at a computing device with a touch screen display. The method reduces the cognitive burden on a user when manipulating a plurality of user interface objects, thereby creating a more efficient human-machine interface. For battery-operated computing devices, enabling a user to manipulate user interface objects faster and more efficiently conserves power and increases the time between battery charges.
The device simultaneously displays (1102) on the touch screen display (e.g., 112 in
The device detects (1104) a first input by a user (e.g., a press and hold finger contact 6052 (
Operations 1108-1126 are performed while the device continues (1106) to detect the first input (e.g., contact 6052 in
The device detects (1108) movement of the first input by the user across the touch screen display to a second location on the touch screen display. For example, as shown in
The device moves (1110) the first user interface object in accordance with the movement 6054 of the first input by the user across the touch screen display to (or proximate to) the second location on the touch screen display. For example, as shown in
The device detects (1112) a second input by the user (e.g., a finger gesture such as a tap gesture 6056 in
In response to detecting the second input by the user on the second user interface object, the device displays (1114) an animation of the second user interface object moving 6058 from the initial second user interface object position (e.g., D24 in
In some embodiments, the device displays (1116) a counter (e.g., 6060 in
In some embodiments, in response to detecting the second input (e.g., tap gesture 6056 in
It should be understood that selecting a second user interface object, as described above can be repeated for any number of user interface objects, and in some embodiments, as each user interface object is selected, an animation is displayed and the counter increases to the number of selected user interface objects. For example, in
In some embodiments, the device detects (1120) a third input by the user (e.g., a finger gesture such as a tap gesture 6066 in
In some embodiments, the device displays (1122) an animation of the second user interface object moving (e.g., movement 6068 in
In some embodiments, the device detects (1124) movement of the first input (e.g., movement 6070 in
In some embodiments, the device detects (1126) lift off of the first input by the user (e.g., lift off of the first finger contact by the user, lift off of the stylus contact, or a mouse up event) from the touch screen display at the destination object or at the area associated with the destination object. In response to detecting lift off of the first input (e.g., contact 6052-5 in
As an example of movement of the first input to an area associated with a destination object, in
As described below, the method 1200 provides an intuitive way to form a group of multiple user interface objects and manipulate the group of user interface objects at a computing device with a touch screen display. The method reduces the cognitive burden on a user when manipulating multiple user interface objects, thereby creating a more efficient human-machine interface. For battery-operated computing devices, enabling a user to manipulate multiple user interface objects faster and more efficiently conserves power and increases the time between battery charges.
The device simultaneously displays (1202 on the touch screen display (e.g., 112 in
The device detects (1204) a first input by a user (e.g., a press and hold finger contact 6100, stylus contact, or mouse click) on a first user interface object (e.g., D31 in
Operations 1208-1226 are performed while the device continues (1206) to detect the first input (e.g., press and hold finger contact 6100 in
The device detects (1208) movement (e.g., 6102 in
The device moves (1210) the first user interface object in accordance with the movement (e.g., 6102 in
The device detects (1212) a second input by the user or series of inputs by the user on two or more user interface objects in the plurality of user interface objects (e.g., a swipe gesture with a finger or stylus that contacts the two or more user interface objects), multiple simultaneous finger gestures (such as concurrent finger contacts on the two or more user interface objects), or a series of tap gestures with a finger or stylus or a series of mouse clicks on the two or more user interface objects). The two or more user interface objects are displayed at respective initial user interface object positions on the touch screen display. If both inputs are finger inputs, the finger that makes the first input by the user is different from the finger that makes the second input by the user or series of inputs by the user. For example, in
In response to detecting the second input (e.g., swipe gesture including contact 6106-1 and movement 6106 of the contact along the touch-sensitive surface in
In some embodiments, the device displays (1216) a counter (e.g., 6108-a in
In some embodiments, in response to detecting the second input by the user or series of inputs by the user on the two or more user interface objects, the device displays (1218) a residual image (e.g., the shaded user interface objects D10, D13, D16, D19, D22, D25, D30, D31, D33 and D36 in
In some embodiments, the device detects (1220) a third input by the user (e.g., a finger gesture such as a tap gesture 6110 in
In some embodiments, the device displays (1222) an animation of the respective user interface object moving from the second location back to the respective initial user interface object position. The animation indicates to a user that the respective user interface object is being removed from the group of objects at the second location. The animation may move the respective user interface object from or out of the first user interface object. For example, in
In some embodiments, the device detects (1224) movement of the first input (e.g., movement 6114 in
In some embodiments, the device detects (1226) lift off of the first input by the user (e.g., lift off of the first finger contact by the user, lift off of the stylus contact, or a mouse up event) from the touch screen display at the destination object or at the area associated with the destination object. In response to detecting lift off of the first input (e.g., lift off of contact 6100-5 in
As an example of movement of the first input to an area associated with a destination object, in
As described below, the method 1300 provides a way to keep track of a particular user interface object in an array when the array is rearranged after enlargement of the particular user interface object (and, typically, other user interface objects in the array) in response to a multitouch gesture. The method reduces the cognitive burden on a user of finding the particular user interface object after rearrangement of the array by keeping the particular user interface object at the same (or substantially the same) vertical position on the touch screen display just before and just after the rearrangement of the array, thereby creating a more efficient human-machine interface. For battery-operated computing devices, enabling a user to faster and more efficiently locate a user interface object in an array conserves power and increases the time between battery charges.
The device simultaneously displays (1302) on the touch screen display (e.g., 112 in
The device detects (1304) simultaneous contacts (e.g., 7004 and 7006 in
The device detects (1306) a gesture (e.g., a depinch gesture) made by the simultaneous contacts that corresponds to a command to zoom in by a user-specified amount. For example, in
In response to detecting the gesture (e.g., the depinching gesture) by the simultaneous contacts, the device enlarges (1308) the first user interface object (e.g., S23 in
After enlarging the first user interface object to the second size and while continuing to detect the simultaneous contacts on the touch screen display, the device determines (1314) an updated centroid position (e.g., 7008-2 in
The device ceases (1316) to detect the simultaneous contacts (e.g., detecting lift off of all of the simultaneous contacts 7004-2 and 7006-2 in
In response to ceasing to detect the simultaneous contacts, the device displays (1318) an animation of the plurality of user interface objects in the array rearranging to form a second arrangement. The second arrangement typically conforms the layout of the enlarged user interface objects to a predefined area of the display (such as the area where a plurality of arrays are being displayed). The second arrangement comprises a second plurality of rows different from the first plurality of rows. The first user interface object is displayed in a row in the second arrangement that includes (e.g., overlaps) the first vertical position on the touch screen display.
For example, in
As noted above, the second arrangement comprises a second plurality of rows different from the first plurality of rows. For example, in array 7002-2 in
As noted above, the first user interface object S23 is displayed in a row in the second arrangement that includes (e.g., overlaps) the first vertical position (e.g., the vertical position of the updated centroid 7008-2 in
The first user interface object has a vertical position on the touch screen display. In some embodiments, the vertical position of the first user interface object moves (1320) in accordance with detected vertical movement of the centroid of the simultaneous contacts prior to ceasing to detect the simultaneous contacts. For example, in
In some embodiments, the plurality of user interface objects are (1322) displayed at the second size in the second arrangement. For example, in
In some embodiments, an analogous rearrangement process occurs after the device detects a gesture made by the simultaneous contacts that corresponds to a command to zoom out by a user-specified amount (e.g., a two-finger pinch gesture) and then the device ceases to detect the simultaneous contacts.
An illustrative example of the analogous rearrangement process is described below with reference to
Continuing this example, in
In some embodiments, after detecting the pinching gesture, the device detects additional movement of the contacts. In the present example, this additional movement is a vertical translation of the contacts (e.g., 7016-2 and 7018-2 in
In the present example, after reducing the size of the first user interface object to the second size and while continuing to detect the simultaneous contacts on the touch screen display, the device determines the updated centroid (e.g., 7020-2 in
Continuing this example, the device ceases to detect the simultaneous contacts (e.g., detecting lift off of all of the simultaneous contacts, as shown in
It should be noted that in the third arrangement (e.g., the arrangement in
As described below, the method 1400 provides an intuitive way to manipulate user interface objects in large data sets at a computing device with a touch screen display. The method reduces the cognitive burden on a user when performing actions on user interface objects in large data sets, thereby creating a more efficient human-machine interface. For battery-operated computing devices, enabling a user to manipulate user interface objects in a plurality of arrays faster and more efficiently conserves power and increases the time between battery charges.
The device simultaneously displays (1402) on the touch screen display (e.g., 112 in
In some embodiments, the device displays (1404) a respective representative user interface object (e.g., digital image S33-r, which is representative of the digital images in array 8054 in
In some embodiments, the device displays (1406) a respective representative user interface object toggle icon (e.g., icon 8056 in
In some embodiments, the representative user interface object toggle icon (e.g., S33-r in
The device detects (1414) a first input by a user (e.g., a vertical or substantially vertical finger swipe gesture or stylus swipe gesture) on the touch screen display. For example, in
In response to detecting the first input by the user on the touch screen display, the device vertically scrolls (1416) the plurality of arrays on the touch screen display. For example, in
In some embodiments the device continues to scroll (e.g., as illustrated by arrow 8068 in
The device detects (1418) a second input by the user (e.g., a horizontal or substantially horizontal finger swipe gesture or stylus swipe gesture) on a single array in the plurality of arrays on the touch screen display. For example, in
In response to detecting the second input by the user on the single array, the device horizontally scrolls (1420) user interface objects in the single array without horizontally scrolling other arrays in the plurality of arrays. In the example above, user interface objects in the array (e.g., 8066 in
In some embodiments, the device displays a rubber-band-like effect to indicate that either the beginning or the end of an array is being displayed during detection of a horizontal scrolling gesture. To indicate the end of an array is being displayed, there is an invisible vertical edge 8074 at the right side of the display (
As a further example of the device scrolling a single array of user interface objects horizontally, the device may also detect a horizontal swipe gesture including a contact (e.g., 8080-1 in
In some embodiments, the device displays (1421) respective representative user interface objects for respective arrays (e.g., representative images F8-r and E45-r in
In some embodiments, the device displays (1422) a list of array name icons (e.g., in
In some embodiments, the device detects (1424) a third input by the user (e.g., a finger tap gesture 8090 in
In some embodiments, the device detects (1426) a third input by the user (e.g., a finger tap gesture 8090 in
For example, in
In some embodiments, the device detects (1430) a depinching finger gesture (e.g., a two-finger depinching gesture) on a first array in the plurality of arrays. For example, in
In some embodiments, the device displays (1436) a first representative user interface object adjacent to the first array (e.g., representative image S33-r for array 8054 in
It should be noted that in the example shown in
Conversely, in some embodiments, the device reduces the size of an array after detecting a pinching finger gesture (e.g., a two-finger pinching gesture) on a first array in the plurality of arrays. For example, in
In some embodiments, the user interface objects are resized about a centroid of the simultaneous user interface contacts (e.g., 8108-2 and 8110-2 in
In some embodiments, the device detects (1440) activation of a respective representative user interface object toggle icon (e.g., icon 8056 in
In some embodiments, in response to detecting activation of the respective representative user interface object toggle icon (e.g., 5086 in
In some embodiments, a single array in the plurality of arrays is rearranged in response to multifinger gestures as described above with respect to
In some embodiments, while the single array is displayed without the representative user interface object (e.g., as in
In some embodiments, the device detects (1444) a first input by the user (e.g., a press and hold finger contact 8122-1 in
In some embodiments, the device displays (1446) a residual image of the first user interface object in the first array on the touch screen display (e.g., shaded user interface object D17 in
In some embodiments, in response to detecting lift off of the first input (e.g., lift off of contact 8122-2 in
In some embodiments, in response to detecting lift off of the first input (e.g., lift off of contact 8122-2 in
In some embodiments, a group of selected objects is formed and then the group is moved/acted upon, as described above with respect to
In some embodiments, the device detects (1452) activation of a respective array name icon that corresponds to a respective array (e.g., array 8052 in
The device detects movement (e.g., 8132 in
The device detects lift off of the input (e.g., contact 8130-2 is present in
In some embodiments, the action is (1454) performed on all of the user interface objects in the respective array (e.g., all of the user interface objects from the “Day at the zoo” array 8052 are made part of the “Family reunion” array 8064, as illustrated in FIG. 8AA).
In some embodiments, in response to detecting activation of the respective array name icon that corresponds to the respective array, the device displays (1456) a counter (e.g., 8136 in
In some embodiments, in response to detecting activation of the respective array name icon (e.g., contact 8130-1 with array name icon “Day at the zoo” 8132 in
In some embodiments, in response to detecting lift off of the input by the user (e.g., lift off of the finger contact or stylus contact) from the touch screen display at the destination object or at the area associated with the destination object, the device displays (1460) the user interface objects in the respective array and ceases to display the residual images of user interface objects in the respective array (i.e., the user interface objects replace their residual images in the respective array). For example, in FIGS. 8Y-8AA, after the device detects lift off of the contact 8130-2 (
In some embodiments, in response to detecting lift off of the input by the user (e.g., lift off of the finger contact or stylus contact) from the touch screen display at the destination object or at the area associated with the destination object, the device disassociates (1462) the user interface objects from the respective array and ceases to display the residual images of the user interface objects in the respective array (not shown).
In some embodiments, in response to detecting movement of the input by the user from the array name icon, the device displays (1464) a residual image of the respective representative user interface object (e.g., shaded representative user interface object D7-r in
In some embodiments, the device detects (1468) activation of a menu category icon (e.g., activation of menu category icon “Events” 8002 for a plurality of array name icons for events 8004, 8006, 8008, 8010, 8012, 8014, 8016, 8018, 8020, 8022, 8024 in FIG. 8AA by a finger tap gesture 8140, stylus gesture, or mouse click on the menu category icon). In response to detecting activation of the menu category icon (e.g., “Events” 8002), the device displays a plurality of representative user interface objects for respective arrays in a menu category that corresponds to the menu category icon, as shown in FIG. 8CC.
In some embodiments, displaying the plurality of representative user interface objects includes overlaying (1470) the plurality of representative user interface objects on user interface objects displayed on the touch screen display immediately prior to detecting activation of the menu category icon. For example, in FIG. 8CC, a plurality of representative user interface objects (e.g., representative images B1-r, D7-r, S33-r, F8-r, E45-r, V17-r, N5-r, L2-r, R11-r, H27-r and P6-r) are displayed overlaid on shaded images F 1-F17, D1′-D16′, and D18′-D36′. In some cases, the representative objects appear as though they are layered on top of the previously displayed user interface. In some embodiments, the device displays an animation where the representative user interface objects (e.g., B1-r, D7-r, S33-r, F8-r, E45-r, V17-r, N5-r, L2-r, R11-r, H27-r and P6-r) are shown coming in from the edges (e.g., top, bottom, right and left sides) of the display and shrinking to fit onto the display. Thus, in FIG. 8BB, the representative user interface objects (e.g., B1-r, D7-r, S33-r, F8-r, E45-r, V17-r, N5-r, L2-r, R11-r, H27-r and P6-r) are larger than the corresponding representative user interface objects in FIG. 8CC, and the user interface objects that are adjacent to the edges of the touch screen display (e.g., B1-r, D7-r, S33-r, F8-r, E45-r, V17-r, H27-r and P6-r) are only partially displayed. Additionally, in some embodiments, the representative user interface objects are initially displayed at a low opacity (e.g., 0% opacity or 10% opacity) and the opacity of the representative user interface objects is gradually increased as the representative user interface objects are reduced in size and moved onto the touch screen display.
In some embodiments, displaying the plurality of representative user interface objects (e.g., B1-r, D7-r, S33-r, F8-r, E45-r, V17-r, N5-r, L2-r, R11-r, H27-r and P6-r in FIG. 8DD) includes ceasing (1472) to display user interface objects displayed on the touch screen display immediately prior to detecting activation of the menu category icon, as shown in FIG. 8DD. In other words, the user interface objects displayed on the touch screen display immediately prior to detecting activation of the menu category icon are replaced by display of the plurality of representative user interface objects for respective arrays in the menu category that corresponds to the activated menu category icon (e.g., as shown in FIG. 8DD).
In some embodiments, only the plurality of representative user interface objects (e.g., B1-r, D7-r, S33-r, F8-r, E45-r, V17-r, N5-r, L2-r, R11-r, H27-r and P6-r in FIG. 8DD) for respective arrays in the menu category that corresponds to the activated menu category icon are (1474) displayed on the touch screen display (e.g., as shown in FIG. 8DD).
In some embodiments, the device detects (1476) an input by the user (e.g., a finger tap gesture 8142 in FIG. 8CC, stylus gesture, or mouse click) on a first representative user interface object (e.g., representative image B1-r in FIG. 8CC) in the plurality of representative user interface objects (e.g., representative images B1-r, D7-r, S33-r, F8-r, E45-r, V17-r, N5-r, L2-r, R1′-r, H27-r and P6-r in FIG. 8CC) for respective arrays in the menu category that corresponds to the activated menu category icon (e.g., 8002 in FIG. 8AA). In response to detecting the input by the user on the first representative user interface object, the device ceases to display the plurality of representative user interface objects and displays an array (e.g., the “Birthday” array 8144 in FIG. 8EE) of user interface objects (e.g., images B1, B2, B3, B4, B6, B7, B8, B9, B10, B11, B13, B14, B15, B16, B17, B18, B19, B20, B21, B22, B23, B24, B25, B26, B27) that correspond to the first representative user interface object (e.g., B1-r in FIG. 8CC).
In some embodiments, in response to detecting the input by the user on the first representative user interface object (e.g., representative image B1-r in FIG. 8CC), the device displays (1478) the first representative user interface object adjacent to the array (e.g., “Birthday” array 8144 in FIG. 8EE) of user interface objects that corresponds to the first representative user interface object (e.g., representative image B1-r in FIG. 8EE).
In some embodiments, in response to detecting the input by the user on the first representative user interface object, the device displays (1480) arrays (e.g., “Day at the zoo” array 8052 in FIG. 8EE) of user interface objects (e.g., images D1, D2, D3, D4, D5, D6, D7, D8, D9, D10, D11, D12, D13, D14, D15, D16, D18, D19, D20, D21, D22, D23, D24, D25, D26, D27, D28, D29, D30, D31, D32, D33, D34, D35, D36 in FIG. 8EE) that do not correspond to the first representative user interface object (e.g., arrays in the plurality of arrays that are adjacent to the array of user interface objects that corresponds to the first representative user interface object).
In some embodiments, selected object(s) are moved to a destination object (e.g., an item in sidebar menu) while input by the user (e.g., a finger contact or stylus contact) is on the destination object, as described above with respect to
In some embodiments, the device detects (1482) a third input by the user (e.g., a finger contact 8146 in FIG. 8FF or stylus contact) on a destination object (e.g., “Adorable children” label icon 8032 in FIG. 8FF). While continuing to detect the third input (e.g., contact 8146 in FIGS. 8FF-8LL) by the user on the destination object (e.g., “Adorable children” label icon 8032 in FIG. 8FF-8LL), the device detects a fourth input by the user on an array name icon (e.g., a finger tap gesture 8148, stylus gesture, or mouse click by the user on an array name icon 8132 in FIG. 8GG displayed adjacent to a respective representative user interface object toggle icon e.g., 8138 in FIG. 8GG). In response to detecting the fourth input (e.g., tap gesture 8148 in FIG. 8GG) by the user on the array name icon (e.g., 8132 in FIG. 8GG), the device performs an action on all user interface objects (e.g., images D1-D16, D18-D36 in FIG. 8GG) in an array (e.g., “Day at the zoo” array 8052 in FIG. 8GG) that corresponds to the array name icon (e.g., 8132 in FIG. 8GG). The action is associated with the destination object (e.g., “Adorable children” label icon 8032 in FIG. 8GG). In some embodiments, the action is a preparatory action, such as preparing to perform an action that will occur upon detecting lift off of the third input (e.g., lift off of the third finger contact 8416 in FIG. 8GG by the user) from the destination object. Exemplary actions include, without limitation: associating a label with digital content or an electronic document; moving digital content or an electronic document from one event to another event; moving digital content or an electronic document to a folder; and printing/publishing a copy of the digital content or electronic document.
In some embodiments, in response to detecting the fourth input (e.g., tap gesture 8148 in FIG. 8GG) by the user on the array name icon (e.g., 8132 in FIG. 8GG), the device displays (1484) an animation of user interface objects in the array (e.g., 8052 in FIGS. 8GG-8II) that corresponds to the array name icon moving from respective initial object positions into the destination object. For example, in FIGS. 8HH and 8II, the device displays representations of the images D1-D16 and D18-D36 moving into the destination object (e.g., 8032 in FIG. 8HH and 8II). In this example, as each user interface object (e.g., D11′ in FIG. 8HH) begins to move towards the destination object (e.g., 8032 in FIG. 8HH), the device resizes the user interface object so as to match the dimensions of the destination object (e.g., 8032 in FIG. 8HH). In the case of image D11′, the object is taller and narrower than the destination object, so in a subsequent frame of the animation (shown in FIG. 8II) the user interface object D11′ is has been resized so that it is shorter and wider than the original user interface object D11 (in FIG. 8GG, before the animation was displayed). This process is performed for some or all of the user interface objects in the array (e.g., 8052 in FIGS. 8HH and 8II). In some embodiments this process is also performed for the representative user interface object (e.g., D7-r′ in FIGS. 8HH and 8II). The animation indicates to a user that an action associated with the destination object will be applied to the user interface objects in this array.
In some embodiments, in response to detecting the fourth input (e.g., tap gesture 8148 in FIG. 8GG) by the user on the array name icon (e.g., 8132 in FIG. 8GG), the device displays (1486) respective residual images (e.g., shaded images D1, D7, D16, D18, D20, D25, etc. in FIGS. 811 and 8JJ) of respective user interface objects at respective initial user interface object positions on the touch screen display (e.g., respective positions of D1, D7, D16, D18, D20, D25, etc. in FIG. 8GG).
In some embodiments, the device detects (1488) a fifth input (e.g., a finger tap gesture 8150 (FIG. 8JJ), stylus gesture, or mouse click) on a respective residual image (e.g., shaded image D12 in FIG. 8JJ) of a respective user interface object at a respective initial user interface object position on the touch screen display while continuing to detect the third input (e.g., contact 8146 in FIG. 8JJ) by the user on the destination object (e.g., “Adorable children” icon 8032 in FIG. 8JJ). In response to detecting the fifth input (e.g., tap gesture 8150 in FIG. 8JJ) by the user on the respective residual image (e.g., shaded image D12 in FIG. 8JJ) of the respective user interface object at the respective initial user interface object position on the touch screen display, the device undoes the action performed on the respective user interface object and displays the respective user interface object at the respective initial user interface object position. For example, image D12 will not be labeled “Adorable children” and the residual shaded image of D12 (FIG. 8JJ) is replaced by the original unshaded image of D12 (FIG. 8LL).
In some embodiments, in response to detecting the fifth input by the user on the respective residual image of the respective user interface object at the respective initial user interface object position on the touch screen display, the device displays (1490) an animation of the respective user interface object moving from the destination object back to the respective initial user interface object position. The animation indicates to a user that an action associated with the destination object will not be applied to the respective user interface object. For example FIG. 8KK illustrates an exemplary an animation of undoing the prior movement of user interface object D12 from its initial position to the destination object “Adorable children” 5030 (as shown in FIGS. 8HH-8II). In this animation, the device moves user interface object D12 along a path (e.g., 8152 in FIG. 8KK) from the location at the destination object 5032 back to its original position (e.g., image D12 in FIG. 8KK). In one embodiment, as the user interface object moves along the path, the user interface object is initially displayed as a resized representation so as to match the size of the destination object. An illustrative example of the movement and resizing (e.g., from D12″″ to D12′″ to D12″ to D12′ in FIG. 8KK and finally to D12 in FIG. 8LL) of the user interface object is shown in FIGS. 8KK-8LL. In this example, destination object (e.g., 8032 in FIG. 8KK) is larger along the horizontal dimension (i.e., longer) and smaller along the vertical dimension (i.e., shorter) than the image D12. Thus, as illustrated in FIG. 8KK, the user interface object is initially displayed as a representation of the user interface object (e.g., D12″″) that is stretched horizontally and compressed vertically compared to the original user interface object (e.g., image D12). As the user interface object moves (e.g., from D12″″ to D12′″ to D12″ to D12′ and finally to D12) towards the original position of the image D12, the user interface object is compressed horizontally and stretched vertically so that it returns to the dimensions of the original image D12. It should be understood that, typically the various resized representations of the user interface object (e.g., D12, D12′, D12″, D12′″ and D12″″ shown in FIGS. 8KK-8LL) are not simultaneously displayed, but are instead displayed in sequence as the user interface object moves along the path 8152 towards the destination object. In some embodiments, where the user interface object includes an image, the image is distorted as the object is resized.
After the device undoes the action performed on the respective user interface object, the respective user interface object is displayed at the initial respective user interface object position (e.g., unshaded image D12, as illustrated in FIG. 8LL).
In some embodiments, the device detects (1491) an input by the user (e.g., a finger contact 8154 in FIG. 8MM or stylus contact) on a user interface object (e.g., image B26 in FIG. 8MM) in an array (e.g., the “Birthday” array 8144 in FIG. 8MM) in the plurality of arrays (e.g., including arrays 8144, 8052 and 8054 in FIG. 8MM). While continuing to detect the input (e.g., contact 8154) by the user on the user interface object in the array in the plurality of arrays, for a plurality of destination objects (e.g., array name icons 8006 and 8008, and label 8032 in sidebar menu 8156, FIG. 8MM), the device detects a respective input by the user (e.g., a finger or stylus gesture such as a tap gestures 8158, 8160, and 8162 in FIG. 8MM) on a respective destination object. In response to each respective input by the user on each respective destination object, the device performs a respective action on the user interface object in the array in the plurality of arrays. The respective action is associated with the respective destination object. In some embodiments, the respective action is a preparatory action, such as preparing to perform an action that will occur upon detecting lift off of the input by the user (e.g., lift off of the finger contact 8154 in FIG. 8MM) from the user interface object in the array. Exemplary actions include, without limitation: associating a label with digital content or an electronic document; moving digital content or an electronic document from one event to another event; moving digital content or an electronic document to a folder; and printing/publishing a copy of the digital content or electronic document.
For example, in FIG. 8MM, while continuing to detect finger contact 8154 on image B26, the device detects three respective user inputs (e.g., tap gesture 8158, tap gesture 8160, and tap gesture 8162) associated with respective destination objects (e.g., “Day at the zoo” array name destination object 8006, “School garden” array name destination object 8008, and “Adorable children” label destination object 8032.) In response to the each of the respective inputs, the device performs an action associated with the input. For example, in response to the tap gesture 8158 on the “Day at the zoo” array name 8006, the device makes image B26 part of the “Day at the zoo” array 8052 (FIG. 8NN). In response to the tap gesture 8160 on the “School garden” array name 8008, the device makes image B26 part of the “School garden” array 8054 (FIG. 8NN). In response to the tap gesture 8162 on the “Adorable children” label 8032, the device adds the label “Adorable children” to image B26. Thus, the user is able to perform multiple actions on a single user interface object by maintaining one input (e.g., contact 8154 in FIG. 8MM) on the single user interface object and simultaneously providing other inputs (e.g., tap gestures 8158, 8160, and 8162 in FIG. 8MM) on destination objects (e.g., 8006, 8008 and 8032 in FIG. 8MM) in a menu (e.g., 8156 in FIG. 8MM).
In some embodiments, in response to each respective input by the user on each respective destination object, the device displays (1492) a respective animation of the user interface object in the array moving from a respective initial object position into the respective destination object, as described previously with reference to
In some embodiments, the device detects (1493) an input (e.g., a finger or stylus gesture such as a double tap gesture 8164 in FIG. 8NN) by the user on a first user interface object (e.g., image D29 in FIG. 8NN) in a first array (e.g., “Day at the zoo” array 8052 in FIG. 8NN) in the plurality of arrays (e.g., including arrays 8144, 8052, and 8054 in FIG. 8NN). In response to detecting the input by the user on the first user interface object in the first array in the plurality of arrays, the device displays a first enlarged image (e.g., image D29-f in FIG. 8OO) that corresponds to the first user interface object (e.g., a full-screen image of a photograph or a preview image of an electronic document file that corresponds to user interface object D29 in FIG. 8NN).
The device detects a horizontal (or substantially horizontal) swipe gesture (e.g., contact 8166 followed by movement 8168 of the contact in a direction that is substantially horizontal in FIG. 8OO) by the user on the first enlarged image (e.g., image D29-f in
In some embodiments, the device detects (1494) a vertical (or substantially vertical) swipe gesture by the user on the first enlarged image (e.g., D29-f in FIG. 8OO). In response to detecting the vertical (or substantially vertical) swipe gesture by the user on the first enlarged image, the device scrolls the first enlarged image (not shown).
In some embodiments, the device detects (1495) an input by the user (e.g., a press and hold gesture 8172 in FIG. 8OO) on the first enlarged image (e.g., image D29-f in FIG. 8OO). In response to detecting the input by the user on the first enlarged image, the device displays the user interface objects in the first array in a cover flow mode of display. For example, in FIG. 8RR, the enlarged images of the user interface objects in the “Day at the zoo” array 8052 (FIG. 8NN) are displayed in cover flow mode. In some embodiments, cover flow mode is a mode where the currently displayed user interface item (e.g., image D29-f in FIG. 8RR) is displayed to the user, while skewed representations of adjacent user interface items (e.g., images D28-f and D30-f in FIG. 8RR) are displayed on each side of the currently displayed user interface item. Cover flow mode is described in U.S. patent application Ser. No. 11/519,460, “Media Manager With Integrated Browsers,” filed Sep. 11, 2006, which is hereby incorporated by reference herein in its entirety. In response to a swipe gesture (not shown) the device scrolls through the enlarged representations of user interface items in the cover flow view, displaying a current enlarged representation of a user interface item in the center of the display (e.g., image D29-f in FIG. 8RR). In some embodiments, the speed of the scrolling is determined based on the speed of the swipe gesture.
In some embodiments, the device detects (1496) an input by the user (e.g., a finger or stylus contact 8174-1 in FIG. 8SS) on a first user interface object in a first array (e.g., image D22 in the “Day at the zoo” array 8052 in FIGS. 855-8UU) of user interface objects (e.g., images D1-D16, D18-D36) in the plurality of arrays (e.g., including arrays 8144 and 8052 in FIGS. 855-8UU). The device detects movement (e.g., movement 8176 in FIG. 8SS) of the input (e.g., contact 8174) by the user to a representative user interface object (e.g., representative image D7-r in FIG. 8SS) for the first array (e.g., 8052 in FIG. 8SS) of user interface objects. The device detects lift off of the input by the user (e.g., lift off of the finger contact or stylus contact 8174-2) from the representative user interface object for the first array of user interface objects. In response to detecting lift off of the input by the user from the representative user interface object (e.g., representative image D7-r in FIG. 8TT) for the first array of user interface objects, the device makes the first user interface object the representative user interface object (e.g., representative image D22-r in FIG. 8UU) for the first array of user interface objects (e.g., 8052 in FIG. 8UU).
For example, the device detects a contact 8174-1 with image D22 in FIG. 8SS, and movement 8176 of the contact (e.g., from 8174-1 to 8174-2 in FIG. 8SS) to the current representative image D7-r, which is a representation of user interface object D7 (e.g., an enlarged version of D7). In the present example, in FIG. 8TT, the device ceases to detect the contact 8174-2 with image D22′ while the contact is located over the current representative image D7-r. In some embodiments, when the device detects a release of the contact while it is over the current representative user interface object, the device displays an animation (e.g., image D22′ expanding upwards and to the left, as shown in FIG. 8TT) of replacing the current representative user interface object (e.g., representative image D7-r in FIG. 8TT) with a new representative user interface object (e.g., representative image D22-r in FIG. 8UU, which is a representation of image D22, such as an enlarged version of image D22). In FIG. 8UU, the “Day at the zoo” array 8052 is shown with a new representative user interface object, namely representative image D22-r.
As described below, the method 1500 provides an intuitive way to manipulate all user interface objects in an array of user interface objects at a computing device with a touch screen display. The method reduces the cognitive burden on a user when performing the same action on all user interface objects in an array of user interface objects, thereby creating a more efficient human-machine interface. For battery-operated computing devices, enabling a user to manipulate all user interface objects in an array of user interface objects faster and more efficiently conserves power and increases the time between battery charges.
The device simultaneously displays (1502) on the touch screen display at least one destination object (e.g., an array name icon in a list or menu of such icons) and at least a subset of a plurality of arrays (e.g., arrays 8052 and 8054 in
The device detects (1504) activation of a respective array name icon that corresponds to a respective array (e.g., array 8052 in
In response to detecting activation of the respective array name icon that corresponds to the respective array, the device displays (1506) an animation of user interface objects in the respective array moving into a respective representative user interface object (e.g., D7-r in
In some embodiments, in response to detecting activation of the respective array name icon (e.g., 8132 in
In some embodiments, in response to detecting activation of the respective array name icon that corresponds to the respective array, the device displays (1510) a counter (e.g., 8136 in
The device detects (1512) movement (e.g., 8132 in
The device moves (1514) the respective representative user interface object (e.g., representative image D7-r in
In some embodiments, in response to detecting movement of the input by the user from the array name icon, the device displays (1516) a residual image of the respective representative user interface object (e.g., shaded representative image D7-r in
The device detects (1520) lift off of the input by the user (e.g., lift off of the finger contact or stylus contact) from the touch screen display at the destination object or at the area (e.g., 8134 in
In response to detecting lift off of the input by the user from the touch screen display at the destination object or at the area associated with the destination object, the device performs (1522) an action on the user interface objects in the respective array. The action is associated with the destination object. Exemplary actions include, without limitation: associating a label with digital content or an electronic document; moving digital content or an electronic document from one event to another event; moving digital content or an electronic document to a folder; and printing/publishing a copy of the digital content or electronic document, as described in greater detail above with reference to FIGS. 8Y-8AA.
In some embodiments, the action is (1524) performed on all of the user interface objects in the respective array (e.g., on all of the images D1-D16, D81-D36 in array 8052 in
In some embodiments, in response to detecting lift off of the input by the user (e.g., lift off of the finger contact 8130-2 in
In some embodiments, in response to detecting lift off of the input by the user (e.g., lift off of the finger contact 8130-2 in
As described below, the method 1600 provides an intuitive way to quickly find and select an array in a plurality of arrays at a computing device with a touch screen display. The method reduces the cognitive burden on a user when trying to find a particular array in a plurality of arrays, thereby creating a more efficient human-machine interface. For battery-operated computing devices, enabling a user to find a particular array faster and more efficiently conserves power and increases the time between battery charges.
The device simultaneously displays (1602) on the touch screen display at least one destination object (e.g., an array name icon in a list or menu of such icons) and at least a subset of a plurality of arrays of user interface objects. Depending on the number of arrays, it may not be possible to simultaneously display every array in the plurality of arrays. In such cases, a subset of the plurality of arrays is displayed and different subsets may be viewed by scrolling the plurality of arrays (e.g., in response to detecting a first finger swipe gesture on the touch screen display, such as a vertical or substantially vertical finger swipe gesture).
The device detects (1604) activation of a menu category icon (e.g., activation of menu category icon “Events” 8002 for a plurality of array name icons for events 8004, 8006, 8008, 8010, 8012, 8014, 8016, 8018, 8020, 8022, 8024 in FIG. 8AA by a finger tap gesture 8140, stylus gesture, or mouse click on the menu category icon).
In response to detecting activation of the menu category icon (e.g., “Events” 8002), the device displays (1606) a plurality of representative user interface objects for respective arrays in a menu category that corresponds to the menu category icon, (e.g., representative images B1-r, D7-r, S33-r, F8-r, E45-r, V17-r, N5-r, L2-r, R11-r, H27-r and P6-r in FIGS. 8BB-8DD).
In some embodiments, displaying (1608) the plurality of representative user interface objects includes overlaying the plurality of representative user interface objects (e.g., representative images B1-r, D7-r, S33-r, F8-r, E45-r, V17-r, N5-r, L2-r, R11-r, H27-r and P6-r in FIGS. 8BB-8CC) on user interface objects displayed on the touch screen display immediately prior to detecting activation of the menu category icon, as described in greater detail above with reference to FIGS. 8BB-8CC. In some embodiments, displaying the plurality of representative user interface objects includes ceasing (1610) to display user interface objects displayed on the touch screen display immediately prior to detecting activation of the menu category icon. In other words, the user interface objects displayed on the touch screen display immediately prior to detecting activation of the menu category icon are replaced by display of the plurality of representative user interface objects (e.g., representative images B1-r, D7-r, S33-r, F8-r, E45-r, V17-r, N5-r, L2-r, R11-r, H27-r and P6-r in FIG. 8DD) for respective arrays in the menu category that corresponds to the activated menu category icon, as described in greater detail above with reference to FIG. 8DD.
In some embodiments, only the plurality of representative user interface objects for respective arrays in the menu category that corresponds to the activated menu category icon are (1612) displayed on the touch screen display. For example in FIGS. 8BB-8CC the device displays representative user interface objects for a plurality of the “Events” which include arrays of user interface objects. Similarly, if the “Labels” category icon 8026 (
In some embodiments, the device detects (1614) an input by the user (e.g., a finger tap gesture e.g., 8142 in FIG. 8CC, stylus gesture, or mouse click) on a first representative user interface object (e.g., representative image B1-r in FIG. 8CC) in the plurality of representative user interface objects for respective arrays in the menu category that corresponds to the activated menu category icon. In response to detecting the input (e.g., tap gesture 8142 in FIG. 8CC) by the user on the first representative user interface object, the device ceases to display the plurality of representative user interface objects (e.g., representative image B1-r, D7-r, S33-r, F8-r, E45-r, V17-r, N5-r, L2-r, R11-r, H27-r and P6-r in FIG. 8CC) and displays an array of user interface objects that corresponds to the first representative user interface object (e.g., images in the “Birthday” array 8144, as shown in FIG. 8EE).
In some embodiments, in response to detecting the input by the user on the first representative user interface object, the device displays (1616) the first representative user interface object (e.g., representative image B1-r in FIG. 8EE) adjacent to the array (e.g., “Birthday” array 8144 in FIG. 8EE) of user interface objects that corresponds to the first representative user interface object.
In some embodiments, in response to detecting the input by the user on the first representative user interface object, the device displays (1618) arrays (e.g., 8052 in FIG. 8EE) of user interface objects that do not correspond to the first representative user interface object (e.g., B1-r in FIG. 8EE). In other words, the device displays arrays in the plurality of arrays that are adjacent to the array of user interface objects that corresponds to the first representative user interface object.
In some embodiments, selected object(s) are moved to a destination object (e.g., an item in sidebar menu) while input by the user (e.g., a finger contact or stylus contact) is on the destination object, as described above with respect to
As described below, the method 1700 provides an intuitive way to perform an action on all or most user interface objects in one array of a plurality of arrays at a computing device with a touch screen display. The method reduces the cognitive burden on a user when performing the same action on all or most user interface objects in an array of user interface objects, thereby creating a more efficient human-machine interface. For battery-operated computing devices, enabling a user to perform the same action on all or most interface object in an array faster and more efficiently conserves power and increases the time between battery charges.
The device simultaneously displays (1702) on the touch screen display at least one destination object (e.g., an array name icon in a list or menu of such icons) and at least a subset of a plurality of arrays (e.g., 8144 and 8052 in FIG. 8FF) of user interface objects. Depending on the number of arrays, it may not be possible to simultaneously display every array in the plurality of arrays. In such cases, a subset of the plurality of arrays is displayed and different subsets may be viewed by scrolling the plurality of arrays (e.g., in response to detecting a first finger swipe gesture on the touch screen display, such as a vertical or substantially vertical finger swipe gesture), as described in greater detail above with reference to
The device detects (1704) a first input by a user (e.g., a finger contact 8146 in FIG. 8FF or stylus contact) on a destination object (e.g., “Adorable children” label icon 8032 in FIG. 8FF).
While continuing to detect the first input (e.g., contact 8146 in FIGS. 8FF-8LL) by the user on the destination object (e.g., “Adorable children” label icon 8032 in FIGS. 8FF-8LL), the device detects (1706) a second input by the user on an array name icon (e.g., a finger tap gesture 8148 in FIG. 8GG, stylus gesture, or mouse click by the user on an array name icon 8132 in FIG. 8GG displayed adjacent to a respective representative user interface object toggle icon 8138 in FIG. 8GG).
In response to detecting the second input (e.g., tap gesture 8148 in FIG. 8GG) by the user on the array name icon, the device performs (1708) an action on all user interface objects (e.g., images D1-D16, D18-D36 in FIG. 8GG) in an array (e.g., “Day at the zoo” array 8052 in FIG. 8GG) that corresponds to the array name icon (e.g., 8132 in FIG. 8GG). The action is associated with the destination object (e.g., “Adorable children” label icon 8032 in FIG. 8HH). In some embodiments, the action is a preparatory action, such as preparing to perform an action that will occur upon detecting lift off of the first input (e.g., lift off of the first finger contact 8416 in FIG. 8GG by the user) from the destination object. Exemplary actions include, without limitation: associating a label with digital content or an electronic document; moving digital content or an electronic document from one event to another event; moving digital content or an electronic document to a folder; and printing/publishing a copy of the digital content or electronic document.
In some embodiments, in response to detecting the second input (e.g., tap gesture 8148 in FIG. 8GG) by the user on the array name icon (e.g., 8132 in FIG. 8GG), the device displays (1710) an animation of user interface objects in the array (e.g., 8052 in FIGS. 8GG-8II) that correspond to the array name icon moving from respective initial object positions into the destination object (e.g., 8032 in FIGS. 8GG-8II), as described in greater detail above with reference to FIGS. 8GG-8JJ. The animation indicates to a user that an action associated with the destination object will be applied to the user interface objects in this array.
In some embodiments, in response to detecting the second input (e.g., tap gesture 8148 in FIG. 8GG) by the user on the array name icon (e.g., 8132 in FIG. 8GG), the device displays (1712) respective residual images (e.g., shaded images D1-D16 and D18-D36 in FIG. 8JJ) of respective user interface objects at respective initial user interface object positions on the touch screen display.
In some embodiments, the device detects (1714) a third input by the user (e.g., a finger tap gesture 8150 (FIG. 8JJ), stylus gesture, or mouse click) on a respective residual image (e.g., shaded image D12 in FIG. 8JJ) of a respective user interface object at a respective initial user interface object position on the touch screen display while continuing to detect the first input by the user on the destination object (e.g., contact 8146 on “Adorable children” icon 8032 in FIG. 8JJ). In response to detecting the third input (e.g., tap gesture 8150 in FIG. 8JJ) by the user on the respective residual image of the respective user interface object (e.g., shaded image D12 in FIG. 8JJ) at the respective initial user interface object position on the touch screen display, the device undoes the action performed on the respective user interface object and displays the respective user interface object at the respective initial user interface object position, as described in greater detail above with reference to FIGS. 8JJ-8LL. For example, image D12 will not be labeled “Adorable children” and the residual shaded image of D12 (FIG. 8JJ) is replaced by the original unshaded image of D12 (FIG. 8LL).
In some embodiments, in response to detecting the third input (e.g., tap gesture 8150 in FIG. 8JJ) by the user on the respective residual image (e.g., shaded image D12 in FIG. 8JJ) of the respective user interface object at the respective initial user interface object position on the touch screen display, the device displays (1716) an animation of the respective user interface object moving from the destination object back to the respective initial user interface object position, as described in greater detail above with reference to FIG. 8KK. The animation indicates to a user that an action associated with the destination object will not be applied to the respective user interface object.
The steps in the information processing methods described above may be implemented by running one or more functional modules in information processing apparatus such as general purpose processors or application specific chips. These modules, combinations of these modules, and/or their combination with general hardware (e.g., as described above with respect to
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 the invention 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 best explain the principles of the invention and its practical applications, to thereby enable others skilled in the art to best utilize the invention and various embodiments with various modifications as are suited to the particular use contemplated.
This application is a continuation of U.S. patent application Ser. No. 12/567,570, “Device, Method, and Graphical User Interface for Manipulating User Interface Objects,” filed Sep. 25, 2009, which claims priority to International Application No. PCT/US09/57899, “Device, Method, and Graphical User Interface for Manipulating User Interface Objects,” filed Sep. 22, 2009), which are incorporated by reference herein in their entirety. This application is related to the following applications: (1) U.S. patent application Ser. No. 12/567,405, “Device, Method, and Graphical User Interface for Manipulating User Interface Objects,” filed Sep. 25, 2009; (2) U.S. patent application Ser. No. 12/567,460, “Device, Method, and Graphical User Interface for Manipulating User Interface Objects,” filed Sep. 25, 2009; and (3) U.S. patent application Ser. No. 12/567,553, “Device, Method, and Graphical User Interface for Manipulating User Interface Objects,” filed Sep. 25, 2009, which are incorporated by reference herein in their entirety.
Number | Date | Country | |
---|---|---|---|
Parent | 12567570 | Sep 2009 | US |
Child | 13909001 | US |