The disclosed implementations relate generally to graphical user interfaces.
A hallmark of modern graphical user interfaces is that they allow a large number of graphical objects or items to be displayed on a display screen at the same time. Leading personal computer operating systems, such as Apple Mac OS®, provide user interfaces in which a number of windows can be displayed, overlapped, resized, moved, configured, and reformatted according to the needs of the user or application. Taskbars, menus, virtual buttons and other user interface elements provide mechanisms for accessing and activating windows even when they are hidden behind other windows.
Although users appreciate interfaces that can present information on a screen via multiple windows, the result can be overwhelming. For example, users may find it difficult to navigate to a particular user interface element or to locate a desired element among a large number of onscreen elements. The problem is further compounded when user interfaces allow users to position elements in a desired arrangement, including overlapping, minimizing, maximizing, and the like. Although such flexibility may be useful to the user, it can result in a cluttered display screen. Having too many elements displayed on the screen can lead to “information overload,” thus inhibiting the user to efficiently use the computer equipment.
Many of the deficiencies of conventional user interfaces can be reduced using “widgets.” Generally, widgets are user interface elements that include information and one or more tools (e.g., applications) that let the user perform common tasks and provide fast access to information. Widgets can perform a variety of tasks, including without limitation, communicating with a remote server to provide information to the user (e.g., weather report), providing commonly needed functionality (e.g., a calculator), or acting as an information repository (e.g., a notebook). Widgets can be displayed and accessed through a user interface, such as a “dashboard layer,” which is also referred to as a “dashboard.” Widgets and dashboards are described in co-pending U.S. patent application Ser. No. 10/877,968, entitled “Unified Interest Layer For User Interface.”
Due to the large number of widgets available to a user, a virtual desktop or dashboard can become cluttered and disorganized, making it difficult for the user to quickly locate and access a widget. Moreover, the user may have to invoke multiple widgets to perform a single task, which can lead to an inefficient use of widget resources. In some cases, the user may not readily recognize the relationship between two widgets, which leads to additional inefficiencies when using widgets.
Systems, methods, computer-readable mediums, user interfaces and other implementations are disclosed for synchronizing widgets and dashboards.
In some implementations, a method comprises: receiving a first set of widget information associated with a first device; and synchronizing the first set of widget information with a data source.
In some implementations, a method, comprises: receiving a first set of dashboard information associated with a first device; and synchronizing the first set of dashboard information with a data source.
In some implementations, a method comprises: identifying configuration information associated with one or more widgets; and updating the configuration information.
In some implementations, a system includes a first device, a second device and a sync engine. The first device includes a first dashboard including a first set of widgets. The second device includes a second dashboard including a second set of widgets. The sync engine is operatively coupled to the first and second devices and configurable to synchronize the first and second dashboards.
In some implementations, an apparatus includes a computer-readable medium adapted for storing a first set of dashboard information, and a sync engine operatively coupled to the computer-readable medium and configurable for synchronizing the first set of dashboard information with a data source.
Other implementations are disclosed which are directed to systems, methods, computer-readable mediums and user interfaces.
The computer 102 also includes a local storage device 106 and a graphics module 113 (e.g., graphics card) for storing information and generating graphical objects, respectively. The local storage device 106 can be a computer-readable medium. The term “computer-readable medium” refers to any medium that participates in providing instructions to a processor for execution, including without limitation, non-volatile media (e.g., optical or magnetic disks), volatile media (e.g., memory) and transmission media. Transmission media includes, without limitation, coaxial cables, copper wire, fiber optics, and computer buses. Transmission media can also take the form of acoustic, light or radio frequency waves.
While widgets are described herein with respect to a personal computer 102, it should be apparent that the disclosed implementations can be incorporated in, or integrated with, any electronic device that is capable of using widgets, including without limitation, portable and desktop computers, servers, electronics, media players, game devices, mobile phones, email devices, personal digital assistants (PDAs), televisions, etc.
A dashboard system and method for managing and displaying dashboards and widgets can be implemented as one or more plug-ins that are installed and run on the personal computer 102. The plug-ins can be configured to interact with an operating system (e.g., MAC OS® X, WINDOWS XP, LINUX, etc.) and to perform the various dashboard and widget functions, as described with respect of
For illustrative purposes, widgets (including linked widgets) are described as a feature of an operating system. Widgets, however, can be implemented in other contexts as well, including e-mail environments, desktop environments, application environments, hand-held displays, and any other display devices.
In response to such invocation, the current state of the user interface is saved (203), the user interface is temporarily inactivated (204), an animation or effect is played or presented to introduce the dashboard (205) and the dashboard is displayed with one or more widgets (206). If applicable, a previous state of the dashboard is retrieved, so that the dashboard can be displayed in its previous configuration.
In some implementations, the dashboard is overlaid on an existing user interface (UI) (e.g., a desktop UI). When the dashboard is activated, the existing UI may be faded, darkened, brightened, blurred, distorted, or otherwise altered to emphasize that it is temporarily inactivated. The existing UI may or may not be visible behind the dashboard. The UI can also be shrunk to a small portion of the display screen while the dashboard is active, and can be re-activated by clicking on it. In some implementations, the UI is shrunk and presented as a widget. The UI can be re-activated by clicking on the widget. In some implementations the UI remains active when the dashboard is active.
The user interacts with and/or configures widgets as desired (207). In some implementations, the user can move widgets around the screen, and can resize widgets if applicable. Some widgets are resizable and some have a fixed size. A widget author can specify whether a widget can be resized. Some widgets automatically resize themselves based on the amount or nature of the data being displayed. Widgets can overlap and or repel one another. For example, if the user attempts to move one widget to a screen position occupied by another widget, one of the widgets is automatically moved out of the way or repelled by the other widget. In some implementations, a user can link widgets together using a widget link manager, as described with respect to
In some implementations, the user dismisses the dashboard (208) by invoking a dismissal command, which causes the UI layer to return or re-present itself to the display screen. In some implementations, the dashboard is dismissed when the user presses a function key or key combination (which may be the same or different than the key or combination used to activate the dashboard), or clicks on a close box or other icon, or clicks on negative space within the dashboard (e.g., a space between widgets), or moves an onscreen cursor to a predefined corner of the screen. Other dismissal methods are possible.
In some implementations, the dashboard is automatically dismissed (i.e., without user input) after some predetermined period of time or in response to a trigger event. An animation or other effect can be played or presented to provide a transition as the dashboard is dismissed (209). When the dashboard is dismissed, the current configuration or state of the widgets (e.g., position, size, etc.) is stored, so that it can be retrieved the next time the dashboard is activated. In some implementations, an animation or effect is played or presented when re-introducing the UI. The UI is restored to its previous state (210) so that the user can resume interaction with software applications and/or the operating system.
In some implementations, the dashboard is configurable. The user can select a number of widgets to be displayed, for example, by dragging the widgets from a configuration bar (or other user interface element) onto the dashboard. The configuration bar can include different types of widgets, and can be categorized and/or hierarchically organized. In some implementations, in response to the user dragging a widget onto the configuration bar, the widget is downloaded from a server and automatically installed (if not previously installed). In some implementations, certain widgets can be purchased, so the user is requested to provide a credit card number or some other form of payment before the widget is installed on the user's device. In some implementations, widgets are already installed on the user's device, but are only made visible when they have been dragged from the configuration bar onto the dashboard. The configuration bar is merely an example of one type of UI element for configuring the dashboard. Other configuration mechanisms can be used, such as an icon tray or menu system.
It should be apparent that there are many ways in which dashboards and widgets can be displayed other than those implementations described herein. For example, widgets can be displayed on any surface, user interface or user interface element, including but not limited to desktops, browser or application windows, menu systems, trays, multi-touch sensitive displays and other widgets.
In some implementations, the widgets 303 are displayed using HTML and related web technology. The dashboard server 301 manages and launches the dashboard client 302 processes. Each dashboard client 302 loads a widget 303 (e.g., an HTML webpage) and related resources needed to display the page. In some implementations, the dashboard clients 302 display the widgets 303 without a conventional window frame, menu bar, or other components typically associated with on-screen windows. This technique provides a clean, straightforward display of the overall dashboard to reduce confusion and clutter. The dashboard clients 302 display their respective widgets 303 by rendering web pages into a “WebView,” as described in U.S. patent application Ser. No. 11/148,010, entitled “Preview and Installation of User Interface Elements in a Display Environment.” The size of each WebView can be defined as metadata associated with the corresponding widget 303. The server 301 provides data for rendering the dashboard layer that can be overlaid on a desktop user interface. In some implementations, the widgets 303 are rendered into the dashboard layer, which is drawn on top of the desktop user interface, so as to partially or completely obscure the desktop user interface while the dashboard layer is active.
The dashboard server 301 (also referred to as “server”) can be a stand-alone process or embedded in another process. The server 301 can be located at the computer 102 or at the remote server 107. In some implementations, the server 301 provides functionality for one or more processes, including but not limited to: non-widget UI management, window management, fast login, event management, loading widgets, widget arbitration, Core Image integration and widget preference management, as described in U.S. patent application Ser. No. 11/148,010, entitled “Preview and Installation of User Interface Elements in a Display Environment.”
In some implementations, a dashboard client 302 is a process that uses, for example, objects that are defined as part of a development environment, such as Apple Computer's Cocoa Application Framework (also referred to as the Application Kit, or AppKit) for the Mac OS® operating system. In some implementations, the dashboard clients 302 can be implemented as simplified browser screens that omit conventional interface features such as a menu bar, window frame, and the like.
In one implementation, each widget 303 is implemented as an HTML file. The HTML file can reference other local and remote resources such as style sheets (e.g., Cascading Style Sheets), other HTML files, JavaScript files, images, and the like. Widgets 303 can be implemented using, for example, a flat bundle file format or a packaged HTML file format. In some implementations, the Flat Bundle format includes an info.plist file.
The Info.plist files describes a widget 303 and provides an identifier for a widget 303. Table I provides an example of Info.plist file contents.
The keys AllowFileAccessOutsideofWidget, AllowFullAccess AllowInternetPlugins, AllowJava, AllowNetworkAccess, and AllowSystem are Boolean types that can be set by a widget author to enable certain levels of resource access.
In some implementations, the Info.plist file includes N WidgetLinkInfo strings, for storing the names of widgets that can be linked to the widget associated with the Info.plist file. This information can be used to automatically link widgets, as described with respect to
In some implementations, the user can drag the icon 403 to any location on the screen, and the position of the icon 403 will remain persistent from one invocation of the dashboard layer 402 to the next. The user can click on the icon 403 to activate the configuration bar 408, as shown in
Note that the particular configuration and appearance of configuration bar 408 in
Elements, including user interface elements such as widgets can be displayed as discussed below. One display, a dashboard layer, will be used for illustrative purposes. Installation can include a preview operation as is discussed below. Installation can include selection of the element, such as by a drag and drop action. Other selection means can be used. In one example, a user can drag widgets from configuration bar 408 onto the surface of the dashboard (in other words, anywhere on the screen), using standard drag-and-drop functionality for moving objects on a screen.
In some implementations, widgets in the configuration bar 408 are smaller than their actual size when installed. When the user clicks on a widget and begins to drag it into a dashboard or other display, the widget can be animated to its actual or installed size to assist the user in the real-time layout of the dashboard. By animating the widget to its actual size, the user will know the actual size of the widget prior to its installation.
In some implementations, an animation, such as a ripple animation, is shown when the user “drops” a widget by releasing a mouse button (or equivalent input device) to place a widget at the desired location. In one implementation, the dragging of the widget to the dashboard layer 402 invokes an installation process for installing the widget including previewing. After installation, the user can move a widget, to any other desired location, or can remove the widget from the screen, for example by dragging it off the screen, or dragging it back onto the configuration bar 408, by invoking a remove command, disabling a widget in a menu associated with a widget manager or canceling the installation during the preview. In some implementations, the position, state, and configuration of a widget are preserved when the dashboard layer 402 is dismissed, so that these characteristics are restored the next time the dashboard layer 402 is activated.
In some implementations, widgets and/or dashboard layers (including widgets) can be installed from within a running application. For example, a widget and/or dashboard (including widgets) can be an attachment to an email. When the user clicks the attachment, an installation process is invoked for the widget and/or dashboard which can also include a preview.
Widgets can be created or instantiated using an installer process. The installer process can include a separate user interface or an integrated user interface (e.g., integrated in the display area or separate from the display area, for example, in another display area associated with another application, such as an email application) for selecting and installing widgets in a display area. For example, a widget received as an email attachment can be launched by a user from directly within a user interface of the email application.
Widgets can be created or instantiated using an installer process. The installer process can include a separate user interface or an integrated user interface (e.g., integrated in the display area or separate from the display area for example in another display area associated with another application, such as an email application) for selecting and installing widgets in a display area. Thus, the installation area for the widget can be embedded within an application display area or window. For example, if a user receives a widget as an attachment to an email, the user can invoke and install the widget from within the email message window without the need for a separate installation window.
In general, an installer process is used to provide additional functionality to the creation/instantiation process, beyond the simple drag and drop operation describe above. Additional functionality can include preview, linking, security and deletion functionality in a singular interface. The installer process can be a separate process or combined in another process. The installer process can itself be a separate application that is executable to install widgets (or other elements) in a display area. As used herein, the term “process” refers to a combination of functions that can be implemented in hardware, software, firmware or the like.
The use of nested display areas associated with different dashboard environments enables users to organize dashboards into hierarchies. For example, a dashboard environment including widgets for use with operating system utilities can include nested display areas for displaying widgets associated with particular types of utilities (e.g., date and time, memory management, network resource management, etc.)
In some implementations, the user interface 504 includes a background image, a menu bar 502, and other UI common features (e.g., windows, icons, etc.). The user can activate the dashboard layer 506 by selecting an item from the menu bar 502, or by clicking an icon, or by pressing a function key or key combination, or by some other means for invoking activation. In some implementations, a configuration bar 503 is displayed, which includes one or more widget icons and a widget link manager icon 514. The configuration bar 503 can be scrolled from left to right to reveal more widget icons. A user can install a widget by dragging its associated widget icon from the configuration bar 503 and dropping it in the dashboard layer 506, or by using other installation techniques, as described with respect to
In some implementations, two or more widgets are automatically linked in response to a trigger event. A trigger event can be generated by downloading, installing, previewing, launching, manipulating, updating, operating or otherwise interacting with a widget. A trigger event can also be generated by exercising the functionality of a widget.
Widgets can be automatically or manually linked together based on any suitable criteria or no criteria. For example, widgets can be linked based on the type of data or information the widgets use or share (e.g., time, date, place, etc.), the origin of the widgets (e.g., received from friends, downloaded from a common website, etc.) and the time when the widgets were downloaded (e.g., widgets downloaded at the same time of day). Widgets can be linked based on their membership in a widget class (e.g., financial widgets, stock market widgets, etc.). Widgets can also be linked based on their participation in a process or workflow (e.g., a stock market widget providing data to a 3D graph widget).
The concept of linked widgets can be illustrated by the following example involving a search widget 508, a map widget 510 and a weather widget 512. When the user installs the search widget 508 in the dashboard layer 506, a trigger event is generated which causes the map widget 510 and the weather widget 512 to be automatically linked to the search widget 508 and displayed in the dashboard layer 506. A user enters a search query in a search box of the search widget 508 to determine the location of a favorite restaurant. The search widget 508 returns location information (e.g., address, coordinates, etc.) for the restaurant, which is shared with the map widget 510 and the weather widget 512. The map widget 510 uses the address to generate a map and driving directions. The weather widget 512 uses the address to determine the current weather for the location of the restaurant. If the map and weather widgets 510, 512, are already installed and launched in the dashboard layer 506 when the search widget 508 is installed, then the links are established directly without re-installing and launching the widgets 510, 512. If the widgets 510, 512, are not installed, then the widgets 510, 512 are installed and launched before or after being linked. If the widgets 510, 512 are not available on the computer system 102, a message is displayed instructing the user on how to obtain the widgets 510, 512 from another source. For example, the message can include a link to a website where the widgets 510, 512 can be downloaded to the computer system 102.
Generally, any two widgets can be linked and share information. The amount and type of information shared is dependant on the widgets that are linked. For example, the widgets 508, 510 and 512 could share location information (e.g., address, latitude, longitude, etc.).
The widgets 508, 510 and 512 are examples of widgets that can be linked based on the type of information the widgets use and share (i.e., location information). Other examples of widgets that can be linked include but are not limited to: a calendar widget that can be linked to a scheduling widget; a dictionary widget that can be linked to a word processing widget; a telephone directory widget that can be linked to dial-up widget; a stock widget that can be linked to a graph widget for presenting stock information in different types of graphs (e.g., pie graph, bar graph, etc.); an image processing/editing widget that can be linked to a picture frame widget for viewing a digital image; and a media player widget that can be linked to a ticket vending widget (e.g., a Ticketmaster™ widget) for providing a touring schedule and a mechanism for purchasing concert tickets to see an artist whose song is currently playing in the media player widget.
In some implementations, widgets can be linked to one or more non-widget applications and can interact with and receive data from those applications. A non-widget application can also provide a bridge between two or more widgets. For example, when an application is invoked (e.g., a word processor) can search for widgets that can support the application or specific feature of the application (e.g., dictionary or thesaurus widgets). The widgets can communicate directly with each other and/or indirectly through the application.
In some implementations, links are established between widgets only if one or more conditions, events or triggers are satisfied. For example, a link may only be established upon completion of one or more tasks, or at a certain time of day, or only between widgets that are currently running, or only between widgets in the same dashboard layer, etc. The conditions for establishing links can be a set of rules that should be satisfied before a link is established. The rules can be generated manually by the user or programmatically at run time. Rules can also be dynamically generated by a running widget or non-widget application that is associated with widgets. The rules can be stored in a widget file or other data structure. The rules for linking widgets can be different based on the type of device where the widgets reside (e.g., a portable device, mobile phone, etc.).
Linked widgets can be located in the same dashboard or different dashboards in a multiple dashboard environment. In some implementations, linked widgets can communicate even when installed in different display areas. Linked widgets can reside on a single device or on multiple devices and communicate over a network connection established between the devices (e.g., Internet, Ethernet, wireless, etc.).
In some implementations, linked widgets include a link element 516 (e.g., a button), which if selected disables links to other widgets. For example, clicking on the link element 516 of the search widget 508 causes the map and weather widgets 510, 512, to be unlinked to the search widget 508. In some implementations, when widgets are unlinked they are altered or obfuscated in the dashboard layer 506 (e.g., grayed out, dimmed, made semi-translucent, etc.). Alternatively, unlinked widgets can remain visible but a link indicator 518 (e.g., a virtual lamp, etc.) is altered to indicate a widget's link status. For example, the link indicator 518 can change color (e.g., from green to red) to assist users to visually identify the link status of a widget. In other implementations, the icon associated with a widget is modified to indicate the widgets link status (e.g., the icon change colors or displays informative text).
In some implementations, widgets that are linked (or that are capable of being linked) have a gravitational or magnetic attraction or repulsion to each other. For example, when two widgets are linked together, the widgets positions in a dashboard layer or other user interface can be automatically adjusted so the linked widgets are adjacent or proximate to each other. Under such a simulated gravitational attraction or repulsion, widgets can cluster together in the dashboard layer or user interface to indicate their linked status. The clustering visually indicates to the user that the widgets are linked (or not linked) or that the widgets can be linked. A visual indication of the strength of a link (or the potential to link) can be displayed by changing one or more properties of the widgets, such as the color of the widgets or the distance between widgets. For example, red widgets could indicate a strong link (or potential to link) and green widgets could indicate a weak link (or potential to link). Also, a shorter distance between linked widgets in a dashboard layer or user interface could indicate a stronger link (or potential to link) than widgets that are separated by a greater distance. If the user moves a widget around a dashboard layer or a user interface, other widgets in the dashboard layer or user interface can be attracted to or repulsed by the moving widget to indicate their link status or link potential.
Widgets can be linked in a variety of topologies. For example, a single widget can be linked to multiple widgets and configured to provide those widgets with common or personalized information (e.g., a broadcasting widget). In some implementations, a widget can behave like a server (“server widget”) and interact and exchange information with one or more “client” widgets.
In some implementations, widgets can be linked at several levels and conceptually organized into a widget hierarchy, for example, forming a “tree” structure where the widget at the top of the tree is a “root” widget and the other widgets are “leafs” or “node” widgets.
In some implementations, the linkage between two or more widgets can be bi-directional, so that each widget in a pair of linked widgets can be invoked (e.g., launched, installed, updated, etc.) by the other widget in the pair. Also, each widget in a widget pair can transmit and receive information from the other widget in the pair.
In some implementations, the user interface 504 can be obfuscated to reveal a dashboard layer 506 containing only linked widgets. For example, the user can press a predetermined key combination or other input mechanism, which causes the appearance of unlinked widgets to be altered or otherwise obfuscated so that only linked widgets are visible on the display screen. A key combination can be specified by the user in a preference pane or other user input mechanism.
In some implementations, a widget link manager enables a user to manually establish and edit widget links, as described with respect to
When a link is manually or automatically established between the phone book widget 520 and the sports widget 522, information can be exchanged between the phone book widget 520 and the sports widget 522. For example, the sports widget 522 can send the phone book widget 520 the name of a sports venue. The phone book widget 520 can then use the name of the sport venue to look up the address and telephone number of the sports venue. Once the address and number are retrieved, the phone book widget 520 sends the address and telephone number to the sports widget 522, where the information can be used to augment or enhance the sporting event information 524.
The process 600 begins when a widget linking trigger event is detected (602). A widget linking trigger event can generated (e.g., by a dashboard server) in response to the downloading, installation, previewing, launching, updating, manipulation, operation and/or interaction with a widget. A widget linking trigger event can also be the exercise of a feature or functionality of one or more widgets. A widget linking trigger event can be generated by user input or programmatically by software (e.g., operating system, application, etc.) or hardware (e.g., mouse click, hardware plug-in, etc.).
In response to a trigger event, the process 600 determines a set of candidate widgets that can be linked (604). Candidate widgets can be determined from predetermined or dynamically generated link information. In some implementations, predetermined link information can be stored in the dashboard configuration information 304, as shown in
In some implementations, a dashboard can scan for installed widgets to create a collection of linkages, or possible linkages which are stored during runtime. In some implementations, the user can control the linkages which can be stored by the dashboard server. For example, the user can manually establish linkages using a widget link manager or bridging elements, as described with respect to
When a set of candidate widgets is determined, the process 600 automatically links (and installs and launches, if necessary) the candidate widgets (606). In some implementations a manual step can be used in combination with the process 600 by automatically presenting a user interface that includes a list of candidate widgets that can be linked to a particular widget (e.g., the widget that generated the trigger event). The candidate widgets can be organized into a file system that can be navigated. For example, launched widgets that are running on the host device can be listed separately from widgets that are residing on the host device but have not been launched.
The user can manually select one or more widgets from the candidate widget list for linking. In other embodiments, a link or other mechanism can be provided in the dashboard layer and/or in a configuration bar that the user can select to invoke the user interface having candidate widgets and/or to direct the user to another source of candidate widgets (e.g., a link to a website).
In some implementations, a communication channel is established between the linked widgets using known object oriented programming (OOP) techniques and languages (e.g., Java, C++, Smalltalk, etc.) for transmitting and receiving messages (608). In some implementations, each widget in a linked pair of widgets can “pull” information from the other widget, “push” information to the other widget, or both (i.e., bidirectional communication). In other implementations, each widget writes information to a shared memory or storage location (e.g., local storage 106) where it can be read by other widgets. The type and amount of information shared is dependent on the needs of the widgets that are linked. An examples of shared link information would be the coordinate or location data between the widgets 508, 510 and 512, as described with respect to
In some implementations, the widgets share security information (e.g., keys, secret data, etc.) for secured communications. When widgets share information, there is a danger that malicious widgets will gain access to restricted information. If confidential information is to be shared between widgets, then the widgets can be signed and undergo an authentication procedure during linking using one or more known authentication techniques (e.g., Digital Signature Algorithm (DSA)).
When communication between linked widgets is established, the process 600 monitors the link status (610) for changes. Changes could be failed links, temporarily disable links, new links, etc. The process 600 detects any changes and modifies the link information as appropriate. For example, if a new link is established the process 600 will add the link to the link information associated with the widgets forming the link, as described with respect to Table I.
The widget linker 702 is responsible for implementing the process 600, as described with respect to
Referring to Table I, an exemplary data structure includes a Name field, a Widget ID field, a Linked To field and a Sharing field. More or fewer fields can be used, as desired. The Name field stores the name of the widget, the Widget ID field stores a unique ID for the widget (e.g., a fingerprint or hash), the Linked To field includes the Widget IDs for all the widgets that are linked to the widget identified in the Name and Widget ID fields. The Sharing field includes a description of information to be shared by the widget having the Widget ID. The data structure can be stored as a text file in a directory where it can be edited by a user through, for example, a text editor.
In some implementations, the widget linker 702 keeps track of the physical and/or logical address locations of shared information, the types of data that can be shared and the widgets that are allowed to share data. In some implementations, the user or a system administrator can prevent a widget from sharing its data with any other widget (e.g., as a security precaution) by setting the “sharing” field to None. Content feeds and other external information sources can be similarly protected. In some implementations, some widget data can be shared and other widget data can remain private. Such an implementation can be realized by adding one or more additional fields in the data structure shown in Table I. For example, one or more fields can be added that list the source of a trigger event or that stores instantaneous IDs for multiple instances of widgets.
The process 800 begins when the user selects a first widget for linking (802). In some implementations, the first widget includes a linking mechanism (e.g., menu item, button) which, when selected (e.g., mouse clicked), configures the widget for linking with other widgets, and invokes a widget link manager for manually establishing links with other widgets. In other implementations, the widget flips when the linking mechanism is selected, and a widget link manager user interface is presented on the backside of the widget. An example of a user interface for a widget link manager is described with respect to
After the first widget is selected, the user can select information belonging to the first widget which can be shared with other widgets. In some cases, the user may desire to keep certain widget information private but allow other widget information to be made public (i.e., shared with other widgets). In some cases, there may be restrictions on the number and types of widgets that can be linked to the first widget. For example, widgets that have access to certain local or network resources (e.g., file systems, private information, etc.) may be restricted by the user (or the user's privileges) from linking with other widgets for security reasons. For example, a user can turn off automatic widget linking for all or some widgets, or restrict certain widgets from linking with certain other widgets. Such restrictions or any other security methods can be specified or set by a user or administrator through a security preference pane or other input mechanism. These restrictions can be placed in a widget file that is distributed with the widget (e.g., info.plist) or added at a later time by a system administrator or user through a widget manager, as described with respect to
The user selects a second widget for linking with the first widget (804). The user can also select information belonging to the second widget which can be shared with the first widget. Once the first and second widgets are specified, including a specification of shared data, the widgets can be linked (806).
In some implementations, the widget link manager 900 is invoked by clicking on the widget link manager icon 514 or other input mechanism (e.g., key combination, menu option, etc.). The widget link manager 900 can be closed by clicking the button 908 or other input mechanism. When invoked the widget link manager provides a display area including a search panel 802 and a link panel 904. The search panel 902 includes a search box 906 for searching for widgets. For example, a user can put name of a widget in the search box 906 and click a “Go” button 910 to run a search for the search widget 508. Alternatively, the user can browse a directory structure for widgets, using techniques commonly employed by file systems to search for files (e.g., Mac OS® Finder or Spotlight).
When the search widget 508 is selected its icon or other identifier can be displayed in the search area 902. To link the search widget 508 with the map widget 510, the user can, for example, drag the icon for the map widget 510 from the configuration bar 503 and drops the icon in the link area 904. In some implementations, the widget link manager 900 determines whether the map widget 510 can be linked to the search widget 508 by, for example, examining link information for the widgets. If the map widget 510 can be linked, the map widget 510 can appear in a list 914 of linked widgets in the link area 904. If the map widget 510 cannot be linked to the search widget 508, the map widget 510 is not displayed in the list 914 and the user is notified (e.g., by an alert message). A link failure could occur if the map and search widgets 508, 510, are restricted from being linked to each other, or if there is insufficient link information available for one or both widgets, or for any other reason (e.g., security restrictions). Note that the link information shared is dependant on the widgets that are linked. For example, the search, map and weather widgets would share location information (e.g., address, latitude, longitude, etc.).
It should be apparent that other implementations of the widget link manager 900 are possible. For example, all or part of the functionality of the widget link manager 900 can be accessible on the flip-side of a widget. If a user wants to link widgets, the user can flip the widget to display the search area 902 and link area 904.
When the end of the first bridging element 916a is over or in the proximity of the dock 918b, the user releases the mouse button and the bridge between the widgets 508 and 510 is completed, resulting in the widgets 508 and 510 being linked. The user can repeat the same procedure using a second bridging element 916b and docks 918a and 918c. In some implementations, the bridging element is displayed until the widgets are linked at which time is removed or otherwise obfuscated. For example, once the widgets have been bridged, the bridging element can disappear or be obfuscated and the widget's properties or characteristics can be altered to indicate link status (e.g., the widgets change color).
In some implementations, the widgets can be unlinked by clicking on each widget of a link, which causes the bridging element to be displayed again. The user can then manually “snip” the bridging element by clicking on it with a mouse or other pointing device. Other techniques for removing links using bridging elements are possible.
Users may have several devices that utilize widgets and dashboards. For example, a user may have a desktop computer with certain dashboards and widgets installed and a portable computer with the same or different dashboards and widgets installed. The system 1000 allows a user to synchronize dashboards and widgets installed on a host device, network or storage media to one or more data sources. Data sources can be any source that provides data for creating, installing, operating or managing widgets and/or dashboards, or any data used or presented by widgets and/or dashboards. In the example shown, the host device 1006a (“host device A”) can synchronize directly with the host device 1006b (“host device B”) using a known or standard bus technology (e.g., USB, FireWire™) or indirectly through the network server 1002 and network 1080.
In some implementations, a synchronization service can be used to non-destructively synchronize widgets and/or dashboards between two devices. In the example shown, the host device 1006a has installed widgets A, B, and C. Widget A is installed on a user interface provided by, for example, an operating system or application running on the host device 1006a. The widgets B and C are installed in a dashboard layer, referred to as “dashboard 1.” The host device 1006a can be connected directly to the host device 1006b and a synchronization can be initiated by the host device 1006a. Synchronization can be initiated manually by user or automatically on a scheduled based or in response to a trigger event. Manual synchronization can be initiated by selecting an option from a menu or other user interface element (e.g., virtual button) presented on a display device of the host device 1006a and/or by a hardware mechanism (e.g., a mechanical button, switch, key). When synchronization is initiated, the user can be presented with several options for synchronization. For example, the user can be presented with a list of items (e.g., dashboards, widgets, files, database records, etc.) that can be synchronized with corresponding checkboxes that can be checked by the user to allow the item to be included or excluded from the synchronization process. Once the synchronization process has begun, the user can be presented with a dialog reporting the progress of the synchronization and a summary of the synchronization results. In some implementations, the synchronization results provides a list of potential conflicts and allows the user to manually resolve the conflicts. For example, a conflict may arise between two different versions of the same widget and/or dashboard. The user can be prompted in real time to resolve the conflict by selecting one version over another version. In some implementations, such conflict resolutions and other specifications for synchronization can be pre-selected by the user through a preference pane or other dialog.
The synchronization process can be performed using known synchronization technologies and/or services. An example of a suitable synchronization service is “Sync Services” provided by Apple Computer, Inc. Sync Services is a framework containing components needed by a developer to sync an application and devices. Data can be synced with other applications and devices on the same device, or other devices over a network using, for example, .Mac (a web-based service provided by Apple). Sync Services is publicly available as an Objective-C Application Programming Interface (API) for Mac OS® X version 10.4 and later. The architecture and logic of Sync Services is described with reference to
In some implementations, the system 1000 can use peer-to-peer or network-less syncing. In such an implementation, the network device that is used for syncing may or may not be independent of the target device which is receiving the synced data. For example, Apple Computer Inc.'s “Sync Services” can sync information to a device or to Mac and then to another device. In the former case, there is no “network” other than the network formed by the two devices being synced. In the latter case, there is a network server that holds the information before it is synced to the target device. In some implementations, two peer-to-peer devices can sync in an ad hoc network where no network server is available.
A desirable feature of the system 1000 is the ability to synchronize non-destructively. For example, assume that Widgets A, B and C are installed on host device 1006a and Widgets B, C, D and E are installed on host device 1600b, but not Widget A. If host device 1006a initiates a synchronization with host device 1006b, then Widget A will be added to host device 1600b and Widgets B and C on host device 1006b will be replaced with Widgets B and C on host device 1006a (assuming the user or an application has specified such a replacement). After synchronization has completed, the host device 1006b will have Widgets A, B, C, D and E. Now if the host device 1006b initiates a synchronization with the host device 1006a, then Widgets D and E will be added to the host device 1006a, Widgets B and C will be replaced and Widget A will remain unaffected. Since Widget A is not removed from the host device 1006a, the synchronization is referred to as “non-destructive.”
In some implementations, local configuration information (e.g., parameter data) can be identified as related to dashboards and/or widgets on a host device and evaluated for consistency with master configuration information stored locally on the host device or remotely on, for example, a network device (e.g., network server 1002). If the information is different, then local configuration information can be updated with master configuration information or vice versa.
In some implementations, different versions of the same widget/dashboard and/or different widget/dashboard can be synced based on sync preferences, which can be specified by a user. If a device does not have a widget/dashboard installed, then the settings for the widget/dashboard can be synced, so that when the widget/dashboard is later installed, the widget/dashboard is invoked with the correct settings. If a widget cannot be synced (e.g. it is a purchased widget), then a “dummy” widget can be synced and the user can be provided instructions on how to obtain the widget.
In some implementations, a removable storage media can be synchronized with a host device. In the example shown, the removable storage media 1010, which includes Widget A, can be synchronized with the host device 1006a, which also includes a version of Widget A. Examples of removable storage media 1010 include but are not limited to: external hard drives, USB flash drives, Firewire™ drives, floppy disks, compact discs, an any other storage media that can be plugged into or otherwise connected with a host device. In some implementations, the system 1000 can be used with Portable Home Directories (PHDs) as provided by Apple Computer's Mac OS® X (Tiger) operating system or similar technologies.
In some implementations, the host device 1006a scans for removable media 1010. If detected, the host device 1006a mounts the removable media 1010 and searches for widgets/dashboards to be synchronized. If found, then the configurations for the widgets/dashboards can be compared against master information stored locally on the host device 1006a or remotely on a network device, and a synchronization process can be initialized manually (e.g., by the user) or automatically, such as the synchronization process described in reference to
The use of removable media allows users to maintain widgets and dashboards on multiple devices and to transfer changes made to widgets and dashboards on one device to other devices. For example, a user could carry their customized dashboards and widgets on a USB flash drive. The user can plug the drive into any device capable of supporting dashboards and widgets, and install or cause to be installed, the customized dashboards and widgets. The user can then make changes to widgets and dashboards, which can be stored on the USB flash drive. When the user plugs the drive into another device the changes are detected and synchronized to the new device or other user devices through a network synchronization process, such as is described with reference to
In some implementations, the network server 1002 can act as a centralized repository for information relating to a user's widgets and dashboards, which can be downloaded to a device through a network connection. The user can manage the information using the device.
In some implementations, one or more uses can subscribe to a synchronization service. The service can provide a web site where a user can login and specify certain synchronization services. The service can be part of a service that aggregates and distributes widgets and dashboards. For example, a user device could receive updated versions of widgets and/or dashboards by syncing with a network device. The syncing can be initiated by the user device (“sync client”) or by the sync service and changes to widgets and/or dashboards can be either pushed by or pulled from a sync engine running on the network device, as described in reference to
It should be apparent that the widgets 1106 and 1108 are different or disparate and that it is the data associated with the widgets 1106 and 1108 that is synced. This process can be compared to the example synchronization process described in reference to
In some implementations, the sync engine 1304 merges changes to be pulled by different sync clients 1302. The sync engine 1304 can be invoked on a scheduled basis or triggered by an event. A network-based sync engine 1304 can coordinate the requests of multiple sync devices 1302 simultaneously and can notify a dependent sync device 1302 that an observed sync device 1302 is syncing, and allow the sync device 1302 to join a sync session.
In some implementations, the sync engine 1304 selects an appropriate sync mode for each client 1302. In a “slow syncing mode,” the first time a sync client 1302 syncs, it pushes all its widget/dashboard information in a “bundle” to the sync engine 1304 and pull changes computed by the sync engine 1304. In a “fast syncing mode,” while a client 1302 is pushing and pulling information, the sync engine 1304 keeps track of the client's state using, for example, a snapshot so that subsequent syncs can be more efficient. The next time a client 1302 syncs, only changes are pushed and pulled. In some implementations, the sync engine 1304 assumes the client 1302 is fast syncing unless the client negotiates another sync mode or some state has changed that requires a different mode. Intelligence can be built into the sync engine 1304 to resolve conflicts and duplicates without requiring user input. In some implementations, the sync engine 1304 is a differencing engine that processes changes to individual parameters associated with a widget or dashboard. If two clients 1302 modify the same parameter for a widget or dashboard, the sync engine 1304 can generate a conflict.
In some implementations, the truth database 1306 contains an aggregate of all the client's widget and dashboard information. The truth database 1306 can use a canonical scheme that is an aggregate of all the widget and dashboard schemas used by all the clients 1302.
It will be understood by those skilled in the relevant art that the above-described implementations are merely exemplary, and many changes can be made without departing from the true spirit and scope of the present invention. Therefore, it is intended by the appended claims to cover all such changes and modifications that come within the true spirit and scope of this invention.
This application is a continuation-in-part of U.S. patent application Ser. No. 10/877,968, for “Unified Interest Layer For User Interface,” filed Jun. 25, 2004 now U.S. Pat. No. 7,490,295, which patent application is incorporated by reference herein in its entirety. This application is related to the following jointly owned and co-pending patent applications, each incorporated herein by reference in its entirety: U.S. Provisional Patent Application No. 60/583,125, for “Procedurally Expressing Graphic Objects for Web Pages,” filed Jun. 25, 2004;U.S. patent application Ser. No. 10/874,829, for “User Interface for Assisting in the Installation of an Asset,” filed Jun. 22, 2004;U.S. patent application Ser. No. 10/877,968, for “Unified Interest Layer For User Interface,” filed Jun. 25, 2004;U.S. patent application Ser. No. 11/145,561, for “Application Clipper,” filed Jun. 3, 2005;U.S. patent application Ser. No. 11/145,560, for “Web View Applications,” filed Jun. 3, 2005;U.S. patent application Ser. No. 11/145,023, for “Clip View Applications,” filed Jun. 3, 2005;U.S. patent application Ser. No. 11/148,010, for “Preview and Installation of User Interface Elements in a Display Environment,” filed Jun. 7, 2005;U.S. Provisional Patent Application No. 60/734,016, for “Preview Including Theme Based Installation of User Interface Elements In A Display Environment,” filed Nov. 4, 2005, which provisional patent application is incorporated herein by reference in its entirety;U.S. Provisional Patent Application No. 60/730,956, for “Widget Security,” filed Oct. 27, 2005, which provisional application is incorporated herein by reference in its entirety;U.S. patent application Ser. No. 11/282,110, for “Preview Including Theme Based Installation of User Interface Elements In A Display Environment,” filed Nov. 16, 2005;U.S. Provisional Patent Application No. 60/737,899, for “Management of User Interface Elements In A Display Environment,” filed Nov. 18, 2005; andU.S. patent application Ser. No. 11/346,603, for “Multiple Dashboards,” filed Feb. 1, 2006;U.S. patent application Ser. No. 11/403,644, for “Linked Widgets,” filed Apr. 12, 2006; andU.S. patent application Ser. No. 11/499,494, for “Management and Generation of Dashboards,” filed Aug. 4, 2006.
Number | Name | Date | Kind |
---|---|---|---|
4752893 | Guttag et al. | Jun 1988 | A |
5168441 | Ornaheim et al. | Dec 1992 | A |
5289574 | Sawyer | Feb 1994 | A |
5297250 | Leroy et al. | Mar 1994 | A |
5351995 | Booker | Oct 1994 | A |
5357603 | Parker | Oct 1994 | A |
5388201 | Hourvitz et al. | Feb 1995 | A |
5416890 | Beretta | May 1995 | A |
5481665 | Okada et al. | Jan 1996 | A |
5490246 | Brotsky et al. | Feb 1996 | A |
5522022 | Rao et al. | May 1996 | A |
5537630 | Berry et al. | Jul 1996 | A |
5564002 | Brown | Oct 1996 | A |
5564022 | Debnath et al. | Oct 1996 | A |
5588098 | Chen et al. | Dec 1996 | A |
5602997 | Carpenter et al. | Feb 1997 | A |
5638501 | Gough et al. | Jun 1997 | A |
5644737 | Tuniman et al. | Jul 1997 | A |
5644739 | Moursund | Jul 1997 | A |
5651107 | Frank et al. | Jul 1997 | A |
5657049 | Ludolph et al. | Aug 1997 | A |
5659693 | Hansen et al. | Aug 1997 | A |
5659694 | Bibayan | Aug 1997 | A |
5666416 | Micali | Sep 1997 | A |
5666530 | Clark et al. | Sep 1997 | A |
5671343 | Kondo et al. | Sep 1997 | A |
5689664 | Narayanan et al. | Nov 1997 | A |
5708764 | Borrel et al. | Jan 1998 | A |
5710884 | Dedrick | Jan 1998 | A |
5710922 | Alley et al. | Jan 1998 | A |
5721848 | Joseph | Feb 1998 | A |
5727135 | Webb et al. | Mar 1998 | A |
5731819 | Gagne et al. | Mar 1998 | A |
5742285 | Ueda | Apr 1998 | A |
5754174 | Carpenter et al. | May 1998 | A |
5760773 | Berman et al. | Jun 1998 | A |
5764229 | Bennett | Jun 1998 | A |
5764238 | Lum et al. | Jun 1998 | A |
5790120 | Lozares et al. | Aug 1998 | A |
5793376 | Tanaka et al. | Aug 1998 | A |
5796402 | Ellison-Taylor | Aug 1998 | A |
5801703 | Bowden et al. | Sep 1998 | A |
5809230 | Pereira | Sep 1998 | A |
5835692 | Cragun et al. | Nov 1998 | A |
5835693 | Lynch et al. | Nov 1998 | A |
5838316 | Arruza | Nov 1998 | A |
5845293 | Veghte et al. | Dec 1998 | A |
5870734 | Kao | Feb 1999 | A |
5877741 | Chee et al. | Mar 1999 | A |
5877762 | Young et al. | Mar 1999 | A |
5878219 | Vance et al. | Mar 1999 | A |
5883639 | Walton et al. | Mar 1999 | A |
5900876 | Yagita et al. | May 1999 | A |
5903896 | Waldman et al. | May 1999 | A |
5917436 | Endo et al. | Jun 1999 | A |
5920659 | Iverson et al. | Jul 1999 | A |
5929852 | Fisher et al. | Jul 1999 | A |
5933148 | Oka et al. | Aug 1999 | A |
5949409 | Tanaka et al. | Sep 1999 | A |
5963191 | Jaaskelainen, Jr. | Oct 1999 | A |
5974238 | Chase, Jr. | Oct 1999 | A |
5978579 | Buxton et al. | Nov 1999 | A |
5999948 | Nelson et al. | Dec 1999 | A |
6000000 | Hawkins et al. | Dec 1999 | A |
6005568 | Simonoff et al. | Dec 1999 | A |
6006231 | Popa | Dec 1999 | A |
6006274 | Hawkins et al. | Dec 1999 | A |
6011562 | Gagne et al. | Jan 2000 | A |
6023708 | Mendez et al. | Feb 2000 | A |
6031937 | Graffagnino | Feb 2000 | A |
6034621 | Kaufman | Mar 2000 | A |
6045446 | Ohshima | Apr 2000 | A |
6061695 | Slivka et al. | May 2000 | A |
6075543 | Akeley | Jun 2000 | A |
6128010 | Baxter et al. | Oct 2000 | A |
6133915 | Arcuri et al. | Oct 2000 | A |
6144381 | Lection et al. | Nov 2000 | A |
6154601 | Yaegashi et al. | Nov 2000 | A |
6166748 | Van Hook et al. | Dec 2000 | A |
6167533 | Potterveld et al. | Dec 2000 | A |
6178443 | Lin | Jan 2001 | B1 |
6188399 | Voas et al. | Feb 2001 | B1 |
6191797 | Politis | Feb 2001 | B1 |
6195664 | Tolfa | Feb 2001 | B1 |
6211890 | Ohba | Apr 2001 | B1 |
6243705 | Kucala | Jun 2001 | B1 |
6246418 | Oka | Jun 2001 | B1 |
6253122 | Razavi et al. | Jun 2001 | B1 |
6259432 | Yamada et al. | Jul 2001 | B1 |
6266053 | French et al. | Jul 2001 | B1 |
6266430 | Rhoads | Jul 2001 | B1 |
6269405 | Dutcher et al. | Jul 2001 | B1 |
6272484 | Martin et al. | Aug 2001 | B1 |
6272558 | Hui et al. | Aug 2001 | B1 |
6275831 | Bodnar et al. | Aug 2001 | B1 |
6278448 | Brown et al. | Aug 2001 | B1 |
6278450 | Arcuri et al. | Aug 2001 | B1 |
6295541 | Bodnar et al. | Sep 2001 | B1 |
6300947 | Kanevsky | Oct 2001 | B1 |
6304684 | Niczyporuk et al. | Oct 2001 | B1 |
6307574 | Ashe et al. | Oct 2001 | B1 |
6310621 | Gagne et al. | Oct 2001 | B1 |
6311232 | Cagle et al. | Oct 2001 | B1 |
6313851 | Matthews, III et al. | Nov 2001 | B1 |
6321314 | Van Dyke | Nov 2001 | B1 |
6330618 | Hawkins et al. | Dec 2001 | B1 |
6333753 | Hinckley | Dec 2001 | B1 |
6344855 | Fisher et al. | Feb 2002 | B1 |
6353437 | Gagne | Mar 2002 | B1 |
6369823 | Ohba | Apr 2002 | B2 |
6369830 | Brunner et al. | Apr 2002 | B1 |
6396520 | Ording | May 2002 | B1 |
6401104 | LaRue et al. | Jun 2002 | B1 |
6411301 | Parikh et al. | Jun 2002 | B1 |
6412021 | Nguyen et al. | Jun 2002 | B1 |
6421058 | Parikh et al. | Jul 2002 | B2 |
6424348 | Parikh | Jul 2002 | B2 |
6430576 | Gates et al. | Aug 2002 | B1 |
6434744 | Chamberlain et al. | Aug 2002 | B1 |
6452600 | Parikh et al. | Sep 2002 | B1 |
6456290 | Parikh et al. | Sep 2002 | B2 |
6457034 | Morein | Sep 2002 | B1 |
6466218 | Parikh et al. | Oct 2002 | B2 |
6466237 | Miyao et al. | Oct 2002 | B1 |
6469714 | Buxton et al. | Oct 2002 | B2 |
6483524 | Petchenkine et al. | Nov 2002 | B1 |
6484261 | Wiegel | Nov 2002 | B1 |
6487560 | LaRue et al. | Nov 2002 | B1 |
6489963 | Parikh et al. | Dec 2002 | B2 |
6512522 | Miller et al. | Jan 2003 | B1 |
6515682 | Washington et al. | Feb 2003 | B1 |
6525736 | Erikawa et al. | Feb 2003 | B1 |
6526174 | Graffagnino | Feb 2003 | B1 |
6535892 | LaRue et al. | Mar 2003 | B1 |
6536041 | Knudson et al. | Mar 2003 | B1 |
6542160 | Abgrall | Apr 2003 | B1 |
6542166 | Washington et al. | Apr 2003 | B1 |
6544295 | Bodnar | Apr 2003 | B1 |
6571245 | Huang et al. | May 2003 | B2 |
6571328 | Liao et al. | May 2003 | B2 |
6573896 | Ribadeau Dumas et al. | Jun 2003 | B1 |
6577317 | Duluk, Jr. et al. | Jun 2003 | B1 |
6580430 | Hollis et al. | Jun 2003 | B1 |
6590592 | Nason et al. | Jul 2003 | B1 |
6609977 | Shimizu et al. | Aug 2003 | B1 |
6614444 | Duluk, Jr. et al. | Sep 2003 | B1 |
6618048 | Leather | Sep 2003 | B1 |
6636214 | Leather et al. | Oct 2003 | B1 |
6639595 | Drebin et al. | Oct 2003 | B1 |
6661426 | Jetha et al. | Dec 2003 | B1 |
6664958 | Leather et al. | Dec 2003 | B1 |
6664962 | Komsthoeft et al. | Dec 2003 | B1 |
6664986 | Kopelman et al. | Dec 2003 | B1 |
6674438 | Yamamoto et al. | Jan 2004 | B1 |
6687745 | Franco et al. | Feb 2004 | B1 |
6697074 | Parikh et al. | Feb 2004 | B2 |
6707462 | Peercy et al. | Mar 2004 | B1 |
6714201 | Grinstein et al. | Mar 2004 | B1 |
6714221 | Christie et al. | Mar 2004 | B1 |
6715053 | Grigor | Mar 2004 | B1 |
6717599 | Olano | Apr 2004 | B1 |
6724403 | Santoro et al. | Apr 2004 | B1 |
6734864 | Abgrall | May 2004 | B2 |
6738804 | Lo | May 2004 | B1 |
6741242 | Itoh et al. | May 2004 | B1 |
6742042 | Holden et al. | May 2004 | B1 |
6757698 | McBride et al. | Jun 2004 | B2 |
6760046 | I'Anson et al. | Jul 2004 | B2 |
6765592 | Pletcher et al. | Jul 2004 | B1 |
6788318 | Chen | Sep 2004 | B2 |
6792616 | Jerding et al. | Sep 2004 | B1 |
6806892 | Plow et al. | Oct 2004 | B1 |
6882979 | Reay et al. | Apr 2005 | B1 |
6892360 | Pabla et al. | May 2005 | B1 |
6906720 | Emberling et al. | Jun 2005 | B2 |
6910000 | Yedidia et al. | Jun 2005 | B1 |
6910052 | Gates et al. | Jun 2005 | B2 |
6911984 | Sabella et al. | Jun 2005 | B2 |
6918091 | Leavitt et al. | Jul 2005 | B2 |
6925477 | Champagne et al. | Aug 2005 | B1 |
6931633 | Vazquez et al. | Aug 2005 | B1 |
6944829 | Dando | Sep 2005 | B2 |
6993721 | Rosin et al. | Jan 2006 | B2 |
7007041 | Multer et al. | Feb 2006 | B2 |
7007242 | Suomela et al. | Feb 2006 | B2 |
7016011 | De Haan | Mar 2006 | B2 |
7024381 | Hastings et al. | Apr 2006 | B1 |
7027055 | Anderson et al. | Apr 2006 | B2 |
7028264 | Santoro et al. | Apr 2006 | B2 |
7036083 | Zenith | Apr 2006 | B1 |
7050955 | Carmel et al. | May 2006 | B1 |
7076730 | Baker | Jul 2006 | B1 |
7085994 | Gvily | Aug 2006 | B2 |
7107546 | Coulthard | Sep 2006 | B2 |
7127473 | Agassi et al. | Oct 2006 | B2 |
7127509 | Wu | Oct 2006 | B2 |
7127713 | Davis et al. | Oct 2006 | B2 |
7146563 | Hesmer et al. | Dec 2006 | B2 |
7174512 | Martin et al. | Feb 2007 | B2 |
7185290 | Cadiz et al. | Feb 2007 | B2 |
7191399 | Ohtani et al. | Mar 2007 | B2 |
7216351 | Maes | May 2007 | B1 |
7222155 | Gebhardt et al. | May 2007 | B1 |
7242406 | Robotham et al. | Jul 2007 | B2 |
7249327 | Nelson et al. | Jul 2007 | B2 |
7260380 | Dietl et al. | Aug 2007 | B2 |
7269792 | Consolatti et al. | Sep 2007 | B2 |
7281202 | Croney et al. | Oct 2007 | B2 |
7293034 | Paya et al. | Nov 2007 | B2 |
7315848 | Pearse et al. | Jan 2008 | B2 |
7328435 | Trifon | Feb 2008 | B2 |
7346766 | Mackin et al. | Mar 2008 | B2 |
7353465 | Callaway et al. | Apr 2008 | B2 |
7356816 | Goodman et al. | Apr 2008 | B2 |
7392483 | Wong et al. | Jun 2008 | B2 |
7401104 | Shah et al. | Jul 2008 | B2 |
7437485 | Kruglikov et al. | Oct 2008 | B1 |
7472350 | Hintermeister et al. | Dec 2008 | B2 |
7502838 | Franco et al. | Mar 2009 | B2 |
7503010 | Chaudhri et al. | Mar 2009 | B2 |
7516158 | Drukman et al. | Apr 2009 | B2 |
7523401 | Aldridge | Apr 2009 | B1 |
7530026 | Chaudhri et al. | May 2009 | B2 |
7613834 | Pallipuram et al. | Nov 2009 | B1 |
7756723 | Rosow et al. | Jul 2010 | B2 |
7765326 | Robbin et al. | Jul 2010 | B2 |
7797446 | Heller et al. | Sep 2010 | B2 |
7802246 | Kennedy et al. | Sep 2010 | B1 |
7814148 | Bell et al. | Oct 2010 | B2 |
8260353 | Hugot | Sep 2012 | B2 |
20010030647 | Sowizral et al. | Oct 2001 | A1 |
20010035885 | Iron et al. | Nov 2001 | A1 |
20020013822 | West | Jan 2002 | A1 |
20020026474 | Wang et al. | Feb 2002 | A1 |
20020054148 | Okada | May 2002 | A1 |
20020059594 | Rasmussen et al. | May 2002 | A1 |
20020065946 | Narayan | May 2002 | A1 |
20020067418 | I | Jun 2002 | A1 |
20020078255 | Narayan | Jun 2002 | A1 |
20020078453 | Kuo | Jun 2002 | A1 |
20020087632 | Keskar | Jul 2002 | A1 |
20020089526 | Buxton et al. | Jul 2002 | A1 |
20020093516 | Brunner et al. | Jul 2002 | A1 |
20020099678 | Albright et al. | Jul 2002 | A1 |
20020105548 | Hayton et al. | Aug 2002 | A1 |
20020111934 | Narayan | Aug 2002 | A1 |
20020112180 | Land et al. | Aug 2002 | A1 |
20020114466 | Tanaka et al. | Aug 2002 | A1 |
20020118217 | Fujiki | Aug 2002 | A1 |
20020120673 | Tolson et al. | Aug 2002 | A1 |
20020123739 | Haacke et al. | Sep 2002 | A1 |
20020129092 | Tolson et al. | Sep 2002 | A1 |
20020133508 | LaRue et al. | Sep 2002 | A1 |
20020140740 | Chen | Oct 2002 | A1 |
20020152098 | Evans et al. | Oct 2002 | A1 |
20020156798 | LaRue et al. | Oct 2002 | A1 |
20020158902 | Hooker et al. | Oct 2002 | A1 |
20020171682 | Frank et al. | Nov 2002 | A1 |
20020174003 | Redmann et al. | Nov 2002 | A1 |
20020174181 | Wei | Nov 2002 | A1 |
20020180798 | Poor et al. | Dec 2002 | A1 |
20020186257 | Cadiz et al. | Dec 2002 | A1 |
20020194090 | Gagnon et al. | Dec 2002 | A1 |
20020196268 | Wolff et al. | Dec 2002 | A1 |
20030008661 | Joyce et al. | Jan 2003 | A1 |
20030008711 | Corbo | Jan 2003 | A1 |
20030009267 | Dunsky et al. | Jan 2003 | A1 |
20030018971 | McKenna, Jr. | Jan 2003 | A1 |
20030020671 | Santoro et al. | Jan 2003 | A1 |
20030032409 | Hutcheson et al. | Feb 2003 | A1 |
20030046316 | Gergic et al. | Mar 2003 | A1 |
20030061482 | Emmerichs | Mar 2003 | A1 |
20030067489 | Candy Wong et al. | Apr 2003 | A1 |
20030069904 | Hsu et al. | Apr 2003 | A1 |
20030076369 | Resner et al. | Apr 2003 | A1 |
20030079038 | Robbin et al. | Apr 2003 | A1 |
20030080995 | Tenenbaum et al. | May 2003 | A1 |
20030097659 | Goldman | May 2003 | A1 |
20030101046 | Krasnov | May 2003 | A1 |
20030122787 | Zimmerman et al. | Jul 2003 | A1 |
20030123739 | Graffagnino | Jul 2003 | A1 |
20030125057 | Pesola | Jul 2003 | A1 |
20030125962 | Holliday et al. | Jul 2003 | A1 |
20030130984 | Quinlan et al. | Jul 2003 | A1 |
20030146934 | Bailey et al. | Aug 2003 | A1 |
20030154239 | Davis et al. | Aug 2003 | A1 |
20030158975 | Frank et al. | Aug 2003 | A1 |
20030164862 | Cadiz et al. | Sep 2003 | A1 |
20030169306 | Makipaa et al. | Sep 2003 | A1 |
20030174136 | Emberling et al. | Sep 2003 | A1 |
20030174154 | Yukie et al. | Sep 2003 | A1 |
20030184552 | Chadha | Oct 2003 | A1 |
20030184584 | Vachuska et al. | Oct 2003 | A1 |
20030189597 | Anderson et al. | Oct 2003 | A1 |
20030191799 | Araujo et al. | Oct 2003 | A1 |
20030206195 | Matsa et al. | Nov 2003 | A1 |
20030208685 | Abdel-Rahman | Nov 2003 | A1 |
20040003402 | McKenna, Jr. | Jan 2004 | A1 |
20040012626 | Brookins | Jan 2004 | A1 |
20040015942 | Branson et al. | Jan 2004 | A1 |
20040024616 | Spector et al. | Feb 2004 | A1 |
20040032409 | Girard | Feb 2004 | A1 |
20040036711 | Anderson | Feb 2004 | A1 |
20040039934 | Land et al. | Feb 2004 | A1 |
20040054711 | Multer | Mar 2004 | A1 |
20040070629 | Seifert | Apr 2004 | A1 |
20040125128 | Chang et al. | Jul 2004 | A1 |
20040142711 | Mahonen et al. | Jul 2004 | A1 |
20040179019 | Sabella et al. | Sep 2004 | A1 |
20040181580 | Baranshamaje | Sep 2004 | A1 |
20040183800 | Peterson | Sep 2004 | A1 |
20040194020 | Beda et al. | Sep 2004 | A1 |
20040199574 | Franco et al. | Oct 2004 | A1 |
20040203684 | Jokinen et al. | Oct 2004 | A1 |
20040205504 | Phillips | Oct 2004 | A1 |
20040212640 | Mann et al. | Oct 2004 | A1 |
20040215740 | Frank et al. | Oct 2004 | A1 |
20040223003 | Heirich et al. | Nov 2004 | A1 |
20040225955 | Ly | Nov 2004 | A1 |
20040230911 | Bent et al. | Nov 2004 | A1 |
20040237082 | Alcazar et al. | Nov 2004 | A1 |
20040255253 | Marcjan | Dec 2004 | A1 |
20040261012 | Balsiger | Dec 2004 | A1 |
20040261037 | Ording et al. | Dec 2004 | A1 |
20040261038 | Ording et al. | Dec 2004 | A1 |
20050010419 | Pourhamid | Jan 2005 | A1 |
20050010634 | Henderson et al. | Jan 2005 | A1 |
20050021935 | Schillings et al. | Jan 2005 | A1 |
20050022139 | Gettman et al. | Jan 2005 | A1 |
20050039144 | Wada et al. | Feb 2005 | A1 |
20050057497 | Kawahara | Mar 2005 | A1 |
20050060655 | Gray et al. | Mar 2005 | A1 |
20050060661 | Kawahara et al. | Mar 2005 | A1 |
20050076305 | Hintermeister et al. | Apr 2005 | A1 |
20050088447 | Hanggie et al. | Apr 2005 | A1 |
20050088452 | Hanggie et al. | Apr 2005 | A1 |
20050091571 | Leichtling | Apr 2005 | A1 |
20050091690 | Delpuch et al. | Apr 2005 | A1 |
20050093868 | Hinckley | May 2005 | A1 |
20050114021 | Krull et al. | May 2005 | A1 |
20050144563 | Hough et al. | Jun 2005 | A1 |
20050144595 | McLean | Jun 2005 | A1 |
20050149458 | Eglen et al. | Jul 2005 | A1 |
20050160368 | Liu et al. | Jul 2005 | A1 |
20050168471 | Paquette | Aug 2005 | A1 |
20050168476 | Levene et al. | Aug 2005 | A1 |
20050172239 | Liu et al. | Aug 2005 | A1 |
20050183026 | Amano et al. | Aug 2005 | A1 |
20050193368 | Becker et al. | Sep 2005 | A1 |
20050198584 | Matthews et al. | Sep 2005 | A1 |
20050215310 | Boyd et al. | Sep 2005 | A1 |
20050221808 | Karlsson et al. | Oct 2005 | A1 |
20050234884 | Drukman et al. | Oct 2005 | A1 |
20050240857 | Benedict et al. | Oct 2005 | A1 |
20050243373 | Silverbrook et al. | Nov 2005 | A1 |
20050256940 | Henderson et al. | Nov 2005 | A1 |
20050278651 | Coe et al. | Dec 2005 | A1 |
20050282612 | Mathews | Dec 2005 | A1 |
20050283734 | Santoro et al. | Dec 2005 | A1 |
20060001652 | Chiu et al. | Jan 2006 | A1 |
20060004913 | Chong | Jan 2006 | A1 |
20060005207 | Louch et al. | Jan 2006 | A1 |
20060010394 | Chaudhri et al. | Jan 2006 | A1 |
20060015818 | Chaudhri et al. | Jan 2006 | A1 |
20060015846 | Fraleigh et al. | Jan 2006 | A1 |
20060031264 | Bosworth et al. | Feb 2006 | A1 |
20060031587 | Paterson et al. | Feb 2006 | A1 |
20060036703 | Fulmer et al. | Feb 2006 | A1 |
20060036941 | Neil | Feb 2006 | A1 |
20060036969 | Guido et al. | Feb 2006 | A1 |
20060053384 | La Fetra et al. | Mar 2006 | A1 |
20060075033 | Bienstock et al. | Apr 2006 | A1 |
20060075106 | Hochmuth et al. | Apr 2006 | A1 |
20060075141 | Boxenhorn | Apr 2006 | A1 |
20060089840 | May | Apr 2006 | A1 |
20060095331 | O'Malley et al. | May 2006 | A1 |
20060107231 | Matthews et al. | May 2006 | A1 |
20060112123 | Clark et al. | May 2006 | A1 |
20060123356 | Sobeski et al. | Jun 2006 | A1 |
20060123359 | Schatzberger et al. | Jun 2006 | A1 |
20060136843 | Shafron | Jun 2006 | A1 |
20060150118 | Chaudhri et al. | Jul 2006 | A1 |
20060154649 | Pedersen et al. | Jul 2006 | A1 |
20060156248 | Chaudhri et al. | Jul 2006 | A1 |
20060168536 | Portmann | Jul 2006 | A1 |
20060206835 | Chaudhri et al. | Sep 2006 | A1 |
20060218499 | Matthews et al. | Sep 2006 | A1 |
20060236257 | Othmer et al. | Oct 2006 | A1 |
20060277469 | Chaudhri et al. | Dec 2006 | A1 |
20070038934 | Fellman | Feb 2007 | A1 |
20070044029 | Fisher et al. | Feb 2007 | A1 |
20070044039 | Amadio et al. | Feb 2007 | A1 |
20070061724 | Slothouber et al. | Mar 2007 | A1 |
20070101146 | Louch et al. | May 2007 | A1 |
20070101279 | Chaudhri et al. | May 2007 | A1 |
20070101288 | Forstall et al. | May 2007 | A1 |
20070101291 | Forstall | May 2007 | A1 |
20070101297 | Forstall et al. | May 2007 | A1 |
20070101433 | Forstall et al. | May 2007 | A1 |
20070118813 | Forstall et al. | May 2007 | A1 |
20070129888 | Rosenberg | Jun 2007 | A1 |
20070162850 | Adler et al. | Jul 2007 | A1 |
20070203984 | AlHusseini et al. | Aug 2007 | A2 |
20070209013 | Ramsey et al. | Sep 2007 | A1 |
20070266093 | Forstall et al. | Nov 2007 | A1 |
20080016468 | Chambers et al. | Jan 2008 | A1 |
20080034309 | Louch et al. | Feb 2008 | A1 |
20080034314 | Louch et al. | Feb 2008 | A1 |
20080155453 | Othmer | Jun 2008 | A1 |
20080168367 | Chaudhri et al. | Jul 2008 | A1 |
20080168368 | Louch et al. | Jul 2008 | A1 |
20080168382 | Louch et al. | Jul 2008 | A1 |
20080235602 | Strauss et al. | Sep 2008 | A1 |
20080288578 | Silfverberg | Nov 2008 | A1 |
20090021486 | Chaudhri et al. | Jan 2009 | A1 |
20090024944 | Louch et al. | Jan 2009 | A1 |
20090044138 | Rudolph et al. | Feb 2009 | A1 |
20090125815 | Chaudhri et al. | May 2009 | A1 |
20090144644 | Chaudhri et al. | Jun 2009 | A1 |
20090158193 | Chaudhri et al. | Jun 2009 | A1 |
20090187841 | Chaudhri et al. | Jul 2009 | A1 |
20090228824 | Forstall et al. | Sep 2009 | A1 |
20090260022 | Louch et al. | Oct 2009 | A1 |
20090271724 | Chaudhri et al. | Oct 2009 | A1 |
Number | Date | Country |
---|---|---|
102 42 378 | Mar 2004 | DE |
548586 | Jun 1993 | EP |
0694879 | Jan 1996 | EP |
0 908 835 | Apr 1999 | EP |
1 237 076 | Sep 2002 | EP |
1383080 | Jan 2004 | EP |
0972273 | Mar 2004 | EP |
1 724 996 | Nov 2006 | EP |
WO 9606401 | Feb 1996 | WO |
WO 9707467 | Feb 1997 | WO |
WO 9807112 | Feb 1998 | WO |
WO 9845815 | Oct 1998 | WO |
WO 0209039 | Jan 2002 | WO |
WO 03023593 | Mar 2003 | WO |
WO 2004027707 | Apr 2004 | WO |
WO 2004076977 | Sep 2004 | WO |
WO 2006012343 | Feb 2006 | WO |
WO 2006020304 | Feb 2006 | WO |
WO 2006119269 | Nov 2006 | WO |
WO 2009012319 | Dec 2009 | WO |
WO 2009012330 | Dec 2009 | WO |
Entry |
---|
http://en.wikipedia.org/wiki/SideKick {retreived 2009} “Sidekick”. |
“Writing a Desk Accessory,” Developer Connection, Apple Computer, Inc. Jul. 3, 1996, [online] [Retrieved on Jan. 3, 2006] Retrieved from the Internet URL: http://developer.apple.com/documentation/mac/devices/devices-16.html>, 3 pages. |
Conner Borookshire D. et al. “Three-Dimensional Widgets” ACM 1992, 8 pages. |
Elliott, Conal, “Programming Graphics Processors Functionally,” Proceedings of the 2004 Haskell Workshop, Sep. 22, 2004. 11 pages. |
Http://en.wikipedia.org/wiki/Comparison—of—widget—engines, 2007, 6 pages. |
http://en.wikipedia.org/wild/Windows-Sidebar, 2007, 7 pages. |
http://www.nat.org/dashboard/blog.php3 Dec. 2003, 31 pages. |
International Search Report , PCT/US2005/008804, Jul. 27, 2005, 3 pages. |
International Search Report and Writen Opinion, PCT/US2005/022152, Jul. 10, 2006, 8 pages. |
Shiozawa, Hidekazu et al., “Perspective Layered Visualization of Collaborative Workspaces,” Proceedings of the International ACM SIGGROUP conference on Supporting Group Work Publisher, Nov. 1999, 5 pages. |
Snippet Software Inc. et al. “Corporate Portal Newsletter” Oct. 2000, 3 pages. |
Snippet Software Inc. et al. “Snippets Software” Jun. 2001, 16 pages. |
Stardock.com et al. “DesktopX Whitepaper and users Guide” 1999, 72 pages. |
Tang, J.C. et al., “ConNexus to Awarenex: Extending Awareness to Mobile Users,” SIGCHI '01, AMC, Mar. 31-Apr. 4, 2001, 8 pages. |
Wardell, Brad, Konfabulator for Windows, Jan. 10, 2004; [online] Retrieved from the Internet Mar. 6, 2006] Retrieved from the Internet: URL: http://www.xpthemes.com/forums.asp?MID=19&CMID=19&AID=4472, 6 pages. |
“Coolsmartphone”; [online] [Retrieved on Apr. 13, 2006]; Retrieved from the Internet, URL: http://www.coolsmartphone.com/article569.html; 57 pages. |
“GPS Blogging Phones”; [online] [Retrieved on Apr. 5, 2006] Retrieve from the Internet, URL: http://www.dailywireless.org/modules.php?name=News&file=article&sid=4613; 3 pages. |
“International Roaming Guide—Personal Experience(s) from Customer and Community Member”; [online] [Retrieved Jun. 26, 2006] Retrieved from the Internet <URL: http://forums.cingular.com/cng/board/message?board.id=1185; 6 pages. |
“Writing a Desk Accessory,” Developer Connection, Apple Computer, Inc. Jul. 3, 1996, [online].[Retrieved on Jan. 3, 2006] Retrieved from the Internet URL: http://developer.apple.com/documentation/mac/devices/devices-16.html>, 3 pages. |
Akeley, Kurt, and Hanrahan, Pat, “Real-Time Graphics Architecture,” http://www.grahics.stanford.edu/courses/cs448a-01-fall, the OpenGL Graphics System, CS448 Lecture 15, Fall, 2001, pp. 1-20. |
Altman, R.B., “Visual Quickstart Guide Power Point 2000/98, Applying Preset Animations,” ProQuest Safari Books, Peachpit Press, May 7, 1999, 7 pages [online] Retrieved from the Internet: <URL: http://proquest.safaribooksonline.com/0201354411>. |
Archive of “Objects, Images and Applets,” W3C Recommendation, Feb. 10, 2003, [online] [Archived by http://archivve.org; Retrieved on Apr. 13, 2006] Retrieved from the Internet URL:http://web.archivve.org/web/20030210154019/http://www.w3.org/TR/REC-html140/struct/objects.html, 21 pages. |
Beier et al., “The bull's-eye: a framework for web application user interface design guidelines”, Proceedings of the Sigchi Conference on Human Factors in Computing Systems, Apr. 2003, pp. 489-496. |
Cadiz, JJ et al., “Slideshow: Providing Peripheral Awareness of Important Information,” Technical Report MSR-TR-2001-83, (Sep. 14, 2001), 9 pages. Microsoft Corporation, Redmond, WA. |
Carey et al., “Integrating Widget Design Knowledge with User Interface Toolkits”, Proceedings of the Fifth International Workshop on Computer-Aided Software Engineering, Jul. 1992, pp. 204-212. |
Chen et al., “The Model of Optimum Route Selection in Vehicle Automatic Navigation System Based on Unblocked Reliability Analyses”, Intelligent Transportation Systems, 2003, Proceedings, IEEE (2003), vol. 2, Oct. 12-15, 2003, pp. 975-978. |
Chinese Notification of First Office Action, Chinese Patent Application No. 200580016349.3, Jul. 25, 2008, 21 pages. |
Conner et al. “Three-Dimensional Widgets” ACM 1992, pp. 183-231. |
Elliott, “Programming Graphics Processors Functionally,” Proceedings of the 2004 Haskell Workshop, Sep. 22, 2004. 11 pages. |
Fried, Ina, “Developer Calls Apple's Tiger a Copycat,” CNET News.com, Jun. 28, 2004 [online] Retrieved on Jul. 1, 2004] Retrieved from the Internet URL:http://zdnet.com.com/2102-1104—2-250692.html?tag=printthis, 2 pages. |
Fried, Ina, “For Apple's Tiger, the Keyword is Search”, CNET News.com, Jun. 28, 2004 [online] Retrieved on Jul. 1, 2004] Retrieved from the Internet URL:http://zdnet.com.com/2102-1103—2-5250346.html?tag=printthis, 2 pages. |
Guber, John et al., “Dashboard vs. Konfabulator”, Jun. 2004, 9 pages. |
Haeberli, P. et al., “The Accumulation Buffer: Hardware Support for High-Quality Rendering,” Computer Graphics, Aug. 1990, pp. 309-318, vol. 24, No. 4. |
Han; “Bi-manual, multi-point, and multi-user interactions on a graphical interaction surface”; Mutli-Touch Interaction Research; [online] [Retrieved on Apr. 13, 2006]; Retrieved from the Internet, URL: http://mr1.nyu.edu/˜jhan/ftirtouch/; 4 pages. |
International Search Report, PCT/US2005/008804, Jul. 27, 2005, 3 pages. |
International Search Report and Written Opinion, PCT/US2005/022152, Jul. 10, 2006, 8 pages. |
International Search report, PCT/US2005/008805, Aug. 8, 2005, 3 pages. |
Invitation to Pay Additional Fees(Form PCT/ISA/206) and Communication Relating to the Results of the Partial International Search (PCT/ISA/206 (Annex)) for PCT/US2007/077441; dated Jan. 28, 2008, 8 pages. |
Invitation to Pay Additional Fees(Form PCT/ISA/206) and Communication Relating to the Results of the Partial International Search (PCT/ISA/206 (Annex)) for PCT/US2008/050295; dated Jul. 29, 2008. |
Konfabulator, “Cupertino, Start your Photocopiers!,” [online] [Retrieved on Jul. 1, 2004] Retrieved from the Internet <URL: http://www.konfabulator.com>, 1 page. |
Konfabulator, “Konfabulator & Widget Basics,” [online] [Retrieved on Jul. 1, 2004] Retrieved from the Internet <URL: http://www.konfabulator.com/info/basics.html>, 3 pages. |
Konfabulator, “Screenshots,” [online] [Retrieved on Jul. 1, 2004] Retrieved from the Internet <URL: http://www.konfabulator.com/info/screenshots.html>, 2 pages. |
Konfabulator, “What is Konfabulator?,” [online] [Retrieved on Jul. 1, 2004] Retrieved from the Internet <URL: http://www.konfabulator.com/info/, 3 pages. |
Lammers, J.., et al., “Maya 4.5 Fundamentals: Particles, ”New Riders Publishing, Jan. 14, 2003, 12 pages, [online] [retrieved on Feb. 17, 2007] Retrieved from ProQuest Safari Books Online on the Internet: <URL: http://proquest.safaribooksonline.com/0735713278>, 12 pages. |
Microsoft Corporation, “Microsoft® Windows™ Graphical Environment User's Guide”, Version 3.0 for MS-DOS® or PC-DOS Operating System, 1990, Document No. SY06851-0290, pp. Cover-vii, 15-75, 315-353. |
Microsoft Corporation, “User's Guide Microsoft® Windows™ and MS-DOS® 6”, 1993, pp. Cover-xvi, 112-121. |
Notification of Transmittal of the International Search Report and the Written Opinion of the International Searching Authority, PCT/US2005/022579, 15 pages. |
Notification of Transmittal of the International Search Report and the Written Opinion of the International Searching Authority, PCT/US2007/077441, May 8, 2008; 17 pages. |
Nvidia, “CG—Teaching Cg,” Power Point Presentation, Author and date unknown, pp. 1-16. |
Puder, A., “Extending Desktop Applications to the Web,” ACM International Conference Proceedings Series, Proceedings of the Jun. 2004 International Symposium on Information and Communication Technologies, 2004, vol. 90, 6 pages. |
Rist et al., “Customizing Graphics for Tiny Displays of Mobile Devices”, Personal and Ubiquitous Computing, 2002, pp. 260-268, vol. 6. |
Rochkind, M. et al., “Common Elements in Today's Graphical User Interfaces: The Good, the Bad, and the Ugly,” Interchi '93, AMC, Apr. 24-29, 1993, pp. 470-473. |
Segal, Mark and Akeley, Kurt, “The OpenGL Graphics System: A Specification (Version 1.5),” Copyright 1992-2003 Silicon Graphics, Inc., Oct. 30, 2003, 334 pages. |
Shantzis, Michael A., “A Model for Efficient and Flexible Image Computing,” Computer Graphics Proceedings, Annual Conference Series, Orlando, Florida, Jul. 24-29, 1994, pp. 147-154. |
Shiozawa et al., “Perspective Layered Visualization of Collaborative Workspaces,” Proceedings of the International ACM SIGGROUP conference on Supporting Group Work Publisher, Nov. 1999, 5 pages. |
Snippet Software, “Product Spotlight Non-browser based portal solution from Snippets Software”, Corporate Portal Newsletter, Oct. 2000, vol. 1, No. 10, 3 pages. |
Snippet Software, “Snippets Software Platform”, Retrieved from the Internet on Jun. 11, 2001 <URL:http://www.snippets.com/products/>. |
Snippets Software et al., “Products Overview”, Feb. 2002, [online] [Retrieved on Feb. 5, 2008] Retrieved from the Internet URL: http://web.archive.org/web/20020206061508/http://www.snippets.com/products/>. |
Staples, Loretta, “Representation in Virtual Space: Visual Convention in the Graphical User Interface,” Proceedings of the SIGCHI Conference on Human Factors in Computing Systems, Apr. 1993. http://www.nat.org/dashboard/blog.php3 Dec. 2003, 8 pages. |
Stardock et al., “DesktopX General Guide,” Aug. 2000, [online] [Retrieved on Jan. 31, 2008] Retrieved from the Internet URL:http://www.stardock.com/products/desktopx/docs/. |
Stardock et al., “DesktopX Tutorial”, Aug. 2000, [online] [Retrieved on Jan. 31, 2008] Retrieved from the Internet URL:http://www.stardock.com/products/desktopx/tutorial.html. |
Stardock et al., “DesktopX WhitePaper”, Aug. 2000, [online] [Retrieved on Jan. 31, 2008] Retrieved from the Internet <URL:http://www.stardock.net/media/whitepaper—desktopx.html. |
Stardock et al., “The User Guide—Version 2”, DesktopX 2000. |
Stardock et al., “What Can It Do? Making Objects”, DesktopX Tutorial, 2001, [online] [Retrieved on Apr. 11, 2008] Retrieved from the Internet URL:http://web.archive.org/web/2001101922285/http://www.stardock.com/products/desktopx/ . . . . |
Stardock News, DesktopX User Manual On-line:, 1999, 2003 [online] [Retrieved from the Internet on May 11, 2007] <URL:http://www.stardock.comnewsitem.asp?id=538>. |
Stardock News/Media/Press. |
Stardock, “DesktopX Whitepaper and users Guide” Retrived from the Internet <URL:http://www.stardock.net/media/whitepaper—desktopx.html>, 1999, 72 pages. |
Tang, J.C. et al., “ConNexto Awarenex: Extending Awareness to Mobile Users,” SIGCHI '01, AMC, Mar. 31-Apr. 4, 2001, 8 pages. |
Ullenboom, C., “Java is auch eine Insel,” 2003, [online] [Retrieved on Apr. 13, 2006] Retrieved from the Internet URL: http://www.galileocomputing.de/openbook/javainse12//java—140000.htm#Xxx998138, 3 pages. |
Van Gelder, Allen, and Kwansik, Kim, “Direct Volume Rendering with Shading via Three-Dimensional Textures,” Computer Science Dept., Univ. of California, Santa Cruz, CA 95064, 9 pages. |
Wardell, “Konfabulator for Windows”, Jan. 10, 2004, Retrieved from the Internet on Mar. 6, 2006, URL: http://www.xpthemes.com/forums.aps?MID=19&CMID=19&AID=4472, 6 pages. |
Partial International Search Report, dated May 15, 2009, issued in International Application No. PCT/US2008/050047. |
Invitation to Pay fees and Partial International Search Report, dated May 8, 2009, issued in PCT/US2008/050038. |
Archive of BabelFish.com Inc., Oct. 2003, [online] [Archived by http://archive.org on Oct. 2, 2003; retrieved on Dec. 8, 2008] Retrieved from the Internet URL: <http://web.archive.org/web/20031002115902/www.babelfish.com/en/index.html>. |
Archive of movies.com, Jan. 2002, [online] [Archived by http://archive.org on Jan. 18, 2002; Retrieved on Dec. 8, 2008] Retrieved from the Internet URL: <http://www.archive.org/web/20020118102516/movies.go.com>. |
Baratz et al., “DesktopX 3/1”, Ars Technica, Nov. 17, 2005, [online] [Retrieved on Aug. 1, 2008] Retrieved from the Internet URL: <http://arstechnica.com/reviews/apps/desktopx/ars.>. |
Siracusa et al., “Mac OA 10.4 Tiger: Dashboard”, Apr. 28, 2005, [online] [Retrieved on Aug. 1, 2008] Retrieved from the Internet URL: <http://arstechnica.com/reviews/os/macosz-10-4.ars/17>. |
Wardell et al. “Apple's Dashboard vs. Konfabulator vs. DesktopX”, Skinning the frog, Jul. 1, 2004, [online] [Retrieved on Aug. 1, 2008] Retrieved from the Internet URL: <http://frogboy.joeuser.com/article/19800>. |
Thomas et al., “Animating Widgets in the InterViews Toolkit”, Lecture Notes in Computer Science, pp. 26-44, 1995. |
JavaBoutique, Oct. 1, 2002. Available at: <http://javaboutique.internet.com/utilities/counter.html>. |
Forstall et al., U.S. Appl. No. 12/469,555, filed May 20, 2009. |
“Coolsmartphone”; Apr. 17, 2006, [online] [Retrieved on Sep. 11, 2009]; Retrieved from the Internet, URL: http://www.web.archive.org/web/20060417080115/http://www.coolsmartphone.com/article569.html; 24 pages. |
“Desktop Sidebar”, [online] [Retrieved on May 11, 2007] Retrieved from the Internet URL: http://web.archive.org/web/20040101160831/http://www.desktopsidebar.com/; 5 pages. |
Garmin® nüvifone™ Images, [online] [Retrieved from the Internet on Feb. 4, 2008], URL: http://www8.garmin.com/buzz/nuvifone/media—gallery.jsp; 2 pages. |
“Garmin® nüvifone™ Takes Personal Navigation and Communication to the Next Level”; Garmin International; [online] [Retrieved on Mar. 17, 2008]; Retrieved from the Internet, URL: http://www8.garmin.com/pressroom/mobile/013008.html; 3 pages. |
“Inter-widget communication?”, [online] [Retrieved on Jun. 5, 2009], Retrieved from the Internet URL: http://www2.konfabulator.com/forums/lofiversion/index.php/t125.html; 3 pages. |
“Portlet Communication: What is application scope, anyway?”, Sep. 18, 2002, [online]; Retrieved from the Internet at URL: http://wwwcoderanch.com/t/203244/Portals-Portlets/java/Portlet-Communication-What-application-scope; 3 pages. |
“Portlet-to-portlet communication between JSR 168 portlets on public pages”, Apr. 5, 2006, [online]; Retrieved from the Internet URL: http://www.ibm.developerworks/websphere/library/techarticles/0604—scott/0604—scott.html; 9 pages. |
Akeley, “Cg—Teaching Cg,” Power Point Presentation, NVIDIA Corporation, 2002; 1 page. |
International Search Report and Written Opinion, dated Sep. 3, 2009, issued in International Application No. PCT/US2008/050047; 17 pages. |
Konfabulator, “Konfabulator & Widget Basics—A Refresher Course in Widgetology”, [online] [Retrieved on Jun. 5, 2009], Retrieved from the Internet URL: http://web.archive.org/web/20050811020610/http://konfabulator.com/basics; 16 pages. |
Stardock, “Gallactica Civilization: Dread Lords—User Manual”, Stardock Entertainment © 2006; 65 pages. |
Stardock, “Your Edge in Software”, [online] [Retrieved on May 11, 2007]; Retrieved from the Internet URL: http://www.stardock.com/media.asp?cmd=mediakits; 56 pages. |
Van Gelder et al., “Direct Volume Rendering with Shading via Three-Dimensional Textures,” Computer Science Dept., Univ. of California, Santa Cruz, CA 95064, Jul. 19, 1996; 17 pages. |
Louch et al., “Multidimensional Widgets”, U.S. Appl. No. 12/612,301, filed Nov. 4, 2009. |
International Search Report and Written Opinion, dated Oct. 16, 2009, issued in International Application No. PCT/US2008/070217. |
Caceres et al., “Widget 1.0 Requirements”, [Online] [Downloaded on Sep. 10, 2009]; Retrieved from the Internet at URL: http://www.w3.org/TR/2007/WD-widgets-reqs-20070705; 30 pages. |
Warren, “The VMware Workstation 5 Handbook”, Jun. 2005, Course Technology PTR, 50 pages. |
Lieberman and Selker, “Agents for the User Interface,” Handbook of Agent Technology, 2003, pp. 1-21, Retrieved from the Internet, URL: http://web.media.mit.edu/{lieber/Publications/Agents—for—UI.pdf> [retrieved on Sep. 15, 2009]. |
“Dashboard Blog”, Dec. 11, 2003, [online] [Retrieved from the Internet on May 11, 2007], URL: http://www.nat.org/dashboard/blog.php3, 31pages. |
“Starfish Software Introduces Starfish Internet Sidekick; Starfish Internet Sidekick is the best way for Internet users to manage their calendar, contacts and communications,” Business Wire, Sep. 23, 1996, [online] [Retrieved on Dec. 8, 2008]; Retrieved from the Internet URL: http://findarticles.com/articles/mi—mOEIN/is—1996—Sept—23/ai—18704672?tag=rel.resl; 2 pages. |
“Welcome to the Gigaplex!™”, Lazar Productions, Nov. 1996, [online] [Retrieved on Dec. 8, 2008]; Retrieved from the Internet URL: http://web.archive.org/web/19961105081827/www.gigaplex.com/; 4 pages. |
“Convert just about Anything to Anything else”, Online Conversion.com, [online] [Retrieved on Jun. 22, 2008]; Retrieved from the Internet, URL: http://web.archive.org/web/20000815055422/http://www.onlineconversion.com/; 2 pages. |
Akeley et al., “Real-Time Graphics Architecture,” http://www.grahics.stanford.edu/courses/cs448a-01-fall, the OpenGL® Graphics System, CS448 Lecture 15, Fall, 2001, pp. 1-20. |
Javaboutique. Oct. 8, 2008. Available at: http://web.archive.org/web/20021208051951/http://javaboutique.internet.com/utilities/counter.html. |
Number | Date | Country | |
---|---|---|---|
20070130541 A1 | Jun 2007 | US |
Number | Date | Country | |
---|---|---|---|
60583125 | Jun 2004 | US | |
60734016 | Nov 2005 | US | |
60730956 | Oct 2005 | US | |
60737899 | Nov 2005 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 10877968 | Jun 2004 | US |
Child | 11499887 | US |